00001 #include "DQM/HcalMonitorClient/interface/HcalTrigPrimClient.h"
00002 #include "DQM/HcalMonitorClient/interface/HcalClientUtils.h"
00003 #include "DQM/HcalMonitorClient/interface/HcalHistoUtils.h"
00004
00005 #include "CondFormats/HcalObjects/interface/HcalChannelStatus.h"
00006 #include "CondFormats/HcalObjects/interface/HcalChannelQuality.h"
00007 #include "CondFormats/HcalObjects/interface/HcalCondObjectContainer.h"
00008
00009 #include <iostream>
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020 HcalTrigPrimClient::HcalTrigPrimClient(std::string myname)
00021 {
00022 name_=myname;
00023 }
00024
00025 HcalTrigPrimClient::HcalTrigPrimClient(std::string myname, const edm::ParameterSet& ps)
00026 {
00027 name_=myname;
00028 enableCleanup_ = ps.getUntrackedParameter<bool>("enableCleanup",false);
00029 debug_ = ps.getUntrackedParameter<int>("debug",0);
00030 prefixME_ = ps.getUntrackedParameter<std::string>("subSystemFolder","Hcal/");
00031 if (prefixME_.substr(prefixME_.size()-1,prefixME_.size())!="/")
00032 prefixME_.append("/");
00033 subdir_ = ps.getUntrackedParameter<std::string>("TrigPrimFolder","TrigPrimMonitor_Hcal/");
00034 if (subdir_.size()>0 && subdir_.substr(subdir_.size()-1,subdir_.size())!="/")
00035 subdir_.append("/");
00036 subdir_=prefixME_+subdir_;
00037
00038 validHtmlOutput_ = ps.getUntrackedParameter<bool>("TrigPrim_validHtmlOutput",true);
00039 cloneME_ = ps.getUntrackedParameter<bool>("cloneME", true);
00040 badChannelStatusMask_ = ps.getUntrackedParameter<int>("TrigPrim_BadChannelStatusMask",
00041 ps.getUntrackedParameter<int>("BadChannelStatusMask",0));
00042
00043 minerrorrate_ = ps.getUntrackedParameter<double>("TrigPrim_minerrorrate",
00044 ps.getUntrackedParameter<double>("minerrorrate",0.01));
00045 minevents_ = ps.getUntrackedParameter<int>("TrigPrim_minevents",
00046 ps.getUntrackedParameter<int>("minevents",1));
00047 Online_ = ps.getUntrackedParameter<bool>("online",false);
00048
00049 ProblemCells=0;
00050 ProblemCellsByDepth=0;
00051 }
00052
00053 void HcalTrigPrimClient::analyze()
00054 {
00055 if (debug_>2) std::cout <<"\tHcalTrigPrimClient::analyze()"<<std::endl;
00056 calculateProblems();
00057 }
00058
00059 void HcalTrigPrimClient::calculateProblems()
00060 {
00061 if (debug_>2) std::cout <<"\t\tHcalTrigPrimClient::calculateProblems()"<<std::endl;
00062 if(!dqmStore_) return;
00063 double totalevents=0;
00064 int etabins=0, phibins=0;
00065 double problemvalue=0;
00066 enoughevents_=false;
00067
00068
00069 if (ProblemCells!=0)
00070 {
00071 ProblemCells->Reset();
00072 (ProblemCells->getTH2F())->SetMaximum(1.05);
00073 (ProblemCells->getTH2F())->SetMinimum(0.);
00074 }
00075 for (unsigned int d=0;d<ProblemCellsByDepth->depth.size();++d)
00076 {
00077 if (ProblemCellsByDepth->depth[d]!=0)
00078 {
00079 ProblemCellsByDepth->depth[d]->Reset();
00080 (ProblemCellsByDepth->depth[d]->getTH2F())->SetMaximum(1.05);
00081 (ProblemCellsByDepth->depth[d]->getTH2F())->SetMinimum(0.);
00082 }
00083 }
00084
00085 for (unsigned int d=0;d<ProblemsByDepthZS_->depth.size();++d)
00086 {
00087 if (ProblemsByDepthZS_->depth[d]!=0)
00088 {
00089 ProblemsByDepthZS_->depth[d]->Reset();
00090 (ProblemsByDepthZS_->depth[d]->getTH2F())->SetMaximum(1.05);
00091 (ProblemsByDepthZS_->depth[d]->getTH2F())->SetMinimum(0.);
00092 }
00093 }
00094
00095 for (unsigned int d=0;d<ProblemsByDepthNZS_->depth.size();++d)
00096 {
00097 if (ProblemsByDepthNZS_->depth[d]!=0)
00098 {
00099 ProblemsByDepthNZS_->depth[d]->Reset();
00100 (ProblemsByDepthNZS_->depth[d]->getTH2F())->SetMaximum(1.05);
00101 (ProblemsByDepthNZS_->depth[d]->getTH2F())->SetMinimum(0.);
00102 }
00103 }
00104
00105
00106
00107
00108 std::vector<std::string> name = HcalEtaPhiHistNames();
00109
00110
00111
00112
00113 MonitorElement* me;
00114 TH2F *goodZS=0;
00115 TH2F *badZS=0;
00116 TH2F* goodNZS=0;
00117 TH2F* badNZS=0;
00118
00119 me=dqmStore_->get(subdir_+"Good TPs_ZS");
00120 if (!me && debug_>0)
00121 std::cout <<"<HcalTrigPrimClient::calculateProblems> Could not get histogram named '"<<subdir_<<"Good TPs_ZS'"<<std::endl;
00122 else goodZS = HcalUtilsClient::getHisto<TH2F*>(me, cloneME_, goodZS, debug_);
00123
00124 me=dqmStore_->get(subdir_+"Bad TPs_ZS");
00125 if (!me && debug_>0)
00126 std::cout <<"<HcalTrigPrimClient::calculateProblems> Could not get histogram named '"<<subdir_<<"Bad TPs_ZS'"<<std::endl;
00127 else badZS = HcalUtilsClient::getHisto<TH2F*>(me, cloneME_, badZS, debug_);
00128
00129 me=dqmStore_->get(subdir_+"noZS/Good TPs_noZS");
00130 if (!me && debug_>0)
00131 std::cout <<"<HcalTrigPrimClient::calculateProblems> Could not get histogram named '"<<subdir_<<"noZS/Good TPs_noZS'"<<std::endl;
00132 else goodNZS = HcalUtilsClient::getHisto<TH2F*>(me, cloneME_, goodNZS, debug_);
00133
00134 me=dqmStore_->get(subdir_+"noZS/Bad TPs_noZS");
00135 if (!me && debug_>0)
00136 std::cout <<"<HcalTrigPrimClient::calculateProblems> Could not get histogram named '"<<subdir_<<"noZS/Bad TPs_noZS'"<<std::endl;
00137 else badNZS = HcalUtilsClient::getHisto<TH2F*>(me, cloneME_, badNZS, debug_);
00138
00139
00140 if (goodZS!=0)
00141 {
00142 etabins=goodZS->GetNbinsX();
00143 phibins=goodZS->GetNbinsY();
00144 totalevents=goodNZS->GetBinContent(0);
00145 }
00146 else if (goodNZS!=0)
00147 {
00148 etabins=goodNZS->GetNbinsX();
00149 phibins=goodNZS->GetNbinsY();
00150 totalevents=goodNZS->GetBinContent(0);
00151 }
00152
00153 if (totalevents<minevents_)
00154 {
00155 enoughevents_=false;
00156 if (debug_>2) std::cout <<"<HcalTrigPrimClient::calculateProblems()> Not enough events! events = "<<totalevents<<" minimum required = "<<minevents_<<std::endl;
00157 return;
00158 }
00159 enoughevents_=true;
00160
00161
00162
00163 int ieta=-99, iphi=-99;
00164 int badvalZS=0, goodvalZS=0;
00165 int badvalNZS=0, goodvalNZS=0;
00166 for (int eta=1;eta<=etabins;++eta)
00167 {
00168 ieta=eta-33;
00169 for (int phi=1;phi<=phibins;++phi)
00170 {
00171 badvalZS=0, goodvalZS=0;
00172 badvalNZS=0, goodvalNZS=0;
00173 iphi=phi;
00174 if (badZS!=0) badvalZS=(int)badZS->GetBinContent(eta,phi);
00175 if (badNZS!=0) badvalNZS=(int)badNZS->GetBinContent(eta,phi);
00176 if (badvalZS+badvalNZS==0) continue;
00177 if (goodZS!=0) goodvalZS=(int)goodZS->GetBinContent(eta,phi);
00178 if (goodNZS!=0) goodvalNZS=(int)goodNZS->GetBinContent(eta,phi);
00179
00180 if (badvalNZS>0)
00181 {
00182 problemvalue=badvalNZS*1./(badvalNZS+goodvalNZS);
00183 if (abs(ieta)<29)
00184 {
00185 ProblemsByDepthNZS_->depth[0]->Fill(ieta,iphi,problemvalue);
00186 if (abs(ieta)==28)
00187 ProblemsByDepthNZS_->depth[0]->Fill(ieta+abs(ieta)/ieta,iphi,problemvalue);
00188 }
00189 else
00190 {
00191
00192
00193
00194
00195
00196
00197
00198 int newieta=-99;
00199 for (int i=0;i<3;++i)
00200 {
00201 newieta=i+29+3*(abs(ieta)-29)+1;
00202 if (ieta<0) newieta*=-1;
00203 ProblemsByDepthNZS_->depth[0]->Fill(newieta,iphi,problemvalue);
00204 ProblemsByDepthNZS_->depth[0]->Fill(newieta,(iphi-2+72)%72,problemvalue);
00205 }
00206 if (abs(ieta)==32)
00207 {
00208 ProblemsByDepthNZS_->depth[0]->Fill(42*abs(ieta)/ieta,iphi,problemvalue);
00209 ProblemsByDepthNZS_->depth[0]->Fill(newieta,(iphi-2+72)%72,problemvalue);
00210 }
00211 }
00212 }
00213 if (badvalZS>0)
00214 {
00215 problemvalue=badvalZS*1./(badvalZS+goodvalZS);
00216 if (abs(ieta)<29)
00217 {
00218 ProblemsByDepthZS_->depth[0]->Fill(ieta,iphi,problemvalue);
00219 if (abs(ieta)==28)
00220 ProblemsByDepthZS_->depth[0]->Fill(ieta+abs(ieta)/ieta,iphi,problemvalue);
00221 }
00222 else
00223 {
00224 int newieta=-99;
00225 for (int i=0;i<3;++i)
00226 {
00227 newieta=i+29+3*(abs(ieta)-29)+1;
00228 if (ieta<0) newieta*=-1;
00229 ProblemsByDepthZS_->depth[0]->Fill(newieta,iphi,problemvalue);
00230 ProblemsByDepthZS_->depth[0]->Fill(newieta,(iphi-2+72)%72,problemvalue);
00231 }
00232 if (abs(ieta)==32)
00233 {
00234 ProblemsByDepthZS_->depth[0]->Fill(42*abs(ieta)/ieta,iphi,problemvalue);
00235 ProblemsByDepthZS_->depth[0]->Fill(42*abs(ieta)/ieta,(iphi-2+72)%72,problemvalue);
00236 }
00237 }
00238 }
00239 if (badvalZS>0 || badvalNZS>0)
00240 {
00241
00242
00243
00244
00245 if (badvalZS==0) continue;
00246 problemvalue=(badvalZS*1.)/(badvalZS+goodvalZS);
00247 if (abs(ieta)<29)
00248 {
00249 ProblemCellsByDepth->depth[0]->Fill(ieta,iphi,problemvalue);
00250 ProblemCells->Fill(ieta,iphi,problemvalue);
00251 if (abs(ieta)==28)
00252 {
00253 ProblemCellsByDepth->depth[0]->Fill(ieta+abs(ieta)/ieta,iphi,problemvalue);
00254 ProblemCells->Fill(ieta+abs(ieta)/ieta,iphi,problemvalue);
00255 }
00256 }
00257 else
00258 {
00259 int newieta=-99;
00260 int newiphi=(iphi-2+72)%72;
00261
00262
00263
00264 for (int i=0;i<3;++i)
00265 {
00266 newieta=i+29+3*(abs(ieta)-29)+1;
00267 if (ieta<0) newieta*=-1;
00268 ProblemCellsByDepth->depth[0]->Fill(newieta,iphi,problemvalue);
00269 ProblemCells->Fill(newieta,iphi,problemvalue);
00270 ProblemCellsByDepth->depth[0]->Fill(newieta,newiphi,problemvalue);
00271 ProblemCells->Fill(newieta,newiphi,problemvalue);
00272 }
00273 if (abs(ieta)==32)
00274 {
00275 ProblemCellsByDepth->depth[0]->Fill(42*abs(ieta)/ieta,iphi,problemvalue);
00276 ProblemCells->Fill(42*abs(ieta)/ieta,iphi,problemvalue);
00277 ProblemCellsByDepth->depth[0]->Fill(42*abs(ieta)/ieta,newiphi,problemvalue);
00278 ProblemCells->Fill(42*abs(ieta)/ieta,newiphi,problemvalue);
00279 }
00280 }
00281 }
00282 }
00283 }
00284
00285
00286 if (ProblemCells==0)
00287 {
00288 if (debug_>0) std::cout <<"<HcalTrigPrimClient::analyze> ProblemCells histogram does not exist!"<<std::endl;
00289 return;
00290 }
00291
00292
00293 etabins=(ProblemCells->getTH2F())->GetNbinsX();
00294 phibins=(ProblemCells->getTH2F())->GetNbinsY();
00295 for (int eta=0;eta<etabins;++eta)
00296 {
00297 for (int phi=0;phi<phibins;++phi)
00298 {
00299 if (ProblemCells->getBinContent(eta+1,phi+1)>1. && ProblemCells->getBinContent(eta+1,phi+1)<999)
00300 ProblemCells->setBinContent(eta+1,phi+1,1.);
00301 }
00302 }
00303
00304 FillUnphysicalHEHFBins(*ProblemCellsByDepth);
00305 FillUnphysicalHEHFBins(*ProblemsByDepthZS_);
00306 FillUnphysicalHEHFBins(*ProblemsByDepthNZS_);
00307 FillUnphysicalHEHFBins(ProblemCells);
00308 return;
00309 }
00310
00311 void HcalTrigPrimClient::beginJob()
00312 {
00313 dqmStore_ = edm::Service<DQMStore>().operator->();
00314 if (debug_>0)
00315 {
00316 std::cout <<"<HcalTrigPrimClient::beginJob()> Displaying dqmStore directory structure:"<<std::endl;
00317 dqmStore_->showDirStructure();
00318 }
00319 }
00320 void HcalTrigPrimClient::endJob(){}
00321
00322 void HcalTrigPrimClient::beginRun(void)
00323 {
00324 enoughevents_=false;
00325 if (!dqmStore_)
00326 {
00327 if (debug_>0) std::cout <<"<HcalTrigPrimClient::beginRun> dqmStore does not exist!"<<std::endl;
00328 return;
00329 }
00330 dqmStore_->setCurrentFolder(subdir_);
00331 problemnames_.clear();
00332
00333
00334 ProblemCells=dqmStore_->book2D(" ProblemTriggerPrimitives",
00335 " Problem Trigger Primitive Rate for all HCAL;ieta;iphi",
00336 85,-42.5,42.5,
00337 72,0.5,72.5);
00338 problemnames_.push_back(ProblemCells->getName());
00339 if (debug_>1)
00340 std::cout << "Tried to create ProblemCells Monitor Element in directory "<<subdir_<<" \t Failed? "<<(ProblemCells==0)<<std::endl;
00341 dqmStore_->setCurrentFolder(subdir_+"problem_triggerprimitives");
00342 ProblemCellsByDepth = new EtaPhiHists();
00343 ProblemCellsByDepth->setup(dqmStore_," Problem Trigger Primitive Rate");
00344 for (unsigned int i=0; i<ProblemCellsByDepth->depth.size();++i)
00345 problemnames_.push_back(ProblemCellsByDepth->depth[i]->getName());
00346 nevts_=0;
00347
00348 dqmStore_->setCurrentFolder(subdir_+"problem_ZS");
00349 ProblemsByDepthZS_ = new EtaPhiHists();
00350 ProblemsByDepthZS_->setup(dqmStore_,"ZS Problem Trigger Primitive Rate");
00351 dqmStore_->setCurrentFolder(subdir_+"problem_NZS");
00352 ProblemsByDepthNZS_ = new EtaPhiHists();
00353 ProblemsByDepthNZS_->setup(dqmStore_,"NZS Problem Trigger Primitive Rate");
00354 }
00355
00356 void HcalTrigPrimClient::endRun(void){analyze();}
00357
00358 void HcalTrigPrimClient::setup(void){}
00359 void HcalTrigPrimClient::cleanup(void){}
00360
00361 bool HcalTrigPrimClient::hasErrors_Temp(void)
00362 {
00363 if (!ProblemCells)
00364 {
00365 if (debug_>1) std::cout <<"<HcalTrigPrimClient::hasErrors_Temp> ProblemCells histogram does not exist!"<<std::endl;
00366 return false;
00367 }
00368 int problemcount=0;
00369 int ieta=-9999;
00370
00371 for (int depth=0;depth<4; ++depth)
00372 {
00373 int etabins = (ProblemCells->getTH2F())->GetNbinsX();
00374 int phibins = (ProblemCells->getTH2F())->GetNbinsY();
00375 for (int hist_eta=0;hist_eta<etabins;++hist_eta)
00376 {
00377 for (int hist_phi=0; hist_phi<phibins;++hist_phi)
00378 {
00379 ieta=CalcIeta(hist_eta,depth+1);
00380 if (ieta==-9999) continue;
00381 if (ProblemCellsByDepth->depth[depth]==0)
00382 continue;
00383 if (ProblemCellsByDepth->depth[depth]->getBinContent(hist_eta,hist_phi)>minerrorrate_)
00384 ++problemcount;
00385
00386 }
00387 }
00388 }
00389
00390 if (problemcount>0) return true;
00391 return false;
00392 }
00393
00394 bool HcalTrigPrimClient::hasWarnings_Temp(void){return false;}
00395 bool HcalTrigPrimClient::hasOther_Temp(void){return false;}
00396 bool HcalTrigPrimClient::test_enabled(void){return true;}
00397
00398
00399 void HcalTrigPrimClient::updateChannelStatus(std::map<HcalDetId, unsigned int>& myqual)
00400 {
00401
00402
00403
00404
00405 }
00406
00407