#include <ESSummaryClient.h>
Public Member Functions | |
void | analyze (void) |
Analyze. | |
void | beginJob (DQMStore *dqmStore) |
BeginJob. | |
void | beginRun (void) |
BeginRun. | |
void | cleanup (void) |
Cleanup. | |
void | endJob (void) |
EndJob. | |
void | endLumiAnalyze () |
EndLumiAnalyze. | |
void | endRun (void) |
EndRun. | |
ESSummaryClient (const edm::ParameterSet &ps) | |
Constructor. | |
int | getEvtPerJob () |
Get Functions. | |
int | getEvtPerRun () |
void | setFriends (std::vector< ESClient * > clients) |
Set Clients. | |
void | setup (void) |
Setup. | |
void | softReset (bool flag) |
SoftReset. | |
virtual | ~ESSummaryClient () |
Destructor. | |
Private Attributes | |
std::vector< ESClient * > | clients_ |
bool | cloneME_ |
bool | debug_ |
DQMStore * | dqmStore_ |
bool | enableCleanup_ |
int | ievt_ |
int | jevt_ |
std::string | prefixME_ |
bool | verbose_ |
Definition at line 14 of file ESSummaryClient.h.
ESSummaryClient::ESSummaryClient | ( | const edm::ParameterSet & | ps | ) |
Constructor.
Definition at line 14 of file ESSummaryClient.cc.
References edm::ParameterSet::getUntrackedParameter().
{ cloneME_ = ps.getUntrackedParameter<bool>("cloneME", true); verbose_ = ps.getUntrackedParameter<bool>("verbose", true); debug_ = ps.getUntrackedParameter<bool>("debug", false); prefixME_ = ps.getUntrackedParameter<string>("prefixME", ""); enableCleanup_ = ps.getUntrackedParameter<bool>("enableCleanup", false); }
ESSummaryClient::~ESSummaryClient | ( | ) | [virtual] |
void ESSummaryClient::analyze | ( | void | ) | [virtual] |
Analyze.
Implements ESClient.
Definition at line 120 of file ESSummaryClient.cc.
References MonitorElement::Fill(), MonitorElement::getBinContent(), timingPdfMaker::histo, i, j, AlCaHLTBitMon_ParallelJobs::p, MonitorElement::setBinContent(), x, detailsBasic3DVector::y, and z.
{ char histo[200]; float nDI_FedErr[80][80]; float DCC[80][80]; float eCount; MonitorElement* me; for (int i=0; i<80; ++i) for (int j=0; j<80; ++j) { nDI_FedErr[i][j] = -1; DCC[i][j]=0; } for (int i=0; i<2; ++i) { for (int j=0; j<2; ++j) { int iz = (i==0)? 1:-1; sprintf(histo, "ES Integrity Errors Z %d P %d", iz, j+1); me = dqmStore_->get(prefixME_ + "/ESIntegrityTask/" + histo); if (me) for (int x=0; x<40; ++x) for (int y=0; y<40; ++y) nDI_FedErr[i*40+x][(1-j)*40+y] = me->getBinContent(x+1, y+1); sprintf(histo, "ES Integrity Summary 1 Z %d P %d", iz, j+1); me = dqmStore_->get(prefixME_ + "/ESIntegrityClient/" + histo); if (me) for (int x=0; x<40; ++x) for (int y=0; y<40; ++y) DCC[i*40+x][(1-j)*40+y] = me->getBinContent(x+1, y+1); sprintf(histo, "ES RecHit 2D Occupancy Z %d P %d", iz, j+1); me = dqmStore_->get(prefixME_ + "/ESOccupancyTask/" + histo); if (me) eCount = me->getBinContent(40,40); else eCount = 1.; } } //The global-summary //ReportSummary Map // ES+F ES-F // ES+R ES-R float nValidChannels=0; float nGlobalErrors=0; float nValidChannelsES[2][2]={}; float nGlobalErrorsES[2][2]={}; me = dqmStore_->get(prefixME_ + "/EventInfo/reportSummaryMap"); if (me) { for (int x=0; x<80; ++x) { if (eCount < 1) break; //Fill reportSummaryMap after have 1 event for (int y=0; y<80; ++y) { int z = (x<40) ? 0:1; int p = (y>=40) ? 0:1; if (DCC[x][y]==0.) { me->setBinContent(x+1, y+1, -1.); } else { if (nDI_FedErr[x][y] >= 0) { me->setBinContent(x+1, y+1, 1-(nDI_FedErr[x][y]/eCount)); nValidChannels++; nGlobalErrors += nDI_FedErr[x][y]/eCount; nValidChannelsES[z][p]++; nGlobalErrorsES[z][p] += nDI_FedErr[x][y]/eCount; } else { me->setBinContent(x+1, y+1, -1.); } } } } } for (int i=0; i<2; ++i) { for (int j=0; j<2; ++j) { int iz = (i==0)? 1:-1; float reportSummaryES = -1.; if (nValidChannelsES[i][j] != 0) reportSummaryES = 1.0 - nGlobalErrorsES[i][j]/nValidChannelsES[i][j]; sprintf(histo, "EcalPreshower Z %d P %d", iz, j+1); me = dqmStore_->get(prefixME_ + "/EventInfo/reportSummaryContents/" + histo); if ( me ) me->Fill(reportSummaryES); } } //Return ratio of good channels float reportSummary = -1.0; if ( nValidChannels != 0 ) reportSummary = 1.0 - nGlobalErrors/nValidChannels; me = dqmStore_->get(prefixME_ + "/EventInfo/reportSummary"); if ( me ) me->Fill(reportSummary); }
void ESSummaryClient::beginJob | ( | DQMStore * | dqmStore | ) | [virtual] |
BeginJob.
Implements ESClient.
Definition at line 27 of file ESSummaryClient.cc.
References gather_cfg::cout, MonitorElement::Fill(), MonitorElement::getName(), timingPdfMaker::histo, i, j, MonitorElement::setAxisTitle(), and MonitorElement::setBinContent().
{ dqmStore_ = dqmStore; if ( debug_ ) cout << "ESSummaryClient: beginJob" << endl; ievt_ = 0; jevt_ = 0; char histo[200]; MonitorElement* me; dqmStore_->setCurrentFolder( prefixME_ + "/EventInfo" ); sprintf(histo, "reportSummary"); me = dqmStore_->get(prefixME_ + "/EventInfo/" + histo); if ( me ) { dqmStore_->removeElement(me->getName()); } me = dqmStore_->bookFloat(histo); me->Fill(-1.0); dqmStore_->setCurrentFolder( prefixME_ + "/EventInfo/reportSummaryContents" ); for (int i=0 ; i<2; ++i){ for (int j=0 ; j<2; ++j){ int iz = (i==0)? 1:-1; sprintf(histo, "EcalPreshower Z %d P %d", iz, j+1); me = dqmStore_->get(prefixME_ + "/EventInfo/reportSummaryContents/" + histo); if(me){ dqmStore_->removeElement(me->getName()); } me = dqmStore_->bookFloat(histo); me->Fill(-1.0); } } dqmStore_->setCurrentFolder( prefixME_ + "/EventInfo" ); sprintf(histo, "reportSummaryMap"); me = dqmStore_->get(prefixME_ + "/EventInfo/" + histo); if ( me ) { dqmStore_->removeElement(me->getName()); } me = dqmStore_->book2D(histo, histo, 80, 0.5, 80.5, 80, 0.5, 80.5); me->setAxisTitle("Si X", 1); me->setAxisTitle("Si Y", 2); for ( int i = 0; i < 80; i++ ) { for ( int j = 0; j < 80; j++ ) { me->setBinContent( i+1, j+1, -1. ); } } }
void ESSummaryClient::beginRun | ( | void | ) | [virtual] |
BeginRun.
Implements ESClient.
Definition at line 84 of file ESSummaryClient.cc.
References gather_cfg::cout, and HcalObjRepresent::setup().
void ESSummaryClient::cleanup | ( | void | ) | [virtual] |
Cleanup.
Implements ESClient.
Definition at line 114 of file ESSummaryClient.cc.
{ if ( ! enableCleanup_ ) return; }
void ESSummaryClient::endJob | ( | void | ) | [virtual] |
EndJob.
Implements ESClient.
Definition at line 94 of file ESSummaryClient.cc.
References edm::cleanup(), and gather_cfg::cout.
void ESSummaryClient::endLumiAnalyze | ( | void | ) | [virtual] |
EndLumiAnalyze.
Implements ESClient.
Definition at line 228 of file ESSummaryClient.cc.
References MonitorElement::Fill(), MonitorElement::getBinContent(), timingPdfMaker::histo, i, and j.
{ char histo[200]; MonitorElement* me = 0; MonitorElement* me_report = 0; sprintf(histo, "ES Good Channel Fraction"); me = dqmStore_->get(prefixME_+"/ESIntegrityTask/"+histo); if (!me) return; for (int i=0; i<2; ++i) { for (int j=0; j<2; ++j) { int iz = (i==0)? 1:-1; sprintf(histo, "EcalPreshower Z %d P %d", iz, j+1); me_report = dqmStore_->get(prefixME_+"/EventInfo/reportSummaryContents/" + histo); if (me_report) { me_report->Fill(me->getBinContent(i+1, j+1)); } } } me_report = dqmStore_->get(prefixME_ + "/EventInfo/reportSummary"); if ( me_report ) me_report->Fill(me->getBinContent(3,3)); }
void ESSummaryClient::endRun | ( | void | ) | [virtual] |
EndRun.
Implements ESClient.
Definition at line 102 of file ESSummaryClient.cc.
References edm::cleanup(), and gather_cfg::cout.
int ESSummaryClient::getEvtPerJob | ( | void | ) | [inline] |
int ESSummaryClient::getEvtPerRun | ( | void | ) | [inline] |
void ESSummaryClient::setFriends | ( | std::vector< ESClient * > | clients | ) | [inline] |
Set Clients.
Definition at line 53 of file ESSummaryClient.h.
References clients_.
{ clients_ = clients; }
void ESSummaryClient::setup | ( | void | ) | [virtual] |
void ESSummaryClient::softReset | ( | bool | flag | ) |
std::vector<ESClient*> ESSummaryClient::clients_ [private] |
Definition at line 70 of file ESSummaryClient.h.
Referenced by setFriends().
bool ESSummaryClient::cloneME_ [private] |
Definition at line 63 of file ESSummaryClient.h.
bool ESSummaryClient::debug_ [private] |
Definition at line 65 of file ESSummaryClient.h.
DQMStore* ESSummaryClient::dqmStore_ [private] |
Definition at line 72 of file ESSummaryClient.h.
bool ESSummaryClient::enableCleanup_ [private] |
Definition at line 66 of file ESSummaryClient.h.
int ESSummaryClient::ievt_ [private] |
Definition at line 60 of file ESSummaryClient.h.
Referenced by getEvtPerJob().
int ESSummaryClient::jevt_ [private] |
Definition at line 61 of file ESSummaryClient.h.
Referenced by getEvtPerRun().
std::string ESSummaryClient::prefixME_ [private] |
Definition at line 68 of file ESSummaryClient.h.
bool ESSummaryClient::verbose_ [private] |
Definition at line 64 of file ESSummaryClient.h.