ATLAS Offline Software
Public Member Functions | List of all members
ParticleLevelPhotonsConfig.ParticleLevelPhotonsBlock Class Reference
Inheritance diagram for ParticleLevelPhotonsConfig.ParticleLevelPhotonsBlock:
Collaboration diagram for ParticleLevelPhotonsConfig.ParticleLevelPhotonsBlock:

Public Member Functions

def __init__ (self)
 
def makeAlgs (self, config)
 

Detailed Description

ConfigBlock for particle-level truth photons

Definition at line 6 of file ParticleLevelPhotonsConfig.py.

Constructor & Destructor Documentation

◆ __init__()

def ParticleLevelPhotonsConfig.ParticleLevelPhotonsBlock.__init__ (   self)

Definition at line 9 of file ParticleLevelPhotonsConfig.py.

9  def __init__(self):
10  super(ParticleLevelPhotonsBlock, self).__init__()
11  self.addOption('containerName', 'TruthPhotons', type=str,
12  info='the name of the input truth photons container')
13  self.addOption('selectionName', '', type=str,
14  info='the name of the selection to create. The default is "",'
15  ' which applies the selection to all truth photons.')
16  self.addOption('isolated', True, type=bool,
17  info='select only truth photons that are isolated.')
18  self.addOption('isolationVariable', '', type=str,
19  info='variable to use in isolation cuts of the form "var/pT < cut".')
20  self.addOption('isolationCut', -1, type=float,
21  info='threshold to use in isolation cuts of the form "var/pT < cut".')
22  # Always skip on data
23  self.setOptionValue('skipOnData', True)
24 

Member Function Documentation

◆ makeAlgs()

def ParticleLevelPhotonsConfig.ParticleLevelPhotonsBlock.makeAlgs (   self,
  config 
)

Definition at line 25 of file ParticleLevelPhotonsConfig.py.

25  def makeAlgs(self, config):
26  config.setSourceName (self.containerName, self.containerName)
27 
28  # decorate the missing elements of the 4-vector so we can save it later
29  alg = config.createAlgorithm('CP::ParticleLevelPtEtaPhiDecoratorAlg', 'ParticleLevelPtEtaPhiDecoratorPhotons' + self.selectionName)
30  alg.particles = self.containerName
31 
32  # check for prompt isolation
33  alg = config.createAlgorithm('CP::ParticleLevelIsolationAlg', 'ParticleLevelIsolationPhotons' + self.selectionName)
34  alg.particles = self.containerName
35  alg.isolation = 'isIsolated' + self.selectionName if self.isolated else 'isIsolatedButNotRequired' + self.selectionName
36  alg.notTauOrigin = 'notFromTauButNotRequired' + self.selectionName
37  alg.checkType = 'IsoPhoton'
38  if self.isolationVariable != '':
39  alg.isoVar = self.isolationVariable
40  alg.isoCut = self.isolationCut
41 
42  if self.isolated:
43  config.addSelection (self.containerName, self.selectionName, alg.isolation+',as_char')
44 
45  # output branches to be scheduled only once
46  if ParticleLevelPhotonsBlock.get_instance_count() == 1:
47  outputVars = [
48  ['pt', 'pt'],
49  ['eta', 'eta'],
50  ['phi', 'phi'],
51  ['e', 'e'],
52  ['classifierParticleType', 'type'],
53  ['classifierParticleOrigin', 'origin'],
54  ]
55  for decoration, branch in outputVars:
56  config.addOutputVar (self.containerName, decoration, branch, noSys=True)

The documentation for this class was generated from the following file:
python.processes.powheg.ZZ.ZZ.__init__
def __init__(self, base_directory, **kwargs)
Constructor: all process options are set here.
Definition: ZZ.py:18