33 def makeAlgs(self, config):
34 config.setSourceName (self.containerName, self.containerName)
35
36
37 alg = config.createAlgorithm('CP::ParticleLevelPtEtaPhiDecoratorAlg',
38 'ParticleLevelPtEtaPhiDecoratorPhotons',
39 reentrant=True)
40 alg.particles = self.containerName
41
42
43 alg = config.createAlgorithm('CP::ParticleLevelIsolationAlg',
44 'ParticleLevelIsolationPhotons',
45 reentrant=True)
46 alg.particles = self.containerName
47 alg.isolation = 'isIsolated' + self.selectionName if self.isolated else 'isIsolatedButNotRequired' + self.selectionName
48 alg.notTauOrigin = 'notFromTauButNotRequired' + self.selectionName
49 alg.checkType = 'IsoPhoton'
50 if self.isolationVariable != '':
51 alg.isoVar = self.isolationVariable
52 alg.isoCut = self.isolationCut
53
54 if self.isolated:
55 config.addSelection (self.containerName, self.selectionName, alg.isolation+',as_char')
56
57
58 if ParticleLevelPhotonsBlock.get_instance_count() == 1 or 'pt' not in config.getOutputVars(self.containerName):
59 outputVars = [
60 ['pt', 'pt'],
61 ['eta', 'eta'],
62 ['phi', 'phi'],
63 ['e', 'e'],
64 ['classifierParticleType', 'type'],
65 ['classifierParticleOrigin', 'origin'],
66 ]
67 if self.saveUID:
68 outputVars += [['uid', 'uid']]
69 for decoration, branch in outputVars:
70 config.addOutputVar (self.containerName, decoration, branch, noSys=True)