CMS 3D CMS Logo

Public Member Functions | Private Member Functions | Private Attributes

SiStripHistoryDQMService Class Reference

#include <SiStripHistoryDQMService.h>

Inheritance diagram for SiStripHistoryDQMService:
DQMHistoryServiceBase

List of all members.

Public Member Functions

 SiStripHistoryDQMService (const edm::ParameterSet &, const edm::ActivityRegistry &)
 ~SiStripHistoryDQMService ()

Private Member Functions

uint32_t returnDetComponent (const MonitorElement *ME)
bool setDBLabelsForUser (std::string &keyName, std::vector< std::string > &userDBContent, std::string &quantity)
bool setDBValuesForUser (std::vector< MonitorElement * >::const_iterator iterMes, HDQMSummary::InputVector &values, std::string &quantity)

Private Attributes

edm::ParameterSet iConfig_

Detailed Description

Author:
D. Giordano, A.-C. Le Bihan to read DQM root file & insert summary informations to DB

Definition at line 11 of file SiStripHistoryDQMService.h.


Constructor & Destructor Documentation

SiStripHistoryDQMService::SiStripHistoryDQMService ( const edm::ParameterSet iConfig,
const edm::ActivityRegistry aReg 
) [explicit]

Definition at line 11 of file SiStripHistoryDQMService.cc.

: DQMHistoryServiceBase::DQMHistoryServiceBase(iConfig, aReg), iConfig_(iConfig)
{
  edm::LogInfo("SiStripHistoryDQMService") <<  "[SiStripHistoryDQMService::SiStripHistoryDQMService]";
}
SiStripHistoryDQMService::~SiStripHistoryDQMService ( )

Definition at line 18 of file SiStripHistoryDQMService.cc.

                                                    { 
  edm::LogInfo("SiStripHistoryDQMService") <<  "[SiStripHistoryDQMService::~SiStripHistoryDQMService]";
}

Member Function Documentation

uint32_t SiStripHistoryDQMService::returnDetComponent ( const MonitorElement ME) [private, virtual]

Reimplemented from DQMHistoryServiceBase.

Definition at line 23 of file SiStripHistoryDQMService.cc.

References MonitorElement::getName(), LogTrace, DetId::rawId(), AlCaHLTBitMon_QueryRunRegistry::string, and DetId::Tracker.

                                                                             {
  LogTrace("SiStripHistoryDQMService") <<  "[SiStripHistoryDQMService::returnDetComponent]";
  std::string str=ME->getName();
  size_t __key_length__=7;
  size_t __detid_length__=9;

  uint32_t layer=0,side=0;

  if(str.find("__det__")!= std::string::npos){
    return atoi(str.substr(str.find("__det__")+__key_length__,__detid_length__).c_str());
  }
  //TIB
  else if(str.find("TIB")!= std::string::npos){
    if (str.find("layer")!= std::string::npos) 
      layer=atoi(str.substr(str.find("layer__")+__key_length__,1).c_str());
    return TIBDetId(layer,0,0,0,0,0).rawId();
  }
  //TOB
  else if(str.find("TOB")!= std::string::npos){
    if (str.find("layer")!= std::string::npos) 
      layer=atoi(str.substr(str.find("layer__")+__key_length__,1).c_str());
    return TOBDetId(layer,0,0,0,0).rawId();
  }
  //TID
  else if(str.find("TID")!= std::string::npos){  
    if (str.find("side")!= std::string::npos){
      side=atoi(str.substr(str.find("_side__")+__key_length__,1).c_str());
      if (str.find("wheel")!= std::string::npos){
        layer=atoi(str.substr(str.find("wheel__")+__key_length__,1).c_str());
      }
    }
    return TIDDetId(side,layer,0,0,0,0).rawId();
  } 
  //TEC
  else if(str.find("TEC")!= std::string::npos){  
    if (str.find("side")!= std::string::npos){
      side=atoi(str.substr(str.find("_side__")+__key_length__,1).c_str());
      if (str.find("wheel")!= std::string::npos){
        layer=atoi(str.substr(str.find("wheel__")+__key_length__,1).c_str());
      }
    }
    return TECDetId(side,layer,0,0,0,0,0).rawId();
  } 
  else 
    return SiStripDetId(DetId::Tracker,0).rawId(); //Full Tracker
}
bool SiStripHistoryDQMService::setDBLabelsForUser ( std::string &  keyName,
std::vector< std::string > &  userDBContent,
std::string &  quantity 
) [private, virtual]

Reimplemented from DQMHistoryServiceBase.

Definition at line 71 of file SiStripHistoryDQMService.cc.

References DQMHistoryServiceBase::fSep, and AlCaHLTBitMon_QueryRunRegistry::string.

                                                                                                                               {
  if (quantity == "user_2DYmean") {
    userDBContent.push_back(keyName+fSep+std::string("yMean"));
    userDBContent.push_back(keyName+fSep+std::string("yError"));
  } else {
    edm::LogError("SiStripHistoryDQMService") << "ERROR: quantity does not exist in SiStripHistoryDQMService::setDBValuesForUser(): " << quantity;
    return false;
  }
  return true;
}
bool SiStripHistoryDQMService::setDBValuesForUser ( std::vector< MonitorElement * >::const_iterator  iterMes,
HDQMSummary::InputVector values,
std::string &  quantity 
) [private, virtual]

Reimplemented from DQMHistoryServiceBase.

Definition at line 81 of file SiStripHistoryDQMService.cc.

                                                                                                                                                        {
  if (quantity == "user_2DYmean") {
    TH2F* Hist = (TH2F*) (*iterMes)->getTH2F();
    values.push_back( Hist->GetMean(2) );
    values.push_back( Hist->GetRMS(2) );
  } else {
    edm::LogError("SiStripHistoryDQMService") << "ERROR: quantity does not exist in SiStripHistoryDQMService::setDBValuesForUser(): " << quantity;
    return false;
  }
  return true;
}

Member Data Documentation

Reimplemented from DQMHistoryServiceBase.

Definition at line 25 of file SiStripHistoryDQMService.h.