35 def makeAlgs(self, config):
36
37 alg = config.createAlgorithm('CP::JetReclusteringAlg', 'JetReclusteringAlg')
38
39 alg.jets, alg.jetSelection = config.readNameAndSelection(self.jets)
40 alg.reclusteredJets = config.writeName(self.containerName)
41 alg.smallRjetIndices = 'smallRjetIndices_%SYS%'
42 alg.rcJetEnergy = 'e_%SYS%'
43 alg.clusteringAlgorithm = self.clusteringAlgorithm
44 alg.reclusteredJetsRadius = self.reclusteredJetsRadius
45
46
47 if self.minPt > 0 or self.maxEta > 0 or self.maxRapidity > 0 :
48 selAlg = config.createAlgorithm('CP::AsgSelectionAlg', 'RCJetsMinPtAlg')
49 selAlg.selectionDecoration = 'passed_sel,as_bits'
50 config.addPrivateTool('selectionTool', 'CP::AsgPtEtaSelectionTool')
51 selAlg.selectionTool.minPt = self.minPt
52 selAlg.selectionTool.maxEta = self.maxEta
53 selAlg.selectionTool.maxRapidity = self.maxRapidity
54 selAlg.particles = config.readName(self.containerName)
55 selAlg.preselection = config.getPreselection(self.containerName, '')
56 config.addSelection(self.containerName, 'passed_sel', selAlg.selectionDecoration)
57
58 config.addOutputVar(self.containerName, 'pt', 'pt')
59 config.addOutputVar(self.containerName, 'eta', 'eta')
60 config.addOutputVar(self.containerName, 'phi', 'phi')
61 config.addOutputVar(self.containerName, 'm', 'm')
62 config.addOutputVar(self.containerName, alg.rcJetEnergy, 'e')
63 config.addOutputVar(self.containerName, alg.smallRjetIndices, 'small_r_jet_indices')