File indexing completed on 2024-04-06 12:04:21
0001 #ifndef DATAFORMATS_HGCUNCALIBRATEDRECHIT
0002 #define DATAFORMATS_HGCUNCALIBRATEDRECHIT
0003
0004 #include <vector>
0005 #include "DataFormats/DetId/interface/DetId.h"
0006
0007 class HGCUncalibratedRecHit {
0008 public:
0009 typedef DetId key_type;
0010
0011 enum Flags {
0012 kGood = -1,
0013 kPoorReco,
0014 kSaturated,
0015 kOutOfTime
0016 };
0017
0018 HGCUncalibratedRecHit();
0019 HGCUncalibratedRecHit(
0020 const DetId& detId, float ampl, float ped, float jit, float chi2, uint32_t flags = 0, uint32_t aux = 0);
0021
0022 virtual ~HGCUncalibratedRecHit();
0023 float amplitude() const { return amplitude_; }
0024 float pedestal() const { return pedestal_; }
0025 float jitter() const { return jitter_; }
0026 float chi2() const { return chi2_; }
0027 float outOfTimeEnergy() const { return OOTamplitude_; }
0028 float outOfTimeChi2() const { return OOTchi2_; }
0029
0030 uint32_t flags() const { return flags_; }
0031 float jitterError() const;
0032 uint8_t jitterErrorBits() const;
0033 DetId id() const { return id_; }
0034
0035 void setAmplitude(float amplitude) { amplitude_ = amplitude; }
0036 void setPedestal(float pedestal) { pedestal_ = pedestal; }
0037 void setJitter(float jitter) { jitter_ = jitter; }
0038 void setChi2(float chi2) { chi2_ = chi2; }
0039 void setOutOfTimeEnergy(float energy) { OOTamplitude_ = energy; }
0040 void setOutOfTimeChi2(float chi2) { OOTchi2_ = chi2; }
0041
0042 void setJitterError(float jitterErr);
0043 void setFlags(uint32_t flags) { flags_ = flags; }
0044 void setId(DetId id) { id_ = id; }
0045 void setAux(uint32_t aux) { aux_ = aux; }
0046 void setFlagBit(Flags flag);
0047 bool checkFlag(Flags flag) const;
0048
0049 bool isSaturated() const;
0050 bool isJitterValid() const;
0051 bool isJitterErrorValid() const;
0052
0053 private:
0054 float amplitude_;
0055 float pedestal_;
0056 float jitter_;
0057 float chi2_;
0058 float OOTamplitude_;
0059 float OOTchi2_;
0060 uint32_t flags_;
0061 uint32_t aux_;
0062 DetId id_;
0063 };
0064
0065 #endif