-
Notifications
You must be signed in to change notification settings - Fork 11
/
Copy pathtau_ids.py
95 lines (84 loc) · 3.72 KB
/
tau_ids.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
all_tau_ids = [
('byCombinedIsolationDeltaBetaCorrRaw3Hits', float),
('byLooseCombinedIsolationDeltaBetaCorr3Hits', int),
('byMediumCombinedIsolationDeltaBetaCorr3Hits', int),
('byTightCombinedIsolationDeltaBetaCorr3Hits', int),
#('byIsolationMVArun2v1DBoldDMwLTraw', float), # Not in 12_4_6
#('byVVLooseIsolationMVArun2v1DBoldDMwLT', int),
#('byVLooseIsolationMVArun2v1DBoldDMwLT', int),
#('byLooseIsolationMVArun2v1DBoldDMwLT', int),
#('byMediumIsolationMVArun2v1DBoldDMwLT', int),
#('byTightIsolationMVArun2v1DBoldDMwLT', int),
#('byVTightIsolationMVArun2v1DBoldDMwLT', int),
#('byVVTightIsolationMVArun2v1DBoldDMwLT', int),
#('byIsolationMVArun2v1PWoldDMwLTraw', float), # Not in 11_0_0_pre13
#('byVLooseIsolationMVArun2v1PWoldDMwLT', int),
#('byLooseIsolationMVArun2v1PWoldDMwLT', int),
#('byMediumIsolationMVArun2v1PWoldDMwLT', int),
#('byTightIsolationMVArun2v1PWoldDMwLT', int),
#('byVTightIsolationMVArun2v1PWoldDMwLT', int),
#('byVVTightIsolationMVArun2v1PWoldDMwLT', int),
#('byIsolationMVArun2v1DBnewDMwLTraw', float), # Not in 12_4_6
#('byVVLooseIsolationMVArun2v1DBnewDMwLT', int),
#('byVLooseIsolationMVArun2v1DBnewDMwLT', int),
#('byLooseIsolationMVArun2v1DBnewDMwLT', int),
#('byMediumIsolationMVArun2v1DBnewDMwLT', int),
#('byTightIsolationMVArun2v1DBnewDMwLT', int),
#('byVTightIsolationMVArun2v1DBnewDMwLT', int),
#('byVVTightIsolationMVArun2v1DBnewDMwLT', int),
#('byIsolationMVArun2v1DBdR03oldDMwLTraw', float), # Not in 12_4_6
#('byVVLooseIsolationMVArun2v1DBdR03oldDMwLT', int),
#('byVLooseIsolationMVArun2v1DBdR03oldDMwLT', int),
#('byLooseIsolationMVArun2v1DBdR03oldDMwLT', int),
#('byMediumIsolationMVArun2v1DBdR03oldDMwLT', int),
#('byTightIsolationMVArun2v1DBdR03oldDMwLT', int),
#('byVTightIsolationMVArun2v1DBdR03oldDMwLT', int),
#('byVVTightIsolationMVArun2v1DBdR03oldDMwLT', int),
('chargedIsoPtSum', float),
('neutralIsoPtSum', float),
('puCorrPtSum', float),
('neutralIsoPtSumWeight', float),
('footprintCorrection', float),
('photonPtSumOutsideSignalCone', float),
('decayModeFinding', int),
('decayModeFindingNewDMs', int),
]
lepton_tau_ids = [
('againstMuonLoose3', int),
('againstMuonTight3', int),
#('againstElectronVLooseMVA6', int), # Not in 12_4_6
#('againstElectronLooseMVA6', int),
#('againstElectronMediumMVA6', int),
#('againstElectronTightMVA6', int),
#('againstElectronVTightMVA6', int),
#('againstElectronMVA6Raw', float),
]
all_wps = ['VVLoose', 'VLoose', 'Loose', 'Medium', 'Tight', 'VTight', 'VVTight']
def create_tau_ids(name, n_wps=7):
wps = all_wps[:]
if n_wps == 6:
wps = all_wps[1:]
if n_wps == 5:
wps = all_wps[1:6]
if n_wps == 8:
wps.append('VVVLoose')
if n_wps == 4:
wps = all_wps[1:5]
if name[-4:-1] == "201":
rawname = 'by' + name[:-4] + 'raw' + name[-4:]
else:
rawname = 'by' + name + 'raw'
return [('by' + wp + name, int) for wp in wps] + [(rawname, float)]
tau_ids = {
'deepTauIDv2p1VSe':create_tau_ids('DeepTau2017v2p1VSe', 8),
'deepTauIDv2p1VSmu':create_tau_ids('DeepTau2017v2p1VSmu', 4),
'deepTauIDv2p1VSjet':create_tau_ids('DeepTau2017v2p1VSjet', 8),
'2017v2':create_tau_ids('IsolationMVArun2017v2DBoldDMwLT2017'),
'2017v1':create_tau_ids('IsolationMVArun2017v1DBoldDMwLT2017'),
'2016v1':create_tau_ids('IsolationMVArun2v1DBoldDMwLT2016', 6),
'newDM2016v1':create_tau_ids('IsolationMVArun2v1DBnewDMwLT2016', 6),
'dR0p32017v2':create_tau_ids('IsolationMVArun2017v2DBoldDMdR0p3wLT2017')
}
def fill_tau_ids(avd, tau, tau_id_names):
for (tau_id, _) in tau_id_names:
avd['tau_'+tau_id].fill(tau.tauID(tau_id))