From 84e6f7562503671718e87a45f285d484bf4fd10b Mon Sep 17 00:00:00 2001 From: Sunanda Date: Sun, 4 Sep 2022 06:05:47 +0200 Subject: [PATCH] Add scripts to test muon tomography for 2026D49 as well as a few others - backport of #39299 --- .../testHGCalDigiSingleMuonPt100_cfg.py | 189 ++++++++++++++++++ .../testHGCalRecoSingleMuonPt100_cfg.py | 164 +++++++++++++++ ....py => testHGCalSIMSingleMuonPt100_cfg.py} | 61 ++++-- 3 files changed, 395 insertions(+), 19 deletions(-) create mode 100644 Validation/HGCalValidation/scripts/testHGCalDigiSingleMuonPt100_cfg.py create mode 100644 Validation/HGCalValidation/scripts/testHGCalRecoSingleMuonPt100_cfg.py rename Validation/HGCalValidation/scripts/{testHGCalSingleMuonPt100_cfg.py => testHGCalSIMSingleMuonPt100_cfg.py} (73%) diff --git a/Validation/HGCalValidation/scripts/testHGCalDigiSingleMuonPt100_cfg.py b/Validation/HGCalValidation/scripts/testHGCalDigiSingleMuonPt100_cfg.py new file mode 100644 index 0000000000000..0367dd438c0ff --- /dev/null +++ b/Validation/HGCalValidation/scripts/testHGCalDigiSingleMuonPt100_cfg.py @@ -0,0 +1,189 @@ +############################################################################### +# Way to use this: +# cmsRun testHGCalDigi_cfg.py geometry=D92 +# +# Options for geometry D49, D88, D92, D93 +# +############################################################################### +import FWCore.ParameterSet.Config as cms +import os, sys, imp, re, random +import FWCore.ParameterSet.VarParsing as VarParsing + +#################################################################### +### SETUP OPTIONS +options = VarParsing.VarParsing('standard') +options.register('geometry', + "D92", + VarParsing.VarParsing.multiplicity.singleton, + VarParsing.VarParsing.varType.string, + "geometry of operations: D49, D88, D92, D93") + +### get and parse the command line arguments +options.parseArguments() + +print(options) + +#################################################################### +# Use the options + +if (options.geometry == "D49"): + from Configuration.Eras.Era_Phase2C9_cff import Phase2C9 + process = cms.Process('SingleMuonDigi',Phase2C9) + process.load('Configuration.Geometry.GeometryExtended2026D49Reco_cff') + globalTag = "auto:phase2_realistic_T15" +elif (options.geometry == "D88"): + from Configuration.Eras.Era_Phase2C11I13M9_cff import Phase2C11I13M9 + process = cms.Process('SingleMuonDigi',Phase2C11I13M9) + process.load('Configuration.Geometry.GeometryExtended2026D88Reco_cff') + globalTag = "auto:phase2_realistic_T21" +elif (options.geometry == "D93"): + from Configuration.Eras.Era_Phase2C11I13M9_cff import Phase2C11I13M9 + process = cms.Process('SingleMuonDigi',Phase2C11I13M9) + process.load('Configuration.Geometry.GeometryExtended2026D93Reco_cff') + globalTag = "auto:phase2_realistic_T21" +else: + from Configuration.Eras.Era_Phase2C11I13M9_cff import Phase2C11I13M9 + process = cms.Process('SingleMuonDigi',Phase2C11I13M9) + process.load('Configuration.Geometry.GeometryExtended2026D92Reco_cff') + globalTag = "auto:phase2_realistic_T21" + +print("Global Tag: ", globalTag) + +# import of standard configurations +process.load('Configuration.StandardSequences.Services_cff') +process.load('SimGeneral.HepPDTESSource.pythiapdt_cfi') +process.load('FWCore.MessageService.MessageLogger_cfi') +process.load('Configuration.EventContent.EventContent_cff') +process.load('SimGeneral.MixingModule.mixNoPU_cfi') +process.load('Configuration.StandardSequences.MagneticField_cff') +process.load('Configuration.StandardSequences.Digi_cff') +process.load('Configuration.StandardSequences.L1TrackTrigger_cff') +process.load('Configuration.StandardSequences.SimL1Emulator_cff') +process.load('Configuration.StandardSequences.DigiToRaw_cff') +process.load('HLTrigger.Configuration.HLT_Fake2_cff') +process.load('Configuration.StandardSequences.EndOfProcess_cff') +process.load('Configuration.StandardSequences.FrontierConditions_GlobalTag_cff') + +process.maxEvents = cms.untracked.PSet( + input = cms.untracked.int32(-1), + output = cms.optional.untracked.allowed(cms.int32,cms.PSet) +) + +# Input source +process.source = cms.Source("PoolSource", + dropDescendantsOfDroppedBranches = cms.untracked.bool(False), + fileNames = cms.untracked.vstring('file:step1.root'), + inputCommands = cms.untracked.vstring( + 'keep *', + 'drop *_genParticles_*_*', + 'drop *_genParticlesForJets_*_*', + 'drop *_kt4GenJets_*_*', + 'drop *_kt6GenJets_*_*', + 'drop *_iterativeCone5GenJets_*_*', + 'drop *_ak4GenJets_*_*', + 'drop *_ak7GenJets_*_*', + 'drop *_ak8GenJets_*_*', + 'drop *_ak4GenJetsNoNu_*_*', + 'drop *_ak8GenJetsNoNu_*_*', + 'drop *_genCandidatesForMET_*_*', + 'drop *_genParticlesForMETAllVisible_*_*', + 'drop *_genMetCalo_*_*', + 'drop *_genMetCaloAndNonPrompt_*_*', + 'drop *_genMetTrue_*_*', + 'drop *_genMetIC5GenJs_*_*' + ), + secondaryFileNames = cms.untracked.vstring() +) + +process.options = cms.untracked.PSet( + FailPath = cms.untracked.vstring(), + IgnoreCompletely = cms.untracked.vstring(), + Rethrow = cms.untracked.vstring(), + SkipEvent = cms.untracked.vstring(), + accelerators = cms.untracked.vstring('*'), + allowUnscheduled = cms.obsolete.untracked.bool, + canDeleteEarly = cms.untracked.vstring(), + deleteNonConsumedUnscheduledModules = cms.untracked.bool(True), + dumpOptions = cms.untracked.bool(False), + emptyRunLumiMode = cms.obsolete.untracked.string, + eventSetup = cms.untracked.PSet( + forceNumberOfConcurrentIOVs = cms.untracked.PSet( + allowAnyLabel_=cms.required.untracked.uint32 + ), + numberOfConcurrentIOVs = cms.untracked.uint32(0) + ), + fileMode = cms.untracked.string('FULLMERGE'), + forceEventSetupCacheClearOnNewRun = cms.untracked.bool(False), + makeTriggerResults = cms.obsolete.untracked.bool, + numberOfConcurrentLuminosityBlocks = cms.untracked.uint32(0), + numberOfConcurrentRuns = cms.untracked.uint32(1), + numberOfStreams = cms.untracked.uint32(0), + numberOfThreads = cms.untracked.uint32(1), + printDependencies = cms.untracked.bool(False), + sizeOfStackForThreadsInKB = cms.optional.untracked.uint32, + throwIfIllegalParameter = cms.untracked.bool(True), + wantSummary = cms.untracked.bool(False) +) + +# Production Info +process.configurationMetadata = cms.untracked.PSet( + annotation = cms.untracked.string('step2 nevts:1000'), + name = cms.untracked.string('Applications'), + version = cms.untracked.string('$Revision: 1.19 $') +) + +# Output definition + +process.FEVTDEBUGHLToutput = cms.OutputModule("PoolOutputModule", + dataset = cms.untracked.PSet( + dataTier = cms.untracked.string('GEN-SIM-DIGI-RAW'), + filterName = cms.untracked.string('') + ), + fileName = cms.untracked.string('file:step2.root'), + outputCommands = process.FEVTDEBUGHLTEventContent.outputCommands, + splitLevel = cms.untracked.int32(0) +) + +# Additional output definition + +# Other statements +process.mix.digitizers = cms.PSet(process.theDigitizersValid) +from Configuration.AlCa.GlobalTag import GlobalTag +process.GlobalTag = GlobalTag(process.GlobalTag, globalTag, '') + +# Path and EndPath definitions +process.digitisation_step = cms.Path(process.pdigi_valid) +process.L1TrackTrigger_step = cms.Path(process.L1TrackTrigger) +process.L1simulation_step = cms.Path(process.SimL1Emulator) +process.digi2raw_step = cms.Path(process.DigiToRaw) +process.endjob_step = cms.EndPath(process.endOfProcess) +process.FEVTDEBUGHLToutput_step = cms.EndPath(process.FEVTDEBUGHLToutput) + +# Schedule definition +# process.schedule imported from cff in HLTrigger.Configuration +process.schedule.insert(0, process.digitisation_step) +process.schedule.insert(1, process.L1TrackTrigger_step) +process.schedule.insert(2, process.L1simulation_step) +process.schedule.insert(3, process.digi2raw_step) +process.schedule.extend([process.endjob_step,process.FEVTDEBUGHLToutput_step]) + +from PhysicsTools.PatAlgos.tools.helpers import associatePatAlgosToolsTask +associatePatAlgosToolsTask(process) + +# customisation of the process. + +# Automatic addition of the customisation function from HLTrigger.Configuration.customizeHLTforMC +from HLTrigger.Configuration.customizeHLTforMC import customizeHLTforMC + +#call to customisation function customizeHLTforMC imported from HLTrigger.Configuration.customizeHLTforMC +process = customizeHLTforMC(process) + +# End of customisation functions + + +# Customisation from command line + +# Add early deletion of temporary data products to reduce peak memory need +from Configuration.StandardSequences.earlyDeleteSettings_cff import customiseEarlyDelete +process = customiseEarlyDelete(process) +# End adding early deletion diff --git a/Validation/HGCalValidation/scripts/testHGCalRecoSingleMuonPt100_cfg.py b/Validation/HGCalValidation/scripts/testHGCalRecoSingleMuonPt100_cfg.py new file mode 100644 index 0000000000000..b27a9ec64766c --- /dev/null +++ b/Validation/HGCalValidation/scripts/testHGCalRecoSingleMuonPt100_cfg.py @@ -0,0 +1,164 @@ +############################################################################### +# Way to use this: +# cmsRun testHGCalDigi_cfg.py geometry=D92 +# +# Options for geometry D49, D88, D92, D93 +# +############################################################################### +import FWCore.ParameterSet.Config as cms +import os, sys, imp, re, random +import FWCore.ParameterSet.VarParsing as VarParsing + +#################################################################### +### SETUP OPTIONS +options = VarParsing.VarParsing('standard') +options.register('geometry', + "D92", + VarParsing.VarParsing.multiplicity.singleton, + VarParsing.VarParsing.varType.string, + "geometry of operations: D49, D88, D92, D93") + +### get and parse the command line arguments +options.parseArguments() + +print(options) + +#################################################################### +# Use the options + +if (options.geometry == "D49"): + from Configuration.Eras.Era_Phase2C9_cff import Phase2C9 + process = cms.Process('SingleMuonReco',Phase2C9) + process.load('Configuration.Geometry.GeometryExtended2026D49Reco_cff') + globalTag = "auto:phase2_realistic_T15" +elif (options.geometry == "D88"): + from Configuration.Eras.Era_Phase2C11I13M9_cff import Phase2C11I13M9 + process = cms.Process('SingleMuonReco',Phase2C11I13M9) + process.load('Configuration.Geometry.GeometryExtended2026D88Reco_cff') + globalTag = "auto:phase2_realistic_T21" +elif (options.geometry == "D93"): + from Configuration.Eras.Era_Phase2C11I13M9_cff import Phase2C11I13M9 + process = cms.Process('SingleMuonReco',Phase2C11I13M9) + process.load('Configuration.Geometry.GeometryExtended2026D93Reco_cff') + globalTag = "auto:phase2_realistic_T21" +else: + from Configuration.Eras.Era_Phase2C11I13M9_cff import Phase2C11I13M9 + process = cms.Process('SingleMuonReco',Phase2C11I13M9) + process.load('Configuration.Geometry.GeometryExtended2026D92Reco_cff') + globalTag = "auto:phase2_realistic_T21" + +print("Global Tag: ", globalTag) + +# import of standard configurations +process.load('Configuration.StandardSequences.Services_cff') +process.load('SimGeneral.HepPDTESSource.pythiapdt_cfi') +process.load('FWCore.MessageService.MessageLogger_cfi') +process.load('Configuration.EventContent.EventContent_cff') +process.load('SimGeneral.MixingModule.mixNoPU_cfi') +process.load('Configuration.Geometry.GeometryExtended2026D88Reco_cff') +process.load('Configuration.StandardSequences.MagneticField_cff') +process.load('Configuration.StandardSequences.RawToDigi_cff') +process.load('Configuration.StandardSequences.Reconstruction_cff') +process.load('Configuration.StandardSequences.RecoSim_cff') +process.load('Configuration.StandardSequences.FrontierConditions_GlobalTag_cff') + +process.maxEvents = cms.untracked.PSet( + input = cms.untracked.int32(-1), + output = cms.optional.untracked.allowed(cms.int32,cms.PSet) +) + +# Input source +process.source = cms.Source("PoolSource", + fileNames = cms.untracked.vstring('file:step2.root'), + secondaryFileNames = cms.untracked.vstring() +) + +process.options = cms.untracked.PSet( + FailPath = cms.untracked.vstring(), + IgnoreCompletely = cms.untracked.vstring(), + Rethrow = cms.untracked.vstring(), + SkipEvent = cms.untracked.vstring(), + accelerators = cms.untracked.vstring('*'), + allowUnscheduled = cms.obsolete.untracked.bool, + canDeleteEarly = cms.untracked.vstring(), + deleteNonConsumedUnscheduledModules = cms.untracked.bool(True), + dumpOptions = cms.untracked.bool(False), + emptyRunLumiMode = cms.obsolete.untracked.string, + eventSetup = cms.untracked.PSet( + forceNumberOfConcurrentIOVs = cms.untracked.PSet( + allowAnyLabel_=cms.required.untracked.uint32 + ), + numberOfConcurrentIOVs = cms.untracked.uint32(0) + ), + fileMode = cms.untracked.string('FULLMERGE'), + forceEventSetupCacheClearOnNewRun = cms.untracked.bool(False), + makeTriggerResults = cms.obsolete.untracked.bool, + numberOfConcurrentLuminosityBlocks = cms.untracked.uint32(0), + numberOfConcurrentRuns = cms.untracked.uint32(1), + numberOfStreams = cms.untracked.uint32(0), + numberOfThreads = cms.untracked.uint32(1), + printDependencies = cms.untracked.bool(False), + sizeOfStackForThreadsInKB = cms.optional.untracked.uint32, + throwIfIllegalParameter = cms.untracked.bool(True), + wantSummary = cms.untracked.bool(False) +) + +# Production Info +process.configurationMetadata = cms.untracked.PSet( + annotation = cms.untracked.string('step3 nevts:10'), + name = cms.untracked.string('Applications'), + version = cms.untracked.string('$Revision: 1.19 $') +) + +# Output definition + +process.FEVTDEBUGHLToutput = cms.OutputModule("PoolOutputModule", + dataset = cms.untracked.PSet( + dataTier = cms.untracked.string('GEN-SIM-RECO'), + filterName = cms.untracked.string('') + ), + fileName = cms.untracked.string('file:step3.root'), + outputCommands = cms.untracked.vstring( + 'keep *_*hbhe*_*_*', + 'keep *_g4SimHits_*_*', + 'keep *_*HGC*_*_*', + ), + splitLevel = cms.untracked.int32(0) +) + +# Additional output definition + +# Other statements +process.mix.playback = True +process.mix.digitizers = cms.PSet() +for a in process.aliases: delattr(process, a) +process.RandomNumberGeneratorService.restoreStateLabel=cms.untracked.string("randomEngineStateProducer") +from Configuration.AlCa.GlobalTag import GlobalTag +process.GlobalTag = GlobalTag(process.GlobalTag, globalTag, '') + +# Path and EndPath definitions +process.raw2digi_step = cms.Path(process.RawToDigi) +process.reconstruction_step = cms.Path(process.reconstruction) +process.recosim_step = cms.Path(process.recosim) +process.FEVTDEBUGHLToutput_step = cms.EndPath(process.FEVTDEBUGHLToutput) + +# Schedule definition +process.schedule = cms.Schedule(process.raw2digi_step, + process.reconstruction_step, + process.recosim_step, + process.FEVTDEBUGHLToutput_step) + +# customisation of the process. + +# Automatic addition of the customisation function from SimGeneral.MixingModule.fullMixCustomize_cff +from SimGeneral.MixingModule.fullMixCustomize_cff import setCrossingFrameOn + +#call to customisation function setCrossingFrameOn imported from SimGeneral.MixingModule.fullMixCustomize_cff +process = setCrossingFrameOn(process) + +# End of customisation functions + +# Add early deletion of temporary data products to reduce peak memory need +from Configuration.StandardSequences.earlyDeleteSettings_cff import customiseEarlyDelete +process = customiseEarlyDelete(process) +# End adding early deletion diff --git a/Validation/HGCalValidation/scripts/testHGCalSingleMuonPt100_cfg.py b/Validation/HGCalValidation/scripts/testHGCalSIMSingleMuonPt100_cfg.py similarity index 73% rename from Validation/HGCalValidation/scripts/testHGCalSingleMuonPt100_cfg.py rename to Validation/HGCalValidation/scripts/testHGCalSIMSingleMuonPt100_cfg.py index 8743fefbc250a..8debae1e99a9e 100644 --- a/Validation/HGCalValidation/scripts/testHGCalSingleMuonPt100_cfg.py +++ b/Validation/HGCalValidation/scripts/testHGCalSIMSingleMuonPt100_cfg.py @@ -2,7 +2,7 @@ # Way to use this: # cmsRun testHGCalSingleMuonPt100_cfg.py geometry=D92 # -# Options for geometry D88, D92, D93 +# Options for geometry D49, D88, D92, D93 # ############################################################################### import FWCore.ParameterSet.Config as cms @@ -16,7 +16,7 @@ "D92", VarParsing.VarParsing.multiplicity.singleton, VarParsing.VarParsing.varType.string, - "geometry of operations: D88, D92, D93") + "geometry of operations: D49, D88, D92, D93") ### get and parse the command line arguments options.parseArguments() @@ -26,18 +26,32 @@ #################################################################### # Use the options -from Configuration.Eras.Era_Phase2C11I13M9_cff import Phase2C11I13M9 -process = cms.Process('PROD',Phase2C11I13M9) - -if (options.geometry == "D88"): +if (options.geometry == "D49"): + from Configuration.Eras.Era_Phase2C9_cff import Phase2C9 + process = cms.Process('SingleMuon',Phase2C9) + process.load('Configuration.Geometry.GeometryExtended2026D49_cff') + process.load('Configuration.Geometry.GeometryExtended2026D49Reco_cff') + globalTag = "auto:phase2_realistic_T15" +elif (options.geometry == "D88"): + from Configuration.Eras.Era_Phase2C11I13M9_cff import Phase2C11I13M9 + process = cms.Process('SingleMuon',Phase2C11I13M9) process.load('Configuration.Geometry.GeometryExtended2026D88_cff') process.load('Configuration.Geometry.GeometryExtended2026D88Reco_cff') + globalTag = "auto:phase2_realistic_T21" elif (options.geometry == "D93"): + from Configuration.Eras.Era_Phase2C11I13M9_cff import Phase2C11I13M9 + process = cms.Process('SingleMuon',Phase2C11I13M9) process.load('Configuration.Geometry.GeometryExtended2026D93_cff') process.load('Configuration.Geometry.GeometryExtended2026D93Reco_cff') + globalTag = "auto:phase2_realistic_T21" else: + from Configuration.Eras.Era_Phase2C11I13M9_cff import Phase2C11I13M9 + process = cms.Process('SingleMuon',Phase2C11I13M9) process.load('Configuration.Geometry.GeometryExtended2026D92_cff') process.load('Configuration.Geometry.GeometryExtended2026D92Reco_cff') + globalTag = "auto:phase2_realistic_T21" + +print("Global Tag: ", globalTag) # import of standard configurations process.load('Configuration.StandardSequences.Services_cff') @@ -89,21 +103,17 @@ # Output definition process.output = cms.OutputModule("PoolOutputModule", - splitLevel = cms.untracked.int32(0), - eventAutoFlushCompressedSize = cms.untracked.int32(5242880), - outputCommands = cms.untracked.vstring( - 'keep *_*hbhe*_*_*', - 'keep *_g4SimHits_*_*', - 'keep *_*HGC*_*_*', - ), - fileName = cms.untracked.string('step1.root'), + SelectEvents = cms.untracked.PSet( + SelectEvents = cms.vstring('generation_step') + ), dataset = cms.untracked.PSet( filterName = cms.untracked.string(''), dataTier = cms.untracked.string('GEN-SIM-DIGI-RAW-RECO') ), - SelectEvents = cms.untracked.PSet( - SelectEvents = cms.vstring('generation_step') - ) + fileName = cms.untracked.string('step1.root'), + outputCommands = process.FEVTDEBUGEventContent.outputCommands, + eventAutoFlushCompressedSize = cms.untracked.int32(5242880), + splitLevel = cms.untracked.int32(0) ) # Additional output definition @@ -111,7 +121,7 @@ # Other statements process.genstepfilter.triggerConditions=cms.vstring("generation_step") from Configuration.AlCa.GlobalTag import GlobalTag -process.GlobalTag = GlobalTag(process.GlobalTag, 'auto:phase2_realistic', '') +process.GlobalTag = GlobalTag(process.GlobalTag, globalTag, '') process.generator = cms.EDFilter("Pythia8PtGun", PGunParameters = cms.PSet( @@ -138,14 +148,27 @@ process.generation_step = cms.Path(process.pgen) process.simulation_step = cms.Path(process.psim) process.genfiltersummary_step = cms.EndPath(process.genFilterSummary) +process.endjob_step = cms.EndPath(process.endOfProcess) process.out_step = cms.EndPath(process.output) # Schedule definition process.schedule = cms.Schedule(process.generation_step, + process.genfiltersummary_step, process.simulation_step, + process.endjob_step, process.out_step ) +from PhysicsTools.PatAlgos.tools.helpers import associatePatAlgosToolsTask +associatePatAlgosToolsTask(process) # filter all path with the production filter sequence for path in process.paths: - if getattr(process,path)._seq is not None: getattr(process,path)._seq = process.ProductionFilterSequence * getattr(process,path)._seq + getattr(process,path).insert(0, process.ProductionFilterSequence) + + +# Customisation from command line + +# Add early deletion of temporary data products to reduce peak memory need +from Configuration.StandardSequences.earlyDeleteSettings_cff import customiseEarlyDelete +process = customiseEarlyDelete(process) +# End adding early deletion