38 def makeAlgs (self, config) :
39
40 postfix = self.postfix
41 if postfix != '' and postfix[0] != '_' :
42 postfix = '_' + postfix
43
44 inputContainer = "DiTauJets"
45 if self.inputContainer:
46 inputContainer = self.inputContainer
47 config.setSourceName (self.containerName, inputContainer)
48
49
50 if self.rerunTruthMatching and config.dataType() is not DataType.Data:
51 alg = config.createAlgorithm( 'CP::DiTauTruthMatchingAlg',
52 'DiTauTruthMatchingAlg' )
53 config.addPrivateTool( 'matchingTool',
54 'TauAnalysisTools::DiTauTruthMatchingTool' )
55 alg.taus = config.readName (self.containerName)
56 alg.preselection = config.getPreselection (self.containerName, '')
57
58
59
60 if self.decorateTruth and self.rerunTruthMatching and config.dataType() is not DataType.Data:
61
62
63 config.addOutputVar (self.containerName, 'TruthVisLeadPt', 'TruthVisLeadPt', noSys=True)
64 config.addOutputVar (self.containerName, 'TruthVisLeadEta', 'TruthVisLeadEta', noSys=True)
65 config.addOutputVar (self.containerName, 'TruthVisLeadPhi', 'TruthVisLeadPhi', noSys=True)
66 config.addOutputVar (self.containerName, 'TruthVisLeadM', 'TruthVisLeadM', noSys=True)
67 config.addOutputVar (self.containerName, 'TruthLeadPdgID', 'TruthLeadPdgID', noSys=True)
68 config.addOutputVar (self.containerName, 'TruthVisSubleadPt', 'TruthVisSubleadPt', noSys=True)
69 config.addOutputVar (self.containerName, 'TruthVisSubleadEta', 'TruthVisSubleadEta', noSys=True)
70 config.addOutputVar (self.containerName, 'TruthVisSubleadPhi', 'TruthVisSubleadPhi', noSys=True)
71 config.addOutputVar (self.containerName, 'TruthVisSubleadM', 'TruthVisSubleadM', noSys=True)
72 config.addOutputVar (self.containerName, 'TruthSubleadPdgID', 'TruthSubleadPdgID', noSys=True)
73 config.addOutputVar (self.containerName, 'TruthVisDeltaR', 'TruthVisDeltaR', noSys=True)
74 config.addOutputVar (self.containerName, 'TruthVisMass', 'TruthVisMass', noSys=True)
75 config.addOutputVar (self.containerName, 'IsTruthMatched', 'IsTruthMatched', noSys=True)
76 config.addOutputVar (self.containerName, 'IsTruthHadronic', 'IsTruthHadronic', noSys=True)
77
78
79 if self.decorateExtraVariables:
80 alg = config.createAlgorithm( 'CP::DiTauExtraVariablesAlg',
81 'DiTauExtraVariablesAlg',
82 reentrant=True )
83 alg.ditaus = config.readName (self.containerName)
84 config.addOutputVar (self.containerName, 'omniScore', 'omniScore', noSys=True)
85 config.addOutputVar (self.containerName, 'nSubjets', 'nSubjets', noSys=True)
86 config.addOutputVar (self.containerName, 'leadSubjetPt', 'leadSubjetPt', noSys=True)
87 config.addOutputVar (self.containerName, 'leadSubjetEta', 'leadSubjetEta', noSys=True)
88 config.addOutputVar (self.containerName, 'leadSubjetPhi', 'leadSubjetPhi', noSys=True)
89 config.addOutputVar (self.containerName, 'leadSubjetE', 'leadSubjetE', noSys=True)
90 config.addOutputVar (self.containerName, 'leadSubjetNTracks', 'leadSubjetNTracks', noSys=True)
91 config.addOutputVar (self.containerName, 'leadSubjetCharge', 'leadSubjetCharge', noSys=True)
92 config.addOutputVar (self.containerName, 'subleadSubjetPt', 'subleadSubjetPt', noSys=True)
93 config.addOutputVar (self.containerName, 'subleadSubjetEta', 'subleadSubjetEta', noSys=True)
94 config.addOutputVar (self.containerName, 'subleadSubjetPhi', 'subleadSubjetPhi', noSys=True)
95 config.addOutputVar (self.containerName, 'subleadSubjetE', 'subleadSubjetE', noSys=True)
96 config.addOutputVar (self.containerName, 'subleadSubjetNTracks', 'subleadSubjetNTracks', noSys=True)
97 config.addOutputVar (self.containerName, 'subleadSubjetCharge', 'subleadSubjetCharge', noSys=True)
98
99
100 alg = config.createAlgorithm( 'CP::DiTauSmearingAlg', 'DiTauSmearingAlg' )
101 config.addPrivateTool( 'smearingTool', 'TauAnalysisTools::DiTauSmearingTool' )
102 alg.taus = config.readName (self.containerName)
103 alg.tausOut = config.copyName (self.containerName)
104 alg.preselection = config.getPreselection (self.containerName, '')
105
106
107 config.addOutputVar (self.containerName, 'pt', 'pt')
108 config.addOutputVar (self.containerName, 'eta', 'eta', noSys=True)
109 config.addOutputVar (self.containerName, 'phi', 'phi', noSys=True)
110 config.addOutputVar (self.containerName, 'm', 'm', noSys=True)
111
112
113