1 |
#ifndef MUON_SELECTION
|
2 |
#define MUON_SELECTION
|
3 |
|
4 |
#include "Muon.h"
|
5 |
#include "Vertex.h"
|
6 |
#include "PFCandidate.h"
|
7 |
#include "PFCandidateCol.h"
|
8 |
#include "MuonCol.h"
|
9 |
|
10 |
#include "SelectionStatus.h"
|
11 |
#include "ParseArgs.h"
|
12 |
#include "Track.h"
|
13 |
|
14 |
#include "MuonTools.h"
|
15 |
#include "MuonQuality.h"
|
16 |
|
17 |
#include "PileupEnergyDensity.h"
|
18 |
#include "Various.h"
|
19 |
|
20 |
#define MUON_IDMVA_CUT_BIN0 -0.825
|
21 |
#define MUON_IDMVA_CUT_BIN1 -0.725
|
22 |
#define MUON_IDMVA_CUT_BIN2 -0.895
|
23 |
#define MUON_IDMVA_CUT_BIN3 -0.595
|
24 |
#define MUON_IDMVA_CUT_BIN4 -0.865
|
25 |
#define MUON_IDMVA_CUT_BIN5 -0.979
|
26 |
|
27 |
bool muon2012CutBasedIDTightVersionWithOldIsoThatWorksOn2011(ControlFlags &ctrl, const mithep::Muon *mu, const mithep::Vertex * vtx, const mithep::Array<mithep::PFCandidate> * pfCandidates,
|
28 |
const mithep::Array<mithep::PileupEnergyDensity> * puEnergyDensity, mithep::MuonTools::EMuonEffectiveAreaTarget EffectiveAreaVersion);
|
29 |
|
30 |
bool muonPOG2012CutBasedIDTight(const mithep::Muon *mu, const mithep::Vertex * vtx, const mithep::Array<mithep::PFCandidate> * pfCandidates, const mithep::Array<mithep::PileupEnergyDensity> * puEnergyDensity);
|
31 |
|
32 |
SelectionStatus muonDummyVeto(ControlFlags &, const mithep::Muon *, const mithep::Vertex *);
|
33 |
SelectionStatus muonCutBasedVeto(ControlFlags &, const mithep::Muon *, const mithep::Vertex *);
|
34 |
|
35 |
SelectionStatus muonReferencePreSelection( ControlFlags &ctrl,
|
36 |
const mithep::Muon * mu,
|
37 |
const mithep::Vertex * vtx,
|
38 |
const mithep::Array<mithep::PFCandidate> * pfCandidates );
|
39 |
SelectionStatus muonPreSelectionNoD0IP( ControlFlags &ctrl,
|
40 |
const mithep::Muon * mu,
|
41 |
const mithep::Vertex * vtx,
|
42 |
const mithep::Array<mithep::PFCandidate> * pfCandidates );
|
43 |
|
44 |
SelectionStatus muonIDMVASelection(ControlFlags &ctrl,
|
45 |
const mithep::Muon *mu,
|
46 |
const mithep::Vertex * vtx );
|
47 |
void initMuonIDMVA(void);
|
48 |
|
49 |
SelectionStatus muonIDPFSelection(ControlFlags &, const mithep::Muon *, const mithep::Vertex *,
|
50 |
const mithep::Array<mithep::PFCandidate> * );
|
51 |
|
52 |
bool trackToPFMuonSelection( const mithep::Track *track, const mithep::MuonCol * muoncol );
|
53 |
SelectionStatus PassWwMuonSel(const mithep::Muon *mu, const mithep::Vertex *vtx,
|
54 |
const mithep::Array<mithep::PFCandidate> *pfArr
|
55 |
);
|
56 |
#endif
|
57 |
// SelectionStatus muonPreSelectionNoD0DzIP( ControlFlags &ctrl,
|
58 |
// const mithep::Muon * mu,
|
59 |
// const mithep::Vertex * vtx,
|
60 |
// const mithep::Array<mithep::PFCandidate> * pfCandidates );
|