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
|
#ifndef _CSCBADCHAMBERSCONDITIONS_H
#define _CSCBADCHAMBERSCONDITIONS_H
#include "FWCore/Framework/interface/ESHandle.h"
#include "FWCore/Framework/interface/ESProducer.h"
#include "FWCore/Framework/interface/Event.h"
#include "FWCore/Framework/interface/EventSetup.h"
#include "FWCore/Framework/interface/EventSetupRecordIntervalFinder.h"
#include "FWCore/Framework/interface/Frameworkfwd.h"
#include "FWCore/Framework/interface/MakerMacros.h"
#include "FWCore/Framework/interface/SourceFactory.h"
#include "FWCore/ParameterSet/interface/ParameterSet.h"
#include <cmath>
#include <memory>
#include "CondFormats/CSCObjects/interface/CSCBadChambers.h"
#include "CondFormats/DataRecord/interface/CSCBadChambersRcd.h"
#include <DataFormats/MuonDetId/interface/CSCDetId.h>
class CSCBadChambersConditions : public edm::ESProducer, public edm::EventSetupRecordIntervalFinder {
public:
CSCBadChambersConditions(const edm::ParameterSet &);
~CSCBadChambersConditions() override;
inline static CSCBadChambers *prefillBadChambers();
typedef std::unique_ptr<CSCBadChambers> ReturnType;
ReturnType produceBadChambers(const CSCBadChambersRcd &);
private:
// ----------member data ---------------------------
void setIntervalFor(const edm::eventsetup::EventSetupRecordKey &,
const edm::IOVSyncValue &,
edm::ValidityInterval &) override;
CSCBadChambers *cndbBadChambers;
};
#include <fstream>
#include <iostream>
#include <vector>
// to workaround plugin library
inline CSCBadChambers *CSCBadChambersConditions::prefillBadChambers() {
// const int MAX_SIZE = 468;
// cndbbadchambers = new CSCBadChambers();
int new_chambers;
std::vector<int> new_badchambers;
int old_chamber = -1;
int new_nrlines;
new_nrlines = 0;
std::ifstream newdata;
newdata.open("badchambers.dat", std::ios::in);
if (!newdata) {
std::cerr << "Error: badchambers.dat -> no such file!" << std::endl;
exit(1);
}
while (!newdata.eof()) {
newdata >> new_chambers;
if (new_chambers != old_chamber) {
new_badchambers.push_back(new_chambers);
std::cout << new_chambers << std::endl;
++new_nrlines;
}
old_chamber = new_chambers;
}
newdata.close();
CSCBadChambers *cndbbadchambers = new CSCBadChambers(new_nrlines, new_badchambers);
// std::cout <<"numberOfBadChambers "<<new_nrlines<<std::endl;
return cndbbadchambers;
}
#endif
|