GRSISort "v4.0.0.5"
An extension of the ROOT analysis Framework
Loading...
Searching...
No Matches
TIfinHit.cxx
Go to the documentation of this file.
1#include "TIfin.h"
2#include "TIfinHit.h"
3#include "Globals.h"
4#include <cmath>
5#include <iostream>
6
9{
10 // Default Ctor. Ignores TObject Streamer in ROOT < 6.
11#if MAJOR_ROOT_VERSION < 6
12 Class()->IgnoreTObjectStreamer(kTRUE);
13#endif
14 Clear();
15}
16
18{
19 // Copy Ctor. Ignores TObject Streamer in ROOT < 6.
20 Clear();
21 rhs.Copy(*this);
22}
23
25{
26}
27
28TIfinHit::~TIfinHit() = default;
29
30void TIfinHit::Copy(TObject& rhs) const
31{
33}
34
35void TIfinHit::Copy(TObject& obj, bool) const
36{
37 Copy(obj);
38}
39
40void TIfinHit::Clear(Option_t* opt)
41{
42 // Clears the information stored in the TIfinHit.
43 TDetectorHit::Clear(opt); // clears the base (address, position and waveform)
44}
45
46void TIfinHit::Print(Option_t*) const
47{
48 // Prints the Detector Number, Crystal Number, Energy, Time and Angle.
49 Print(std::cout);
50}
51
52void TIfinHit::Print(std::ostream& out) const
53{
54 std::ostringstream str;
55 // Prints the Detector Number, Crystal Number, Energy, Time and Angle.
56 str << "Ifin Detector: " << GetDetector() << std::endl;
57 str << "Ifin Crystal: " << GetCrystal() << std::endl;
58 str << "Ifin Energy: " << GetEnergy() << std::endl;
59 str << "Ifin hit time: " << GetTime() << std::endl;
60 str << "Ifin hit TV3 theta: " << GetPosition().Theta() * 180 / (3.141597) << "\tphi: " << GetPosition().Phi() * 180 / (3.141597) << std::endl;
61 out << str.str();
62}
63
64TVector3 TIfinHit::GetPosition(double dist) const
65{
66 return TIfin::GetPosition(GetDetector(), GetCrystal(), dist);
67}
68
69TVector3 TIfinHit::GetPosition() const
70{
72}
73
74bool TIfinHit::CompareEnergy(const TIfinHit* lhs, const TIfinHit* rhs)
75{
76 return (lhs->GetEnergy() > rhs->GetEnergy());
77}
78
80{
81 const TIfinHit* fippsHit = dynamic_cast<const TIfinHit*>(hit);
82 if(fippsHit == nullptr) {
83 throw std::runtime_error("trying to add non-fipps hit to fipps hit!");
84 }
85 // add another griffin hit to this one (for addback),
86 // using the time and position information of the one with the higher energy
87 if(!CompareEnergy(this, fippsHit)) {
88 SetCfd(fippsHit->GetCfd());
89 SetTime(fippsHit->GetTime());
90 // SetPosition(fippsHit->GetPosition());
91 SetAddress(fippsHit->GetAddress());
92 }
93 SetEnergy(GetEnergy() + fippsHit->GetEnergy());
94 // this has to be done at the very end, otherwise GetEnergy() might not work
95 SetCharge(0);
96 // KValue is somewhate meaningless in addback, so I am using it as an indicator that a piledup hit was added-back RD
97 if(GetKValue() > fippsHit->GetKValue()) {
98 SetKValue(fippsHit->GetKValue());
99 }
100}
101
102Double_t TIfinHit::GetNoCTEnergy(Option_t*) const
103{
104 TChannel* chan = GetChannel();
105 if(chan == nullptr) {
106 Error("GetEnergy", "No TChannel exists for address 0x%08x", GetAddress());
107 return 0.;
108 }
109 return chan->CalibrateENG(Charge(), GetKValue());
110}
double CalibrateENG(double) const
Definition TChannel.cxx:668
void SetKValue(const Short_t &temp_kval)
!
Double_t SetEnergy(const double &energy) const
virtual UInt_t GetAddress() const
!
virtual void SetCfd(const Float_t &val)
!
virtual double GetEnergy(Option_t *opt="") const
virtual Short_t GetKValue() const
!
virtual Int_t GetCrystal() const
!
virtual Float_t Charge() const
!
TChannel * GetChannel() const
!
void SetCharge(const Float_t &temp_charge)
!
void Clear(Option_t *opt="") override
!
virtual Int_t GetDetector() const
!
virtual Float_t GetCfd() const
!
void Copy(TObject &) const override
!
virtual Double_t GetTime(const ETimeFlag &correct_flag=ETimeFlag::kAll, Option_t *opt="") const
Returns a time value to the nearest nanosecond!
void SetAddress(const UInt_t &temp_address)
!
Double_t SetTime(const Double_t &time) const
void Clear(Option_t *opt="") override
!
Definition TIfinHit.cxx:40
Double_t GetDefaultDistance() const
Definition TIfinHit.h:47
void Copy(TObject &) const override
!
Definition TIfinHit.cxx:30
static bool CompareEnergy(const TIfinHit *, const TIfinHit *)
!
Definition TIfinHit.cxx:74
~TIfinHit() override
TVector3 GetPosition() const override
!
Definition TIfinHit.cxx:69
Double_t GetNoCTEnergy(Option_t *opt="") const
Definition TIfinHit.cxx:102
void Print(Option_t *opt="") const override
!
Definition TIfinHit.cxx:46
void Add(const TDetectorHit *) override
!
Definition TIfinHit.cxx:79
static TVector3 GetPosition(int DetNbr, int CryNbr=5, double dist=90.0)
!
Definition TIfin.cxx:435