ATLAS Offline Software
Loading...
Searching...
No Matches
runIDPVM.py
Go to the documentation of this file.
1#!/usr/bin/env python
2# Copyright (C) 2002-2025 CERN for the benefit of the ATLAS collaboration
3
4from glob import glob
5from AthenaConfiguration.ComponentFactory import CompFactory
6import AthenaCommon.SystemOfUnits as Units
7from InDetPhysValMonitoring.InDetPhysValMonitoringConfig import HardScatterStrategy
8
10 from argparse import ArgumentParser
11 IDPVMparser = ArgumentParser(description='Parser for IDPVM configuration')
12 IDPVMparser.add_argument("--filesInput", required=True)
13 IDPVMparser.add_argument("--maxEvents", help="Limit number of events. Default: all input events", default=-1, type=int)
14 IDPVMparser.add_argument("--skipEvents", help="Skip this number of events. Default: no events are skipped", default=0, type=int)
15 IDPVMparser.add_argument("--doLargeD0Tracks", help='also run LRT plots', action='store_true', default=False)
16 IDPVMparser.add_argument("--largeD0TrackCollection", help='Name of LRT collection',default="InDetLargeD0TrackParticles")
17 IDPVMparser.add_argument("--doLowPtRoITracks", help='also run low pt tracks', action='store_true', default=False)
18 IDPVMparser.add_argument("--doMergedLargeD0Tracks", help='also run merged STD+LRT plots', action='store_true', default=False)
19 IDPVMparser.add_argument("--doRecoOnly", help='skip truth-specific processing', action='store_true', default=False)
20 IDPVMparser.add_argument("--doLoose", help='also run loose plots', action='store_true', default=False)
21 IDPVMparser.add_argument("--doTightPrimary", help='also run tight-primary plots', action='store_true', default=False)
22 IDPVMparser.add_argument("--doHILoose", help='also run Heavy Ion loose plots', action='store_true', default=False)
23 IDPVMparser.add_argument("--doTracksInJets", help='also run tracks in jets', action='store_true', default=False)
24 IDPVMparser.add_argument("--doTracksInBJets", help='also run tracks in jets', action='store_true', default=False)
25 IDPVMparser.add_argument("--doTruthOrigin", help='make plots by track origin', action='store_true', default=False)
26 IDPVMparser.add_argument("--doDuplicate", help='make duplicate plots', action='store_true', default=False)
27 IDPVMparser.add_argument("--doHitLevelPlots", help='make hit residual / eff plots', action='store_true', default=False)
28 IDPVMparser.add_argument("--doPerAuthor", help='make plots by track author', action='store_true', default=False)
29 IDPVMparser.add_argument("--doExpertPlots", help='run additional expert-level plots', action='store_true', default=False)
30 IDPVMparser.add_argument("--doMuonMatchedTracks", help='run plots for tracks matched to true muons', action='store_true', default=False)
31 IDPVMparser.add_argument("--doElectronMatchedTracks", help='run plots for tracks matched to true electrons', action='store_true', default=False)
32 IDPVMparser.add_argument("--doTruthToRecoNtuple", help='output track-to-truth ntuple', action='store_true', default=False)
33 IDPVMparser.add_argument("--doActs", help='run plots for acts collections', action='store_true', default=False)
34 IDPVMparser.add_argument("--doHGTD", help='run plots fof HGTD collections', action='store_true', default=False)
35 IDPVMparser.add_argument("--disableDecoration", help='disable extra track and truth decoration if possible', action='store_true', default=False)
36 IDPVMparser.add_argument("--hardScatterStrategy", help='Strategy to select the hard scatter. 0 = SumPt² 1 = SumPt , 2 = Sumptw, 3 = GNN, 4 = H->yy', choices=["0","1","2","3","4"], default="0")
37 IDPVMparser.add_argument("--truthMinPt", help='minimum truth particle pT', type=float, default=None)
38 IDPVMparser.add_argument("--outputFile", help='Name of output file',default="M_output.root")
39 IDPVMparser.add_argument("--HSFlag", help='Hard-scatter flag - decides what is used for truth matching', choices=['HardScatter', 'All', 'PileUp'],default="HardScatter")
40 IDPVMparser.add_argument("--jetsNameForHardScatter", help='Name of jet collection',default="AntiKt4EMTopoJets")
41 IDPVMparser.add_argument("--ancestorIDList", help='List of ancestor truth IDs to match.', default = [], nargs='+', type=int)
42 IDPVMparser.add_argument("--requiredSiHits", help='Number of truth silicon hits', type=int, default=0)
43 IDPVMparser.add_argument("--selectedCharge", help='Charge of selected truth particles (0=inclusive)', type=int, default=0)
44 IDPVMparser.add_argument("--maxProdVertRadius", help='Maximum production radius for truth particles', type=float, default=300)
45 IDPVMparser.add_argument("--minProdVertRadius", help='Minimum production radius for truth particles', type=float, default=0)
46 IDPVMparser.add_argument("--minAbsD0", help='Minimum |d0| for truth particles', type=float, default=0)
47 IDPVMparser.add_argument("--GRL", help='Which GRL(s) to use, if any, when running on data', choices=['2015', '2016', '2017', '2018', '2022', '2023', '2024'], nargs='+', default=[])
48 IDPVMparser.add_argument("--validateExtraTrackCollections", help='List of extra track collection names to be validated in addition to Tracks.', nargs='+', default=[])
49 IDPVMparser.add_argument("--doIDTIDE", help='run the output from IDTIDE derivation', action='store_true', default=False)
50 IDPVMparser.add_argument("--doTechnicalEfficiency", help='fill the technical efficiency plot (requires additional si hit information in the input file)', action='store_true', default=False)
51 IDPVMparser.add_argument("--doPRW", help='apply pileup reweight', action='store_true', default=False)
52 IDPVMparser.add_argument("--maxTrkJetDR", help='the maximum dR to jets to allow for track-in-jet plots', type=float, default=0.4)
53 IDPVMparser.add_argument("--JetAbsEtaMax", help='Maximum Eta value for jet selection', type=float, default=-1)
54 IDPVMparser.add_argument("--PrimaryVertexContainer", help='Name of the primary vertex container', choices=['PrimaryVertices', 'ActsPrimaryVertices', 'HggPrimaryVertices', 'PrimaryVertices_Grid'], default='PrimaryVertices')
55 IDPVMparser.add_argument("--OnlyTrackingPreInclude", help='Disable all flags related to detectors/domains beyond tracking', action='store_true', default=False)
56 IDPVMparser.add_argument("--jetCollection", help='Jet collection for track-in-jet plots', default="AntiKt4EMPFlowJets")
57 IDPVMparser.add_argument("--JetPtMin", help='Minimum pt for jet selection in GeV', type=float, default=100)
58 IDPVMparser.add_argument("--JetPtMax", help='Maximum pt for jet selection in GeV', type=float, default=5000)
59 IDPVMparser.add_argument("--setCSVName", help='Convert AOD to a SCV file for the track overlay ML training dataset', default="")
60 IDPVMparser.add_argument("--vetoPdgId", help='Veto a particle based on PDG ID', type=int, default=-1)
61 IDPVMparser.add_argument("--pdgId", help='Select a particle based on PDG ID', type=int, default=-1)
62 return IDPVMparser.parse_args()
63
64# Parse the arguments
66
67from AthenaConfiguration.Enums import LHCPeriod
68from AthenaConfiguration.AllConfigFlags import initConfigFlags
69flags = initConfigFlags()
70
71flags.Input.Files = []
72for path in MyArgs.filesInput.split(','):
73 flags.Input.Files += glob(path)
74flags.PhysVal.OutputFileName = MyArgs.outputFile
75
76# Set default truthMinPt depending on Run config
77if MyArgs.truthMinPt is None:
78 MyArgs.truthMinPt = 1000 if flags.GeoModel.Run >= LHCPeriod.Run4 \
79 else 500
80
81flags.PhysVal.IDPVM.setTruthStrategy = MyArgs.HSFlag
82flags.PhysVal.IDPVM.doExpertOutput = MyArgs.doExpertPlots or MyArgs.doPerAuthor
83flags.PhysVal.IDPVM.doValidateTruthToRecoNtuple = MyArgs.doTruthToRecoNtuple
84flags.PhysVal.IDPVM.doIDTIDE= MyArgs.doIDTIDE
85if MyArgs.doTracksInJets:
86 flags.PhysVal.IDPVM.doValidateTracksInJets = True
87if MyArgs.doTracksInBJets:
88 flags.PhysVal.IDPVM.doValidateTracksInBJets = True
89if MyArgs.setCSVName != "":
90 flags.PhysVal.IDPVM.setCSVName = MyArgs.setCSVName
91if MyArgs.vetoPdgId > 0:
92 flags.PhysVal.IDPVM.vetoPdgId = MyArgs.vetoPdgId
93if MyArgs.pdgId > 0:
94 flags.PhysVal.IDPVM.pdgId = MyArgs.pdgId
95flags.PhysVal.IDPVM.doValidateLooseTracks = MyArgs.doLoose
96flags.PhysVal.IDPVM.doValidateTightPrimaryTracks = MyArgs.doTightPrimary
97flags.PhysVal.IDPVM.doValidateHILoose = MyArgs.doHILoose
98flags.PhysVal.IDPVM.doTruthOriginPlots = MyArgs.doTruthOrigin
99flags.PhysVal.IDPVM.doDuplicatePlots = MyArgs.doDuplicate
100flags.PhysVal.IDPVM.doValidateMuonMatchedTracks = MyArgs.doMuonMatchedTracks
101flags.PhysVal.IDPVM.doValidateElectronMatchedTracks = MyArgs.doElectronMatchedTracks
102flags.PhysVal.IDPVM.doValidateLargeD0Tracks = MyArgs.doLargeD0Tracks
103flags.PhysVal.IDPVM.largeD0TrackCollection = MyArgs.largeD0TrackCollection
104flags.PhysVal.IDPVM.doValidateMergedLargeD0Tracks = MyArgs.doMergedLargeD0Tracks
105flags.PhysVal.IDPVM.doValidateLowPtRoITracks = MyArgs.doLowPtRoITracks
106flags.PhysVal.IDPVM.doRecoOnly = MyArgs.doRecoOnly
107flags.PhysVal.IDPVM.doPerAuthorPlots = MyArgs.doPerAuthor
108flags.PhysVal.IDPVM.doHitLevelPlots = MyArgs.doHitLevelPlots
109flags.PhysVal.IDPVM.runDecoration = not MyArgs.disableDecoration
110flags.PhysVal.IDPVM.requiredSiHits = MyArgs.requiredSiHits
111flags.PhysVal.IDPVM.selectedCharge = MyArgs.selectedCharge
112flags.PhysVal.IDPVM.maxProdVertRadius = MyArgs.maxProdVertRadius
113flags.PhysVal.IDPVM.minProdVertRadius = MyArgs.minProdVertRadius
114flags.PhysVal.IDPVM.minAbsD0 = MyArgs.minAbsD0
115flags.PhysVal.IDPVM.ancestorIDs = MyArgs.ancestorIDList
116flags.PhysVal.IDPVM.hardScatterStrategy = HardScatterStrategy(int(MyArgs.hardScatterStrategy))
117flags.PhysVal.IDPVM.jetsNameForHardScatter = MyArgs.jetsNameForHardScatter
118flags.PhysVal.IDPVM.truthMinPt = MyArgs.truthMinPt
119flags.PhysVal.IDPVM.GRL = MyArgs.GRL
120flags.PhysVal.IDPVM.validateExtraTrackCollections = MyArgs.validateExtraTrackCollections
121flags.PhysVal.IDPVM.doTechnicalEfficiency = MyArgs.doTechnicalEfficiency
122flags.PhysVal.IDPVM.doPRW = MyArgs.doPRW
123flags.PhysVal.IDPVM.doActs = MyArgs.doActs
124flags.PhysVal.IDPVM.doHGTD = MyArgs.doHGTD
125flags.PhysVal.IDPVM.maxTrkJetDR = MyArgs.maxTrkJetDR
126flags.PhysVal.IDPVM.PrimaryVertexContainer = MyArgs.PrimaryVertexContainer
127flags.PhysVal.IDPVM.jetCollection = MyArgs.jetCollection
128flags.PhysVal.IDPVM.JetPtMin = MyArgs.JetPtMin * Units.GeV
129flags.PhysVal.IDPVM.JetPtMax = MyArgs.JetPtMax * Units.GeV
130if MyArgs.JetAbsEtaMax != -1:
131 flags.PhysVal.IDPVM.JetAbsEtaMax = MyArgs.JetAbsEtaMax
132
133
134flags.Exec.SkipEvents = MyArgs.skipEvents
135flags.Exec.MaxEvents = MyArgs.maxEvents
136
137# force the vertex for hgg case
138if flags.PhysVal.IDPVM.hardScatterStrategy == HardScatterStrategy.HYY:
139 flags.PhysVal.IDPVM.PrimaryVertexContainer = 'HggPrimaryVertices'
140
141if MyArgs.OnlyTrackingPreInclude:
142 from InDetConfig.ConfigurationHelpers import OnlyTrackingPreInclude
143 OnlyTrackingPreInclude(flags)
144
145flags.PhysVal.doExample = False
146
147flags.lock()
148
149from AthenaConfiguration.MainServicesConfig import MainServicesCfg
150acc = MainServicesCfg(flags)
151from AthenaPoolCnvSvc.PoolReadConfig import PoolReadCfg
152acc.merge(PoolReadCfg(flags))
153
154# Schedule ACTS data pool if requested
155if flags.PhysVal.IDPVM.doActs:
156 from ActsConfig.ActsCollectionsConfig import ActsPoolReadCfg
157 acc.merge(ActsPoolReadCfg(flags))
158
159if flags.PhysVal.IDPVM.doPRW:
160 acc.addService(CompFactory.CP.SystematicsSvc("SystematicsSvc"))
161 from AsgAnalysisAlgorithms.PileupReweightingAlgConfig import PileupReweightingAlgCfg
162 acc.merge(PileupReweightingAlgCfg(flags))
163
164from InDetPhysValMonitoring.InDetPhysValMonitoringConfig import InDetPhysValMonitoringCfg
165acc.merge(InDetPhysValMonitoringCfg(flags))
166
167acc.printConfig(withDetails=True)
168
169# Execute and finish
170sc = acc.run()
171
172# Success should be 0
173import sys
174sys.exit(not sc.isSuccess())
GetCustomAthArgs()
Definition runIDPVM.py:9