ATLAS Offline Software
Loading...
Searching...
No Matches
VP1AlgConfig Namespace Reference

Functions

 configureGeometry (flags, cfg)
 getATLASVersion ()
 VP1AlgCfg (flags, name="VP1AlgCA", **kwargs)
 SetupVP1 ()
 setup_live_mode (args, vp1config)
 setup_batch_mode (args)

Function Documentation

◆ configureGeometry()

VP1AlgConfig.configureGeometry ( flags,
cfg )

Definition at line 9 of file VP1AlgConfig.py.

9def configureGeometry(flags, cfg):
10 if flags.Detector.GeometryBpipe:
11 from BeamPipeGeoModel.BeamPipeGMConfig import BeamPipeGeometryCfg
12
13 cfg.merge(BeamPipeGeometryCfg(flags))
14
15 if flags.Detector.GeometryPixel:
16 from PixelGeoModel.PixelGeoModelConfig import PixelReadoutGeometryCfg
17
18 cfg.merge(PixelReadoutGeometryCfg(flags))
19
20 if flags.Detector.GeometrySCT:
21 from SCT_GeoModel.SCT_GeoModelConfig import SCT_ReadoutGeometryCfg
22
23 cfg.merge(SCT_ReadoutGeometryCfg(flags))
24
25 if flags.Detector.GeometryTRT:
26 from TRT_GeoModel.TRT_GeoModelConfig import TRT_ReadoutGeometryCfg
27
28 cfg.merge(TRT_ReadoutGeometryCfg(flags))
29
30 if flags.Detector.GeometryITkPixel:
31 from PixelGeoModelXml.ITkPixelGeoModelConfig import ITkPixelReadoutGeometryCfg
32
33 cfg.merge(ITkPixelReadoutGeometryCfg(flags))
34
35 if flags.Detector.GeometryITkStrip:
36 from StripGeoModelXml.ITkStripGeoModelConfig import ITkStripReadoutGeometryCfg
37
38 cfg.merge(ITkStripReadoutGeometryCfg(flags))
39
40 if flags.Detector.GeometryHGTD:
41 from HGTD_GeoModelXml.HGTD_GeoModelConfig import HGTD_ReadoutGeometryCfg
42
43 cfg.merge(HGTD_ReadoutGeometryCfg(flags))
44
45 if flags.Detector.GeometryLAr:
46 from LArGeoAlgsNV.LArGMConfig import LArGMCfg
47
48 cfg.merge(LArGMCfg(flags))
49
50 if flags.Detector.GeometryTile:
51 from TileGeoModel.TileGMConfig import TileGMCfg
52
53 cfg.merge(TileGMCfg(flags))
54
55 if flags.Detector.GeometryMuon:
56 from MuonConfig.MuonGeometryConfig import MuonGeoModelCfg
57
58 cfg.merge(MuonGeoModelCfg(flags))
59
60 # Trigger the build of the InDetServMat geometry
61 # if any ID subsystems have been enabled
62 if flags.Detector.GeometryID:
63 from InDetServMatGeoModel.InDetServMatGeoModelConfig import (
64 InDetServiceMaterialCfg)
65 cfg.merge(InDetServiceMaterialCfg(flags))
66
67
68

◆ getATLASVersion()

VP1AlgConfig.getATLASVersion ( )

Definition at line 69 of file VP1AlgConfig.py.

69def getATLASVersion():
70 import os
71
72 if "AtlasVersion" in os.environ:
73 return os.environ["AtlasVersion"]
74 if "AtlasBaseVersion" in os.environ:
75 return os.environ["AtlasBaseVersion"]
76 return "Unknown"
77
78

◆ setup_batch_mode()

VP1AlgConfig.setup_batch_mode ( args)

Definition at line 399 of file VP1AlgConfig.py.

399def setup_batch_mode(args):
400 # BATCH-MODE
401 # If "--batch" is True, then set the corresponding env var.
402 # The GUI of VP1 will not be shown, but the config file will be taken
403 # and in the end a render of the 3D window will be saved as PNG file.
404 import os
405
406 if args.batch:
407 os.putenv("VP1_BATCHMODE", "1")
408 if args.batch_all_events:
409 os.putenv("VP1_BATCHMODE_ALLEVENTS", "1")
410 if args.batch_n_events:
411 os.putenv("VP1_BATCHMODE_NEVENTS", str(args.batch_n_events))
412 if args.batch_output_folder:
413 os.putenv("VP1_BATCHMODE_OUT_FOLDER", args.batch_output_folder)
414 if args.batch_random_config:
415 os.putenv("VP1_BATCHMODE_RANDOMCONFIG", "1")
416
417

◆ setup_live_mode()

VP1AlgConfig.setup_live_mode ( args,
vp1config )

Definition at line 384 of file VP1AlgConfig.py.

384def setup_live_mode(args, vp1config):
385 vp1config.setdefault("MultipleFilesON", True)
386 if args.eventcpy:
387 vp1config.setdefault("vp1Alg.MFLocalCopyDir", args.eventcpy)
388 if args.extraevtsrcdir:
389 vp1config.setdefault("MFAvailableLocalInputDirectories", args.extraevtsrcdir)
390 if args.live:
391 vp1config.setdefault(
392 "MFSourceDir",
393 "https://atlas-live.cern.ch/event_files/L1MinBias/vp1fileinfo.txt",
394 )
395 elif args.livelocal:
396 vp1config.setdefault("MFSourceDir", "/VP1_events/")
397
398

◆ SetupVP1()

VP1AlgConfig.SetupVP1 ( )

Definition at line 91 of file VP1AlgConfig.py.

91def SetupVP1():
92 from AthenaConfiguration.Enums import Format
93 from AthenaCommon.Logging import logging
94 from AthenaCommon.Constants import VERBOSE
95
96 # ++++ Firstly we setup flags ++++
97 _logger = logging.getLogger("VP1")
98 _logger.setLevel(VERBOSE)
99
100 from AthenaConfiguration.AllConfigFlags import initConfigFlags
101
102 flags = initConfigFlags()
103 flags.Concurrency.NumThreads = 0
104
105 # ^ VP1 will not work with the scheduler, since its condition/data dependencies are not known in advance
106 # More in details: the scheduler needs to know BEFORE the event, what the dependencies of each Alg are.
107 # So for VP1, no dependencies are declared, which means the conditions data is not there.
108 # So when I load tracks, the geometry is missing and it crashes.
109 # Turning off the scheduler (with NumThreads=0) fixes this.
110
111 parser = flags.getArgumentParser()
112 parser.prog = "vp1"
113 parser.description = """
114 VP1, or Virtual Point 1, is the interactive 3D event display for the ATLAS experiment at CERN.
115 Detailed documentation can be found at the webpage: https://atlas-vp1.web.cern.ch/atlas-vp1
116 but below are the flags that can be used to configure VP1 (most are standard Athena flags, but some are VP1-specific).
117 """
118 parser.description = """
119 So for example, to run VP1 on a file: vp1 [options] myESD.pool.root"""
120 # Add VP1-specific arguments here, but remember you can also directly pass flags in form <flagName>=<value>.
121 group = parser.add_argument_group("VP1 specific")
122 group.add_argument(
123 "Filename",
124 nargs='?',
125 help="Input file to pass to VP1 (i.e. vp1 myESD.pool.root as an alternative to vp1 --filesInput=[])",
126 metavar="File name",
127 )
128 group.add_argument(
129 "--config",
130 nargs="*",
131 help="Config file to use for VP1. If not specified, the default configuration will be used.",
132 )
133 group.add_argument(
134 "--verboseAthena",
135 action="store_true",
136 help="If false, tell Athena to suppress INFO messages and below.",
137 )
138 group.add_argument(
139 "--online", action="store_true", help="Use this flag for running VP1 at P1."
140 )
141 group.add_argument(
142 "--cruise",
143 type=int,
144 help="Start in cruise mode, changing events after N seconds.",
145 )
146 # Phase-II
147 group.add_argument(
148 "--phaseII", action="store_true", help="Use this flag for running VP1 with PhaseII setup."
149 )
150 # Batch
151 group.add_argument(
152 "--batch",
153 action="store_true",
154 help="Run VP1 in 'batch' mode with a given configuration file.",
155 )
156 group.add_argument(
157 "--batch-all-events",
158 action="store_true",
159 help="Process all events in the input data file in '-batch' mode. Use this together with '-batch'.",
160 )
161 group.add_argument(
162 "--batch-n-events",
163 type=int,
164 help="Process 'N' events in the input data file in '-batch' mode. Use this together with '-batch'.",
165 )
166 group.add_argument(
167 "--batch-output-folder",
168 help="Specify an output folder to store the event displays produced with the '-batch' option.",
169 )
170 group.add_argument(
171 "--batch-random-config",
172 action="store_true",
173 help="Run VP1 in 'batch' mode; for each single event a configuration file will be randomly picked out of the configuration files provided by the user. Use this together with '-batch'.",
174 )
175 # Live / Livelocal
176 group.add_argument(
177 "--live", action="store_true", help="Run on live events from point 1."
178 )
179 group.add_argument(
180 "--livelocal",
181 action="store_true",
182 help="Run on live events from point 1 in local directory.",
183 )
184 group.add_argument(
185 "--eventsrc",
186 help="Directory to take single event files from (do not specify input files in this case). To get files from a web server (i.e. live events), put instead the url to the file residing in the same directory (most users should just use the --live option instead).",
187 )
188 group.add_argument(
189 "--extraevtsrcdir",
190 help="Directory to take single event files from (do not specify input files in this case). To get files from a web server (i.e. live events), put instead the url to the file residing in the same directory (most users should just use the -live option instead).",
191 )
192 group.add_argument(
193 "--eventcpy",
194 help="Directory to keep local copies of processed event files. If --eventsrc is set, then -eventcpy will default to /tmp/emoyse/vp1events/6897 .",
195 )
196 # group.add_argument('--nocleanupeventcpy', action='store_true', help="Prevent removal of eventcpy directory after athena process finishes.")
197 # Commented, because I'm not sure how to implement this safely.
198
199 args = flags.fillFromArgs(parser=parser)
200
201 if args.help:
202 print(args)
203 # No point doing more here, since we just want to print the help.
204 import sys
205 sys.exit()
206
207 # Support the positional version of passing file name e.g. vp1 myESD.pool.root
208 if args.Filename and (
209 flags.Input.Files == []
210 or flags.Input.Files == ["_ATHENA_GENERIC_INPUTFILE_NAME_"]
211 ):
212 flags.Input.Files = [args.Filename]
213
214 _logger.verbose("+ About to set flags related to the input")
215
216 # Empty input is not normal for Athena, so we will need to check
217 # this repeatedly below
218 vp1_empty_input = False
219 # This covers the use case where we launch VP1
220 # without input files; e.g., to check the detector description
221 if (flags.Input.Files == [] or flags.Input.Files == [
222 "_ATHENA_GENERIC_INPUTFILE_NAME_"
223 ]) and not args.phaseII:
224 from Campaigns.Utils import Campaign
225 from AthenaConfiguration.TestDefaults import defaultGeometryTags
226
227 vp1_empty_input = True
228 # NB Must set e.g. ConfigFlags.Input.Runparse_args() Number and
229 # ConfigFlags.Input.TimeStamp before calling the
230 # MainServicesCfg to avoid it attempting auto-configuration
231 # from an input file, which is empty in this use case.
232 # If you don't have it, it (and/or other Cfg routines) complains and crashes.
233 # See also:
234 # https://acode-browser1.usatlas.bnl.gov/lxr/source/athena/InnerDetector/InDetConditions/SCT_ConditionsAlgorithms/python/SCT_DCSConditionsTestAlgConfig.py#0023
235 flags.Input.ProjectName = "mc20_13TeV"
236 flags.Input.RunNumbers = [330000]
237 flags.Input.TimeStamps = [1]
238 flags.Input.TypedCollections = []
239
240 # set default CondDB and Geometry version
241 flags.IOVDb.GlobalTag = "OFLCOND-MC23-SDR-RUN3-02"
242 flags.Input.isMC = True
243 flags.Input.MCCampaign = Campaign.Unknown
244 flags.GeoModel.AtlasVersion = defaultGeometryTags.RUN3
245 elif args.phaseII:
246 _logger.verbose("Phase-II mode!")
247 from Campaigns.Utils import Campaign
248 from AthenaConfiguration.TestDefaults import defaultGeometryTags
249 vp1_empty_input = True
250 flags.Input.ProjectName = "mc21_14TeV"
251 flags.Input.RunNumbers = [601229]
252 #flags.Input.ProjectName = "mc20_13TeV"
253 #flags.Input.RunNumbers = [330000]
254 flags.Input.TimeStamps = [1]
255 flags.Input.TypedCollections = []
256
257 # set default CondDB and Geometry version
258 flags.IOVDb.GlobalTag = "OFLCOND-MC16-SDR-15"
259 flags.Input.isMC = True
260 flags.Input.MCCampaign = Campaign.Unknown
261 flags.GeoModel.AtlasVersion = defaultGeometryTags.RUN4
262
263 else:
264 # Now just check file exists, or fail gracefully
265 from os import path
266
267 for file in flags.Input.Files:
268 if not path.exists(flags.Input.Files[0]):
269 _logger.warning("Input file '%s' does not exist", file)
270 import sys
271 sys.exit(1)
272
273 # Set the online flag if we are running at P1
274 if args.online:
275 flags.Common.isOnline = args.online
276 elif "HLTP" in flags.IOVDb.GlobalTag:
277 print(
278 "HLTP detected in the global tag, but --online mode is not enabled. Enabling it now."
279 )
280 flags.Common.isOnline = True
281
282 _logger.verbose("+ ... Input flags done")
283
284 _logger.verbose("+ About to set the detector flags")
285 # So we can now set up the geometry flags from the input
286 from AthenaConfiguration.DetectorConfigFlags import setupDetectorFlags
287
288 setupDetectorFlags(
289 flags,
290 None,
291 use_metadata=not vp1_empty_input,
292 toggle_geometry=True,
293 keep_beampipe=True,
294 )
295 _logger.verbose("+ ... Detector flags done")
296
297 # finalize setting flags: lock them.
298 flags.lock()
299
300 # DEBUG -- inspect the flags
301 flags.dump()
302 # flags._loadDynaFlags('GeoModel')
303 # flags._loadDynaFlags('Detector')
304 # flags.dump('Detector.(Geometry|Enable)', True)
305
306 # ++++ Now we setup the actual configuration ++++
307
308 # NB Must have set ConfigFlags.Input.RunNumber and
309 # ConfigFlags.Input.TimeStamp before calling to avoid
310 # attempted auto-configuration from an input file.
311 _logger.verbose("+ Setup main services, and input file reading")
312
313 from AthenaConfiguration.MainServicesConfig import MainServicesCfg
314
315 cfg = MainServicesCfg(flags)
316
317 if not vp1_empty_input:
318 # Only do this if we have input files, otherwise flags will try to read metadata
319 # Check if we are reading from POOL and setupo convertors if so
320 if flags.Input.Format is Format.POOL:
321 from AthenaPoolCnvSvc.PoolReadConfig import PoolReadCfg
322
323 cfg.merge(PoolReadCfg(flags))
324 # Check if running on legacy inputs
325 if "EventInfo" not in flags.Input.Collections:
326 from xAODEventInfoCnv.xAODEventInfoCnvConfig import EventInfoCnvAlgCfg
327 cfg.merge(EventInfoCnvAlgCfg(flags))
328
329 from TrkConfig.TrackCollectionReadConfig import TrackCollectionReadCfg
330 cfg.merge(TrackCollectionReadCfg(flags, "Tracks"))
331
332 from TrkConfig.AtlasExtrapolationEngineConfig import AtlasExtrapolationEngineCfg
333 AtlasExtrapolationEngine = cfg.getPrimaryAndMerge(AtlasExtrapolationEngineCfg(flags))
334 cfg.addPublicTool(AtlasExtrapolationEngine)
335
336 from TrkEventCnvTools.TrkEventCnvToolsConfig import TrkEventCnvSuperToolCfg
337 cfg.merge(TrkEventCnvSuperToolCfg(flags))
338
339
340 if flags.Input.isMC and "xAOD::TruthEventContainer#TruthEvents" not in flags.Input.TypedCollections:
341 # AOD2xAOD Truth conversion
342 from xAODTruthCnv.xAODTruthCnvConfig import GEN_AOD2xAODCfg
343 cfg.merge(GEN_AOD2xAODCfg(flags))
344
345 _logger.verbose("+ ... Main services done")
346
347 _logger.verbose("+ About to setup geometry")
348 configureGeometry(flags, cfg)
349 _logger.verbose("+ ... Geometry done")
350
351 # Setup some VP1 specific stuff
352 vp1config = {}
353 if not args.verboseAthena:
354 # Suppress the output from Athena
355 print("Suppressing most messages from Athena.")
356 print("To see more, set the --verboseAthena flag to true.")
357 msgService = cfg.getService("MessageSvc")
358 msgService.OutputLevel = 4
359
360 if args.cruise:
361 vp1config.setdefault("InitialCruiseMode", "EVENT")
362 vp1config.setdefault("InitialCruiseModePeriod", args.cruise)
363
364 if args.config:
365 print("Using config file", args.config)
366 vp1config.setdefault("InitialInputVP1Files", args.config)
367
368 # Batch mode
369 if args.batch:
370 setup_batch_mode(args)
371
372 # Event copying and live
373 if args.eventsrc:
374 vp1config.setdefault("MultipleFilesON", True)
375
376 if args.live or args.livelocal:
377 setup_live_mode(args, vp1config)
378
379 # configure VP1
380 cfg.merge(VP1AlgCfg(flags, **vp1config))
381 cfg.run()
382
383
void print(char *figname, TCanvas *c1)

◆ VP1AlgCfg()

VP1AlgConfig.VP1AlgCfg ( flags,
name = "VP1AlgCA",
** kwargs )

Definition at line 79 of file VP1AlgConfig.py.

79def VP1AlgCfg(flags, name="VP1AlgCA", **kwargs):
80 # This is based on a few old-style configuation files:
81 # JiveXML_RecEx_config.py
82 # JiveXML_jobOptionBase.py
83 result = ComponentAccumulator()
84
85 kwargs.setdefault("AtlasRelease", getATLASVersion())
86 the_alg = CompFactory.VP1Alg(name="VP1EventDisplayAlg", **kwargs)
87 result.addEventAlgo(the_alg, primary=True)
88 return result
89
90