CMS 3D CMS Logo

CSCBadStripsConditions.h
Go to the documentation of this file.
1 #ifndef _CSCBADSTRIPSCONDITIONS_H
2 #define _CSCBADSTRIPSCONDITIONS_H
3 
4 #include <memory>
5 #include <cmath>
15 
19 
21  public:
23  ~CSCBadStripsConditions() override;
24 
25 
26  inline static CSCBadStrips * prefillBadStrips();
27 
28  typedef std::unique_ptr<CSCBadStrips> ReturnType;
29 
30  ReturnType produceBadStrips(const CSCBadStripsRcd&);
31 
32  private:
33  // ----------member data ---------------------------
36 
37 };
38 
39 #include<fstream>
40 #include<vector>
41 #include<iostream>
42 
43 // to workaround plugin library
45 {
46  CSCBadStrips * cndbbadstrips = new CSCBadStrips();
47 
48  int new_index, new_chan;
49  int new_layer,new_channel, new_flag1, new_flag2, new_flag3,new_pointer;
50  std::vector<int> new_index_id;
51  std::vector<short int> new_layer_id;
52  std::vector<short int> new_chan_id;
53  std::vector<int> new_badchannels;
54  std::vector<short int> new_flag1_id;
55  std::vector<short int> new_flag2_id;
56  std::vector<short int> new_flag3_id;
57  std::vector<int> new_cham_id;
58  std::vector<int> new_point;
59 
60  //when bad channels exist use the following
61  int new_nrlines1=0;
62  int new_nrlines2=0;
63  //when empty
64  //int new_nrlines1=-1;
65  //int new_nrlines2=-1;
66 
67 
68  std::ifstream newdata1;
69  std::ifstream newdata2;
70 
71  newdata1.open("badstrips1.dat",std::ios::in); //chambercontainer
72  if(!newdata1) {
73  std::cerr <<"Error: badstrips1.dat -> no such file!"<< std::endl;
74  exit(1);
75  }
76  newdata2.open("badstrips2.dat",std::ios::in); //channelcontainer
77  if(!newdata2) {
78  std::cerr <<"Error: badstrips2.dat -> no such file!"<< std::endl;
79  exit(1);
80  }
81 
82  while(!newdata1.eof() ) {
83  newdata1 >> new_index >> new_pointer >> new_chan;
84  new_index_id.push_back(new_index);
85  new_point.push_back(new_pointer);
86  new_badchannels.push_back(new_chan);
87  new_nrlines1++;
88  }
89  newdata1.close();
90 
91  while (!newdata2.eof() ) {
92  newdata2 >> new_layer >> new_channel >> new_flag1 >> new_flag2 >> new_flag3;
93  new_layer_id.push_back(new_layer);
94  new_chan_id.push_back(new_channel);
95  new_flag1_id.push_back(new_flag1);
96  new_flag2_id.push_back(new_flag2);
97  new_flag3_id.push_back(new_flag3);
98  new_nrlines2++;
99  }
100  newdata2.close();
101 
102 
103  CSCBadStrips::BadChamberContainer & itemvector1 = cndbbadstrips->chambers;
104  itemvector1.resize(new_nrlines1);
105 
106  CSCBadStrips::BadChannelContainer & itemvector2 = cndbbadstrips->channels;
107  itemvector2.resize(new_nrlines2);
108 
109  cndbbadstrips->numberOfBadChannels = new_nrlines2;
110 
111  for(int i=0; i<new_nrlines1;i++){
112  itemvector1[i].chamber_index = new_index_id[i];
113  itemvector1[i].pointer = new_point[i];
114  itemvector1[i].bad_channels = new_badchannels[i];
115  }
116 
117  for(int j=0;j<new_nrlines2;j++) {
118  itemvector2[j].layer = new_layer_id[j];
119  itemvector2[j].channel = new_chan_id[j];
120  itemvector2[j].flag1 = new_flag1_id[j];
121  itemvector2[j].flag2 = new_flag2_id[j];
122  itemvector2[j].flag3 = new_flag3_id[j];
123  }
124 
125  return cndbbadstrips;
126 }
127 
128 #endif
129 
static CSCBadStrips * prefillBadStrips()
std::vector< BadChannel > BadChannelContainer
Definition: CSCBadStrips.h:33
void setIntervalFor(const edm::eventsetup::EventSetupRecordKey &, const edm::IOVSyncValue &, edm::ValidityInterval &) override
BadChamberContainer chambers
Definition: CSCBadStrips.h:35
ReturnType produceBadStrips(const CSCBadStripsRcd &)
std::vector< BadChamber > BadChamberContainer
Definition: CSCBadStrips.h:32
int numberOfBadChannels
Definition: CSCBadStrips.h:30
BadChannelContainer channels
Definition: CSCBadStrips.h:36
CSCBadStripsConditions(const edm::ParameterSet &)
std::unique_ptr< CSCBadStrips > ReturnType