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
|
#ifndef RPCOccupancyTest_H
#define RPCOccupancyTest_H
#include "DQM/RPCMonitorClient/interface/RPCClient.h"
#include "DQMServices/Core/interface/DQMStore.h"
#include <map>
#include <memory>
#include <string>
#include <vector>
class RPCOccupancyTest : public RPCClient {
public:
RPCOccupancyTest(const edm::ParameterSet &ps);
~RPCOccupancyTest() override = default;
void clientOperation() override;
void getMonitorElements(std::vector<MonitorElement *> &, std::vector<RPCDetId> &, std::string &) override;
void beginJob(std::string &) override;
void myBooker(DQMStore::IBooker &) override;
protected:
// void OccupancyDist();
void fillGlobalME(RPCDetId &, MonitorElement *);
private:
std::string globalFolder_, prefixDir_;
bool useNormalization_;
bool useRollInfo_;
std::vector<MonitorElement *> myOccupancyMe_;
std::vector<RPCDetId> myDetIds_;
int prescaleFactor_;
float totalActive_, totalStrips_;
int numberOfDisks_, numberOfRings_;
float rpcevents_;
MonitorElement *Active_Fraction; // Fraction of channels with data
MonitorElement *Active_Dead;
MonitorElement *AsyMeWheel[5]; //Left Right Asymetry
MonitorElement *NormOccupWheel[5];
MonitorElement *NormOccupDWheel[5];
MonitorElement *AsyMeDisk[10]; //Left Right Asymetry
MonitorElement *NormOccupDisk[10];
MonitorElement *NormOccupDDisk[10];
MonitorElement *Barrel_OccBySt;
MonitorElement *EndCap_OccByRng;
MonitorElement *EndCap_OccByDisk;
};
#endif
|