1 |
dhidas |
1.1 |
/*
|
2 |
|
|
* Event.h
|
3 |
|
|
*
|
4 |
|
|
* Created on: Jun 25, 2010
|
5 |
|
|
* Author: lkreczko
|
6 |
|
|
*/
|
7 |
|
|
|
8 |
|
|
#ifndef EVENT_H_
|
9 |
|
|
#define EVENT_H_
|
10 |
|
|
#include "RecoObjects/Electron.h"
|
11 |
|
|
#include "RecoObjects/Jet.h"
|
12 |
|
|
#include "RecoObjects/Muon.h"
|
13 |
|
|
#include "RecoObjects/Vertex.h"
|
14 |
|
|
#include "RecoObjects/MET.h"
|
15 |
|
|
#include "RecoObjects/MCParticle.h"
|
16 |
|
|
#include "DataTypes.h"
|
17 |
|
|
#include "Printers/EventContentPrinter.h"
|
18 |
|
|
#include "HighLevelTriggers.h"
|
19 |
|
|
|
20 |
|
|
namespace BAT {
|
21 |
|
|
|
22 |
|
|
|
23 |
|
|
class Event {
|
24 |
|
|
protected:
|
25 |
|
|
boost::shared_ptr<std::vector<int> > HLTs;
|
26 |
|
|
VertexCollection vertices;
|
27 |
|
|
VertexCollection goodVertices;
|
28 |
|
|
TrackCollection tracks;
|
29 |
|
|
ElectronCollection allElectrons;
|
30 |
|
|
ElectronCollection goodElectrons;
|
31 |
|
|
ElectronCollection goodIsolatedElectrons;
|
32 |
|
|
ElectronCollection goodPFIsolatedElectrons;
|
33 |
|
|
ElectronCollection looseElectrons;
|
34 |
|
|
ElectronCollection qcdElectrons;
|
35 |
|
|
ElectronCollection loosePFElectrons;
|
36 |
|
|
|
37 |
|
|
JetCollection allJets;
|
38 |
|
|
JetCollection genJets;
|
39 |
|
|
JetCollection goodJets;
|
40 |
|
|
JetCollection goodBJets;
|
41 |
|
|
|
42 |
|
|
MuonCollection allMuons;
|
43 |
|
|
MuonCollection goodMuons;
|
44 |
|
|
MuonCollection goodIsolatedMuons;
|
45 |
|
|
MuonCollection looseMuons;
|
46 |
|
|
|
47 |
|
|
MCParticleCollection genParticles;
|
48 |
|
|
|
49 |
|
|
METPointer met;
|
50 |
|
|
|
51 |
|
|
DataType::value dataType;
|
52 |
|
|
unsigned long runNumber;
|
53 |
|
|
unsigned long eventNumber;
|
54 |
|
|
unsigned long localEventNumber;
|
55 |
|
|
unsigned long lumiBlock;
|
56 |
|
|
float eventWeight;
|
57 |
|
|
|
58 |
|
|
float jetCleaningEfficiency;
|
59 |
|
|
unsigned int numberOfHighPurityTracks;
|
60 |
|
|
bool isBeamScraping;
|
61 |
|
|
|
62 |
|
|
unsigned int genNumberOfPileUpVertices;
|
63 |
|
|
|
64 |
|
|
public:
|
65 |
|
|
Event();
|
66 |
|
|
virtual ~Event();
|
67 |
|
|
bool isRealData() const;
|
68 |
|
|
const DataType::value getDataType() const;
|
69 |
|
|
void setDataType(DataType::value type);
|
70 |
|
|
void setVertices(VertexCollection vertices);
|
71 |
|
|
void setTracks(TrackCollection tracks);
|
72 |
|
|
void setGenParticles(MCParticleCollection genParticles);
|
73 |
|
|
void setElectrons(ElectronCollection electrons);
|
74 |
|
|
void setLoosePFElectrons(ElectronCollection electrons);
|
75 |
|
|
void setJets(JetCollection jets);
|
76 |
|
|
void setGenJets(JetCollection genJets);
|
77 |
|
|
void setMuons(MuonCollection muons);
|
78 |
|
|
void setMET(const METPointer met);
|
79 |
|
|
void setHLTs(const boost::shared_ptr<std::vector<int> >);
|
80 |
|
|
void setRunNumber(unsigned long number);
|
81 |
|
|
void setEventNumber(unsigned long number);
|
82 |
|
|
void setLocalEventNumber(unsigned long number);
|
83 |
|
|
void setLumiBlock(unsigned long block);
|
84 |
|
|
void setEventWeight(float weight);
|
85 |
|
|
void setBeamScrapingVeto(bool isScraping);
|
86 |
|
|
void setGenNumberOfPileUpVertices(unsigned int pileup);
|
87 |
|
|
|
88 |
|
|
const VertexPointer PrimaryVertex() const;
|
89 |
|
|
const VertexCollection& Vertices() const;
|
90 |
|
|
const VertexCollection& GoodVertices() const;
|
91 |
|
|
const TrackCollection& Tracks() const;
|
92 |
|
|
const MCParticleCollection& GenParticles() const;
|
93 |
|
|
const ElectronCollection& Electrons() const;
|
94 |
|
|
const ElectronCollection& GoodElectrons() const;
|
95 |
|
|
const ElectronCollection& GoodIsolatedElectrons() const;
|
96 |
|
|
const ElectronCollection& GoodPFIsolatedElectrons() const;
|
97 |
|
|
const ElectronCollection& QCDElectrons() const;
|
98 |
|
|
const ElectronCollection& LoosePFElectrons() const;
|
99 |
|
|
const JetCollection& Jets() const;
|
100 |
|
|
const JetCollection& GenJets() const;
|
101 |
|
|
const JetCollection& GoodJets() const;
|
102 |
|
|
const JetCollection& GoodBJets() const;
|
103 |
|
|
const MuonCollection& Muons() const;
|
104 |
|
|
const MuonCollection& GoodMuons() const;
|
105 |
|
|
const MuonCollection& GoodIsolatedMuons() const;
|
106 |
|
|
const METPointer MET() const;
|
107 |
|
|
const ElectronPointer MostIsolatedElectron(bool usePFIso) const;
|
108 |
|
|
const ElectronPointer MostIsolatedElectron() const;
|
109 |
|
|
const ElectronPointer MostPFIsolatedElectron() const;
|
110 |
|
|
unsigned long runnumber() const;
|
111 |
|
|
unsigned long eventnumber() const;
|
112 |
|
|
unsigned long localnumber() const;
|
113 |
|
|
unsigned long lumiblock() const;
|
114 |
|
|
float weight() const;
|
115 |
|
|
void inspect() const;
|
116 |
|
|
bool HLT(HLTriggers::value trigger) const;
|
117 |
|
|
static bool useCustomConversionTagger;
|
118 |
|
|
static bool usePFIsolation;
|
119 |
|
|
|
120 |
|
|
float numberOfGeneratedPileUpVertices() const;
|
121 |
|
|
|
122 |
|
|
private:
|
123 |
|
|
void selectElectronsByQuality();
|
124 |
|
|
void cleanGoodJets();
|
125 |
|
|
template <class PartColl> void cleanGoodJetsAgainstIsolatedLeptons(const PartColl &leptonColl);
|
126 |
|
|
void cleanGoodJetsAgainstMostIsolatedElectron();
|
127 |
|
|
void selectGoodJets();
|
128 |
|
|
void selectMuonsByQuality();
|
129 |
|
|
void selectVerticesByQuality();
|
130 |
|
|
};
|
131 |
|
|
|
132 |
|
|
}
|
133 |
|
|
|
134 |
|
|
#endif /* EVENT_H_ */
|