EcalTimeDigi

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 44 45 46 47 48 49 50 51
#ifndef _DataFormats_EcalDigi_ECALTIMEDIGI_H_
#define _DataFormats_EcalDigi_ECALTIMEDIGI_H_

#include <ostream>
#include <vector>
#include "DataFormats/DetId/interface/DetId.h"

class EcalTimeDigi {
public:
  typedef DetId key_type;  ///< For the sorted collection

  EcalTimeDigi();  // for persistence
  explicit EcalTimeDigi(const DetId& id);

  void swap(EcalTimeDigi& rh) {
    std::swap(id_, rh.id_);
    std::swap(size_, rh.size_);
    std::swap(waveform_, rh.waveform_);
    std::swap(data_, rh.data_);
  }

  const DetId& id() const { return id_; }
  int size() const { return size_; }

  const float& operator[](unsigned int i) const { return data_[i]; }
  const float& sample(unsigned int i) const { return data_[i]; }

  void setSize(unsigned int size);
  void setWaveform(float* waveform);
  void setSample(unsigned int i, const float sam) { data_[i] = sam; }
  void setSampleOfInterest(int i) { sampleOfInterest_ = i; }

  /// Gets the BX==0 sample. If =-1 then it means that only OOT hits are present
  int sampleOfInterest() const { return sampleOfInterest_; }
  std::vector<float> waveform() const { return waveform_; }

  static const unsigned int WAVEFORMSAMPLES = 250;

private:
  DetId id_;
  unsigned int size_;
  int sampleOfInterest_;
  std::vector<float> waveform_;
  std::vector<float> data_;
};

inline void swap(EcalTimeDigi& lh, EcalTimeDigi& rh) { lh.swap(rh); }

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

#endif