EcalUncalibratedRecHit

Flags

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 66 67 68 69 70 71 72 73 74 75 76
#ifndef DATAFORMATS_ECALUNCALIBRATEDRECHIT
#define DATAFORMATS_ECALUNCALIBRATEDRECHIT

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

class EcalUncalibratedRecHit {
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
    kLeadingEdgeRecovered,  // saturated channel: energy estimated from the leading edge before saturation
    kHasSwitchToGain6,      // at least one data frame is in G6
    kHasSwitchToGain1       // at least one data frame is in G1

  };

  EcalUncalibratedRecHit();

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

  float amplitude() const { return amplitude_; }
  float amplitudeError() const { return amplitudeError_; }
  float pedestal() const { return pedestal_; }
  float jitter() const { return jitter_; }
  float chi2() const { return chi2_; }
  float outOfTimeAmplitude(int bx) const { return OOTamplitudes_[bx]; }

  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 setAmplitudeError(float amplitudeerror) { amplitudeError_ = amplitudeerror; }
  void setPedestal(float pedestal) { pedestal_ = pedestal; }
  void setJitter(float jitter) { jitter_ = jitter; }
  void setChi2(float chi2) { chi2_ = chi2; }
  void setOutOfTimeAmplitude(int bx, float amplitude) { OOTamplitudes_[bx] = amplitude; }

  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;

  // For CC Timing reco
  float nonCorrectedTime() const;
  void setNonCorrectedTime(const float correctedJittter, const float nonCorrectedJitter);

private:
  float amplitude_;       //< Reconstructed amplitude
  float amplitudeError_;  //< Reconstructed amplitude uncertainty
  float pedestal_;        //< Reconstructed pedestal
  float jitter_;          //< Reconstructed time jitter
  float chi2_;            //< Chi2 of the pulse
  //< Out-Of-Time reconstructed amplitude, one for each active BX, from readout sample 0 to 9
  float OOTamplitudes_[EcalDataFrame::MAXSAMPLES];
  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