5from PyJobTransforms.TransformUtils
import processPreExec, processPreInclude, processPostExec, processPostInclude
13 from AthenaCommon.Logging
import logging
14 log = logging.getLogger(
"EVNTMerge")
15 log.info(
"****************** STARTING EVNT MERGING *****************")
17 log.info(
"**** Transformation run arguments")
18 log.info(str(runArgs))
20 log.info(
"**** Setting-up configuration flags")
21 from AthenaConfiguration.AllConfigFlags
import initConfigFlags
22 flags = initConfigFlags()
24 from AthenaConfiguration.Enums
import ProductionStep, MetadataCategory
25 flags.Common.ProductionStep = ProductionStep.Generation
27 commonRunArgsToFlags(runArgs, flags)
29 if hasattr(runArgs,
"inputEVNTFile"):
30 flags.Input.Files = runArgs.inputEVNTFile
32 raise RuntimeError(
"No input EVNT file defined")
34 if hasattr(runArgs,
"outputEVNT_MRGFile"):
35 if runArgs.outputEVNT_MRGFile ==
"None":
36 flags.Output.EVNTFileName =
""
39 flags.Output.EVNTFileName = runArgs.outputEVNT_MRGFile
41 raise RuntimeError(
"No outputEVNT_MRGFile defined")
44 processPreInclude(runArgs, flags)
47 processPreExec(runArgs, flags)
55 from AthenaConfiguration.MainServicesConfig
import MainServicesCfg
56 cfg = MainServicesCfg(flags)
58 from AthenaPoolCnvSvc.PoolReadConfig
import PoolReadCfg
59 cfg.merge(PoolReadCfg(flags))
63 if (
'EventInfo' not in flags.Input.Collections
and
64 'McEventInfo' in flags.Input.Collections):
65 from xAODEventInfoCnv.xAODEventInfoCnvConfig
import EventInfoCnvAlgCfg
66 cfg.merge(EventInfoCnvAlgCfg(flags, disableBeamSpot =
True))
68 from OutputStreamAthenaPool.OutputStreamConfig
import OutputStreamCfg
69 cfg.merge(OutputStreamCfg(flags,
"EVNT", disableEventTag =
True, takeItemsFromInput =
True, extendProvenanceRecord =
False))
72 from xAODMetaDataCnv.InfileMetaDataConfig
import SetupMetaDataForStreamCfg
75 SetupMetaDataForStreamCfg(
79 createMetadata=[MetadataCategory.IOVMetaData],
84 processPostInclude(runArgs, flags, cfg)
87 processPostExec(runArgs, flags, cfg)
90 from PyUtils.AMITagHelperConfig
import AMITagCfg
91 cfg.merge(AMITagCfg(flags, runArgs))
94 from AthenaConfiguration.AutoConfigFlags
import GetFileMD
95 hepmc_version = GetFileMD(flags.Input.Files).
get(
"hepmc_version",
None)
96 if hepmc_version
is not None:
97 if hepmc_version ==
"2":
98 hepmc_version =
"HepMC2"
99 elif hepmc_version ==
"3":
100 hepmc_version =
"HepMC3"
101 log.info(
"Input file was produced with %s", hepmc_version)
102 from EventInfoMgt.TagInfoMgrConfig
import TagInfoMgrCfg
103 cfg.merge(TagInfoMgrCfg(flags, tagValuePairs={
"hepmc_version": hepmc_version}))
109 log.info(
"Ran EVNTMerge_tf in " + str(time.time()-tic) +
" seconds")
111 sys.exit(
not sc.isSuccess())