CMS 3D CMS Logo

List of all members | Public Member Functions | Private Attributes
SummaryHistogramFactory< T > Class Template Reference

#include <SummaryHistogramFactory.h>

Public Member Functions

uint32_t extract (const std::map< uint32_t, T > &data)
 
void fill (TH1 &summary_histo)
 
void init (const sistrip::Monitorable &, const sistrip::Presentation &, const sistrip::View &, const std::string &top_level_dir, const sistrip::Granularity &)
 
 SummaryHistogramFactory ()
 
 ~SummaryHistogramFactory ()
 

Private Attributes

SummaryGeneratorgenerator_
 
sistrip::Granularity gran_
 
std::string level_
 
sistrip::Monitorable mon_
 
sistrip::Presentation pres_
 
sistrip::View view_
 

Detailed Description

template<class T>
class SummaryHistogramFactory< T >

Definition at line 13 of file SummaryHistogramFactory.h.

Constructor & Destructor Documentation

template<class T >
SummaryHistogramFactory< T >::~SummaryHistogramFactory ( )

Definition at line 27 of file SummaryHistogramFactory.cc.

References SummaryHistogramFactory< T >::generator_, LogTrace, and sistrip::mlSummaryPlots_.

27  {
28  LogTrace(mlSummaryPlots_) << "[SummaryHistogramFactory::" << __func__ << "]";
29  if ( generator_ ) { delete generator_; }
30 }
#define LogTrace(id)
static const char mlSummaryPlots_[]

Member Function Documentation

template<class T >
uint32_t SummaryHistogramFactory< T >::extract ( const std::map< uint32_t, T > &  data)

Definition at line 59 of file SummaryHistogramFactory.cc.

References SummaryGenerator::clearMap(), SummaryGenerator::fillMap(), SummaryHistogramFactory< T >::generator_, SummaryHistogramFactory< T >::gran_, SummaryHistogramFactory< T >::level_, LogTrace, sistrip::mlSummaryPlots_, and SummaryGenerator::size().

59  {
60  LogTrace(mlSummaryPlots_) << "[SummaryHistogramFactory::" << __func__ << "]";
61 
62  // Check if data are present
63  if ( data.empty() ) {
64  edm::LogWarning(mlSummaryPlots_) << "[SummaryHistogramFactory::" << __func__ << "]"
65  << " No data in monitorables std::map!";
66  return 0;
67  }
68 
69  // Check if instance of generator class exists
70  if ( !generator_ ) {
71  edm::LogWarning(mlSummaryPlots_) << "[SummaryHistogramFactory::" << __func__ << "]"
72  << " NULL pointer to SummaryGenerator object!";
73  return 0;
74  }
75 
76  // Transfer appropriate monitorables info to generator object
78  typename std::map<uint32_t,T>::const_iterator iter = data.begin();
79  for ( ; iter != data.end(); iter++ ) {
80  generator_->fillMap( level_, // top-level directory
81  gran_, // granularity
82  iter->first, // device key
83  static_cast<float>(iter->second) ); // value
84  }
85 
86  return generator_->size();
87 }
void fillMap(const std::string &top_level_dir, const sistrip::Granularity &, const uint32_t &key, const float &value, const float &error=0.)
uint32_t size() const
#define LogTrace(id)
static const char mlSummaryPlots_[]
char data[epos_bytes_allocation]
Definition: EPOS_Wrapper.h:82
template<class T >
void SummaryHistogramFactory< T >::fill ( TH1 &  summary_histo)

Definition at line 92 of file SummaryHistogramFactory.cc.

References SummaryGenerator::format(), SummaryHistogramFactory< T >::generator_, SummaryHistogramFactory< T >::gran_, SummaryGenerator::histo1D(), SummaryGenerator::histo2DScatter(), SummaryGenerator::histo2DSum(), sistrip::HISTO_1D, sistrip::HISTO_2D_SCATTER, sistrip::HISTO_2D_SUM, SummaryHistogramFactory< T >::level_, LogTrace, sistrip::mlSummaryPlots_, SummaryHistogramFactory< T >::mon_, SummaryHistogramFactory< T >::pres_, SummaryGenerator::profile1D(), sistrip::PROFILE_1D, SummaryGenerator::size(), sistrip::UNKNOWN_RUN_TYPE, and SummaryHistogramFactory< T >::view_.

92  {
93  LogTrace(mlSummaryPlots_) << "[SummaryHistogramFactory::" << __func__ << "]";
94 
95  // Check if instance of generator class exists
96  if ( !generator_ ) {
97  edm::LogWarning(mlSummaryPlots_) << "[SummaryHistogramFactory::" << __func__ << "]"
98  << " NULL pointer to SummaryGenerator object!";
99  return;
100  }
101 
102  // Check if std::map is filled
103  if ( !generator_->size() ) {
104  edm::LogWarning(mlSummaryPlots_) << "[SummaryHistogramFactory::" << __func__ << "]"
105  << " No data in the monitorables std::map!";
106  return;
107  }
108 
109  // Generate appropriate summary histogram
110  if ( pres_ == sistrip::HISTO_1D ) {
111  generator_->histo1D( summary_histo );
112  } else if ( pres_ == sistrip::HISTO_2D_SUM ) {
113  generator_->histo2DSum( summary_histo );
114  } else if ( pres_ == sistrip::HISTO_2D_SCATTER ) {
115  generator_->histo2DScatter( summary_histo );
116  } else if ( pres_ == sistrip::PROFILE_1D ) {
117  generator_->profile1D( summary_histo );
118  } else { return; }
119 
120  // Histogram formatting
122 
123 }
void histo2DSum(TH1 &)
void histo2DScatter(TH1 &)
uint32_t size() const
#define LogTrace(id)
void format(const sistrip::RunType &, const sistrip::Monitorable &, const sistrip::Presentation &, const sistrip::View &, const std::string &directory, const sistrip::Granularity &, TH1 &)
static const char mlSummaryPlots_[]
sistrip::Presentation pres_
template<class T >
void SummaryHistogramFactory< T >::init ( const sistrip::Monitorable mon,
const sistrip::Presentation pres,
const sistrip::View view,
const std::string &  top_level_dir,
const sistrip::Granularity gran 
)

Definition at line 35 of file SummaryHistogramFactory.cc.

References SummaryHistogramFactory< T >::generator_, SummaryHistogramFactory< T >::gran_, SummaryGenerator::instance(), SummaryHistogramFactory< T >::level_, LogTrace, sistrip::mlSummaryPlots_, LaserDQM_cfi::mon, SummaryHistogramFactory< T >::mon_, SummaryHistogramFactory< T >::pres_, and SummaryHistogramFactory< T >::view_.

39  {
40  LogTrace(mlSummaryPlots_) << "[SummaryHistogramFactory::" << __func__ << "]";
41  mon_ = mon;
42  pres_ = pres;
43  view_ = view;
44  level_ = top_level_dir;
45  gran_ = gran;
46 
47  // Retrieve utility class used to generate summary histograms
48  if ( generator_ ) {
49  delete generator_;
50  generator_ = 0;
52  }
53 
54 }
static SummaryGenerator * instance(const sistrip::View &)
#define LogTrace(id)
static const char mlSummaryPlots_[]
sistrip::Presentation pres_

Member Data Documentation

template<class T >
SummaryGenerator* SummaryHistogramFactory< T >::generator_
private
template<class T >
sistrip::Granularity SummaryHistogramFactory< T >::gran_
private
template<class T >
std::string SummaryHistogramFactory< T >::level_
private
template<class T >
sistrip::Monitorable SummaryHistogramFactory< T >::mon_
private
template<class T >
sistrip::Presentation SummaryHistogramFactory< T >::pres_
private
template<class T >
sistrip::View SummaryHistogramFactory< T >::view_
private