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
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
|
#ifndef DQM_L1TMONITORCLIENT_L1TDTTF_H
#define DQM_L1TMONITORCLIENT_L1TDTTF_H
// system include files
#include <string>
// user include files
#include "FWCore/Framework/interface/Event.h"
#include "DQMServices/Core/interface/DQMEDHarvester.h"
#include "DQMServices/Core/interface/DQMStore.h"
//
// class declaration
//
class TH1F;
class TH2F;
class L1TDTTFClient : public DQMEDHarvester {
public:
/// Constructor
L1TDTTFClient(const edm::ParameterSet& ps);
/// Destructor
~L1TDTTFClient() override;
protected:
void dqmEndLuminosityBlock(DQMStore::IBooker& ibooker,
DQMStore::IGetter&,
edm::LuminosityBlock const&,
edm::EventSetup const&) override; //performed in the endLumi
void dqmEndJob(DQMStore::IBooker&, DQMStore::IGetter&) override; //performed in the endJob
void book(DQMStore::IBooker& ibooker);
private:
std::string l1tdttffolder_;
edm::InputTag dttfSource_;
bool online_;
bool verbose_;
int resetafterlumi_;
int counterLS_; ///counter
TH2F* occupancy_r_;
std::string wheel_[6];
std::string wheelpath_[6];
std::string inclusivepath_;
std::string gmtpath_;
std::string testpath_;
MonitorElement* dttf_nTracks_integ;
MonitorElement* dttf_occupancySummary;
MonitorElement* dttf_bx_summary;
MonitorElement* dttf_bx_integ;
MonitorElement* dttf_eta_fine_integ;
MonitorElement* dttf_quality_integ;
MonitorElement* dttf_quality_summary;
MonitorElement* dttf_highQual_Summary;
MonitorElement* dttf_phi_eta_coarse_integ;
MonitorElement* dttf_phi_eta_fine_integ;
MonitorElement* dttf_phi_eta_integ;
MonitorElement* dttf_eta_fine_fraction;
MonitorElement* dttf_phi_integ;
MonitorElement* dttf_pt_integ;
MonitorElement* dttf_eta_integ;
MonitorElement* dttf_q_integ;
MonitorElement* dttf_gmt_matching;
MonitorElement* dttf_2ndTrack_Summary;
MonitorElement* dttf_occupancySummary_test;
MonitorElement* dttf_nTracks_integ_2ndTrack;
MonitorElement* dttf_occupancySummary_2ndTrack;
MonitorElement* dttf_bx_summary_2ndTrack;
MonitorElement* dttf_bx_integ_2ndTrack;
MonitorElement* dttf_quality_integ_2ndTrack;
MonitorElement* dttf_quality_summary_2ndTrack;
MonitorElement* dttf_highQual_Summary_2ndTrack;
MonitorElement* dttf_phi_eta_integ_2ndTrack;
MonitorElement* dttf_eta_integ_2ndTrack;
MonitorElement* dttf_phi_integ_2ndTrack;
MonitorElement* dttf_pt_integ_2ndTrack;
MonitorElement* dttf_q_integ_2ndTrack;
MonitorElement* dttf_nTracks_wheel[6];
MonitorElement* dttf_bx_wheel_summary[6];
MonitorElement* dttf_bx_wheel_integ[6];
MonitorElement* dttf_quality_wheel[6];
MonitorElement* dttf_quality_summary_wheel[6];
MonitorElement* dttf_fine_fraction_wh[6];
MonitorElement* dttf_eta_wheel[6];
MonitorElement* dttf_phi_wheel[6];
MonitorElement* dttf_pt_wheel[6];
MonitorElement* dttf_q_wheel[6];
MonitorElement* dttf_nTracks_wheel_2ndTrack[6];
MonitorElement* dttf_bx_wheel_summary_2ndTrack[6];
MonitorElement* dttf_bx_wheel_integ_2ndTrack[6];
TH1F* getTH1F(DQMStore::IGetter& igetter, const char* hname);
TH2F* getTH2F(DQMStore::IGetter& igetter, const char* hname);
void setMapLabel(MonitorElement* me);
void buildHighQualityPlot(DQMStore::IGetter& igetter,
TH2F* occupancySummary,
MonitorElement* highQual_Summary,
const std::string& path);
void buildPhiEtaPlotOFC(DQMStore::IGetter& igetter,
MonitorElement* phi_eta_fine_integ,
MonitorElement* phi_eta_coarse_integ,
MonitorElement* phi_eta_integ,
const std::string& path_fine,
const std::string& path_coarse,
int wh);
void buildPhiEtaPlotO(DQMStore::IGetter& igetter, MonitorElement* phi_eta_integ, const std::string& path, int wh);
/* void buildPhiEtaPlot( MonitorElement * phi_eta_integ, */
/* const std::string & path, */
/* int wh ); */
/* void buildPhiEtaPlotFC( MonitorElement * phi_eta_fine_integ, */
/* MonitorElement * phi_eta_coarse_integ, */
/* MonitorElement * phi_eta_integ, */
/* const std::string & path_fine, */
/* const std::string & path_coarse, */
/* int wh ); */
void makeSummary(DQMStore::IGetter& igetter);
void buildSummaries(DQMStore::IGetter& igetter);
void setGMTsummary(DQMStore::IGetter& igetter);
void setWheelLabel(MonitorElement* me);
void setQualLabel(MonitorElement* me, int axis);
template <typename T>
void normalize(T* me) {
double scale = me->Integral();
if (scale > 0) {
normalize(me, 1. / scale, scale);
}
}
template <typename T>
void normalize(T* me, const double& scale) {
normalize(me, scale, me->Integral());
}
template <typename T>
void normalize(T* me, const double& scale, const double& entries) {
me->SetEntries(entries);
me->Scale(scale);
}
};
#endif
|