38 int kBarrelSize = 61200;
39 int kEndcapSize = 2*7324;
40 int skipped_channels_EB = 0;
41 int skipped_channels_EE = 0;
67 skipped_channels_EB++;
106 skipped_channels_EE++;
119 bool enough_stat =
false;
134 edm::LogError(
"Large Variations found wrt to old pedestals, no file created");
143 throw std::runtime_error(
"PoolDBService required.");
186 std::vector<int>::const_iterator
res =
200 if (dbstatus ==0 )
return true;
208 uint32_t nAnomaliesEB =0;
209 uint32_t nAnomaliesEE =0;
248 MonitorElement * pmeb = ibooker.
book2D(
"meaneb",
"Pedestal Means EB",360, 1., 361., 171, -85., 86.);
249 MonitorElement * preb = ibooker.
book2D(
"rmseb",
"Pedestal RMS EB ",360, 1., 361., 171, -85., 86.);
257 MonitorElement * pmebd = ibooker.
book2D(
"meanebdiff",
"Abs Rel Pedestal Means Diff EB",360,1., 361., 171, -85., 86.);
258 MonitorElement * prebd = ibooker.
book2D(
"rmsebdiff",
"Abs Rel Pedestal RMS Diff E ",360, 1., 361., 171, -85., 86.);
260 MonitorElement * pmeepd = ibooker.
book2D(
"meaneepdiff",
"Abs Rel Pedestal Means Diff EEP",100,1,101,100,1,101);
261 MonitorElement * preepd = ibooker.
book2D(
"rmseepdiff",
"Abs Rel Pedestal RMS Diff EEP",100,1,101,100,1,101);
263 MonitorElement * pmeemd = ibooker.
book2D(
"meaneemdiff",
"Abs Rel Pedestal Means Diff EEM",100,1,101,100,1,101);
264 MonitorElement * preemd = ibooker.
book2D(
"rmseemdiff",
"Abs RelPedestal RMS Diff EEM",100,1,101,100,1,101);
277 float mean= newpeds[di].mean_x12;
278 float rms = newpeds[di].rms_x12;
280 float cmean = (*currentPedestals_)[di].mean_x12;
281 float crms = (*currentPedestals_)[di].rms_x12;
283 if (!
isGood(di) )
continue;
290 hdiffeb->
Fill(mean-cmean);
297 float mean= newpeds[di].mean_x12;
298 float rms = newpeds[di].rms_x12;
299 float cmean = (*currentPedestals_)[di].mean_x12;
300 float crms = (*currentPedestals_)[di].rms_x12;
302 if (!
isGood(di) )
continue;
317 hdiffee->
Fill(mean-cmean);
static EEDetId detIdFromDenseIndex(uint32_t din)
T getParameter(std::string const &) const
double thresholdAnomalies_
const self & getMap() const
int entriesEE_[EEDetId::kSizeForDenseIndexing]
MonitorElement * get(const std::string &path)
bool checkVariation(const EcalPedestalsMap &oldPedestals, const EcalPedestalsMap &newPedestals)
bool isGood(const DetId &id)
double getMean(int axis=1) const
get mean value of histogram along x, y or z axis (axis=1, 2, 3 respectively)
float threshChannelsAnalyzed_
void find(edm::Handle< EcalRecHitCollection > &hits, DetId thisDet, std::vector< EcalRecHitCollection::const_iterator > &hit, bool debug=false)
void dqmEndJob(DQMStore::IBooker &ibooker_, DQMStore::IGetter &igetter_) override
int iphi() const
get the crystal iphi
static EBDetId detIdFromDenseIndex(uint32_t di)
void setValue(const uint32_t id, const Item &item)
ECALpedestalPCLHarvester(const edm::ParameterSet &ps)
void addDefault(ParameterSetDescription const &psetDescription)
const EcalPedestals * g6g1Pedestals_
std::vector< int > chStatusToExclude_
MonitorElement * book1D(Args &&...args)
Abs< T >::type abs(const T &t)
void writeOne(T *payload, Time_t time, const std::string &recordName, bool withlogging=false)
int ieta() const
get the crystal ieta
void dqmPlots(const EcalPedestals &newpeds, DQMStore::IBooker &ibooker)
double getEntries() const
get # of entries
void setCurrentFolder(const std::string &fullpath)
MonitorElement * book2D(Args &&...args)
const EcalChannelStatus * channelStatus_
std::vector< Item >::const_iterator const_iterator
bool checkStatusCode(const DetId &id)
const EcalPedestals * currentPedestals_
double getRMS(int axis=1) const
get RMS of histogram along x, y or z axis (axis=1, 2, 3 respectively)
cond::Time_t currentTime() const
const_iterator find(uint32_t rawId) const
const_iterator end() const
void endRun(edm::Run const &run, edm::EventSetup const &isetup) override
int entriesEB_[EBDetId::kSizeForDenseIndexing]
T const * product() const
static void fillDescriptions(edm::ConfigurationDescriptions &descriptions)