40 def makeAlgs(self, config):
41 if config.dataType() is DataType.Data: return
42
43 alg = config.createAlgorithm('CP::LeptonSFCalculatorAlg',
44 'leptonSFCalculator')
45
46 if self.electrons:
47 electrons, electronSelection = config.readNameAndSelection(self.electrons)
48 alg.electrons = electrons
49 alg.electronSelection = electronSelection
50 if self.electronSFs:
51 alg.electronSFs = self.electronSFs
52 else:
53 alg.electronSFs = [ f'el_reco_effSF_{self.electrons.split(".")[1]}_%SYS%',
54 f'el_id_effSF_{self.electrons.split(".")[1]}_%SYS%' ]
55 if 'isolated' in alg.electronSelection:
56 alg.electronSFs += [ f'el_isol_effSF_{self.electrons.split(".")[1]}_%SYS%' ]
57 if 'chargeID' in alg.electronSelection:
58 alg.electronSFs += [ f'el_ecids_effSF_{self.electrons.split(".")[1]}_%SYS%' ]
59 if self.includeElectronChargeMisID:
60 alg.electronSFs += [ f'el_charge_misid_effSF_{self.electrons.split(".")[1]}_%SYS%' ]
61
62 if self.muons:
63 muons, muonSelection = config.readNameAndSelection(self.muons)
64 alg.muons = muons
65 alg.muonSelection = muonSelection
66 if self.muonSFs:
67 alg.muonSFs = self.muonSFs
68 else:
69 alg.muonSFs = [ f'muon_reco_effSF_{self.muons.split(".")[1]}_%SYS%']
70 if 'trackSelection' in alg.muonSelection:
71 alg.muonSFs += [ f'muon_TTVA_effSF_{self.muons.split(".")[1]}_%SYS%' ]
72 if 'isolated' in alg.muonSelection:
73 alg.muonSFs += [ f'muon_isol_effSF_{self.muons.split(".")[1]}_%SYS%' ]
74 if self.includeMuonBadVeto:
75 alg.muonSFs += [ f'muon_BadMuonVeto_effSF_{self.muons.split(".")[1]}_%SYS%' ]
76
77 if self.photons:
78 photons, photonSelection = config.readNameAndSelection(self.photons)
79 alg.photons = photons
80 alg.photonSelection = photonSelection
81 if self.photonSFs:
82 alg.photonSFs = self.photonSFs
83 else:
84 alg.photonSFs = [ f'ph_id_effSF_{self.photons.split(".")[1]}_%SYS%' ]
85 if 'isolated' in alg.photonSelection:
86 alg.photonSFs += [ f'ph_isol_effSF_{self.photons.split(".")[1]}_%SYS%' ]
87
88 if self.taus:
89 taus, tauSelection = config.readNameAndSelection(self.taus)
90 alg.taus = taus
91 alg.tauSelection = tauSelection
92 if self.tauSFs:
93 alg.tauSFs = self.tauSFs
94 else:
95 alg.tauSFs = [ f'tau_Reco_effSF_{self.taus.split(".")[1]}_%SYS%',
96 f'tau_ID_effSF_{self.taus.split(".")[1]}_%SYS%']
97 if 'eVeto' in alg.tauSelection:
98 alg.tauSFs += [ f'tau_EvetoFakeTau_effSF_{self.taus.split(".")[1]}_%SYS%',
99 f'tau_EvetoTrueTau_effSF_{self.taus.split(".")[1]}_%SYS%']
100
101 alg.event_leptonSF = f'leptonSF_{self.lepton_postfix}_%SYS%'
102
103 config.addOutputVar('EventInfo', alg.event_leptonSF, f'weight_leptonSF_{self.lepton_postfix}')