SummaryHistogramFactory

SummaryHistogramFactory

SummaryHistogramFactory

Line Code
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129
#include "DQM/SiStripCommissioningSummary/interface/SummaryHistogramFactory.h"
#include "DQM/SiStripCommissioningSummary/interface/SummaryGenerator.h"
#include "FWCore/MessageLogger/interface/MessageLogger.h"
#include <iostream>
#include <sstream>

using namespace sistrip;

// -----------------------------------------------------------------------------
//
template <class T>
SummaryHistogramFactory<T>::SummaryHistogramFactory()
    : mon_(sistrip::UNKNOWN_MONITORABLE),
      pres_(sistrip::UNKNOWN_PRESENTATION),
      view_(sistrip::UNKNOWN_VIEW),
      level_(sistrip::root_),
      gran_(sistrip::UNKNOWN_GRAN),
      generator_(nullptr) {
  LogTrace(mlSummaryPlots_) << "[SummaryHistogramFactory::" << __func__ << "]";
}

// -----------------------------------------------------------------------------
//
template <class T>
SummaryHistogramFactory<T>::~SummaryHistogramFactory() {
  LogTrace(mlSummaryPlots_) << "[SummaryHistogramFactory::" << __func__ << "]";
  if (generator_) {
    delete generator_;
  }
}

// -----------------------------------------------------------------------------
//
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) {
  LogTrace(mlSummaryPlots_) << "[SummaryHistogramFactory::" << __func__ << "]";
  mon_ = mon;
  pres_ = pres;
  view_ = view;
  level_ = top_level_dir;
  gran_ = gran;

  // Retrieve utility class used to generate summary histograms
  if (generator_) {
    delete generator_;
    generator_ = nullptr;
    generator_ = SummaryGenerator::instance(view);
  }
}

// -----------------------------------------------------------------------------
//
template <class T>
uint32_t SummaryHistogramFactory<T>::extract(const std::map<uint32_t, T>& data) {
  LogTrace(mlSummaryPlots_) << "[SummaryHistogramFactory::" << __func__ << "]";

  // Check if data are present
  if (data.empty()) {
    edm::LogWarning(mlSummaryPlots_) << "[SummaryHistogramFactory::" << __func__ << "]"
                                     << " No data in monitorables std::map!";
    return 0;
  }

  // Check if instance of generator class exists
  if (!generator_) {
    edm::LogWarning(mlSummaryPlots_) << "[SummaryHistogramFactory::" << __func__ << "]"
                                     << " NULL pointer to SummaryGenerator object!";
    return 0;
  }

  // Transfer appropriate monitorables info to generator object
  generator_->clearMap();
  typename std::map<uint32_t, T>::const_iterator iter = data.begin();
  for (; iter != data.end(); iter++) {
    generator_->fillMap(level_,                             // top-level directory
                        gran_,                              // granularity
                        iter->first,                        // device key
                        static_cast<float>(iter->second));  // value
  }

  return generator_->size();
}

// -----------------------------------------------------------------------------
//
template <class T>
void SummaryHistogramFactory<T>::fill(TH1& summary_histo) {
  LogTrace(mlSummaryPlots_) << "[SummaryHistogramFactory::" << __func__ << "]";

  // Check if instance of generator class exists
  if (!generator_) {
    edm::LogWarning(mlSummaryPlots_) << "[SummaryHistogramFactory::" << __func__ << "]"
                                     << " NULL pointer to SummaryGenerator object!";
    return;
  }

  // Check if std::map is filled
  if (!generator_->size()) {
    edm::LogWarning(mlSummaryPlots_) << "[SummaryHistogramFactory::" << __func__ << "]"
                                     << " No data in the monitorables std::map!";
    return;
  }

  // Generate appropriate summary histogram
  if (pres_ == sistrip::HISTO_1D) {
    generator_->histo1D(summary_histo);
  } else if (pres_ == sistrip::HISTO_2D_SUM) {
    generator_->histo2DSum(summary_histo);
  } else if (pres_ == sistrip::HISTO_2D_SCATTER) {
    generator_->histo2DScatter(summary_histo);
  } else if (pres_ == sistrip::PROFILE_1D) {
    generator_->profile1D(summary_histo);
  } else {
    return;
  }

  // Histogram formatting
  generator_->format(sistrip::UNKNOWN_RUN_TYPE, mon_, pres_, view_, level_, gran_, summary_histo);
}

// -----------------------------------------------------------------------------
//
template class SummaryHistogramFactory<uint32_t>;
template class SummaryHistogramFactory<uint16_t>;
template class SummaryHistogramFactory<float>;