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
#include "CondFormats/SiPixelObjects/interface/SiPixelQualityProbabilities.h"
#include "FWCore/Utilities/interface/Exception.h"
#include "FWCore/MessageLogger/interface/MessageLogger.h"
#include <iostream>
#include <iomanip>  // std::setw

//****************************************************************************//
void SiPixelQualityProbabilities::setProbabilities(const unsigned int puBin, const probabilityVec &theProbabilities) {
  if (m_probabilities.find(puBin) != m_probabilities.end()) {
    edm::LogWarning("SiPixelQualityProbabilities") << "PU bin: " << puBin << " is already in the map!" << std::endl;
    return;
  } else {
    m_probabilities.emplace(puBin, theProbabilities);
  }
}

//****************************************************************************//
SiPixelQualityProbabilities::probabilityVec SiPixelQualityProbabilities::getProbabilities(
    const unsigned int puBin) const {
  probabilityMap::const_iterator it = m_probabilities.find(puBin);

  if (it != m_probabilities.end()) {
    return it->second;
  } else {
    throw cms::Exception("SiPixelQualityProbabilities") << "No Probabilities are defined for PU bin " << puBin << "\n";
  }
}

//****************************************************************************//
const SiPixelQualityProbabilities::probabilityVec &SiPixelQualityProbabilities::getProbabilities(
    const unsigned int puBin) {
  probabilityMap::const_iterator it = m_probabilities.find(puBin);

  if (it != m_probabilities.end()) {
    return it->second;
  } else {
    throw cms::Exception("SiPixelQualityProbabilities") << "No Probabilities are defined for PU bin " << puBin << "\n";
  }
}

//****************************************************************************//
void SiPixelQualityProbabilities::printAll() const {
  edm::LogVerbatim("SiPixelQualityProbabilities") << "SiPixelQualityProbabilities::printAll()";
  edm::LogVerbatim("SiPixelQualityProbabilities") << " ================================================================"
                                                     "===================================================";
  for (auto it = m_probabilities.begin(); it != m_probabilities.end(); ++it) {
    edm::LogVerbatim("SiPixelQualityProbabilities") << "PU :" << it->first << "  \n ";
    for (const auto &entry : it->second) {
      edm::LogVerbatim("SiPixelQualityProbabilities")
          << "SiPixelQuality snapshot: " << entry.first << " |probability: " << entry.second << std::endl;
    }
  }
}

//****************************************************************************//
void SiPixelQualityProbabilities::print(std::ostream &os) const {
  for (auto it = m_probabilities.begin(); it != m_probabilities.end(); ++it) {
    os << "PU :" << it->first << "  \n ";
    for (const auto &entry : it->second) {
      os << "SiPixelQuality snapshot: " << entry.first << " |probability: " << entry.second << std::endl;
    }
  }
}

//****************************************************************************//
std::vector<unsigned int> SiPixelQualityProbabilities::getPileUpBins() const {
  std::vector<unsigned int> bins;
  bins.reserve(m_probabilities.size());

  for (auto it = m_probabilities.begin(); it != m_probabilities.end(); ++it) {
    bins.push_back(it->first);
  }
  return bins;
}

//****************************************************************************//
std::ostream &operator<<(std::ostream &os, SiPixelQualityProbabilities theProbabilities) {
  std::stringstream ss;
  theProbabilities.print(ss);
  os << ss.str();
  return os;
}