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
|