CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
ECALHCAL.py
Go to the documentation of this file.
1 import FWCore.ParameterSet.Config as cms
2 def customise(process):
3 
4 # extend the particle gun acceptance
5 
6  process.generator.AddAntiParticle = cms.bool(False)
7 
8 # no magnetic field
9 
10  process.g4SimHits.UseMagneticField = cms.bool(False)
11  process.UniformMagneticFieldESProducer = cms.ESProducer("UniformMagneticFieldESProducer",
12  ZFieldInTesla = cms.double(0.0)
13  )
14 
15  process.prefer("UniformMagneticFieldESProducer")
16 
17 # add ECAL and HCAL specific Geant4 hits objects
18 
19  process.g4SimHits.Watchers = cms.VPSet(cms.PSet(
20  instanceLabel = cms.untracked.string('EcalValidInfo'),
21  type = cms.string('EcalSimHitsValidProducer'),
22  verbose = cms.untracked.bool(False)
23  ))
24 
25  # use directly the generator output, no Hector
26 
27  process.g4SimHits.Generator.HepMCProductLabel = cms.string('generatorSmeared')
28 
29  # modify the content
30 
31  #process.output.outputCommands.append("keep *_simHcalUnsuppressedDigis_*_*")
32  process.outputModules_().iteritems().next()[1].outputCommands.append("keep *_simHcalUnsuppressedDigis_*_*")
33 
34 # user schedule: use only calorimeters digitization and local reconstruction
35 
36  del process.schedule[:]
37 
38  process.schedule.append(process.generation_step)
39  process.schedule.append(process.simulation_step)
40 
41  process.ecalMultiFitUncalibRecHit.EBdigiCollection = cms.InputTag("simEcalDigis","ebDigis")
42  process.ecalMultiFitUncalibRecHit.EEdigiCollection = cms.InputTag("simEcalDigis","eeDigis")
43  process.ecalPreshowerRecHit.ESdigiCollection = cms.InputTag("simEcalPreshowerDigis")
44 
45  delattr(process,"hbhereco")
46  process.hbhereco = process.hbheprereco.clone()
47  process.hcalLocalRecoSequence.replace(process.hbheprereco,process.hbhereco)
48  process.hbhereco.digiLabel = cms.InputTag("simHcalUnsuppressedDigis")
49  process.horeco.digiLabel = cms.InputTag("simHcalUnsuppressedDigis")
50  process.hfreco.digiLabel = cms.InputTag("simHcalUnsuppressedDigis")
51  process.ecalRecHit.recoverEBIsolatedChannels = cms.bool(False)
52  process.ecalRecHit.recoverEEIsolatedChannels = cms.bool(False)
53  process.ecalRecHit.recoverEBFE = cms.bool(False)
54  process.ecalRecHit.recoverEEFE = cms.bool(False)
55 
56 # process.local_digireco = cms.Path(process.mix * process.calDigi * process.ecalLocalRecoSequence * process.hbhereco * process.hfreco * process.horeco * (process.ecalClusters+process.caloTowersRec) * process.reducedEcalRecHitsSequence )
57 
58  process.reducedEcalRecHitsEB.interestingDetIdCollections = cms.VInputTag(
59  # ecal
60  cms.InputTag("interestingEcalDetIdEB"),
61  cms.InputTag("interestingEcalDetIdEBU"),
62  )
63 
64  process.reducedEcalRecHitsEE.interestingDetIdCollections = cms.VInputTag(
65  # ecal
66  cms.InputTag("interestingEcalDetIdEE"),
67  )
68 
69  process.local_digireco = cms.Path(process.mix * process.addPileupInfo * process.bunchSpacingProducer * process.calDigi * process.ecalPacker * process.esDigiToRaw * process.hcalRawData * process.rawDataCollector * process.ecalDigis * process.ecalPreshowerDigis * process.hcalDigis * process.calolocalreco *(process.ecalClustersNoPFBox+process.caloTowersRec) * process.reducedEcalRecHitsSequenceEcalOnly )
70 
71  process.schedule.append(process.local_digireco)
72 
73  # add HcalNoiseRBXCollection product for Validation/CaloTowers Validation/HcalRecHits
74  process.load( "RecoMET.METProducers.hcalnoiseinfoproducer_cfi" )
75  process.hcalnoise_path = cms.Path( process.hcalnoise )
76  process.schedule.append( process.hcalnoise_path )
77 
78  process.load("Validation/Configuration/ecalSimValid_cff")
79  process.load("Validation/Configuration/hcalSimValid_cff")
80  process.local_validation = cms.Path(process.ecalSimValid+process.hcalSimValid)
81  process.schedule.append(process.local_validation)
82 
83  process.schedule.append(process.endjob_step)
84  #process.schedule.append(process.out_step)
85  process.schedule.append(getattr(process,process.outputModules_().iteritems().next()[0]+"_step"))
86 
87  return(process)
def customise
Definition: ECALHCAL.py:2
return(e1-e2)*(e1-e2)+dp *dp