SiPixelQualityProbabilities

Macros

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
#ifndef CondFormats_SiPixelObjects_SiPixelQualityProbabilities_h
#define CondFormats_SiPixelObjects_SiPixelQualityProbabilities_h

#include "CondFormats/Serialization/interface/Serializable.h"

#include <map>
#include <string>
#include <vector>

class SiPixelQualityProbabilities {
public:
  typedef std::vector<std::pair<std::string, float> > probabilityVec;
  typedef std::map<unsigned int, probabilityVec> probabilityMap;

  SiPixelQualityProbabilities() {}
  SiPixelQualityProbabilities(const SiPixelQualityProbabilities& rhs) { m_probabilities = rhs.getProbability_Map(); };
  virtual ~SiPixelQualityProbabilities() {}

  void setProbabilities(const unsigned int puBin, const probabilityVec& theProbabilities);

  const probabilityMap& getProbability_Map() const { return m_probabilities; }

  probabilityVec getProbabilities(const unsigned int puBin) const;
  const probabilityVec& getProbabilities(const unsigned int puBin);

  double size() const { return m_probabilities.size(); }
  double nelements(const int puBin) const { return m_probabilities.at(puBin).size(); }
  std::vector<unsigned int> getPileUpBins() const;

  void printAll() const;

  //dumping values on output stream
  void print(std::ostream& os) const;

private:
  probabilityMap m_probabilities;

  COND_SERIALIZABLE;
};

std::ostream& operator<<(std::ostream&, SiPixelQualityProbabilities theProbabilities);

#endif  //CondFormats_SiPixelObjects_SiPixelQualityProbabilities_h