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 
129 WElecTagHLT = PassingHLT.clone(
130  InputProducer = cms.InputTag( "PassingWP80" )
131  )
132 
133 ele_sequence = cms.Sequence(
134  goodElectrons +
135  PassingWP80 +
136  WElecTagHLT
137  )
138 
139 
140 
147 
148 MT="sqrt(2*daughter(0).pt*daughter(1).pt*(1 - cos(daughter(0).phi - daughter(1).phi)))"
149 elecMet = cms.EDProducer("CandViewShallowCloneCombiner",
150  decay = cms.string("pfMet WElecTagHLT"), # charge coniugate states are implied
151  checkCharge = cms.bool(False),
152  cut = cms.string(("daughter(0).pt > %f && daughter(1).pt > %f && "+MT+" > %f") % (MET_CUT_MIN, W_ELECTRON_ET_CUT_MIN, MT_CUT_MIN))
153 )
154 elecMetCounter = cms.EDFilter("CandViewCountFilter",
155  src = cms.InputTag("elecMet"),
156  minNumber = cms.uint32(1)
157  )
158 elecMetFilter = cms.Sequence(elecMet * elecMetCounter)
159 
161 WEnuHltFilter = HLTrigger.HLTfilters.hltHighLevel_cfi.hltHighLevel.clone(
162  throw = cms.bool(False),
163  HLTPaths = [HLTPath]
164  )
165 
166 #--------------------------#
167 #recompute rho
169 kt6PFJetsForRhoCorrectionWElectronSkim = RecoJets.Configuration.RecoPFJets_cff.kt6PFJets.clone(
170  doRhoFastjet = True,
171  Rho_EtaMax = 2.5
172 )
173 
174 
175 elecMetSeq = cms.Sequence( WEnuHltFilter * ele_sequence * elecMetFilter * kt6PFJetsForRhoCorrectionWElectronSkim)
176 
177 
178 from Configuration.EventContent.AlCaRecoOutput_cff import OutALCARECOEcalCalElectron
179 WElectronSkimContent = OutALCARECOEcalCalElectron.clone()
180 WElectronSkimContent.outputCommands.extend( [
181  "keep *_pfMet_*_*",
182  "keep *_kt6*_rho_*",
183  "keep *_offlinePrimaryVerticesWithBS_*_*",
184  "keep *_generator_*_*",
185  "keep *_rawDataCollector_*_*",
186  'keep recoCaloClusters_*_*_*',
187  'keep recoPreshowerClusters_*_*_*',
188  'keep *_reducedEcalRecHits*_*_*',
189  'keep *_offlineBeamSpot_*_*',
190  'keep *_allConversions_*_*',
191  'keep *_gtDigis_*_*'
192  ] )
#define str(s)