-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgenanalysis.py
139 lines (131 loc) · 3.96 KB
/
genanalysis.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
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
from __future__ import annotations # needed for type annotations in > python 3.7
from typing import List
from code_generation.modifiers import SampleModifier
from .producers import event as event
from .producers import met as met
from .producers import muons as muons
from .producers import pairquantities as pairquantities
from .producers import genparticles as genparticles
from .producers import pairselection as pairselection
from .producers import embedding as emb
from .quantities import nanoAOD as nanoAOD
from .quantities import output as q
from code_generation.configuration import Configuration
from code_generation.rules import AppendProducer
def build_config(
era: str,
sample: str,
scopes: List[str],
shifts: List[str],
available_sample_types: List[str],
available_eras: List[str],
available_scopes: List[str],
):
if sample == "data":
print("WARNING: no genparticles available in data, what are you doing ??")
configuration = Configuration(
era,
sample,
scopes,
shifts,
available_sample_types,
available_eras,
available_scopes,
)
# first add default parameters necessary for all scopes
configuration.add_config_parameters(
"global",
{
"RunLumiEventFilter_Quantities": ["event", "luminosityBlock"],
"RunLumiEventFilter_Quantity_Types": ["ULong64_t", "UInt_t"],
"RunLumiEventFilter_Selections": ["3", "318"],
"min_muon_pt": 10.0,
"max_muon_eta": 2.4,
"max_muon_dxy": 0.5,
"max_muon_dz": 0.5,
"muon_id": "Muon_looseId",
"muon_iso_cut": 2.5,
},
)
###### scope Specifics ######
# MT/MM scope Muon selection
configuration.add_config_parameters(
["mm"],
{
"muon_index_in_pair": 0,
"second_muon_index_in_pair": 1,
"muon_iso_cut": 0.15,
"min_muon_pt": 23.0,
"max_muon_eta": 2.4,
"max_muon_dxy": 0.045,
"max_muon_dz": 0.2,
"muon_id": "Muon_mediumId",
"truegen_mother_pdgid": SampleModifier(
{"emb_mc": 23, "tt": 6, "vv": 24}, default=None
),
"truegen_daughter_1_pdgid": 13,
"truegen_daugher_2_pdgid": 13,
},
)
configuration.add_producers(
"global",
[
# event.RunLumiEventFilter,
event.Lumi,
muons.BaseMuons,
],
)
configuration.add_producers(
"mm",
[
genparticles.MMTrueGenDiTauPairQuantities,
met.UncorrectedMet,
muons.GoodMuons,
muons.VetoMuons,
muons.VetoSecondMuon,
muons.ExtraMuonsVeto,
pairselection.ZMMPairSelection,
pairselection.GoodMMPairFilter,
pairselection.LVMu1,
pairselection.LVMu2,
pairselection.LVMu1Uncorrected,
pairselection.LVMu2Uncorrected,
pairquantities.MMDiTauPairQuantities,
],
)
configuration.add_outputs(
["mm"],
[
nanoAOD.run,
q.lumi,
nanoAOD.event,
q.gen_pt_1,
q.gen_eta_1,
q.gen_phi_1,
q.gen_mass_1,
q.gen_pt_2,
q.gen_eta_2,
q.gen_phi_2,
q.gen_mass_2,
q.gen_m_vis,
q.pt_1,
q.pt_2,
q.eta_1,
q.eta_2,
q.phi_1,
q.phi_2,
q.m_vis,
q.muon_veto_flag,
],
)
configuration.add_modification_rule(
"global",
AppendProducer(producers=emb.EmbeddingQuantities, samples=["emb", "emb_mc"]),
)
#########################
# Finalize and validate the configuration
#########################
configuration.optimize()
configuration.validate()
configuration.report()
return configuration.expanded_configuration()