35def CommonSimulationCfg(flags, log):
36
37 if not flags.Input.Files:
38
39 from AthenaConfiguration.MainServicesConfig import MainEvgenServicesCfg
40 cfg = MainEvgenServicesCfg(flags)
41
42 from xAODEventInfoCnv.xAODEventInfoCnvConfig import EventInfoCnvAlgCfg
43 cfg.merge(EventInfoCnvAlgCfg(flags, name="xAODMaker::EventInfoCnvAlg", disableBeamSpot = True))
44
45
46
47
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:
53
54 from CosmicGenerator.CosmicGeneratorConfig import CosmicGeneratorCfg
55 cfg.merge(CosmicGeneratorCfg(flags))
56 else:
57
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!")
62 else:
63 log.error("No input file or on-the-fly generation configuration provided!")
64 else:
65
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:
71
72 from TrackRecordGenerator.TrackRecordGeneratorConfig import Input_TrackRecordGeneratorCfg
73 cfg.merge(Input_TrackRecordGeneratorCfg(flags))
74 if flags.Sim.ISF.ReSimulation:
75
76 if "xAOD::EventInfo#EventInfo" not in flags.Input.TypedCollections:
77 from xAODEventInfoCnv.xAODEventInfoCnvConfig import EventInfoCnvAlgCfg
78 cfg.merge(EventInfoCnvAlgCfg(flags))
79 else:
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')
86
87 if flags.Sim.ISF.ReSimulation:
88
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'))
93 else:
94
95
96 from BeamEffects.BeamEffectsAlgConfig import BeamEffectsAlgCfg
97 cfg.merge(BeamEffectsAlgCfg(flags))
98 if flags.Input.Files:
99
100 if "xAOD::EventInfo#EventInfo" not in flags.Input.TypedCollections:
101 from xAODEventInfoCnv.xAODEventInfoCnvConfig import EventInfoCnvAlgCfg
102 cfg.merge(EventInfoCnvAlgCfg(flags))
103 else:
104 from xAODEventInfoCnv.xAODEventInfoCnvConfig import EventInfoUpdateFromContextAlgCfg
105 cfg.merge(EventInfoUpdateFromContextAlgCfg(flags))
106 else:
107
108 pass
109
110 if flags.Beam.Type is BeamType.TestBeam:
111 from TBDetDescrAlg.TBDetDescrAlgConfig import TBDetDescrLoaderCfg
112 cfg.merge(TBDetDescrLoaderCfg(flags))
113 AcceptAlgNames=[]
114 if flags.Sim.ISFRun:
115
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']
121 else:
122 if not flags.Sim.UseG4Workers:
123 AcceptAlgNames = ['G4AtlasAlg']
124
125 from G4AtlasAlg.G4AtlasAlgConfig import G4AtlasAlgCfg
126 cfg.merge(G4AtlasAlgCfg(flags))
127 else:
128 AcceptAlgNames = ['G4RunAlg']
129
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()
140
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))
145
146 from OutputStreamAthenaPool.OutputStreamConfig import OutputStreamCfg, outputStreamName
147 from xAODMetaDataCnv.InfileMetaDataConfig import SetupMetaDataForStreamCfg
148
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
155
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]))
160
161 return cfg