-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathworkflow_ZjetsReco.py
90 lines (73 loc) · 3.58 KB
/
workflow_ZjetsReco.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
import awkward as ak
import numpy as np
from CommonSelectors import *
from pocket_coffea.workflows.base import BaseProcessorABC
from pocket_coffea.utils.configurator import Configurator
from pocket_coffea.lib.hist_manager import Axis
from pocket_coffea.lib.deltaR_matching import delta_phi
from pocket_coffea.lib.objects import (
jet_correction,
lepton_selection,
jet_selection,
# btagging,
# CvsLsorted,
get_dilepton,
get_dijet
)
class ZjetsBaseProcessor(BaseProcessorABC):
def __init__(self, cfg: Configurator):
super().__init__(cfg)
def apply_object_preselection(self, variation):
# Include the supercluster pseudorapidity variable
electron_etaSC = self.events.Electron.eta + self.events.Electron.deltaEtaSC
self.events["Electron"] = ak.with_field(
self.events.Electron, electron_etaSC, "etaSC"
)
# Build masks for selection of muons, electrons, jets, fatjets
self.events["MuonGood"] = lepton_selection(
self.events, "Muon", self.params
)
self.events["ElectronGood"] = lepton_selection(
self.events, "Electron", self.params
)
leptons = ak.with_name(
ak.concatenate((self.events.MuonGood, self.events.ElectronGood), axis=1),
name='PtEtaPhiMCandidate',
)
self.events["LeptonGood"] = leptons[ak.argsort(leptons.pt, ascending=False)]
self.events["ll"] = get_dilepton(
self.events.ElectronGood, self.events.MuonGood
)
self.events["JetGood"], self.jetGoodMask = jet_selection(
self.events, "Jet", self.params, self._year, "LeptonGood"
)
#self.events["BJetGood"] = btagging(
# self.events["JetGood"], self.params.btagging.working_point[self._year], wp=self.params.object_preselection.bJetWP)
def count_objects(self, variation):
self.events["nMuonGood"] = ak.num(self.events.MuonGood)
self.events["nElectronGood"] = ak.num(self.events.ElectronGood)
self.events["nLeptonGood"] = ak.num(self.events.LeptonGood)
self.events["nJet"] = ak.num(self.events.Jet)
self.events["nJetGood"] = ak.num(self.events.JetGood)
#self.events["nBJetGood"] = ak.num(self.events.BJetGood)
# Function that defines common variables employed in analyses and save them as attributes of `events`
def define_common_variables_before_presel(self, variation):
self.events["JetGood_Ht"] = ak.sum(abs(self.events.JetGood.pt), axis=1)
def define_common_variables_after_presel(self, variation):
self.events["dijet"] = get_dijet(self.events.JetGood)
jets = ak.pad_none(self.events.JetGood, 2)
njet = ak.num(jets[~ak.is_none(jets, axis=1)])
j1 = jets[:,0]
j2 = jets[:,1]
l1 = self.events.LeptonGood[:,0]
l2 = self.events.LeptonGood[:,1]
self.events["j1_l1_dr"] = ak.where( (njet >= 1), j1.delta_r(l1), -1)
self.events["j1_l2_dr"] = ak.where( (njet >= 1), j1.delta_r(l2), -1)
self.events["j2_l1_dr"] = ak.where( (njet >= 2), j2.delta_r(l1), -1)
self.events["j2_l2_dr"] = ak.where( (njet >= 2), j2.delta_r(l2), -1)
#self.events["JetsCvsL"] = CvsLsorted(self.events["JetGood"], self.params.ctagging.working_point[self._year])
self.events["ZH_pt_ratio"] = self.events.dijet.pt/self.events.ll.pt
self.events["ZH_deltaPhi"] = np.abs(self.events.ll.delta_phi(self.events.dijet))
self.events["ZH_deltaR"] = np.abs(self.events.ll.delta_r(self.events.dijet))
def compute_weights_extra(self, variation):
pass