-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdemoanalyzer_cfg.py
65 lines (56 loc) · 3.32 KB
/
demoanalyzer_cfg.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
import FWCore.ParameterSet.Config as cms
# from RecoMuon.TrackingTools.MuonServiceProxy_cff import *
import PhysicsTools.PythonAnalysis.LumiList as LumiList
import FWCore.ParameterSet.Types as CfgTypes
process = cms.Process("Demo")
# intialize MessageLogger and output report
process.load("FWCore.MessageLogger.MessageLogger_cfi")
process.MessageLogger.cerr.threshold = 'INFO'
process.MessageLogger.categories.append('Demo')
process.MessageLogger.cerr.INFO = cms.untracked.PSet(limit=cms.untracked.int32(-1))
process.options = cms.untracked.PSet(wantSummary=cms.untracked.bool(True))
# **********************************************************************
# set the maximum number of events to be processed *
# this number (argument of int32) is to be modified by the user *
# according to need and wish *
# default is preset to 10000 events *
# set it to -1 to process all the events *
# **********************************************************************
process.maxEvents = cms.untracked.PSet(input=cms.untracked.int32(10000))
# set the number of events to be skipped (if any) at end of file below
# define JSON file for 2010
goodJSON = 'datasets/Cert_136033-149442_7TeV_Apr21ReReco_Collisions10_JSON_v2.txt'
myLumis = LumiList.LumiList(filename=goodJSON).getCMSSWString().split(',')
# ****************************************************************************
# define the input data set here by inserting the appropriate .txt file list *
# ****************************************************************************
import FWCore.Utilities.FileUtils as FileUtils
#
# ****************************************************************
# load the data set *
# For MUO-10-004, the default is the Mu data set. *
# To run over all data subsets, replace '0000' by '0001' etc. *
# consecutively (make sure you save the output before rerunning) *
# and add up the histograms using root tools. *
# ****************************************************************
#
# *** DoubleMu data set ***
files2010data = FileUtils.loadListFromFile('datasets/CMS_Run2010B_Mu_AOD_Apr21ReReco-v1_0000_file_index.txt')
process.source = cms.Source("PoolSource", fileNames=cms.untracked.vstring(*files2010data))
# apply JSON file
# (needs to be placed *after* the process.source input file definition!)
process.source.lumisToProcess = CfgTypes.untracked(CfgTypes.VLuminosityBlockRange())
process.source.lumisToProcess.extend(myLumis)
# *************************************************
# number of events to be skipped (0 by default) *
# *************************************************
process.source.skipEvents = cms.untracked.uint32(0)
process.demo = cms.EDAnalyzer('DimuonSpectrum2010')
# ***********************************************************
# output file name *
# default is DoulbeMu.root *
# change this according to your wish *
# you may modify it according to different input file *
# ***********************************************************
process.TFileService = cms.Service("TFileService", fileName=cms.string('DoubleMu.root'))
process.p = cms.Path(process.demo)