ATLAS Offline Software
MuonHoughTransformTesterConfig.py
Go to the documentation of this file.
1 # Copyright (C) 2002-2025 CERN for the benefit of the ATLAS collaboration
2 
3 
4 if __name__=="__main__":
5  from MuonGeoModelTestR4.testGeoModel import setupGeoR4TestCfg, SetupArgParser
6  from MuonConfig.MuonConfigUtils import executeTest, setupHistSvcCfg
7  parser = SetupArgParser()
8  parser.add_argument("--noMonitorPlots", help="If set to true, there're no monitoring plots", default = False,
9  action='store_true')
10  parser.add_argument("--writeSpacePoints", help="If set to true, the spacepoints in the bucket are saved to disk",
11  default=False, action='store_true')
12  parser.add_argument("--noPerfMon", help="If set to true, full perfmonMT is enabled",
13  default=False, action='store_true')
14  parser.set_defaults(nEvents = -1)
15  parser.set_defaults(noSTGC=True)
16 
17  parser.set_defaults(outRootFile="HoughTransformTester.root")
18  parser.set_defaults(inputFile=["/cvmfs/atlas-nightlies.cern.ch/repo/data/data-art/MuonGeomRTT/R3SimHits.pool.root"])
19  parser.set_defaults(eventPrintoutLevel = 50)
20 
21  args = parser.parse_args()
22  from AthenaConfiguration.AllConfigFlags import initConfigFlags
23  flags = initConfigFlags()
24  flags.PerfMon.doFullMonMT = not args.noPerfMon
25  flags.PerfMon.OutputJSON="perfmonmt_MuonR4Reco.json"
26 
27  flags.Muon.doFastMMDigitization = True
28  flags, cfg = setupGeoR4TestCfg(args,flags)
29 
30 
31  cfg.getService("MessageSvc").setVerbose = []
32  # from PerfMonVTune.PerfMonVTuneConfig import VTuneProfilerServiceCfg
33  cfg.merge(setupHistSvcCfg(flags,outFile=args.outRootFile,
34  outStream="MuonEtaHoughTransformTest"))
35 
36  from MuonConfig.MuonDataPrepConfig import xAODUncalibMeasPrepCfg
37  cfg.merge(xAODUncalibMeasPrepCfg(flags))
38 
39  from MuonSpacePointFormation.SpacePointFormationConfig import MuonSpacePointFormationCfg
40  cfg.merge(MuonSpacePointFormationCfg(flags))
41 
42  from MuonPatternRecognitionAlgs.MuonHoughTransformAlgConfig import MuonPatternRecognitionCfg
43  from MuonPatternRecognitionTest.PatternTestConfig import MuonHoughTransformTesterCfg, PatternVisualizationToolCfg
44 
45  cfg.merge(MuonPatternRecognitionCfg(flags))
46  if flags.Input.isMC:
47 
50  from IOVDbSvc.IOVDbSvcConfig import addOverride
51  cfg.merge(addOverride(flags, "/MDT/TWINMAPPING", "MDTTwinMapping_compactFormat_Run123"))
52 
53 
54  cfg.merge(MuonHoughTransformTesterCfg(flags,
55  VisualizationTool = cfg.popToolsAndMerge(PatternVisualizationToolCfg(flags, CanvasLimits =0))))
56 
57  if not args.noMonitorPlots and (flags.Detector.GeometryMDT or flags.Detector.GeometryRPC or flags.Detector.GeometryTGC):
58  cfg.getEventAlgo("MuonEtaHoughTransformAlg").VisualizationTool = cfg.popToolsAndMerge(PatternVisualizationToolCfg(flags,
59  CanvasPreFix="EtaHoughPlotValid",
60  AllCanvasName="AllEtaHoughiDiPuffPlots", doPhiBucketViews = False,
61  displayTruthOnly = True, saveSinglePDFs = True, saveSummaryPDF= False))
62  #cfg.getEventAlgo("MuonPhiHoughTransformAlg").VisualizationTool = cfg.popToolsAndMerge(PatternVisualizationToolCfg(flags,
63  # CanvasPreFix="PhiHoughPlotValid",
64  # AllCanvasName="AllPhiHoughiDiPuffPlots",doEtaBucketViews = False,
65  # displayTruthOnly = True, saveSinglePDFs = False, saveSummaryPDF= False))
66  cfg.getEventAlgo("MuonSegmentFittingAlg").VisualizationTool = cfg.popToolsAndMerge(PatternVisualizationToolCfg(flags,
67  CanvasPreFix="SegmentPlotValid",
68  AllCanvasName="AllSegmentFitPlots", displayTruthOnly = True,
69  saveSinglePDFs = True, saveSummaryPDF= False))
70  if not args.noMonitorPlots and (flags.Detector.GeometryMM or flags.Detector.GeometrysTGC):
71  cfg.getEventAlgo("NswEtaHoughTransformAlg").VisualizationTool = cfg.popToolsAndMerge(PatternVisualizationToolCfg(flags,
72  CanvasPreFix="NswEtaHoughPlotValid",
73  AllCanvasName="AllNswEtaHoughiDiPuffPlots",
74  saveSinglePDFs = True, saveSummaryPDF= False))
75  cfg.getEventAlgo("NswPhiSeedFinderAlg").VisualizationTool = cfg.popToolsAndMerge(PatternVisualizationToolCfg(flags,
76  CanvasPreFix="NswPhiHoughPlotValid",
77  AllCanvasName="AllNswPhiHoughiDiPuffPlots",
78  saveSinglePDFs = True, saveSummaryPDF= False))
79  cfg.getEventAlgo("NswSegmentFitter").VisualizationTool = cfg.popToolsAndMerge(PatternVisualizationToolCfg(flags,
80  CanvasPreFix="NswSegmentFitPlotValid",
81  AllCanvasName="AllNswSegmentFitPlots",
82  saveSinglePDFs = True, saveSummaryPDF= False))
83 
84  executeTest(cfg)
85 
PatternTestConfig.PatternVisualizationToolCfg
def PatternVisualizationToolCfg(flags, name="PatternVisualizationTool", **kwargs)
Definition: PatternTestConfig.py:7
PatternTestConfig.MuonHoughTransformTesterCfg
def MuonHoughTransformTesterCfg(flags, name="MuonHoughTransformTester", **kwargs)
Definition: PatternTestConfig.py:28
MdtCablingTester.SetupArgParser
def SetupArgParser()
Definition: MdtCablingTester.py:3
testGeoModel.setupGeoR4TestCfg
def setupGeoR4TestCfg(args, flags=None)
Definition: MuonPhaseII/MuonDetDescr/MuonGeoModelTestR4/python/testGeoModel.py:119
MuonConfigUtils.executeTest
def executeTest(cfg)
Definition: MuonConfigUtils.py:15
MuonHoughTransformAlgConfig.MuonPatternRecognitionCfg
def MuonPatternRecognitionCfg(flags)
Definition: MuonHoughTransformAlgConfig.py:58
python.IOVDbSvcConfig.addOverride
def addOverride(flags, folder, tag, tagType="tag", db=None)
Definition: IOVDbSvcConfig.py:238
MuonDataPrepConfig.xAODUncalibMeasPrepCfg
def xAODUncalibMeasPrepCfg(flags)
Configuriation snippet to schedule all algorithms providing the Uncalibrated measurements.
Definition: MuonDataPrepConfig.py:29
python.AllConfigFlags.initConfigFlags
def initConfigFlags()
Definition: AllConfigFlags.py:19
SpacePointFormationConfig.MuonSpacePointFormationCfg
def MuonSpacePointFormationCfg(flags)
Definition: SpacePointFormationConfig.py:20
MuonConfigUtils.setupHistSvcCfg
def setupHistSvcCfg(flags, str outFile, str outStream)
Configuration snippet to setup the THistSvc.
Definition: MuonConfigUtils.py:5