CMS 3D CMS Logo

WElectronSkim_cff.py
Go to the documentation of this file.
1 import FWCore.ParameterSet.Config as cms
2 
3 
9 
10 HLTPath = "HLT_Ele*"
11 HLTProcessName = "HLT"
12 
13 #electron cuts
14 ELECTRON_ET_CUT_MIN = 10.0
15 TAG_ELECTRON_ET_CUT_MIN = 20.0
16 W_ELECTRON_ET_CUT_MIN = 27.0
17 ELECTRON_COLL = "gedGsfElectrons"
18 ELECTRON_CUTS = "(abs(superCluster.eta)<2.5) && (ecalEnergy*sin(superClusterPosition.theta)>" + str(ELECTRON_ET_CUT_MIN) + ")"
19 
20 #met, mt cuts for W selection
21 MET_CUT_MIN = 20.
22 MT_CUT_MIN = 50.
23 
24 
31 goodElectrons = cms.EDFilter("GsfElectronRefSelector",
32  src = cms.InputTag( ELECTRON_COLL ),
33  cut = cms.string( ELECTRON_CUTS )
34 )
35 
36 GsfMatchedPhotonCands = cms.EDProducer("ElectronMatchedCandidateProducer",
37  src = cms.InputTag("goodPhotons"),
38  ReferenceElectronCollection = cms.untracked.InputTag("goodElectrons"),
39  deltaR = cms.untracked.double(0.3)
40 )
41 
42 
49 PassingWP90 = goodElectrons.clone(
50 cut = cms.string(
51  goodElectrons.cut.value() +
52  " && (gsfTrack.hitPattern().numberOfLostHits(\'MISSING_INNER_HITS\')<=1 && !(-0.02<convDist<0.02 && -0.02<convDcot<0.02))" #wrt std WP90 allowing 1 numberOfMissingExpectedHits
53  " && (ecalEnergy*sin(superClusterPosition.theta)>" + str(ELECTRON_ET_CUT_MIN) + ")"
54  " && ((isEB"
55  " && ( dr03TkSumPt/p4.Pt <0.12 && dr03EcalRecHitSumEt/p4.Pt < 0.09 && dr03HcalTowerSumEt/p4.Pt < 0.1 )"
56  " && (sigmaIetaIeta<0.01)"
57  " && ( -0.8<deltaPhiSuperClusterTrackAtVtx<0.8 )"
58  " && ( -0.007<deltaEtaSuperClusterTrackAtVtx<0.007 )"
59  " && (hadronicOverEm<0.12)"
60  ")"
61  " || (isEE"
62  " && ( dr03TkSumPt/p4.Pt <0.07 && dr03EcalRecHitSumEt/p4.Pt < 0.07 && dr03HcalTowerSumEt/p4.Pt < 0.07 )"
63  " && (sigmaIetaIeta<0.03)"
64  " && ( -0.7<deltaPhiSuperClusterTrackAtVtx<0.7 )"
65  " && ( -0.009<deltaEtaSuperClusterTrackAtVtx<0.009 )"
66  " && (hadronicOverEm<0.1) "
67  "))"
68  )
69 )
70 
71 PassingWP80 = goodElectrons.clone(
72 cut = cms.string(
73  goodElectrons.cut.value() +
74  " && (gsfTrack.hitPattern().numberOfLostHits(\'MISSING_INNER_HITS\')==0 && !(-0.02<convDist<0.02 && -0.02<convDcot<0.02))"
75  " && (ecalEnergy*sin(superClusterPosition.theta)>" + str(ELECTRON_ET_CUT_MIN) + ")"
76  " && ((isEB"
77  " && ( dr03TkSumPt/p4.Pt <0.12 && dr03EcalRecHitSumEt/p4.Pt < 0.09 && dr03HcalTowerSumEt/p4.Pt < 0.1 )" #wrt std WP80 relaxing iso cuts to WP90
78  " && (sigmaIetaIeta<0.01)"
79  " && ( -0.06<deltaPhiSuperClusterTrackAtVtx<0.06 )"
80  " && ( -0.004<deltaEtaSuperClusterTrackAtVtx<0.004 )"
81  " && (hadronicOverEm<0.12)"
82  ")"
83  " || (isEE"
84  " && ( dr03TkSumPt/p4.Pt <0.05 && dr03EcalRecHitSumEt/p4.Pt < 0.06 && dr03HcalTowerSumEt/p4.Pt < 0.03 )"
85  " && (sigmaIetaIeta<0.03)"
86  " && ( -0.03<deltaPhiSuperClusterTrackAtVtx<0.03 )"
87  " && ( -0.007<deltaEtaSuperClusterTrackAtVtx<0.007 )"
88  " && (hadronicOverEm<0.10) "
89  "))"
90  )
91 )
92 
93 
94 
102 PassingHLT = cms.EDProducer("trgMatchGsfElectronProducer",
103  InputProducer = cms.InputTag( ELECTRON_COLL ),
104  hltTags = cms.untracked.string( HLTPath ),
105  triggerEventTag = cms.untracked.InputTag("hltTriggerSummaryAOD","",HLTProcessName),
106  triggerResultsTag = cms.untracked.InputTag("TriggerResults","",HLTProcessName),
107  stageL1Trigger = cms.uint32(1),
108  # Stage-1 L1T inputs
109  l1GtRecordInputTag = cms.InputTag('gtDigis'),
110  l1GtReadoutRecordInputTag = cms.InputTag('gtDigis'),
111 )
112 from Configuration.Eras.Modifier_stage2L1Trigger_cff import stage2L1Trigger
113 stage2L1Trigger.toModify(PassingHLT,
114  stageL1Trigger = 2,
115  # Stage-2 L1T inputs
116  l1tAlgBlkInputTag = cms.InputTag('gtStage2Digis'),
117  l1tExtBlkInputTag = cms.InputTag('gtStage2Digis'),
118  # remove Stage-1 L1T inputs
119  l1GtRecordInputTag = None,
120  l1GtReadoutRecordInputTag = None,
121 )
122 
123 
130 WElecTagHLT = PassingHLT.clone(
131  InputProducer = cms.InputTag( "PassingWP80" )
132  )
133 
134 ele_sequence = cms.Sequence(
135  goodElectrons +
136  PassingWP80 +
137  WElecTagHLT
138  )
139 
140 
141 
148 
149 MT="sqrt(2*daughter(0).pt*daughter(1).pt*(1 - cos(daughter(0).phi - daughter(1).phi)))"
150 elecMet = cms.EDProducer("CandViewShallowCloneCombiner",
151  decay = cms.string("pfMet WElecTagHLT"), # charge coniugate states are implied
152  checkCharge = cms.bool(False),
153  cut = cms.string(("daughter(0).pt > %f && daughter(1).pt > %f && "+MT+" > %f") % (MET_CUT_MIN, W_ELECTRON_ET_CUT_MIN, MT_CUT_MIN))
154 )
155 elecMetCounter = cms.EDFilter("CandViewCountFilter",
156  src = cms.InputTag("elecMet"),
157  minNumber = cms.uint32(1)
158  )
159 elecMetFilter = cms.Sequence(elecMet * elecMetCounter)
160 
162 WEnuHltFilter = HLTrigger.HLTfilters.hltHighLevel_cfi.hltHighLevel.clone(
163  throw = cms.bool(False),
164  HLTPaths = [HLTPath]
165  )
166 
167 #--------------------------#
168 #recompute rho
170 kt6PFJetsForRhoCorrectionWElectronSkim = RecoJets.Configuration.RecoPFJets_cff.kt6PFJets.clone(
171  doRhoFastjet = True,
172  Rho_EtaMax = 2.5
173 )
174 
175 
176 elecMetSeq = cms.Sequence( WEnuHltFilter * ele_sequence * elecMetFilter * kt6PFJetsForRhoCorrectionWElectronSkim)
177 
178 
179 from Configuration.EventContent.AlCaRecoOutput_cff import OutALCARECOEcalCalElectron
180 WElectronSkimContent = OutALCARECOEcalCalElectron.clone()
181 WElectronSkimContent.outputCommands.extend( [
182  "keep *_pfMet_*_*",
183  "keep *_kt6*_rho_*",
184  "keep *_offlinePrimaryVerticesWithBS_*_*",
185  "keep *_generator_*_*",
186  "keep *_rawDataCollector_*_*",
187  'keep recoCaloClusters_*_*_*',
188  'keep recoPreshowerClusters_*_*_*',
189  'keep *_reducedEcalRecHits*_*_*',
190  'keep *_offlineBeamSpot_*_*',
191  'keep *_allConversions_*_*',
192  'keep *_gtDigis_*_*'
193  ] )
#define str(s)