CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
InitialStep_cff.py
Go to the documentation of this file.
1 import FWCore.ParameterSet.Config as cms
2 from Configuration.Eras.Modifier_tracker_apv_vfp30_2016_cff import tracker_apv_vfp30_2016 as _tracker_apv_vfp30_2016
3 from Configuration.Eras.Modifier_fastSim_cff import fastSim
4 
5 #for dnn classifier
6 from Configuration.ProcessModifiers.trackdnn_cff import trackdnn
7 from RecoTracker.IterativeTracking.dnnQualityCuts import qualityCutDictionary
8 
9 # for no-loopers
10 from Configuration.ProcessModifiers.trackingNoLoopers_cff import trackingNoLoopers
11 
12 ### STEP 0 ###
13 
14 # hit building
17 
18 # SEEDING LAYERS
20 import RecoTracker.TkSeedingLayers.PixelLayerQuadruplets_cfi
21 initialStepSeedLayers = RecoTracker.TkSeedingLayers.PixelLayerTriplets_cfi.PixelLayerTriplets.clone()
22 from Configuration.Eras.Modifier_trackingPhase1_cff import trackingPhase1
23 trackingPhase1.toModify(initialStepSeedLayers,
24  layerList = RecoTracker.TkSeedingLayers.PixelLayerQuadruplets_cfi.PixelLayerQuadruplets.layerList.value()
25 )
26 trackingPhase2PU140.toModify(initialStepSeedLayers,
27  layerList = RecoTracker.TkSeedingLayers.PixelLayerQuadruplets_cfi.PixelLayerQuadruplets.layerList.value()
28 )
29 
30 # TrackingRegion
31 from RecoTracker.TkTrackingRegions.globalTrackingRegionFromBeamSpot_cfi import globalTrackingRegionFromBeamSpot as _globalTrackingRegionFromBeamSpot
32 initialStepTrackingRegions = _globalTrackingRegionFromBeamSpot.clone(RegionPSet = dict(
33  ptMin = 0.6,
34  originRadius = 0.02,
35  nSigmaZ = 4.0
36 ))
37 from Configuration.Eras.Modifier_trackingPhase2PU140_cff import trackingPhase2PU140
38 trackingPhase1.toModify(initialStepTrackingRegions, RegionPSet = dict(ptMin = 0.5))
39 from Configuration.Eras.Modifier_highBetaStar_2018_cff import highBetaStar_2018
40 highBetaStar_2018.toModify(initialStepTrackingRegions,RegionPSet = dict(
41  ptMin = 0.05,
42  originRadius = 0.2
43 ))
44 trackingPhase2PU140.toModify(initialStepTrackingRegions, RegionPSet = dict(ptMin = 0.6,originRadius = 0.03))
45 
46 # seeding
47 from RecoTracker.TkHitPairs.hitPairEDProducer_cfi import hitPairEDProducer as _hitPairEDProducer
48 initialStepHitDoublets = _hitPairEDProducer.clone(
49  seedingLayers = 'initialStepSeedLayers',
50  trackingRegions = 'initialStepTrackingRegions',
51  maxElement = 50000000,
52  produceIntermediateHitDoublets = True,
53 )
54 from RecoPixelVertexing.PixelTriplets.pixelTripletHLTEDProducer_cfi import pixelTripletHLTEDProducer as _pixelTripletHLTEDProducer
56 import RecoPixelVertexing.PixelLowPtUtilities.LowPtClusterShapeSeedComparitor_cfi
57 initialStepHitTriplets = _pixelTripletHLTEDProducer.clone(
58  doublets = 'initialStepHitDoublets',
59  produceSeedingHitSets = True,
60  SeedComparitorPSet = RecoPixelVertexing.PixelLowPtUtilities.LowPtClusterShapeSeedComparitor_cfi.LowPtClusterShapeSeedComparitor.clone()
61 )
62 from RecoTracker.TkSeedGenerator.seedCreatorFromRegionConsecutiveHitsEDProducer_cff import seedCreatorFromRegionConsecutiveHitsEDProducer as _seedCreatorFromRegionConsecutiveHitsEDProducer
63 initialStepSeeds = _seedCreatorFromRegionConsecutiveHitsEDProducer.clone(
64  seedingHitSets = 'initialStepHitTriplets',
65 )
66 from RecoPixelVertexing.PixelTriplets.caHitQuadrupletEDProducer_cfi import caHitQuadrupletEDProducer as _caHitQuadrupletEDProducer
67 _initialStepCAHitQuadruplets = _caHitQuadrupletEDProducer.clone(
68  doublets = 'initialStepHitDoublets',
69  extraHitRPhitolerance = initialStepHitTriplets.extraHitRPhitolerance,
70  SeedComparitorPSet = initialStepHitTriplets.SeedComparitorPSet,
71  maxChi2 = dict(
72  pt1 = 0.7, pt2 = 2,
73  value1 = 200, value2 = 50,
74  ),
75  useBendingCorrection = True,
76  fitFastCircle = True,
77  fitFastCircleChi2Cut = True,
78  CAThetaCut = 0.0012,
79  CAPhiCut = 0.2,
80 )
81 highBetaStar_2018.toModify(_initialStepCAHitQuadruplets,
82  CAThetaCut = 0.0024,
83  CAPhiCut = 0.4
84 )
85 initialStepHitQuadruplets = _initialStepCAHitQuadruplets.clone()
86 
87 trackingPhase1.toModify(initialStepHitDoublets, layerPairs = [0,1,2]) # layer pairs (0,1), (1,2), (2,3)
88 
89 trackingPhase2PU140.toModify(initialStepHitDoublets, layerPairs = [0,1,2]) # layer pairs (0,1), (1,2), (2,3)
90 trackingPhase2PU140.toModify(initialStepHitQuadruplets,
91  CAThetaCut = 0.0010,
92  CAPhiCut = 0.175,
93 )
94 
95 from RecoTracker.TkSeedGenerator.seedCreatorFromRegionConsecutiveHitsTripletOnlyEDProducer_cff import seedCreatorFromRegionConsecutiveHitsTripletOnlyEDProducer as _seedCreatorFromRegionConsecutiveHitsTripletOnlyEDProducer
96 _initialStepSeedsConsecutiveHitsTripletOnly = _seedCreatorFromRegionConsecutiveHitsTripletOnlyEDProducer.clone(
97  seedingHitSets = 'initialStepHitTriplets',
98  SeedComparitorPSet = dict(# FIXME: is this defined in any cfi that could be imported instead of copy-paste?
99  ComponentName = 'PixelClusterShapeSeedComparitor',
100  FilterAtHelixStage = cms.bool(False),
101  FilterPixelHits = cms.bool(True),
102  FilterStripHits = cms.bool(False),
103  ClusterShapeHitFilterName = cms.string('ClusterShapeHitFilter'),
104  ClusterShapeCacheSrc = cms.InputTag('siPixelClusterShapeCache')
105  ),
106 )
107 trackingPhase1.toReplaceWith(initialStepSeeds, _initialStepSeedsConsecutiveHitsTripletOnly.clone(
108  seedingHitSets = 'initialStepHitQuadruplets'
109 ))
110 trackingPhase2PU140.toReplaceWith(initialStepSeeds, _initialStepSeedsConsecutiveHitsTripletOnly.clone(
111  seedingHitSets = 'initialStepHitQuadruplets'
112 ))
113 import FastSimulation.Tracking.TrajectorySeedProducer_cfi
114 from FastSimulation.Tracking.SeedingMigration import _hitSetProducerToFactoryPSet
115 _fastSim_initialStepSeeds = FastSimulation.Tracking.TrajectorySeedProducer_cfi.trajectorySeedProducer.clone(
116  trackingRegions = 'initialStepTrackingRegions',
117  seedFinderSelector = dict( pixelTripletGeneratorFactory = _hitSetProducerToFactoryPSet(initialStepHitTriplets).clone(SeedComparitorPSet = dict(ComponentName = 'none')),
118  layerList = initialStepSeedLayers.layerList.value()
119  )
120 )
121 #new for phase1
122 trackingPhase1.toModify(_fastSim_initialStepSeeds, seedFinderSelector = dict(
123  pixelTripletGeneratorFactory = None,
124  CAHitQuadrupletGeneratorFactory = _hitSetProducerToFactoryPSet(initialStepHitQuadruplets).clone(SeedComparitorPSet = dict(ComponentName = 'none')),
125  #new parameters required for phase1 seeding
126  BPix = dict(
127  TTRHBuilder = 'WithoutRefit',
128  HitProducer = 'TrackingRecHitProducer',
129  ),
130  FPix = dict(
131  TTRHBuilder = 'WithoutRefit',
132  HitProducer = 'TrackingRecHitProducer',
133  ),
134  layerPairs = initialStepHitDoublets.layerPairs.value()
135  )
136 )
137 
138 fastSim.toReplaceWith(initialStepSeeds,_fastSim_initialStepSeeds)
139 
140 
141 # building
143 _initialStepTrajectoryFilterBase = TrackingTools.TrajectoryFiltering.TrajectoryFilter_cff.CkfBaseTrajectoryFilter_block.clone(
144  minimumNumberOfHits = 3,
145  minPt = 0.2,
146 )
147 initialStepTrajectoryFilterBase = _initialStepTrajectoryFilterBase.clone(
148  maxCCCLostHits = 0,
149  minGoodStripCharge = cms.PSet(refToPSet_ = cms.string('SiStripClusterChargeCutLoose'))
150 )
151 from Configuration.Eras.Modifier_tracker_apv_vfp30_2016_cff import tracker_apv_vfp30_2016
152 _tracker_apv_vfp30_2016.toModify(initialStepTrajectoryFilterBase, maxCCCLostHits = 2)
153 
154 from Configuration.Eras.Modifier_pp_on_XeXe_2017_cff import pp_on_XeXe_2017
155 from Configuration.ProcessModifiers.pp_on_AA_cff import pp_on_AA
156 (pp_on_XeXe_2017 | pp_on_AA).toModify(initialStepTrajectoryFilterBase, minPt=0.6)
157 highBetaStar_2018.toModify(initialStepTrajectoryFilterBase, minPt = 0.05)
158 
159 initialStepTrajectoryFilterInOut = initialStepTrajectoryFilterBase.clone(
160  minimumNumberOfHits = 4,
161  seedExtension = 1,
162  strictSeedExtension = True, # don't allow inactive
163  pixelSeedExtension = True,
164 )
165 from Configuration.Eras.Modifier_trackingLowPU_cff import trackingLowPU
166 trackingLowPU.toReplaceWith(initialStepTrajectoryFilterBase, _initialStepTrajectoryFilterBase)
167 trackingPhase2PU140.toReplaceWith(initialStepTrajectoryFilterBase, _initialStepTrajectoryFilterBase)
168 
169 import RecoPixelVertexing.PixelLowPtUtilities.StripSubClusterShapeTrajectoryFilter_cfi
170 initialStepTrajectoryFilterShape = RecoPixelVertexing.PixelLowPtUtilities.StripSubClusterShapeTrajectoryFilter_cfi.StripSubClusterShapeTrajectoryFilterTIX12.clone()
171 initialStepTrajectoryFilter = cms.PSet(
172  ComponentType = cms.string('CompositeTrajectoryFilter'),
173  filters = cms.VPSet(
174  cms.PSet( refToPSet_ = cms.string('initialStepTrajectoryFilterBase')),
175  # cms.PSet( refToPSet_ = cms.string('initialStepTrajectoryFilterShape'))
176  ),
177 )
178 
179 trackingPhase2PU140.toReplaceWith(initialStepTrajectoryFilter, TrackingTools.TrajectoryFiltering.TrajectoryFilter_cff.CkfBaseTrajectoryFilter_block.clone(
180  minimumNumberOfHits = 3,
181  minPt = 0.2
182 ))
183 import RecoTracker.MeasurementDet.Chi2ChargeMeasurementEstimator_cfi
184 initialStepChi2Est = RecoTracker.MeasurementDet.Chi2ChargeMeasurementEstimator_cfi.Chi2ChargeMeasurementEstimator.clone(
185  ComponentName = 'initialStepChi2Est',
186  nSigma = 3.0,
187  MaxChi2 = 30.0,
188  clusterChargeCut = cms.PSet(refToPSet_ = cms.string('SiStripClusterChargeCutLoose')),
189  pTChargeCutThreshold = 15.
190 )
191 _tracker_apv_vfp30_2016.toModify(initialStepChi2Est,
192  clusterChargeCut = dict(refToPSet_ = 'SiStripClusterChargeCutTiny')
193 )
194 trackingPhase2PU140.toModify(initialStepChi2Est,
195  clusterChargeCut = dict(refToPSet_ = 'SiStripClusterChargeCutNone'),
196 )
197 
198 
200 initialStepTrajectoryBuilder = RecoTracker.CkfPattern.GroupedCkfTrajectoryBuilder_cfi.GroupedCkfTrajectoryBuilder.clone(
201  trajectoryFilter = cms.PSet(refToPSet_ = cms.string('initialStepTrajectoryFilter')),
202  alwaysUseInvalidHits = True,
203  maxCand = 3,
204  estimator = 'initialStepChi2Est',
205  maxDPhiForLooperReconstruction = cms.double(2.0),
206  maxPtForLooperReconstruction = cms.double(0.7)
207 )
208 trackingNoLoopers.toModify(initialStepTrajectoryBuilder,
209  maxPtForLooperReconstruction = 0.0)
210 trackingLowPU.toModify(initialStepTrajectoryBuilder, maxCand = 5)
211 trackingPhase1.toModify(initialStepTrajectoryBuilder,
212  minNrOfHitsForRebuild = 1,
213  keepOriginalIfRebuildFails = True,
214 )
215 trackingPhase2PU140.toModify(initialStepTrajectoryBuilder,
216  minNrOfHitsForRebuild = 1,
217  keepOriginalIfRebuildFails = True,
218 )
219 
221 # Give handle for CKF for HI
222 _initialStepTrackCandidatesCkf = RecoTracker.CkfPattern.CkfTrackCandidates_cfi.ckfTrackCandidates.clone(
223  src = 'initialStepSeeds',
224  ### these two parameters are relevant only for the CachingSeedCleanerBySharedInput
225  numHitsForSeedCleaner = cms.int32(50),
226  onlyPixelHitsForSeedCleaner = cms.bool(True),
227  TrajectoryBuilderPSet = cms.PSet(refToPSet_ = cms.string('initialStepTrajectoryBuilder')),
228  doSeedingRegionRebuilding = True,
229  useHitsSplitting = True
230 )
231 initialStepTrackCandidates = _initialStepTrackCandidatesCkf.clone()
232 
233 from Configuration.ProcessModifiers.trackingMkFitInitialStep_cff import trackingMkFitInitialStep
234 from RecoTracker.MkFit.mkFitGeometryESProducer_cfi import mkFitGeometryESProducer
235 import RecoTracker.MkFit.mkFitSiPixelHitConverter_cfi as mkFitSiPixelHitConverter_cfi
236 import RecoTracker.MkFit.mkFitSiStripHitConverter_cfi as mkFitSiStripHitConverter_cfi
237 import RecoTracker.MkFit.mkFitEventOfHitsProducer_cfi as mkFitEventOfHitsProducer_cfi
238 import RecoTracker.MkFit.mkFitSeedConverter_cfi as mkFitSeedConverter_cfi
239 import RecoTracker.MkFit.mkFitIterationConfigESProducer_cfi as mkFitIterationConfigESProducer_cfi
240 import RecoTracker.MkFit.mkFitProducer_cfi as mkFitProducer_cfi
241 import RecoTracker.MkFit.mkFitOutputConverter_cfi as mkFitOutputConverter_cfi
242 mkFitSiPixelHits = mkFitSiPixelHitConverter_cfi.mkFitSiPixelHitConverter.clone() # TODO: figure out better place for this module?
243 mkFitEventOfHits = mkFitEventOfHitsProducer_cfi.mkFitEventOfHitsProducer.clone() # TODO: figure out better place for this module?
244 initialStepTrackCandidatesMkFitSeeds = mkFitSeedConverter_cfi.mkFitSeedConverter.clone(
245  seeds = 'initialStepSeeds',
246 )
247 initialStepTrackCandidatesMkFitConfig = mkFitIterationConfigESProducer_cfi.mkFitIterationConfigESProducer.clone(
248  ComponentName = 'initialStepTrackCandidatesMkFitConfig',
249  config = 'RecoTracker/MkFit/data/mkfit-phase1-initialStep.json',
250 )
251 initialStepTrackCandidatesMkFit = mkFitProducer_cfi.mkFitProducer.clone(
252  seeds = 'initialStepTrackCandidatesMkFitSeeds',
253  config = ('', 'initialStepTrackCandidatesMkFitConfig'),
254 )
255 trackingMkFitInitialStep.toReplaceWith(initialStepTrackCandidates, mkFitOutputConverter_cfi.mkFitOutputConverter.clone(
256  seeds = 'initialStepSeeds',
257  mkFitSeeds = 'initialStepTrackCandidatesMkFitSeeds',
258  tracks = 'initialStepTrackCandidatesMkFit',
259 ))
260 
261 import FastSimulation.Tracking.TrackCandidateProducer_cfi
262 fastSim.toReplaceWith(initialStepTrackCandidates,
263  FastSimulation.Tracking.TrackCandidateProducer_cfi.trackCandidateProducer.clone(
264  src = 'initialStepSeeds',
265  MinNumberOfCrossedLayers = 3
266 ))
267 
268 
269 # fitting
271 initialStepTracks = RecoTracker.TrackProducer.TrackProducer_cfi.TrackProducer.clone(
272  src = 'initialStepTrackCandidates',
273  AlgorithmName = 'initialStep',
274  Fitter = 'FlexibleKFFittingSmoother'
275 )
276 fastSim.toModify(initialStepTracks, TTRHBuilder = 'WithoutRefit')
277 
278 #vertices
279 from RecoVertex.PrimaryVertexProducer.OfflinePrimaryVertices_cfi import offlinePrimaryVertices as _offlinePrimaryVertices
280 firstStepPrimaryVerticesUnsorted = _offlinePrimaryVertices.clone(
281  TrackLabel = 'initialStepTracks',
282  vertexCollections = [_offlinePrimaryVertices.vertexCollections[0].clone()]
283 )
284 (pp_on_XeXe_2017 | pp_on_AA).toModify(firstStepPrimaryVerticesUnsorted, TkFilterParameters = dict(trackQuality = 'any'))
285 
286 # we need a replacment for the firstStepPrimaryVerticesUnsorted
287 # that includes tracker information of signal and pile up
288 # after mixing there is no such thing as initialStepTracks,
289 # so we replace the input collection for firstStepPrimaryVerticesUnsorted with generalTracks
290 firstStepPrimaryVerticesBeforeMixing = firstStepPrimaryVerticesUnsorted.clone()
291 fastSim.toModify(firstStepPrimaryVerticesUnsorted, TrackLabel = 'generalTracks')
292 
293 
294 from RecoJets.JetProducers.TracksForJets_cff import trackRefsForJets
295 initialStepTrackRefsForJets = trackRefsForJets.clone(
296  src = 'initialStepTracks'
297 )
298 fastSim.toModify(initialStepTrackRefsForJets, src = 'generalTracks')
300 from CommonTools.RecoAlgos.sortedPrimaryVertices_cfi import sortedPrimaryVertices as _sortedPrimaryVertices
301 firstStepPrimaryVertices = _sortedPrimaryVertices.clone(
302  vertices = 'firstStepPrimaryVerticesUnsorted',
303  particles = 'initialStepTrackRefsForJets',
304 )
305 
306 
307 # Final selection
310 
311 initialStepClassifier1 = TrackMVAClassifierPrompt.clone(
312  src = 'initialStepTracks',
313  mva = dict(GBRForestLabel = 'MVASelectorIter0_13TeV'),
314  qualityCuts = [-0.9,-0.8,-0.7]
315 )
316 fastSim.toModify(initialStepClassifier1,vertices = 'firstStepPrimaryVerticesBeforeMixing')
317 
318 from RecoTracker.IterativeTracking.DetachedTripletStep_cff import detachedTripletStepClassifier1
319 from RecoTracker.IterativeTracking.LowPtTripletStep_cff import lowPtTripletStep
320 initialStepClassifier2 = detachedTripletStepClassifier1.clone(
321  src = 'initialStepTracks'
322 )
323 fastSim.toModify(initialStepClassifier2,vertices = 'firstStepPrimaryVerticesBeforeMixing')
324 initialStepClassifier3 = lowPtTripletStep.clone(
325  src = 'initialStepTracks'
326 )
327 fastSim.toModify(initialStepClassifier3,vertices = 'firstStepPrimaryVerticesBeforeMixing')
328 
330 initialStep = ClassifierMerger.clone(
331  inputClassifiers=['initialStepClassifier1','initialStepClassifier2','initialStepClassifier3']
332 )
333 trackingPhase1.toReplaceWith(initialStep, initialStepClassifier1.clone(
334  mva = dict(GBRForestLabel = 'MVASelectorInitialStep_Phase1'),
335  qualityCuts = [-0.95,-0.85,-0.75]
336 ))
337 
341 trackdnn.toReplaceWith(initialStep, trackTfClassifier.clone(
342  src = 'initialStepTracks',
343  qualityCuts = qualityCutDictionary.InitialStep.value()
344 ))
345 
346 (trackdnn & fastSim).toModify(initialStep,vertices = 'firstStepPrimaryVerticesBeforeMixing')
347 
348 
349 pp_on_AA.toModify(initialStep,
350  mva = dict(GBRForestLabel = 'HIMVASelectorInitialStep_Phase1'),
351  qualityCuts = [-0.9, -0.5, 0.2],
352 )
353 
354 # For LowPU and Phase2PU140
355 import RecoTracker.FinalTrackSelectors.multiTrackSelector_cfi
356 initialStepSelector = RecoTracker.FinalTrackSelectors.multiTrackSelector_cfi.multiTrackSelector.clone(
357  src = 'initialStepTracks',
358  useAnyMVA = cms.bool(False),
359  GBRForestLabel = cms.string('MVASelectorIter0'),
360  trackSelectors = [
361  RecoTracker.FinalTrackSelectors.multiTrackSelector_cfi.looseMTS.clone(
362  name = 'initialStepLoose',
363  ), #end of pset
364  RecoTracker.FinalTrackSelectors.multiTrackSelector_cfi.tightMTS.clone(
365  name = 'initialStepTight',
366  preFilterName = 'initialStepLoose',
367  ),
368  RecoTracker.FinalTrackSelectors.multiTrackSelector_cfi.highpurityMTS.clone(
369  name = 'QualityMasks',
370  preFilterName = 'initialStepTight',
371  ),
372  ] #end of vpset
373 ) #end of clone
374 trackingPhase2PU140.toModify(initialStepSelector,
375  useAnyMVA = None,
376  GBRForestLabel = None,
377  trackSelectors= cms.VPSet(
378  RecoTracker.FinalTrackSelectors.multiTrackSelector_cfi.looseMTS.clone(
379  name = 'initialStepLoose',
380  chi2n_par = 2.0,
381  res_par = ( 0.003, 0.002 ),
382  minNumberLayers = 3,
383  maxNumberLostLayers = 3,
384  minNumber3DLayers = 3,
385  d0_par1 = ( 0.8, 4.0 ),
386  dz_par1 = ( 0.9, 4.0 ),
387  d0_par2 = ( 0.6, 4.0 ),
388  dz_par2 = ( 0.8, 4.0 )
389  ), #end of pset
390  RecoTracker.FinalTrackSelectors.multiTrackSelector_cfi.tightMTS.clone(
391  name = 'initialStepTight',
392  preFilterName = 'initialStepLoose',
393  chi2n_par = 1.4,
394  res_par = ( 0.003, 0.002 ),
395  minNumberLayers = 3,
396  maxNumberLostLayers = 2,
397  minNumber3DLayers = 3,
398  d0_par1 = ( 0.7, 4.0 ),
399  dz_par1 = ( 0.8, 4.0 ),
400  d0_par2 = ( 0.5, 4.0 ),
401  dz_par2 = ( 0.7, 4.0 )
402  ),
403  RecoTracker.FinalTrackSelectors.multiTrackSelector_cfi.highpurityMTS.clone(
404  name = 'initialStep',
405  preFilterName = 'initialStepTight',
406  min_eta = -4.1,
407  max_eta = 4.1,
408  chi2n_par = 1.2,
409  res_par = ( 0.003, 0.001 ),
410  minNumberLayers = 3,
411  maxNumberLostLayers = 2,
412  minNumber3DLayers = 3,
413  d0_par1 = ( 0.6, 4.0 ),
414  dz_par1 = ( 0.7, 4.0 ),
415  d0_par2 = ( 0.45, 4.0 ),
416  dz_par2 = ( 0.55, 4.0 )
417  ),
418  ), #end of vpset
419 ) #end of clone
420 
421 
422 
423 # Final sequence
424 InitialStepTask = cms.Task(initialStepSeedLayers,
425  initialStepTrackingRegions,
426  initialStepHitDoublets,
427  initialStepHitTriplets,
428  initialStepSeeds,
429  initialStepTrackCandidates,
430  initialStepTracks,
431  firstStepPrimaryVerticesUnsorted,
432  initialStepTrackRefsForJets,
433  firstStepPrimaryVertices,
434  initialStepClassifier1,initialStepClassifier2,initialStepClassifier3,
435  initialStep,caloJetsForTrkTask)
436 InitialStep = cms.Sequence(InitialStepTask)
437 
438 from Configuration.ProcessModifiers.trackingMkFitCommon_cff import trackingMkFitCommon
439 _InitialStepTask_trackingMkFitCommon = InitialStepTask.copy()
440 _InitialStepTask_trackingMkFitCommon.add(mkFitSiPixelHits, mkFitEventOfHits, mkFitGeometryESProducer)
441 trackingMkFitCommon.toReplaceWith(InitialStepTask, _InitialStepTask_trackingMkFitCommon)
442 
443 _InitialStepTask_trackingMkFit = InitialStepTask.copy()
444 _InitialStepTask_trackingMkFit.add(initialStepTrackCandidatesMkFitSeeds, initialStepTrackCandidatesMkFit, initialStepTrackCandidatesMkFitConfig)
445 trackingMkFitInitialStep.toReplaceWith(InitialStepTask, _InitialStepTask_trackingMkFit)
446 
447 _InitialStepTask_LowPU = InitialStepTask.copyAndExclude([firstStepPrimaryVerticesUnsorted, initialStepTrackRefsForJets, caloJetsForTrkTask, firstStepPrimaryVertices, initialStepClassifier1, initialStepClassifier2, initialStepClassifier3])
448 _InitialStepTask_LowPU.replace(initialStep, initialStepSelector)
449 trackingLowPU.toReplaceWith(InitialStepTask, _InitialStepTask_LowPU)
450 
451 _InitialStepTask_Phase1 = InitialStepTask.copyAndExclude([initialStepClassifier2, initialStepClassifier3])
452 _InitialStepTask_Phase1.replace(initialStepHitTriplets, initialStepHitQuadruplets)
453 trackingPhase1.toReplaceWith(InitialStepTask, _InitialStepTask_Phase1)
454 
455 _InitialStepTask_trackingPhase2 = InitialStepTask.copyAndExclude([initialStepClassifier1, initialStepClassifier2, initialStepClassifier3])
456 _InitialStepTask_trackingPhase2.replace(initialStepHitTriplets, initialStepHitQuadruplets)
457 _InitialStepTask_trackingPhase2.replace(initialStep, initialStepSelector)
458 trackingPhase2PU140.toReplaceWith(InitialStepTask, _InitialStepTask_trackingPhase2)
459 
460 from Configuration.Eras.Modifier_fastSim_cff import fastSim
461 _InitialStepTask_fastSim = cms.Task(initialStepTrackingRegions
462  ,initialStepSeeds
463  ,initialStepTrackCandidates
464  ,initialStepTracks
465  ,firstStepPrimaryVerticesBeforeMixing
466  ,initialStepClassifier1,initialStepClassifier2,initialStepClassifier3
467  ,initialStep
468  )
469 fastSim.toReplaceWith(InitialStepTask, _InitialStepTask_fastSim)
COSMIC RUN SETTING.
TEveGeoShape * clone(const TEveElement *element, TEveElement *parent)
Definition: eve_macros.cc:135