37 if not flags.Input.Files:
39 from AthenaConfiguration.MainServicesConfig
import MainEvgenServicesCfg
40 cfg = MainEvgenServicesCfg(flags)
42 from xAODEventInfoCnv.xAODEventInfoCnvConfig
import EventInfoCnvAlgCfg
43 cfg.merge(EventInfoCnvAlgCfg(flags, name=
"xAODMaker::EventInfoCnvAlg", disableBeamSpot =
True))
48 cfg.getService(
"EventSelector").FirstLB = flags.Input.LumiBlockNumbers[0]
49 cfg.getService(
"EventSelector").OverrideRunNumber =
True
50 from AthenaKernel.EventIdOverrideConfig
import EvtIdModifierSvcCfg
51 cfg.merge(EvtIdModifierSvcCfg(flags))
52 if flags.Beam.Type
is BeamType.Cosmics:
54 from CosmicGenerator.CosmicGeneratorConfig
import CosmicGeneratorCfg
55 cfg.merge(CosmicGeneratorCfg(flags))
58 fragment = flags.Sim.GenerationConfiguration
59 if fragment
and fragment !=
'NONE':
60 executeFromFragment(fragment, flags, cfg)
61 log.info(
"On-the-fly generation using ParticleGun!")
63 log.error(
"No input file or on-the-fly generation configuration provided!")
66 from AthenaConfiguration.MainServicesConfig
import MainServicesCfg
67 cfg = MainServicesCfg(flags)
68 from AthenaPoolCnvSvc.PoolReadConfig
import PoolReadCfg
69 cfg.merge(PoolReadCfg(flags))
70 if flags.Sim.ReadTR
or flags.Sim.CavernBackground
is CavernBackground.Read:
72 from TrackRecordGenerator.TrackRecordGeneratorConfig
import Input_TrackRecordGeneratorCfg
73 cfg.merge(Input_TrackRecordGeneratorCfg(flags))
74 if flags.Sim.ISF.ReSimulation:
76 if "xAOD::EventInfo#EventInfo" not in flags.Input.TypedCollections:
77 from xAODEventInfoCnv.xAODEventInfoCnvConfig
import EventInfoCnvAlgCfg
78 cfg.merge(EventInfoCnvAlgCfg(flags))
80 from xAODEventInfoCnv.xAODEventInfoCnvConfig
import EventInfoUpdateFromContextAlgCfg
81 cfg.merge(EventInfoUpdateFromContextAlgCfg(flags))
82 from McEventCollectionFilter.McEventCollectionFilterConfig
import TruthResetAlgCfg
83 cfg.merge(TruthResetAlgCfg(flags))
84 cfg.addSequence(CompFactory.AthSequencer(
'SimSequence'), parentName=
'AthAlgSeq')
85 cfg.addSequence(CompFactory.AthSequencer(
'CopyHitSequence'), parentName=
'AthAlgSeq')
87 if flags.Sim.ISF.ReSimulation:
89 from ISF_Algorithms.ISF_AlgorithmsConfig
import SimEventFilterCfg, InvertedSimEventFilterCfg, RenameHitCollectionsCfg
90 cfg.merge(SimEventFilterCfg(flags, sequenceName=
'SimSequence'))
91 cfg.merge(InvertedSimEventFilterCfg(flags, sequenceName=
'CopyHitSequence'))
92 cfg.merge(RenameHitCollectionsCfg(flags, sequenceName=
'CopyHitSequence'))
96 from BeamEffects.BeamEffectsAlgConfig
import BeamEffectsAlgCfg
97 cfg.merge(BeamEffectsAlgCfg(flags))
100 if "xAOD::EventInfo#EventInfo" not in flags.Input.TypedCollections:
101 from xAODEventInfoCnv.xAODEventInfoCnvConfig
import EventInfoCnvAlgCfg
102 cfg.merge(EventInfoCnvAlgCfg(flags))
104 from xAODEventInfoCnv.xAODEventInfoCnvConfig
import EventInfoUpdateFromContextAlgCfg
105 cfg.merge(EventInfoUpdateFromContextAlgCfg(flags))
110 if flags.Beam.Type
is BeamType.TestBeam:
111 from TBDetDescrAlg.TBDetDescrAlgConfig
import TBDetDescrLoaderCfg
112 cfg.merge(TBDetDescrLoaderCfg(flags))
116 from ISF_Config.ISF_MainConfig
import ISF_KernelCfg
117 cfg.merge(ISF_KernelCfg(flags))
118 AcceptAlgNames = [
'ISF_Kernel_' + flags.Sim.ISF.Simulator.value]
119 if flags.Sim.ISF.ReSimulation:
120 AcceptAlgNames += [
'RenameHitCollections']
122 if not flags.Sim.UseG4Workers:
123 AcceptAlgNames = [
'G4AtlasAlg']
125 from G4AtlasAlg.G4AtlasAlgConfig
import G4AtlasAlgCfg
126 cfg.merge(G4AtlasAlgCfg(flags))
128 AcceptAlgNames = [
'G4RunAlg']
130 from G4AtlasAlg.G4RunAlgConfig
import G4RunAlgCfg
131 cfg.merge(G4RunAlgCfg(flags))
132 from SimulationConfig.SimEnums
import LArParameterization
133 if flags.Sim.LArParameterization
is LArParameterization.FastCaloSim:
134 cfg.getEventAlgo(
"ISF_CollectionMerger").InputLArEMBHits.data.sort()
135 cfg.getEventAlgo(
"ISF_CollectionMerger").InputLArEMECHits.data.sort()
136 cfg.getEventAlgo(
"ISF_CollectionMerger").InputLArFCALHits.data.sort()
137 cfg.getEventAlgo(
"ISF_CollectionMerger").InputLArHECHits.data.sort()
138 cfg.getEventAlgo(
"ISF_CollectionMerger").InputTileHits.data.sort()
139 cfg.getEventAlgo(
"ISF_CollectionMerger").InputMBTSHits.data.sort()
141 from SimulationConfig.SimEnums
import CalibrationRun
142 if flags.Sim.CalibrationRun
in [CalibrationRun.LAr, CalibrationRun.LArTile, CalibrationRun.LArTileZDC]:
143 from LArG4SD.LArG4SDToolConfig
import DeadMaterialCalibrationHitMergerCfg
144 cfg.merge(DeadMaterialCalibrationHitMergerCfg(flags))
146 from OutputStreamAthenaPool.OutputStreamConfig
import OutputStreamCfg, outputStreamName
147 from xAODMetaDataCnv.InfileMetaDataConfig
import SetupMetaDataForStreamCfg
149 if flags.Output.HITSFileName:
150 from SimuJobTransforms.SimOutputConfig
import getStreamHITS_ItemList
151 cfg.merge( OutputStreamCfg(flags,
"HITS", ItemList=getStreamHITS_ItemList(flags), disableEventTag=
False, AcceptAlgs=AcceptAlgNames) )
152 cfg.merge(SetupMetaDataForStreamCfg(flags,
"HITS", AcceptAlgs=AcceptAlgNames, createMetadata=[MetadataCategory.IOVMetaData]))
153 if flags.Sim.ISF.ReSimulation:
154 cfg.getEventAlgo(outputStreamName(
"HITS")).TakeItemsFromInput=
False
156 if flags.Output.EVNT_TRFileName:
157 from SimuJobTransforms.SimOutputConfig
import getStreamEVNT_TR_ItemList
158 cfg.merge( OutputStreamCfg(flags,
"EVNT_TR", ItemList=getStreamEVNT_TR_ItemList(flags), disableEventTag=
True, AcceptAlgs=AcceptAlgNames) )
159 cfg.merge(SetupMetaDataForStreamCfg(flags,
"EVNT_TR", AcceptAlgs=AcceptAlgNames, createMetadata=[MetadataCategory.IOVMetaData]))