ATLAS Offline Software
Loading...
Searching...
No Matches
python.ConfigFactory.ConfigFactory Class Reference
Collaboration diagram for python.ConfigFactory.ConfigFactory:

Public Member Functions

 __init__ (self, addDefaultBlocks=True)
 addAlgConfigBlock (self, algName, alg, defaults=None, pos=None, superBlocks=None)
 printAlgs (self, printOpts=True)
 makeConfig (self, name, **kwargs)
 addDefaultAlgs (self)

Public Attributes

str ROOTNAME = 'root'

Protected Attributes

dict _algs = {}
dict _order = {self.ROOTNAME: []}

Detailed Description

This class provides a configuration manager that is intended to allow the user to:
    - define and configure functions that return an algSequence(?) object

Definition at line 110 of file ConfigFactory.py.

Constructor & Destructor Documentation

◆ __init__()

python.ConfigFactory.ConfigFactory.__init__ ( self,
addDefaultBlocks = True )

Definition at line 114 of file ConfigFactory.py.

114 def __init__(self, addDefaultBlocks=True):
115 self.ROOTNAME = 'root' # constant
116 self._algs = {}
117 self._order = {self.ROOTNAME: []}
118 if addDefaultBlocks:
119 self.addDefaultAlgs()
120
121

Member Function Documentation

◆ addAlgConfigBlock()

python.ConfigFactory.ConfigFactory.addAlgConfigBlock ( self,
algName,
alg,
defaults = None,
pos = None,
superBlocks = None )
Add class to list of available algorithms

Definition at line 122 of file ConfigFactory.py.

122 def addAlgConfigBlock(self, algName, alg, defaults=None, pos=None, superBlocks=None):
123 """Add class to list of available algorithms"""
124 if not callable(alg):
125 raise ValueError(f"{algName} is not a callable.")
126 opts = getFuncArgs(alg)
127
128 if superBlocks is None:
129 superBlocks = [self.ROOTNAME]
130 elif not isinstance(superBlocks, list):
131 superBlocks = [superBlocks]
132
133 # add new alg block to subAlgs dict of super block
134 for block in superBlocks:
135 if block not in self._order:
136 self._order[block] = []
137 order = self._order[block]
138
139 if block == self.ROOTNAME:
140 algs = self._algs
141 else:
142 if block not in self._algs:
143 raise ValueError(f"{block} not added")
144 algs = self._algs[block].subAlgs
145
146 if algName in algs:
147 raise ValueError(f"{algName} has already been added.")
148
149 if block != self.ROOTNAME:
150 factoryName = f"{block}.{algName}"
151 else:
152 factoryName = algName
153
154 # create FactoryBlock with alg information
155 algs[algName] = FactoryBlock(
156 alg=alg,
157 factoryName=factoryName,
158 algName=algName,
159 options=opts,
160 defaults=defaults,
161 subAlgs={}
162 )
163 # insert into order (list)
164 if pos is None:
165 order.append(algName)
166 elif pos in order:
167 order.insert(order.index(pos), algName)
168 else:
169 raise ValueError(f"{pos} does not exit in already added config blocks")
170 return
171
172

◆ addDefaultAlgs()

python.ConfigFactory.ConfigFactory.addDefaultAlgs ( self)
add algorithms and options

Definition at line 230 of file ConfigFactory.py.

230 def addDefaultAlgs(self):
231 """add algorithms and options"""
232
233 # CommonServices
234 from AsgAnalysisAlgorithms.AsgAnalysisConfig import CommonServices
235 self.addAlgConfigBlock(algName="CommonServices", alg=CommonServices)
236
237 # pileup reweighting
238 from AsgAnalysisAlgorithms.AsgAnalysisConfig import PileupReweightingBlock
239 self.addAlgConfigBlock(algName="PileupReweighting", alg=PileupReweightingBlock)
240
241 # event cleaning
242 from AsgAnalysisAlgorithms.EventCleaningConfig import EventCleaningBlock
243 self.addAlgConfigBlock(algName="EventCleaning", alg=EventCleaningBlock)
244
245 # trigger
246 from TriggerAnalysisAlgorithms.TriggerAnalysisConfig import Trigger
247 self.addAlgConfigBlock(algName="Trigger", alg=Trigger)
248 from TriggerAnalysisAlgorithms.TriggerAnalysisSFConfig import TriggerAnalysisSFBlock
249 self.addAlgConfigBlock(algName="TriggerMatching", alg=TriggerAnalysisSFBlock)
250
251 # HSTP filter for dijet MC
252 from AsgAnalysisAlgorithms.HSTPFilterConfig import HSTPFilterBlock
253 self.addAlgConfigBlock(algName="HSTPFilter", alg=HSTPFilterBlock)
254
255 # jets
256 from JetAnalysisAlgorithms.JetAnalysisConfig import Jets
257 self.addAlgConfigBlock(algName="Jets", alg=Jets)
258 from JetAnalysisAlgorithms.JetAnalysisConfig import JvtWorkingPoint
259 self.addAlgConfigBlock(algName="JVTWorkingPoint", alg=JvtWorkingPoint,
260 superBlocks="Jets")
261 from JetAnalysisAlgorithms.JetAnalysisConfig import FJvtWorkingPoint
262 self.addAlgConfigBlock(algName="FJVTWorkingPoint", alg=FJvtWorkingPoint,
263 superBlocks="Jets")
264 from JetAnalysisAlgorithms.JetJvtAnalysisConfig import JetJvtAnalysisConfig
265 self.addAlgConfigBlock(algName="JVT", alg=JetJvtAnalysisConfig,
266 superBlocks="Jets")
267 from JetAnalysisAlgorithms.BJetCalibAnalysisConfig import BJetCalibAnalysisConfig
268 self.addAlgConfigBlock(algName="BJetCalib", alg=BJetCalibAnalysisConfig,
269 superBlocks="Jets")
270 from JetAnalysisAlgorithms.JetTriggerAnalysisConfig import JetTriggerMatchingBlock
271 self.addAlgConfigBlock(algName="TriggerMatching", alg=JetTriggerMatchingBlock,
272 superBlocks="Jets")
273 from FTagAnalysisAlgorithms.FTagTrigMatchAnalysisConfig import FTagJetTrigMatchingBlock
274 self.addAlgConfigBlock(algName="FTagTriggerMatching", alg=FTagJetTrigMatchingBlock,
275 superBlocks="Jets")
276 from FTagAnalysisAlgorithms.FTagAnalysisConfig import FTagConfig
277 self.addAlgConfigBlock(algName="FlavourTagging", alg=FTagConfig,
278 defaults={'selectionName': ''},
279 superBlocks="Jets")
280 from FTagAnalysisAlgorithms.XbbAnalysisConfig import XbbConfig
281 self.addAlgConfigBlock(algName="XbbTagging", alg=XbbConfig,
282 superBlocks="Jets")
283 from FTagAnalysisAlgorithms.FTagSFAnalysisConfig import FlavourTaggingEventSF
284 self.addAlgConfigBlock(algName="FlavourTaggingEventSF",
285 alg=FlavourTaggingEventSF,
286 defaults={'selectionName': ''},
287 superBlocks="Jets")
288
289 # muons
290 from MuonAnalysisAlgorithms.MuonAnalysisConfig import MuonCalibration
291 self.addAlgConfigBlock(algName="Muons", alg=MuonCalibration)
292 from MuonAnalysisAlgorithms.MuonAnalysisConfig import MuonWorkingPoint
293 self.addAlgConfigBlock(algName="WorkingPoint", alg=MuonWorkingPoint,
294 superBlocks="Muons")
295 from MuonAnalysisAlgorithms.MuonAnalysisConfig import MuonTriggerAnalysisSFBlock
296 self.addAlgConfigBlock(algName="TriggerSF", alg=MuonTriggerAnalysisSFBlock,
297 superBlocks="Muons")
298 from MuonAnalysisAlgorithms.MuonAnalysisConfig import MuonLRTMergedConfig
299 self.addAlgConfigBlock(algName="LRTMerging", alg=MuonLRTMergedConfig,
300 superBlocks="Muons")
301 from MuonAnalysisAlgorithms.MuonAnalysisConfig import MuonContainerMergingConfig
302 self.addAlgConfigBlock(algName="ContainerMerging", alg=MuonContainerMergingConfig,
303 superBlocks="Muons")
304
305 # electrons
306 from EgammaAnalysisAlgorithms.ElectronAnalysisConfig import ElectronCalibration
307 self.addAlgConfigBlock(algName="Electrons", alg=ElectronCalibration)
308 from EgammaAnalysisAlgorithms.ElectronAnalysisConfig import ElectronWorkingPoint
309 self.addAlgConfigBlock(algName="WorkingPoint", alg=ElectronWorkingPoint,
310 superBlocks="Electrons")
311 from EgammaAnalysisAlgorithms.ElectronAnalysisConfig import ElectronLRTMergedConfig
312 self.addAlgConfigBlock(algName="LRTMerging", alg=ElectronLRTMergedConfig,
313 superBlocks="Electrons")
314 from EgammaAnalysisAlgorithms.ElectronAnalysisConfig import ElectronTriggerAnalysisSFBlock
315 self.addAlgConfigBlock(algName="TriggerSF", alg=ElectronTriggerAnalysisSFBlock,
316 superBlocks="Electrons")
317
318 # photons
319 from EgammaAnalysisAlgorithms.PhotonAnalysisConfig import PhotonCalibrationConfig
320 self.addAlgConfigBlock(algName="Photons", alg=PhotonCalibrationConfig)
321 from EgammaAnalysisAlgorithms.PhotonAnalysisConfig import PhotonWorkingPoint
322 self.addAlgConfigBlock(algName="WorkingPoint", alg=PhotonWorkingPoint,
323 superBlocks="Photons")
324 from EgammaAnalysisAlgorithms.PhotonExtraVariablesConfig import PhotonExtraVariablesBlock
325 self.addAlgConfigBlock(algName="ExtraVariables", alg=PhotonExtraVariablesBlock,
326 superBlocks="Photons")
327
328 # tauJets
329 from TauAnalysisAlgorithms.TauAnalysisConfig import TauCalibrationConfig
330 self.addAlgConfigBlock(algName="TauJets", alg=TauCalibrationConfig)
331 from TauAnalysisAlgorithms.TauAnalysisConfig import TauWorkingPoint
332 self.addAlgConfigBlock(algName="WorkingPoint", alg=TauWorkingPoint,
333 superBlocks="TauJets")
334 from TauAnalysisAlgorithms.TauAnalysisConfig import TauTriggerAnalysisSFBlock
335 self.addAlgConfigBlock(algName="TriggerSF", alg=TauTriggerAnalysisSFBlock,
336 superBlocks="TauJets")
337
338 # diTauJets
339 from TauAnalysisAlgorithms.DiTauAnalysisConfig import DiTauCalibrationConfig
340 self.addAlgConfigBlock(algName="DiTauJets", alg=DiTauCalibrationConfig)
341 from TauAnalysisAlgorithms.DiTauAnalysisConfig import DiTauWorkingPoint
342 self.addAlgConfigBlock(algName="WorkingPoint", alg=DiTauWorkingPoint,
343 superBlocks="DiTauJets")
344
345 # tracks
346 from TrackingAnalysisAlgorithms.TrackingAnalysisConfig import InDetTrackCalibrationConfig
347 self.addAlgConfigBlock(algName="InDetTracks", alg=InDetTrackCalibrationConfig)
348 from TrackingAnalysisAlgorithms.TrackingAnalysisConfig import InDetTrackWorkingPointConfig
349 self.addAlgConfigBlock(algName="WorkingPoint", alg=InDetTrackWorkingPointConfig,
350 superBlocks="InDetTracks")
351
352 # SystObjectLink
353 from AsgAnalysisAlgorithms.SystObjectLinkConfig import SystObjectLinkBlock
354 self.addAlgConfigBlock(algName="SystObjectLink", alg=SystObjectLinkBlock,
355 superBlocks=[self.ROOTNAME, "Jets", "Electrons", "Photons", "Muons", "TauJets"])
356
357 # Particle-level truth algorithms
358 from TruthParticleLevelAnalysisAlgorithms.ParticleLevelElectronsConfig import ParticleLevelElectronsBlock
359 self.addAlgConfigBlock(algName="PL_Electrons", alg=ParticleLevelElectronsBlock)
360 from TruthParticleLevelAnalysisAlgorithms.ParticleLevelMuonsConfig import ParticleLevelMuonsBlock
361 self.addAlgConfigBlock(algName="PL_Muons", alg=ParticleLevelMuonsBlock)
362 from TruthParticleLevelAnalysisAlgorithms.ParticleLevelNeutrinosConfig import ParticleLevelNeutrinosBlock
363 self.addAlgConfigBlock(algName="PL_Neutrinos", alg=ParticleLevelNeutrinosBlock)
364 from TruthParticleLevelAnalysisAlgorithms.ParticleLevelJetsConfig import ParticleLevelJetsBlock
365 self.addAlgConfigBlock(algName="PL_Jets", alg=ParticleLevelJetsBlock)
366 from TruthParticleLevelAnalysisAlgorithms.ParticleLevelTausConfig import ParticleLevelTausBlock
367 self.addAlgConfigBlock(algName="PL_Taus", alg=ParticleLevelTausBlock)
368 from TruthParticleLevelAnalysisAlgorithms.ParticleLevelPhotonsConfig import ParticleLevelPhotonsBlock
369 self.addAlgConfigBlock(algName="PL_Photons", alg=ParticleLevelPhotonsBlock)
370 from TruthParticleLevelAnalysisAlgorithms.ParticleLevelResonancesConfig import ParticleLevelResonancesBlock
371 self.addAlgConfigBlock(algName="PL_Resonances", alg=ParticleLevelResonancesBlock)
372 from TruthParticleLevelAnalysisAlgorithms.ParticleLevelMissingETConfig import ParticleLevelMissingETBlock
373 self.addAlgConfigBlock(algName="PL_MissingET", alg=ParticleLevelMissingETBlock)
374 from TruthParticleLevelAnalysisAlgorithms.ParticleLevelOverlapRemovalConfig import ParticleLevelOverlapRemovalBlock
375 self.addAlgConfigBlock(algName="PL_OverlapRemoval", alg=ParticleLevelOverlapRemovalBlock)
376
377 # Parton-level truth algorithms
378 from TruthPartonLevelAnalysisAlgorithms.PartonHistoryConfig import PartonHistoryBlock
379 self.addAlgConfigBlock(algName="PartonHistory", alg=PartonHistoryBlock)
380
381 # IFF truth classification
382 from AsgAnalysisAlgorithms.AsgAnalysisConfig import IFFLeptonDecorationBlock
383 self.addAlgConfigBlock(algName="IFFClassification", alg=IFFLeptonDecorationBlock,
384 superBlocks=["Electrons", "Muons",
385 "PL_Electrons", "PL_Muons"])
386 # MCTC truth classification
387 from AsgAnalysisAlgorithms.AsgAnalysisConfig import MCTCLeptonDecorationBlock
388 self.addAlgConfigBlock(algName="MCTCClassification", alg=MCTCLeptonDecorationBlock,
389 superBlocks=["Electrons", "Muons", "TauJets",
390 "PL_Electrons", "PL_Muons", "PL_Taus"])
391
392 # pT/Eta Selection
393 from AsgAnalysisAlgorithms.AsgAnalysisConfig import PtEtaSelectionBlock
394 self.addAlgConfigBlock(algName="PtEtaSelection", alg=PtEtaSelectionBlock,
395 defaults={'selectionName': ''},
396 superBlocks=[self.ROOTNAME,
397 "Jets", "Electrons", "Photons", "Muons", "TauJets", "DiTauJets",
398 "PL_Jets", "PL_Electrons", "PL_Photons", "PL_Muons", "PL_Taus", "PL_Neutrinos", "PL_Resonances"])
399
400 # met
401 from MetAnalysisAlgorithms.MetAnalysisConfig import MetAnalysisConfig
402 self.addAlgConfigBlock(algName="MissingET", alg=MetAnalysisConfig)
403
404 # overlap removal
405 from AsgAnalysisAlgorithms.OverlapAnalysisConfig import OverlapAnalysisConfig
406 self.addAlgConfigBlock(algName="OverlapRemoval", alg=OverlapAnalysisConfig,
407 defaults={'configName': 'OverlapRemoval'})
408
409 # object-based cutflow
410 from AsgAnalysisAlgorithms.AsgAnalysisConfig import ObjectCutFlowBlock
411 self.addAlgConfigBlock(algName='ObjectCutFlow', alg=ObjectCutFlowBlock)
412
413 # jet reclustering
414 from JetAnalysisAlgorithms.JetReclusteringConfig import JetReclusteringBlock
415 self.addAlgConfigBlock(algName="JetReclustering", alg=JetReclusteringBlock)
416
417 # jet reclustering calibration
418 from JetAnalysisAlgorithms.ReclusteredJetCalibrationConfig import ReclusteredJetCalibrationBlock
419 self.addAlgConfigBlock(algName="ReclusteredJetCalibration", alg=ReclusteredJetCalibrationBlock)
420
421 # event selection
422 from EventSelectionAlgorithms.EventSelectionConfig import EventSelection
423 self.addAlgConfigBlock(algName='EventSelection', alg=EventSelection)
424
425 # event-based cutflow
426 from AsgAnalysisAlgorithms.AsgAnalysisConfig import EventCutFlowBlock
427 self.addAlgConfigBlock(algName='EventCutFlow', alg=EventCutFlowBlock)
428
429 # generator level analysis
430 from AsgAnalysisAlgorithms.AsgAnalysisConfig import GeneratorAnalysisBlock
431 self.addAlgConfigBlock(algName="GeneratorLevelAnalysis", alg=GeneratorAnalysisBlock)
432
433 # bootstraps
434 from AsgAnalysisAlgorithms.BootstrapGeneratorConfig import BootstrapGeneratorConfig
435 self.addAlgConfigBlock(algName='Bootstraps', alg=BootstrapGeneratorConfig)
436
437 # per-event scale factor calculation
438 from AsgAnalysisAlgorithms.AsgAnalysisConfig import PerEventSFBlock
439 self.addAlgConfigBlock(algName='PerEventSF', alg=PerEventSFBlock)
440
441 # per-event unified lepton scale factor calculation
442 from AsgAnalysisAlgorithms.LeptonSFCalculatorConfig import LeptonSFCalculatorBlock
443 self.addAlgConfigBlock(algName='LeptonSF', alg=LeptonSFCalculatorBlock)
444
445 # thinning
446 from AsgAnalysisAlgorithms.AsgAnalysisConfig import OutputThinningBlock
447 self.addAlgConfigBlock(algName="Thinning", alg=OutputThinningBlock,
448 defaults={'configName': 'Thinning'})
449
450 # selection decorations
451 from AsgAnalysisAlgorithms.AsgAnalysisConfig import SelectionDecorationBlock
452 self.addAlgConfigBlock(algName='SelectionDecoration',
453 alg=SelectionDecorationBlock)
454
455 # di-tau mass calculator
456 from TauAnalysisAlgorithms.DiTauMassConfig import DiTauMassBlock
457 self.addAlgConfigBlock(algName="DiTauMMC", alg=DiTauMassBlock)
458
459 # IFF fake background estimator
460 from AsgAnalysisAlgorithms.FakeBkgConfig import FakeBkgBlock
461 self.addAlgConfigBlock(algName='FakeBkgCalculator', alg=FakeBkgBlock)
462
463 # VGamma overlap removal
464 from AsgAnalysisAlgorithms.VGammaORConfig import VGammaORBlock
465 self.addAlgConfigBlock(algName='VGammaOR', alg=VGammaORBlock)
466
467 # Event shape density
468 from AsgAnalysisAlgorithms.EventShapeDensityDumperConfig import EventShapeDensityDumperBlock
469 self.addAlgConfigBlock(algName='EventShape', alg=EventShapeDensityDumperBlock)
470
471 # output
472 from AsgAnalysisAlgorithms.OutputAnalysisConfig import OutputAnalysisConfig
473 self.addAlgConfigBlock(algName="Output", alg=OutputAnalysisConfig,
474 defaults={'configName': 'Output'})
475
476 # IOStats printouts
477 from AsgAnalysisAlgorithms.AsgAnalysisConfig import IOStatsBlock
478 self.addAlgConfigBlock(algName="IOStats", alg=IOStatsBlock)
479
480 # configuration printer
481 from AsgAnalysisAlgorithms.PrintToolConfigAlgConfig import PrintToolConfigAlgBlock
482 self.addAlgConfigBlock(algName="PrintConfiguration", alg=PrintToolConfigAlgBlock)
483
484 return

◆ makeConfig()

python.ConfigFactory.ConfigFactory.makeConfig ( self,
name,
** kwargs )
Returns:
    configSeq: configSequence object

Definition at line 203 of file ConfigFactory.py.

203 def makeConfig(self, name, **kwargs):
204 """
205 Returns:
206 configSeq: configSequence object
207 """
208 try:
209 if '.' in name:
210 algContext, algName = name.split('.')
211 block = self._algs[algContext].subAlgs[algName]
212 else:
213 block = self._algs[name]
214 except KeyError:
215 raise ValueError(f"{name} config block not found. Make sure context is correct.")
216 # Optional **kwargs are in the process of being retired. While the process is not fully complete
217 # we still need to allow them to be passed. However, for blocks where they have already been retired
218 # we want to raise an error so users don't experience undesirable behaviour where their extra options
219 # are being ignored, or run into related cryptic crashes.
220 already_fixed_blocks = {
221 'Electrons','Photons','Muons','TauJets','DiTauJets','MissingET','FlavourTagging','FlavourTaggingEventSF','XbbTagging',
222 'InDetTracks','KLFitter','PtEtaSelection','ObjectCutFlow','EventCutFlow','Thinning',
223 'IFFClassification','MCTCClassification','PerEventSF','SelectionDecoration','SystObjectLink'}
224 if kwargs and name.split('.')[-1] in already_fixed_blocks:
225 raise ValueError(f"Config block '{name}' no longer accepts **kwargs. Use config.setOptionValue('option', value) instead!")
226 configSeq, _ = block.makeConfig(kwargs)
227 return configSeq
228
229

◆ printAlgs()

python.ConfigFactory.ConfigFactory.printAlgs ( self,
printOpts = True )
Prints algorithms exposed to configuration

Definition at line 173 of file ConfigFactory.py.

173 def printAlgs(self, printOpts=True):
174 """Prints algorithms exposed to configuration"""
175 printed = [] # some subblocks exist for multiple superblocks
176 def printAlg(algs):
177 for alg, algInfo in algs.items():
178 algName = algInfo.alg.__name__
179 algOptions = algInfo.options
180 if algName not in printed:
181 printed.append(algName)
182 logCPAlgCfgFactory.info(f"\033[4m{alg}\033[0m -> \033[4m{algName}\033[0m")
183 if printOpts:
184 try:
185 if inspect.isclass(algInfo.alg):
186 # block
187 algInfo.alg().printOptions(verbose=printOpts)
188 else:
189 # make function
190 seq = ConfigSequence()
191 algInfo.alg(seq=seq)
192 seq.printOptions(verbose=printOpts)
193 except Exception:
194 # either a TypeError or something else due to missing args
195 # try to print something for casses with required args
196 for opt in algOptions:
197 logCPAlgCfgFactory.info(f" {opt}")
198 printAlg(algInfo.subAlgs)
199 printAlg(self._algs)
200 return
201
202

Member Data Documentation

◆ _algs

python.ConfigFactory.ConfigFactory._algs = {}
protected

Definition at line 116 of file ConfigFactory.py.

◆ _order

dict python.ConfigFactory.ConfigFactory._order = {self.ROOTNAME: []}
protected

Definition at line 117 of file ConfigFactory.py.

◆ ROOTNAME

str python.ConfigFactory.ConfigFactory.ROOTNAME = 'root'

Definition at line 115 of file ConfigFactory.py.


The documentation for this class was generated from the following file: