HcalHistogramDigi

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
#ifndef DATAFORMATS_HCALDIGI_HCALHISTOGRAMDIGI_H
#define DATAFORMATS_HCALDIGI_HCALHISTOGRAMDIGI_H 1

#include <ostream>
#include "DataFormats/HcalDetId/interface/HcalDetId.h"
#include <cstdint>

/** \class HcalHistogramDigi
  *  
  * \author J. Mans - Minnesota
  */
class HcalHistogramDigi {
public:
  typedef HcalDetId key_type;  ///< For the sorted collection

  HcalHistogramDigi();  // For persistence
  explicit HcalHistogramDigi(const HcalDetId& id);

  const HcalDetId& id() const { return id_; }
  /// get the contents of the specified bin for the specified capid (0-3)
  uint16_t get(int capid, int bin) const;
  /// get the contents of the specified bin summed over capids
  int getSum(int bin) const;

  /// get the array for the specified capid
  uint16_t* getArray(int capid);

  static const int BINS_PER_HISTOGRAM = 32;

private:
  HcalDetId id_;
  uint16_t bins_[BINS_PER_HISTOGRAM * 4];
};

std::ostream& operator<<(std::ostream&, const HcalHistogramDigi& digi);

#endif