Flags

HGCUncalibratedRecHit

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 52 53 54 55 56 57 58 59 60 61 62 63 64 65
#ifndef DATAFORMATS_HGCUNCALIBRATEDRECHIT
#define DATAFORMATS_HGCUNCALIBRATEDRECHIT

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

class HGCUncalibratedRecHit {
public:
  typedef DetId key_type;

  enum Flags {
    kGood = -1,  // channel is good (mutually exclusive with other states)  setFlagBit(kGood) reset flags_ to zero
    kPoorReco,   // channel has been badly reconstructed (e.g. bad shape, bad chi2 etc.)
    kSaturated,  // saturated channel
    kOutOfTime   // channel out of time
  };

  HGCUncalibratedRecHit();
  HGCUncalibratedRecHit(
      const DetId& detId, float ampl, float ped, float jit, float chi2, uint32_t flags = 0, uint32_t aux = 0);

  virtual ~HGCUncalibratedRecHit();
  float amplitude() const { return amplitude_; }
  float pedestal() const { return pedestal_; }
  float jitter() const { return jitter_; }
  float chi2() const { return chi2_; }
  float outOfTimeEnergy() const { return OOTamplitude_; }
  float outOfTimeChi2() const { return OOTchi2_; }

  uint32_t flags() const { return flags_; }
  float jitterError() const;
  uint8_t jitterErrorBits() const;
  DetId id() const { return id_; }

  void setAmplitude(float amplitude) { amplitude_ = amplitude; }
  void setPedestal(float pedestal) { pedestal_ = pedestal; }
  void setJitter(float jitter) { jitter_ = jitter; }
  void setChi2(float chi2) { chi2_ = chi2; }
  void setOutOfTimeEnergy(float energy) { OOTamplitude_ = energy; }
  void setOutOfTimeChi2(float chi2) { OOTchi2_ = chi2; }

  void setJitterError(float jitterErr);
  void setFlags(uint32_t flags) { flags_ = flags; }
  void setId(DetId id) { id_ = id; }
  void setAux(uint32_t aux) { aux_ = aux; }
  void setFlagBit(Flags flag);
  bool checkFlag(Flags flag) const;

  bool isSaturated() const;
  bool isJitterValid() const;
  bool isJitterErrorValid() const;

private:
  float amplitude_;     //< Reconstructed amplitude
  float pedestal_;      //< Reconstructed pedestal
  float jitter_;        //< Reconstructed time jitter
  float chi2_;          //< Chi2 of the pulse
  float OOTamplitude_;  //< Out-Of-Time reconstructed amplitude
  float OOTchi2_;       //< Out-Of-Time Chi2
  uint32_t flags_;      //< flag to be propagated to RecHit
  uint32_t aux_;        //< aux word; first 8 bits contain time (jitter) error
  DetId id_;            //< Detector ID
};

#endif