KaliVeda  1.13/01
Heavy-Ion Analysis Toolkit
KVCalibratedSignal.h
Go to the documentation of this file.
1 
4 #ifndef __KVCALIBRATEDSIGNAL_H
5 #define __KVCALIBRATEDSIGNAL_H
6 
7 #include "KVDetectorSignal.h"
8 #include "KVCalibrator.h"
9 
67 
68  friend class KVDetector;
69 
73 
74 protected:
76  : KVDetectorSignal(output, input->GetDetector()), fInputSignal(input), fCalibrator(nullptr), fInversionFail(false)
77  {
79  SetTitle(Form("Signal %s calculated from signal %s of detector %s", GetName(), input->GetName(), GetDetector()->GetName()));
80  }
82  : KVDetectorSignal(calib->GetOutputSignalType(), input->GetDetector()), fInputSignal(input), fCalibrator(calib), fInversionFail(false)
83  {
85  SetTitle(Form("Signal %s calculated from signal %s of detector %s", GetName(), input->GetName(), GetDetector()->GetName()));
86  }
87 public:
89  : KVDetectorSignal(), fInputSignal(nullptr), fCalibrator(nullptr), fInversionFail(false)
90  {}
92  {}
93 
94  Double_t GetValue(const KVNameValueList& params = "") const;
95  Double_t GetInverseValue(Double_t out_val, const TString& in_sig, const KVNameValueList& params = "") const;
97  {
98  return fInputSignal;
99  }
100 
102  {
103  return fCalibrator;
104  }
105  Bool_t IsRaw() const
106  {
108  return kFALSE;
109  }
111  {
112  return fInversionFail;
113  }
114  virtual Bool_t IsAvailableFor(const KVNameValueList& params) const
115  {
120 
121  Bool_t ok = kTRUE;
122  if (fInputSignal) ok &= fInputSignal->IsAvailableFor(params);
123  if (fCalibrator) ok &= fCalibrator->IsAvailableFor(params);
124  return ok;
125  }
126 
127  ClassDef(KVCalibratedSignal, 1) //Detector signal produced by a calibrator
128 };
129 
130 #endif
const Bool_t kFALSE
bool Bool_t
double Double_t
const Bool_t kTRUE
#define ClassDef(name, id)
char * Form(const char *fmt,...)
Output signal from detector obtained by calibration.
KVCalibrator * fCalibrator
calibrator used to transform input signal
Bool_t InversionFailure() const
KVCalibratedSignal(KVDetectorSignal *input, KVCalibrator *calib)
KVCalibratedSignal(KVDetectorSignal *input, const KVString &output)
virtual Bool_t IsAvailableFor(const KVNameValueList &params) const
Bool_t fInversionFail
set to true when failing to compute an inverted calibrator
KVCalibrator * GetCalibrator() const
KVDetectorSignal * fInputSignal
signal which is used as input to generate calibrated signal
Double_t GetValue(const KVNameValueList &params="") const
KVDetectorSignal * GetInputSignal() const
Double_t GetInverseValue(Double_t out_val, const TString &in_sig, const KVNameValueList &params="") const
Base class for all detector calibrations.
Definition: KVCalibrator.h:98
virtual Bool_t IsAvailableFor(const KVNameValueList &) const
Definition: KVCalibrator.h:201
Base class for output signal data produced by a detector.
virtual Bool_t IsAvailableFor(const KVNameValueList &) const
const KVDetector * GetDetector() const
Base class for detector geometry description.
Definition: KVDetector.h:159
Handles lists of named parameters with different types, a list of KVNamedParameter objects.
Extension of ROOT TString class which allows backwards compatibility with ROOT v3....
Definition: KVString.h:72
virtual const char * GetName() const
virtual void SetTitle(const char *title="")