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