#include <EBTestPulseClient.h>
Public Member Functions | |
void | analyze (void) |
Analyze. | |
void | beginJob (void) |
BeginJob. | |
void | beginRun (void) |
BeginRun. | |
void | cleanup (void) |
Cleanup. | |
EBTestPulseClient (const edm::ParameterSet &ps) | |
Constructor. | |
void | endJob (void) |
EndJob. | |
void | endRun (void) |
EndRun. | |
int | getEvtPerJob () |
Get Functions. | |
int | getEvtPerRun () |
Returns the number of processed events in this Run. | |
void | setup (void) |
Setup. | |
virtual | ~EBTestPulseClient () |
Destructor. | |
Private Attributes | |
float | amplitudeThreshold_ |
float | amplitudeThresholdPnG01_ |
float | amplitudeThresholdPnG16_ |
bool | cloneME_ |
bool | debug_ |
DQMStore * | dqmStore_ |
bool | enableCleanup_ |
TProfile2D * | ha01_ [36] |
TProfile2D * | ha02_ [36] |
TProfile2D * | ha03_ [36] |
TProfile2D * | hs01_ [36] |
TProfile2D * | hs02_ [36] |
TProfile2D * | hs03_ [36] |
TProfile * | i01_ [36] |
TProfile * | i02_ [36] |
TProfile * | i03_ [36] |
TProfile * | i04_ [36] |
int | ievt_ |
int | jevt_ |
MonitorElement * | me_hs01_ [36] |
MonitorElement * | me_hs02_ [36] |
MonitorElement * | me_hs03_ [36] |
MonitorElement * | mea01_ [36] |
MonitorElement * | mea02_ [36] |
MonitorElement * | mea03_ [36] |
MonitorElement * | meg01_ [36] |
MonitorElement * | meg02_ [36] |
MonitorElement * | meg03_ [36] |
MonitorElement * | meg04_ [36] |
MonitorElement * | meg05_ [36] |
MonitorElement * | mer04_ [36] |
MonitorElement * | mer05_ [36] |
std::vector< int > | MGPAGains_ |
std::vector< int > | MGPAGainsPN_ |
float | pedPnDiscrepancyMean_ [2] |
float | pedPnExpectedMean_ [2] |
float | pedPnRMSThreshold_ [2] |
float | percentVariation_ |
std::string | prefixME_ |
float | RMSThreshold_ |
std::vector< int > | superModules_ |
bool | verbose_ |
Friends | |
class | EBSummaryClient |
Definition at line 33 of file EBTestPulseClient.h.
EBTestPulseClient::EBTestPulseClient | ( | const edm::ParameterSet & | ps | ) |
Constructor.
Definition at line 40 of file EBTestPulseClient.cc.
References amplitudeThreshold_, amplitudeThresholdPnG01_, amplitudeThresholdPnG16_, cloneME_, debug_, enableCleanup_, edm::ParameterSet::getUntrackedParameter(), ha01_, ha02_, ha03_, hs01_, hs02_, hs03_, i, i01_, i02_, i03_, i04_, ecalpyutils::ism(), me_hs01_, me_hs02_, me_hs03_, mea01_, mea02_, mea03_, meg01_, meg02_, meg03_, meg04_, meg05_, mer04_, mer05_, MGPAGains_, MGPAGainsPN_, pedPnDiscrepancyMean_, pedPnExpectedMean_, pedPnRMSThreshold_, percentVariation_, prefixME_, RMSThreshold_, superModules_, and verbose_.
{ // cloneME switch cloneME_ = ps.getUntrackedParameter<bool>("cloneME", true); // verbose switch verbose_ = ps.getUntrackedParameter<bool>("verbose", true); // debug switch debug_ = ps.getUntrackedParameter<bool>("debug", false); // prefixME path prefixME_ = ps.getUntrackedParameter<std::string>("prefixME", ""); // enableCleanup_ switch enableCleanup_ = ps.getUntrackedParameter<bool>("enableCleanup", false); // vector of selected Super Modules (Defaults to all 36). superModules_.reserve(36); for ( unsigned int i = 1; i <= 36; i++ ) superModules_.push_back(i); superModules_ = ps.getUntrackedParameter<std::vector<int> >("superModules", superModules_); MGPAGains_.reserve(3); for ( unsigned int i = 1; i <= 3; i++ ) MGPAGains_.push_back(i); MGPAGains_ = ps.getUntrackedParameter<std::vector<int> >("MGPAGains", MGPAGains_); MGPAGainsPN_.reserve(2); for ( unsigned int i = 1; i <= 3; i++ ) MGPAGainsPN_.push_back(i); MGPAGainsPN_ = ps.getUntrackedParameter<std::vector<int> >("MGPAGainsPN", MGPAGainsPN_); for ( unsigned int i=0; i<superModules_.size(); i++ ) { int ism = superModules_[i]; ha01_[ism-1] = 0; ha02_[ism-1] = 0; ha03_[ism-1] = 0; hs01_[ism-1] = 0; hs02_[ism-1] = 0; hs03_[ism-1] = 0; i01_[ism-1] = 0; i02_[ism-1] = 0; i03_[ism-1] = 0; i04_[ism-1] = 0; } for ( unsigned int i=0; i<superModules_.size(); i++ ) { int ism = superModules_[i]; meg01_[ism-1] = 0; meg02_[ism-1] = 0; meg03_[ism-1] = 0; meg04_[ism-1] = 0; meg05_[ism-1] = 0; mea01_[ism-1] = 0; mea02_[ism-1] = 0; mea03_[ism-1] = 0; mer04_[ism-1] = 0; mer05_[ism-1] = 0; me_hs01_[ism-1] = 0; me_hs02_[ism-1] = 0; me_hs03_[ism-1] = 0; } percentVariation_ = 0.2; RMSThreshold_ = 300.0; amplitudeThreshold_ = 100.; amplitudeThresholdPnG01_ = 200./16.; amplitudeThresholdPnG16_ = 200.; pedPnExpectedMean_[0] = 750.0; pedPnExpectedMean_[1] = 750.0; pedPnDiscrepancyMean_[0] = 100.0; pedPnDiscrepancyMean_[1] = 100.0; pedPnRMSThreshold_[0] = 999.; pedPnRMSThreshold_[1] = 999.; }
EBTestPulseClient::~EBTestPulseClient | ( | ) | [virtual] |
void EBTestPulseClient::analyze | ( | void | ) | [virtual] |
Analyze.
Implements EBClient.
Definition at line 666 of file EBTestPulseClient.cc.
References abs, amplitudeThreshold_, amplitudeThresholdPnG01_, amplitudeThresholdPnG16_, cloneME_, gather_cfg::cout, debug_, dqmStore_, EcalBarrel, MonitorElement::Fill(), spr::find(), DQMStore::get(), UtilsClient::getBinStatistics(), UtilsClient::getFirstNonEmptyChannel(), getHisto(), ha01_, ha02_, ha03_, hs01_, hs02_, hs03_, i, i01_, i02_, i03_, i04_, Numbers::icEB(), ievt_, jevt_, UtilsClient::maskBinContent(), Masks::maskChannel(), Masks::maskPn(), me_hs01_, me_hs02_, me_hs03_, mea01_, mea02_, mea03_, meg01_, meg02_, meg03_, meg04_, meg05_, mer04_, mer05_, MGPAGains_, MGPAGainsPN_, EcalDQMStatusHelper::PEDESTAL_HIGH_GAIN_MEAN_ERROR, EcalDQMStatusHelper::PEDESTAL_HIGH_GAIN_RMS_ERROR, EcalDQMStatusHelper::PEDESTAL_LOW_GAIN_MEAN_ERROR, EcalDQMStatusHelper::PEDESTAL_LOW_GAIN_RMS_ERROR, pedPnDiscrepancyMean_, pedPnExpectedMean_, pedPnRMSThreshold_, percentVariation_, prefixME_, MonitorElement::Reset(), RMSThreshold_, Numbers::sEB(), MonitorElement::setBinContent(), MonitorElement::setBinError(), MonitorElement::setEntries(), superModules_, EcalDQMStatusHelper::TESTPULSE_HIGH_GAIN_MEAN_ERROR, EcalDQMStatusHelper::TESTPULSE_HIGH_GAIN_RMS_ERROR, EcalDQMStatusHelper::TESTPULSE_LOW_GAIN_MEAN_ERROR, EcalDQMStatusHelper::TESTPULSE_LOW_GAIN_RMS_ERROR, EcalDQMStatusHelper::TESTPULSE_MIDDLE_GAIN_MEAN_ERROR, and EcalDQMStatusHelper::TESTPULSE_MIDDLE_GAIN_RMS_ERROR.
{ ievt_++; jevt_++; if ( ievt_ % 10 == 0 ) { if ( debug_ ) std::cout << "EBTestPulseClient: ievt/jevt = " << ievt_ << "/" << jevt_ << std::endl; } uint32_t bits01 = 0; bits01 |= 1 << EcalDQMStatusHelper::TESTPULSE_LOW_GAIN_MEAN_ERROR; bits01 |= 1 << EcalDQMStatusHelper::TESTPULSE_LOW_GAIN_RMS_ERROR; uint32_t bits02 = 0; bits02 |= 1 << EcalDQMStatusHelper::TESTPULSE_MIDDLE_GAIN_MEAN_ERROR; bits02 |= 1 << EcalDQMStatusHelper::TESTPULSE_MIDDLE_GAIN_RMS_ERROR; uint32_t bits03 = 0; bits03 |= 1 << EcalDQMStatusHelper::TESTPULSE_HIGH_GAIN_MEAN_ERROR; bits03 |= 1 << EcalDQMStatusHelper::TESTPULSE_HIGH_GAIN_RMS_ERROR; uint32_t bits04 = 0; bits04 |= 1 << EcalDQMStatusHelper::PEDESTAL_LOW_GAIN_MEAN_ERROR; bits04 |= 1 << EcalDQMStatusHelper::PEDESTAL_LOW_GAIN_RMS_ERROR; uint32_t bits05 = 0; bits05 |= 1 << EcalDQMStatusHelper::PEDESTAL_HIGH_GAIN_MEAN_ERROR; bits05 |= 1 << EcalDQMStatusHelper::PEDESTAL_HIGH_GAIN_RMS_ERROR; MonitorElement* me; for ( unsigned int i=0; i<superModules_.size(); i++ ) { int ism = superModules_[i]; if (find(MGPAGains_.begin(), MGPAGains_.end(), 1) != MGPAGains_.end() ) { me = dqmStore_->get( prefixME_ + "/EBTestPulseTask/Gain01/EBTPT amplitude " + Numbers::sEB(ism) + " G01" ); ha01_[ism-1] = UtilsClient::getHisto( me, cloneME_, ha01_[ism-1] ); } if (find(MGPAGains_.begin(), MGPAGains_.end(), 6) != MGPAGains_.end() ) { me = dqmStore_->get( prefixME_ + "/EBTestPulseTask/Gain06/EBTPT amplitude " + Numbers::sEB(ism) + " G06" ); ha02_[ism-1] = UtilsClient::getHisto( me, cloneME_, ha02_[ism-1] ); } if (find(MGPAGains_.begin(), MGPAGains_.end(), 12) != MGPAGains_.end() ) { me = dqmStore_->get( prefixME_ + "/EBTestPulseTask/Gain12/EBTPT amplitude " + Numbers::sEB(ism) + " G12" ); ha03_[ism-1] = UtilsClient::getHisto( me, cloneME_, ha03_[ism-1] ); } if (find(MGPAGains_.begin(), MGPAGains_.end(), 1) != MGPAGains_.end() ) { me = dqmStore_->get( prefixME_ + "/EBTestPulseTask/Gain01/EBTPT shape " + Numbers::sEB(ism) + " G01" ); hs01_[ism-1] = UtilsClient::getHisto( me, cloneME_, hs01_[ism-1] ); } if (find(MGPAGains_.begin(), MGPAGains_.end(), 6) != MGPAGains_.end() ) { me = dqmStore_->get( prefixME_ + "/EBTestPulseTask/Gain06/EBTPT shape " + Numbers::sEB(ism) + " G06" ); hs02_[ism-1] = UtilsClient::getHisto( me, cloneME_, hs02_[ism-1] ); } if (find(MGPAGains_.begin(), MGPAGains_.end(), 12) != MGPAGains_.end() ) { me = dqmStore_->get( prefixME_ + "/EBTestPulseTask/Gain12/EBTPT shape " + Numbers::sEB(ism) + " G12" ); hs03_[ism-1] = UtilsClient::getHisto( me, cloneME_, hs03_[ism-1] ); } if (find(MGPAGainsPN_.begin(), MGPAGainsPN_.end(), 1) != MGPAGainsPN_.end() ) { me = dqmStore_->get( prefixME_ + "/EBTestPulseTask/PN/Gain01/EBTPT PNs amplitude " + Numbers::sEB(ism) + " G01" ); i01_[ism-1] = UtilsClient::getHisto( me, cloneME_, i01_[ism-1] ); } if (find(MGPAGainsPN_.begin(), MGPAGainsPN_.end(), 16) != MGPAGainsPN_.end() ) { me = dqmStore_->get( prefixME_ + "/EBTestPulseTask/PN/Gain16/EBTPT PNs amplitude " + Numbers::sEB(ism) + " G16" ); i02_[ism-1] = UtilsClient::getHisto( me, cloneME_, i02_[ism-1] ); } if (find(MGPAGainsPN_.begin(), MGPAGainsPN_.end(), 1) != MGPAGainsPN_.end() ) { me = dqmStore_->get( prefixME_ + "/EBTestPulseTask/PN/Gain01/EBTPT PNs pedestal " + Numbers::sEB(ism) + " G01" ); i03_[ism-1] = UtilsClient::getHisto( me, cloneME_, i03_[ism-1] ); } if (find(MGPAGainsPN_.begin(), MGPAGainsPN_.end(), 16) != MGPAGainsPN_.end() ) { me = dqmStore_->get( prefixME_ + "/EBTestPulseTask/PN/Gain16/EBTPT PNs pedestal " + Numbers::sEB(ism) + " G16" ); i04_[ism-1] = UtilsClient::getHisto( me, cloneME_, i04_[ism-1] ); } if ( meg01_[ism-1] ) meg01_[ism-1]->Reset(); if ( meg02_[ism-1] ) meg02_[ism-1]->Reset(); if ( meg03_[ism-1] ) meg03_[ism-1]->Reset(); if ( meg04_[ism-1] ) meg04_[ism-1]->Reset(); if ( meg05_[ism-1] ) meg05_[ism-1]->Reset(); if ( mea01_[ism-1] ) mea01_[ism-1]->Reset(); if ( mea02_[ism-1] ) mea02_[ism-1]->Reset(); if ( mea03_[ism-1] ) mea03_[ism-1]->Reset(); if ( mer04_[ism-1] ) mer04_[ism-1]->Reset(); if ( mer05_[ism-1] ) mer05_[ism-1]->Reset(); if ( me_hs01_[ism-1] ) me_hs01_[ism-1]->Reset(); if ( me_hs02_[ism-1] ) me_hs02_[ism-1]->Reset(); if ( me_hs03_[ism-1] ) me_hs03_[ism-1]->Reset(); float meanAmpl01, meanAmpl02, meanAmpl03; int nCry01, nCry02, nCry03; meanAmpl01 = meanAmpl02 = meanAmpl03 = 0.; nCry01 = nCry02 = nCry03 = 0; for ( int ie = 1; ie <= 85; ie++ ) { for ( int ip = 1; ip <= 20; ip++ ) { bool update01; bool update02; bool update03; float num01, num02, num03; float mean01, mean02, mean03; float rms01, rms02, rms03; update01 = UtilsClient::getBinStatistics(ha01_[ism-1], ie, ip, num01, mean01, rms01); update02 = UtilsClient::getBinStatistics(ha02_[ism-1], ie, ip, num02, mean02, rms02); update03 = UtilsClient::getBinStatistics(ha03_[ism-1], ie, ip, num03, mean03, rms03); if ( update01 ) { meanAmpl01 += mean01; nCry01++; } if ( update02 ) { meanAmpl02 += mean02; nCry02++; } if ( update03 ) { meanAmpl03 += mean03; nCry03++; } } } if ( nCry01 > 0 ) meanAmpl01 /= float (nCry01); if ( nCry02 > 0 ) meanAmpl02 /= float (nCry02); if ( nCry03 > 0 ) meanAmpl03 /= float (nCry03); for ( int ie = 1; ie <= 85; ie++ ) { for ( int ip = 1; ip <= 20; ip++ ) { if ( meg01_[ism-1] ) meg01_[ism-1]->setBinContent( ie, ip, 2. ); if ( meg02_[ism-1] ) meg02_[ism-1]->setBinContent( ie, ip, 2. ); if ( meg03_[ism-1] ) meg03_[ism-1]->setBinContent( ie, ip, 2. ); bool update01; bool update02; bool update03; float num01, num02, num03; float mean01, mean02, mean03; float rms01, rms02, rms03; update01 = UtilsClient::getBinStatistics(ha01_[ism-1], ie, ip, num01, mean01, rms01); update02 = UtilsClient::getBinStatistics(ha02_[ism-1], ie, ip, num02, mean02, rms02); update03 = UtilsClient::getBinStatistics(ha03_[ism-1], ie, ip, num03, mean03, rms03); if ( update01 ) { float val; val = 1.; if ( std::abs(mean01 - meanAmpl01) > std::abs(percentVariation_ * meanAmpl01) || mean01 < amplitudeThreshold_ ) val = 0.; if ( rms01 > RMSThreshold_ ) val = 0.; if ( meg01_[ism-1] ) meg01_[ism-1]->setBinContent( ie, ip, val ); int ic = Numbers::icEB(ism, ie, ip); if ( mea01_[ism-1] ) { if ( mean01 > 0. ) { mea01_[ism-1]->setBinContent( ic, mean01 ); mea01_[ism-1]->setBinError( ic, rms01 ); } else { mea01_[ism-1]->setEntries( 1.+mea01_[ism-1]->getEntries() ); } } } if ( update02 ) { float val; val = 1.; if ( std::abs(mean02 - meanAmpl02) > std::abs(percentVariation_ * meanAmpl02) || mean02 < amplitudeThreshold_ ) val = 0.; if ( rms02 > RMSThreshold_ ) val = 0.; if ( meg02_[ism-1] ) meg02_[ism-1]->setBinContent( ie, ip, val ); int ic = Numbers::icEB(ism, ie, ip); if ( mea02_[ism-1] ) { if ( mean02 > 0. ) { mea02_[ism-1]->setBinContent( ic, mean02 ); mea02_[ism-1]->setBinError( ic, rms02 ); } else { mea02_[ism-1]->setEntries( 1.+mea02_[ism-1]->getEntries() ); } } } if ( update03 ) { float val; val = 1.; if ( std::abs(mean03 - meanAmpl03) > std::abs(percentVariation_ * meanAmpl03) || mean03 < amplitudeThreshold_ ) val = 0.; if ( rms03 > RMSThreshold_ ) val = 0.; if ( meg03_[ism-1] ) meg03_[ism-1]->setBinContent( ie, ip, val ); int ic = Numbers::icEB(ism, ie, ip); if ( mea03_[ism-1] ) { if ( mean03 > 0. ) { mea03_[ism-1]->setBinContent( ic, mean03 ); mea03_[ism-1]->setBinError( ic, rms03 ); } else { mea03_[ism-1]->setEntries( 1.+mea03_[ism-1]->getEntries() ); } } } if ( Masks::maskChannel(ism, ie, ip, bits01, EcalBarrel) ) UtilsClient::maskBinContent( meg01_[ism-1], ie, ip ); if ( Masks::maskChannel(ism, ie, ip, bits02, EcalBarrel) ) UtilsClient::maskBinContent( meg02_[ism-1], ie, ip ); if ( Masks::maskChannel(ism, ie, ip, bits03, EcalBarrel) ) UtilsClient::maskBinContent( meg03_[ism-1], ie, ip ); } } for ( int i = 1; i <= 10; i++ ) { if ( meg04_[ism-1] ) meg04_[ism-1]->setBinContent( i, 1, 2. ); if ( meg05_[ism-1] ) meg05_[ism-1]->setBinContent( i, 1, 2. ); bool update01; bool update02; bool update03; bool update04; float num01, num02, num03, num04; float mean01, mean02, mean03, mean04; float rms01, rms02, rms03, rms04; update01 = UtilsClient::getBinStatistics(i01_[ism-1], i, 0, num01, mean01, rms01); update02 = UtilsClient::getBinStatistics(i02_[ism-1], i, 0, num02, mean02, rms02); update03 = UtilsClient::getBinStatistics(i03_[ism-1], i, 0, num03, mean03, rms03); update04 = UtilsClient::getBinStatistics(i04_[ism-1], i, 0, num04, mean04, rms04); if ( mer04_[ism-1] ) mer04_[ism-1]->Fill(rms03); if ( mer05_[ism-1] ) mer05_[ism-1]->Fill(rms04); if ( update01 && update03 ) { float val; val = 1.; if ( mean01 < amplitudeThresholdPnG01_ ) val = 0.; if ( mean03 < pedPnExpectedMean_[0] - pedPnDiscrepancyMean_[0] || pedPnExpectedMean_[0] + pedPnDiscrepancyMean_[0] < mean03) val = 0.; if ( rms03 > pedPnRMSThreshold_[0] ) val = 0.; if ( meg04_[ism-1] ) meg04_[ism-1]->setBinContent(i, 1, val); } if ( update02 && update04 ) { float val; val = 1.; if ( mean02 < amplitudeThresholdPnG16_ ) val = 0.; if ( mean04 < pedPnExpectedMean_[1] - pedPnDiscrepancyMean_[1] || pedPnExpectedMean_[1] + pedPnDiscrepancyMean_[1] < mean04) val = 0.; if ( rms04 > pedPnRMSThreshold_[1] ) val = 0.; if ( meg05_[ism-1] ) meg05_[ism-1]->setBinContent(i, 1, val); } if ( Masks::maskPn(ism, i, bits01|bits04, EcalBarrel) ) UtilsClient::maskBinContent( meg04_[ism-1], i, 1 ); if ( Masks::maskPn(ism, i, bits03|bits05, EcalBarrel) ) UtilsClient::maskBinContent( meg05_[ism-1], i, 1 ); } for ( int i = 1; i <= 10; i++ ) { if ( hs01_[ism-1] ) { int ic = UtilsClient::getFirstNonEmptyChannel( hs01_[ism-1] ); if ( me_hs01_[ism-1] ) { me_hs01_[ism-1]->setBinContent( i, hs01_[ism-1]->GetBinContent(ic, i) ); me_hs01_[ism-1]->setBinError( i, hs01_[ism-1]->GetBinError(ic, i) ); } } if ( hs02_[ism-1] ) { int ic = UtilsClient::getFirstNonEmptyChannel( hs02_[ism-1] ); if ( me_hs02_[ism-1] ) { me_hs02_[ism-1]->setBinContent( i, hs02_[ism-1]->GetBinContent(ic, i) ); me_hs02_[ism-1]->setBinError( i, hs02_[ism-1]->GetBinError(ic, i) ); } } if ( hs03_[ism-1] ) { int ic = UtilsClient::getFirstNonEmptyChannel( hs03_[ism-1] ); if ( me_hs03_[ism-1] ) { me_hs03_[ism-1]->setBinContent( i, hs03_[ism-1]->GetBinContent(ic, i) ); me_hs03_[ism-1]->setBinError( i, hs03_[ism-1]->GetBinError(ic, i) ); } } } } }
void EBTestPulseClient::beginJob | ( | void | ) | [virtual] |
BeginJob.
Implements EBClient.
Definition at line 136 of file EBTestPulseClient.cc.
References gather_cfg::cout, debug_, dqmStore_, ievt_, jevt_, and cmsCodeRules::cppFunctionSkipper::operator.
void EBTestPulseClient::beginRun | ( | void | ) | [virtual] |
void EBTestPulseClient::cleanup | ( | void | ) | [virtual] |
Cleanup.
Implements EBClient.
Definition at line 322 of file EBTestPulseClient.cc.
References cloneME_, dqmStore_, enableCleanup_, edm::getName(), ha01_, ha02_, ha03_, hs01_, hs02_, hs03_, i, i01_, i02_, i03_, i04_, ecalpyutils::ism(), me_hs01_, me_hs02_, me_hs03_, mea01_, mea02_, mea03_, meg01_, meg02_, meg03_, meg04_, meg05_, mer04_, mer05_, prefixME_, DQMStore::removeElement(), DQMStore::setCurrentFolder(), and superModules_.
Referenced by endJob(), and endRun().
{ if ( ! enableCleanup_ ) return; for ( unsigned int i=0; i<superModules_.size(); i++ ) { int ism = superModules_[i]; if ( cloneME_ ) { if ( ha01_[ism-1] ) delete ha01_[ism-1]; if ( ha02_[ism-1] ) delete ha02_[ism-1]; if ( ha03_[ism-1] ) delete ha03_[ism-1]; if ( hs01_[ism-1] ) delete hs01_[ism-1]; if ( hs02_[ism-1] ) delete hs02_[ism-1]; if ( hs03_[ism-1] ) delete hs03_[ism-1]; if ( i01_[ism-1] ) delete i01_[ism-1]; if ( i02_[ism-1] ) delete i02_[ism-1]; if ( i03_[ism-1] ) delete i03_[ism-1]; if ( i04_[ism-1] ) delete i04_[ism-1]; } ha01_[ism-1] = 0; ha02_[ism-1] = 0; ha03_[ism-1] = 0; hs01_[ism-1] = 0; hs02_[ism-1] = 0; hs03_[ism-1] = 0; i01_[ism-1] = 0; i02_[ism-1] = 0; i03_[ism-1] = 0; i04_[ism-1] = 0; } for ( unsigned int i=0; i<superModules_.size(); i++ ) { int ism = superModules_[i]; dqmStore_->setCurrentFolder( prefixME_ + "/EBTestPulseClient" ); if ( meg01_[ism-1] ) dqmStore_->removeElement( meg01_[ism-1]->getName() ); meg01_[ism-1] = 0; if ( meg02_[ism-1] ) dqmStore_->removeElement( meg02_[ism-1]->getName() ); meg02_[ism-1] = 0; if ( meg03_[ism-1] ) dqmStore_->removeElement( meg03_[ism-1]->getName() ); meg03_[ism-1] = 0; if ( meg04_[ism-1] ) dqmStore_->removeElement( meg04_[ism-1]->getName() ); meg04_[ism-1] = 0; if ( meg05_[ism-1] ) dqmStore_->removeElement( meg05_[ism-1]->getName() ); meg05_[ism-1] = 0; if ( mea01_[ism-1] ) dqmStore_->removeElement( mea01_[ism-1]->getName() ); mea01_[ism-1] = 0; if ( mea02_[ism-1] ) dqmStore_->removeElement( mea02_[ism-1]->getName() ); mea02_[ism-1] = 0; if ( mea03_[ism-1] ) dqmStore_->removeElement( mea03_[ism-1]->getName() ); mea03_[ism-1] = 0; if ( mer04_[ism-1] ) dqmStore_->removeElement( mer04_[ism-1]->getName() ); mer04_[ism-1] = 0; if ( mer05_[ism-1] ) dqmStore_->removeElement( mer05_[ism-1]->getName() ); mer05_[ism-1] = 0; if ( me_hs01_[ism-1] ) dqmStore_->removeElement( me_hs01_[ism-1]->getName() ); me_hs01_[ism-1] = 0; if ( me_hs02_[ism-1] ) dqmStore_->removeElement( me_hs02_[ism-1]->getName() ); me_hs02_[ism-1] = 0; if ( me_hs03_[ism-1] ) dqmStore_->removeElement( me_hs03_[ism-1]->getName() ); me_hs03_[ism-1] = 0; } }
void EBTestPulseClient::endJob | ( | void | ) | [virtual] |
void EBTestPulseClient::endRun | ( | void | ) | [virtual] |
int EBTestPulseClient::getEvtPerJob | ( | void | ) | [inline, virtual] |
Get Functions.
Implements EBClient.
Definition at line 72 of file EBTestPulseClient.h.
References ievt_.
{ return ievt_; }
int EBTestPulseClient::getEvtPerRun | ( | void | ) | [inline, virtual] |
void EBTestPulseClient::setup | ( | void | ) | [virtual] |
Setup.
Implements EBClient.
Definition at line 173 of file EBTestPulseClient.cc.
References DQMStore::book1D(), DQMStore::book2D(), dqmStore_, spr::find(), edm::getName(), i, ecalpyutils::ism(), me_hs01_, me_hs02_, me_hs03_, mea01_, mea02_, mea03_, meg01_, meg02_, meg03_, meg04_, meg05_, mer04_, mer05_, MGPAGains_, MGPAGainsPN_, mergeVDriftHistosByStation::name, prefixME_, DQMStore::removeElement(), MonitorElement::Reset(), Numbers::sEB(), MonitorElement::setAxisTitle(), MonitorElement::setBinContent(), DQMStore::setCurrentFolder(), and superModules_.
Referenced by beginRun().
{ std::string name; dqmStore_->setCurrentFolder( prefixME_ + "/EBTestPulseClient" ); for ( unsigned int i=0; i<superModules_.size(); i++ ) { int ism = superModules_[i]; if (find(MGPAGains_.begin(), MGPAGains_.end(), 1) != MGPAGains_.end() ) { if ( meg01_[ism-1] ) dqmStore_->removeElement( meg01_[ism-1]->getName() ); name = "EBTPT test pulse quality G01 " + Numbers::sEB(ism); meg01_[ism-1] = dqmStore_->book2D(name, name, 85, 0., 85., 20, 0., 20.); meg01_[ism-1]->setAxisTitle("ieta", 1); meg01_[ism-1]->setAxisTitle("iphi", 2); } if (find(MGPAGains_.begin(), MGPAGains_.end(), 6) != MGPAGains_.end() ) { if ( meg02_[ism-1] ) dqmStore_->removeElement( meg02_[ism-1]->getName() ); name = "EBTPT test pulse quality G06 " + Numbers::sEB(ism); meg02_[ism-1] = dqmStore_->book2D(name, name, 85, 0., 85., 20, 0., 20.); meg02_[ism-1]->setAxisTitle("ieta", 1); meg02_[ism-1]->setAxisTitle("iphi", 2); } if (find(MGPAGains_.begin(), MGPAGains_.end(), 12) != MGPAGains_.end() ) { if ( meg03_[ism-1] ) dqmStore_->removeElement( meg03_[ism-1]->getName() ); name = "EBTPT test pulse quality G12 " + Numbers::sEB(ism); meg03_[ism-1] = dqmStore_->book2D(name, name, 85, 0., 85., 20, 0., 20.); meg03_[ism-1]->setAxisTitle("ieta", 1); meg03_[ism-1]->setAxisTitle("iphi", 2); } if (find(MGPAGainsPN_.begin(), MGPAGainsPN_.end(), 1) != MGPAGainsPN_.end() ) { if ( meg04_[ism-1] ) dqmStore_->removeElement( meg04_[ism-1]->getName() ); name = "EBTPT test pulse quality PNs G01 " + Numbers::sEB(ism); meg04_[ism-1] = dqmStore_->book2D(name, name, 10, 0., 10., 1, 0., 5.); meg04_[ism-1]->setAxisTitle("pseudo-strip", 1); meg04_[ism-1]->setAxisTitle("channel", 2); } if (find(MGPAGainsPN_.begin(), MGPAGainsPN_.end(), 16) != MGPAGainsPN_.end() ) { if ( meg05_[ism-1] ) dqmStore_->removeElement( meg05_[ism-1]->getName() ); name = "EBTPT test pulse quality PNs G16 " + Numbers::sEB(ism); meg05_[ism-1] = dqmStore_->book2D(name, name, 10, 0., 10., 1, 0., 5.); meg05_[ism-1]->setAxisTitle("pseudo-strip", 1); meg05_[ism-1]->setAxisTitle("channel", 2); } if (find(MGPAGains_.begin(), MGPAGains_.end(), 1) != MGPAGains_.end() ) { if ( mea01_[ism-1] ) dqmStore_->removeElement( mea01_[ism-1]->getName() ); name = "EBTPT test pulse amplitude G01 " + Numbers::sEB(ism); mea01_[ism-1] = dqmStore_->book1D(name, name, 1700, 0., 1700.); mea01_[ism-1]->setAxisTitle("channel", 1); mea01_[ism-1]->setAxisTitle("amplitude", 2); } if (find(MGPAGains_.begin(), MGPAGains_.end(), 6) != MGPAGains_.end() ) { if ( mea02_[ism-1] ) dqmStore_->removeElement( mea02_[ism-1]->getName() ); name = "EBTPT test pulse amplitude G06 " + Numbers::sEB(ism); mea02_[ism-1] = dqmStore_->book1D(name, name, 1700, 0., 1700.); mea02_[ism-1]->setAxisTitle("channel", 1); mea02_[ism-1]->setAxisTitle("amplitude", 2); } if (find(MGPAGains_.begin(), MGPAGains_.end(), 12) != MGPAGains_.end() ) { if ( mea03_[ism-1] ) dqmStore_->removeElement( mea03_[ism-1]->getName() ); name = "EBTPT test pulse amplitude G12 " + Numbers::sEB(ism); mea03_[ism-1] = dqmStore_->book1D(name, name, 1700, 0., 1700.); mea03_[ism-1]->setAxisTitle("channel", 1); mea03_[ism-1]->setAxisTitle("amplitude", 2); } if (find(MGPAGainsPN_.begin(), MGPAGainsPN_.end(), 1) != MGPAGainsPN_.end() ) { if ( mer04_[ism-1] ) dqmStore_->removeElement( mer04_[ism-1]->getName() ); name = "EBTPT PNs pedestal rms " + Numbers::sEB(ism) + " G01"; mer04_[ism-1] = dqmStore_->book1D(name, name, 100, 0., 10.); mer04_[ism-1]->setAxisTitle("rms", 1); } if (find(MGPAGainsPN_.begin(), MGPAGainsPN_.end(), 16) != MGPAGainsPN_.end() ) { if ( mer05_[ism-1] ) dqmStore_->removeElement( mer05_[ism-1]->getName() ); name = "EBTPT PNs pedestal rms " + Numbers::sEB(ism) + " G16"; mer05_[ism-1] = dqmStore_->book1D(name, name, 100, 0., 10.); mer05_[ism-1]->setAxisTitle("rms", 1); } if (find(MGPAGains_.begin(), MGPAGains_.end(), 1) != MGPAGains_.end() ) { if ( me_hs01_[ism-1] ) dqmStore_->removeElement( me_hs01_[ism-1]->getName() ); name = "EBTPT test pulse shape G01 " + Numbers::sEB(ism); me_hs01_[ism-1] = dqmStore_->book1D(name, name, 10, 0., 10.); me_hs01_[ism-1]->setAxisTitle("sample", 1); me_hs01_[ism-1]->setAxisTitle("amplitude", 2); } if (find(MGPAGains_.begin(), MGPAGains_.end(), 6) != MGPAGains_.end() ) { if ( me_hs02_[ism-1] ) dqmStore_->removeElement( me_hs02_[ism-1]->getName() ); name = "EBTPT test pulse shape G06 " + Numbers::sEB(ism); me_hs02_[ism-1] = dqmStore_->book1D(name, name, 10, 0., 10.); me_hs02_[ism-1]->setAxisTitle("sample", 1); me_hs02_[ism-1]->setAxisTitle("amplitude", 2); } if (find(MGPAGains_.begin(), MGPAGains_.end(), 12) != MGPAGains_.end() ) { if ( me_hs03_[ism-1] ) dqmStore_->removeElement( me_hs03_[ism-1]->getName() ); name = "EBTPT test pulse shape G12 " + Numbers::sEB(ism); me_hs03_[ism-1] = dqmStore_->book1D(name, name, 10, 0., 10.); me_hs03_[ism-1]->setAxisTitle("sample", 1); me_hs03_[ism-1]->setAxisTitle("amplitude", 2); } } for ( unsigned int i=0; i<superModules_.size(); i++ ) { int ism = superModules_[i]; if ( meg01_[ism-1] ) meg01_[ism-1]->Reset(); if ( meg02_[ism-1] ) meg02_[ism-1]->Reset(); if ( meg03_[ism-1] ) meg03_[ism-1]->Reset(); if ( meg04_[ism-1] ) meg04_[ism-1]->Reset(); if ( meg05_[ism-1] ) meg05_[ism-1]->Reset(); for ( int ie = 1; ie <= 85; ie++ ) { for ( int ip = 1; ip <= 20; ip++ ) { if ( meg01_[ism-1] ) meg01_[ism-1]->setBinContent( ie, ip, 2. ); if ( meg02_[ism-1] ) meg02_[ism-1]->setBinContent( ie, ip, 2. ); if ( meg03_[ism-1] ) meg03_[ism-1]->setBinContent( ie, ip, 2. ); } } for ( int i = 1; i <= 10; i++ ) { if ( meg04_[ism-1] ) meg04_[ism-1]->setBinContent( i, 1, 2. ); if ( meg05_[ism-1] ) meg05_[ism-1]->setBinContent( i, 1, 2. ); } if ( mea01_[ism-1] ) mea01_[ism-1]->Reset(); if ( mea02_[ism-1] ) mea02_[ism-1]->Reset(); if ( mea03_[ism-1] ) mea03_[ism-1]->Reset(); if ( mer04_[ism-1] ) mer04_[ism-1]->Reset(); if ( mer05_[ism-1] ) mer05_[ism-1]->Reset(); if ( me_hs01_[ism-1] ) me_hs01_[ism-1]->Reset(); if ( me_hs02_[ism-1] ) me_hs02_[ism-1]->Reset(); if ( me_hs03_[ism-1] ) me_hs03_[ism-1]->Reset(); } }
friend class EBSummaryClient [friend] |
Definition at line 35 of file EBTestPulseClient.h.
float EBTestPulseClient::amplitudeThreshold_ [private] |
Definition at line 130 of file EBTestPulseClient.h.
Referenced by analyze(), and EBTestPulseClient().
float EBTestPulseClient::amplitudeThresholdPnG01_ [private] |
Definition at line 134 of file EBTestPulseClient.h.
Referenced by analyze(), and EBTestPulseClient().
float EBTestPulseClient::amplitudeThresholdPnG16_ [private] |
Definition at line 135 of file EBTestPulseClient.h.
Referenced by analyze(), and EBTestPulseClient().
bool EBTestPulseClient::cloneME_ [private] |
Definition at line 80 of file EBTestPulseClient.h.
Referenced by analyze(), cleanup(), and EBTestPulseClient().
bool EBTestPulseClient::debug_ [private] |
Definition at line 83 of file EBTestPulseClient.h.
Referenced by analyze(), beginJob(), beginRun(), EBTestPulseClient(), endJob(), and endRun().
DQMStore* EBTestPulseClient::dqmStore_ [private] |
Definition at line 93 of file EBTestPulseClient.h.
Referenced by analyze(), beginJob(), cleanup(), and setup().
bool EBTestPulseClient::enableCleanup_ [private] |
Definition at line 87 of file EBTestPulseClient.h.
Referenced by cleanup(), and EBTestPulseClient().
TProfile2D* EBTestPulseClient::ha01_[36] [private] |
Definition at line 95 of file EBTestPulseClient.h.
Referenced by analyze(), cleanup(), and EBTestPulseClient().
TProfile2D* EBTestPulseClient::ha02_[36] [private] |
Definition at line 96 of file EBTestPulseClient.h.
Referenced by analyze(), cleanup(), and EBTestPulseClient().
TProfile2D* EBTestPulseClient::ha03_[36] [private] |
Definition at line 97 of file EBTestPulseClient.h.
Referenced by analyze(), cleanup(), and EBTestPulseClient().
TProfile2D* EBTestPulseClient::hs01_[36] [private] |
Definition at line 99 of file EBTestPulseClient.h.
Referenced by analyze(), cleanup(), and EBTestPulseClient().
TProfile2D* EBTestPulseClient::hs02_[36] [private] |
Definition at line 100 of file EBTestPulseClient.h.
Referenced by analyze(), cleanup(), and EBTestPulseClient().
TProfile2D* EBTestPulseClient::hs03_[36] [private] |
Definition at line 101 of file EBTestPulseClient.h.
Referenced by analyze(), cleanup(), and EBTestPulseClient().
TProfile* EBTestPulseClient::i01_[36] [private] |
Definition at line 121 of file EBTestPulseClient.h.
Referenced by analyze(), cleanup(), and EBTestPulseClient().
TProfile* EBTestPulseClient::i02_[36] [private] |
Definition at line 122 of file EBTestPulseClient.h.
Referenced by analyze(), cleanup(), and EBTestPulseClient().
TProfile* EBTestPulseClient::i03_[36] [private] |
Definition at line 123 of file EBTestPulseClient.h.
Referenced by analyze(), cleanup(), and EBTestPulseClient().
TProfile* EBTestPulseClient::i04_[36] [private] |
Definition at line 124 of file EBTestPulseClient.h.
Referenced by analyze(), cleanup(), and EBTestPulseClient().
int EBTestPulseClient::ievt_ [private] |
Definition at line 77 of file EBTestPulseClient.h.
Referenced by analyze(), beginJob(), endJob(), and getEvtPerJob().
int EBTestPulseClient::jevt_ [private] |
Definition at line 78 of file EBTestPulseClient.h.
Referenced by analyze(), beginJob(), beginRun(), endRun(), and getEvtPerRun().
MonitorElement* EBTestPulseClient::me_hs01_[36] [private] |
Definition at line 117 of file EBTestPulseClient.h.
Referenced by analyze(), cleanup(), EBTestPulseClient(), and setup().
MonitorElement* EBTestPulseClient::me_hs02_[36] [private] |
Definition at line 118 of file EBTestPulseClient.h.
Referenced by analyze(), cleanup(), EBTestPulseClient(), and setup().
MonitorElement* EBTestPulseClient::me_hs03_[36] [private] |
Definition at line 119 of file EBTestPulseClient.h.
Referenced by analyze(), cleanup(), EBTestPulseClient(), and setup().
MonitorElement* EBTestPulseClient::mea01_[36] [private] |
Definition at line 110 of file EBTestPulseClient.h.
Referenced by EBSummaryClient::analyze(), analyze(), cleanup(), EBTestPulseClient(), and setup().
MonitorElement* EBTestPulseClient::mea02_[36] [private] |
Definition at line 111 of file EBTestPulseClient.h.
Referenced by EBSummaryClient::analyze(), analyze(), cleanup(), EBTestPulseClient(), and setup().
MonitorElement* EBTestPulseClient::mea03_[36] [private] |
Definition at line 112 of file EBTestPulseClient.h.
Referenced by EBSummaryClient::analyze(), analyze(), cleanup(), EBTestPulseClient(), and setup().
MonitorElement* EBTestPulseClient::meg01_[36] [private] |
Definition at line 103 of file EBTestPulseClient.h.
Referenced by EBSummaryClient::analyze(), analyze(), cleanup(), EBTestPulseClient(), and setup().
MonitorElement* EBTestPulseClient::meg02_[36] [private] |
Definition at line 104 of file EBTestPulseClient.h.
Referenced by EBSummaryClient::analyze(), analyze(), cleanup(), EBTestPulseClient(), and setup().
MonitorElement* EBTestPulseClient::meg03_[36] [private] |
Definition at line 105 of file EBTestPulseClient.h.
Referenced by EBSummaryClient::analyze(), analyze(), cleanup(), EBTestPulseClient(), and setup().
MonitorElement* EBTestPulseClient::meg04_[36] [private] |
Definition at line 107 of file EBTestPulseClient.h.
Referenced by EBSummaryClient::analyze(), analyze(), cleanup(), EBTestPulseClient(), and setup().
MonitorElement* EBTestPulseClient::meg05_[36] [private] |
Definition at line 108 of file EBTestPulseClient.h.
Referenced by EBSummaryClient::analyze(), analyze(), cleanup(), EBTestPulseClient(), and setup().
MonitorElement* EBTestPulseClient::mer04_[36] [private] |
Definition at line 114 of file EBTestPulseClient.h.
Referenced by analyze(), cleanup(), EBTestPulseClient(), and setup().
MonitorElement* EBTestPulseClient::mer05_[36] [private] |
Definition at line 115 of file EBTestPulseClient.h.
Referenced by analyze(), cleanup(), EBTestPulseClient(), and setup().
std::vector<int> EBTestPulseClient::MGPAGains_ [private] |
Definition at line 90 of file EBTestPulseClient.h.
Referenced by analyze(), EBTestPulseClient(), and setup().
std::vector<int> EBTestPulseClient::MGPAGainsPN_ [private] |
Definition at line 91 of file EBTestPulseClient.h.
Referenced by analyze(), EBTestPulseClient(), and setup().
float EBTestPulseClient::pedPnDiscrepancyMean_[2] [private] |
Definition at line 137 of file EBTestPulseClient.h.
Referenced by analyze(), and EBTestPulseClient().
float EBTestPulseClient::pedPnExpectedMean_[2] [private] |
Definition at line 136 of file EBTestPulseClient.h.
Referenced by analyze(), and EBTestPulseClient().
float EBTestPulseClient::pedPnRMSThreshold_[2] [private] |
Definition at line 138 of file EBTestPulseClient.h.
Referenced by analyze(), and EBTestPulseClient().
float EBTestPulseClient::percentVariation_ [private] |
Definition at line 128 of file EBTestPulseClient.h.
Referenced by analyze(), and EBTestPulseClient().
std::string EBTestPulseClient::prefixME_ [private] |
Definition at line 85 of file EBTestPulseClient.h.
Referenced by analyze(), cleanup(), EBTestPulseClient(), and setup().
float EBTestPulseClient::RMSThreshold_ [private] |
Definition at line 129 of file EBTestPulseClient.h.
Referenced by analyze(), and EBTestPulseClient().
std::vector<int> EBTestPulseClient::superModules_ [private] |
Definition at line 89 of file EBTestPulseClient.h.
Referenced by analyze(), cleanup(), EBTestPulseClient(), and setup().
bool EBTestPulseClient::verbose_ [private] |
Definition at line 82 of file EBTestPulseClient.h.
Referenced by EBTestPulseClient().