28 def makeAlgs(self, config):
29 config.setSourceName (self.containerName, self.containerName)
30
31
32 alg = config.createAlgorithm('CP::ParticleLevelPtEtaPhiDecoratorAlg',
33 'ParticleLevelPtEtaPhiEDecoratorNeutrinos',
34 reentrant=True)
35 alg.particles = self.containerName
36
37
38 alg = config.createAlgorithm('CP::ParticleLevelIsolationAlg',
39 'ParticleLevelIsolationNeutrinos',
40 reentrant=True)
41 alg.particles = self.containerName
42 alg.isolation = 'isIsolated' + self.selectionName if self.isolated else 'isIsolatedButNotRequired' + self.selectionName
43 alg.notTauOrigin = 'notFromTau' + self.selectionName if self.notFromTau else 'notFromTauButNotRequired' + self.selectionName
44 alg.checkType = 'Neutrino'
45
46 if self.isolated:
47 config.addSelection (self.containerName, self.selectionName, alg.isolation+',as_char')
48 if self.notFromTau:
49 config.addSelection (self.containerName, self.selectionName, alg.notTauOrigin+',as_char')
50
51
52 if ParticleLevelNeutrinosBlock.get_instance_count() == 1 or 'pt' not in config.getOutputVars(self.containerName):
53 outputVars = [
54 ['pt', 'pt'],
55 ['eta', 'eta'],
56 ['phi', 'phi'],
57 ['e', 'e'],
58 ]
59 for decoration, branch in outputVars:
60 config.addOutputVar (self.containerName, decoration, branch, noSys=True)