11 #include "KVTGIDManager.h"
12 #include "KVTGIDGrid.h"
32 KVTGIDManager::~KVTGIDManager()
109 const Char_t* id_type,
110 const Char_t* grid_type)
129 const Char_t* id_type,
130 const Char_t* grid_type)
136 return (Form(
"%s_%s_%s", idt_name, id_type, grid_type));
154 Double_t
KVTGIDManager::IdentZ(
const Char_t* idtelescope_name, Double_t id_map_X, Double_t id_map_Y, Double_t& funLTG,
155 const Char_t* grid_type)
180 _tgid->SetParameter(
"X", id_map_X);
181 _tgid->SetParameter(
"Y", id_map_Y);
183 Double_t Zfound = -1.;
186 if ((Int_t) Zmax == (Int_t)
GetIDmax()) {
225 Double_t
KVTGIDManager::IdentA(
const Char_t* idtelescope_name, Double_t id_map_X, Double_t id_map_Y, Double_t& funLTG,
226 const Char_t* grid_type, Int_t Z)
258 _tgid->SetParameter(
"X", id_map_X);
259 _tgid->SetParameter(
"Y", id_map_Y);
260 _tgid->SetParameter(
"Z", Z);
262 Double_t Afound = -1., Amin, Amax;
286 Amin = TMath::Max((Z + 1.), (1.8 * (Z - 2.) + 1.));
312 Double_t xmax, Double_t xmin,
313 Int_t ID_min, Int_t ID_max,
314 Int_t npoints, Bool_t logscale)
324 gr->
Generate(xmax, xmin, ID_min, ID_max, npoints, logscale);
337 Double_t xmax, Double_t xmin,
338 Int_t ID_min, Int_t ID_max,
339 Int_t npoints, Bool_t logscale)
346 return GetTGIDGrid(
GetTGID(tgid_name), xmax, xmin, ID_min, ID_max, npoints, logscale);
360 const Char_t* id_type,
361 const Char_t* grid_type,
362 Double_t xmax, Double_t xmin,
363 Int_t ID_min, Int_t ID_max,
364 Int_t npoints, Bool_t logscale)
373 xmin, ID_min, ID_max, npoints, logscale);
390 static TString messages[] = {
392 "no KVTGID for requested identification",
393 "point to identify outside of identification range of function",
394 "IdentA called with Z<1",
395 "IdentA called with Z larger than max Z defined for KVTGIDZA isotopic identification object"
399 return messages[status];
400 return Form(
"no call to IdentZ()/IdentA() performed yet");
virtual void Add(TObject *obj)
virtual TObject * Remove(TObject *obj)
Remove object from list.
virtual void Delete(Option_t *option="")
virtual TObject * FindObject(const char *name) const
Grid representing result of fit.
virtual void Generate(Double_t xmax, Double_t xmin, Int_t ID_min=0, Int_t ID_max=0, Int_t npoints=50, Bool_t logscale=kTRUE)
Handles a set of Tassan-Got functional-based identifications (KVTGID objects) for use by a KVIDTelesc...
virtual void RemoveTGID(const Char_t *name)
Delete the identification object with name.
virtual const Char_t * GetStatusString(ETGIDMStatus s=kCurrentStatus) const
virtual void RemoveAllTGID()
Delete all identification objects.
Double_t fID_max
maximum ID of all TGID objects
KVList fIDList
KVTGID objects for identifications.
virtual Double_t IdentA(const Char_t *, Double_t, Double_t, Double_t &funLTG, const Char_t *grid_type, Int_t Z)
virtual KVTGIDGrid * GetTGIDGrid(KVTGID *tgid, Double_t xmax, Double_t xmin=0., Int_t ID_min=0, Int_t ID_max=0, Int_t npoints=100, Bool_t logscale=kFALSE)
virtual void AddTGID(KVTGID *)
const Char_t * GetTGIDName(const Char_t *idt_name, const Char_t *id_type, const Char_t *grid_type)
ETGIDMStatus
status codes for IdentZ/IdentA
Int_t fStatus
transient member used to hold status of last call to IdentZ/IdentA
Double_t GetIDmax() const
virtual Int_t GetStatus() const
virtual Double_t IdentZ(const Char_t *, Double_t, Double_t, Double_t &funLTG, const Char_t *grid_type)
KVTGID * GetTGID(const Char_t *name)
Retrieve the identification object with name.
Abstract base class for particle identfication using functionals developed by L. Tassan-Got (IPN Orsa...
@ kStatus_NotBetween_IDMin_IDMax
Double_t GetIDmin() const
Double_t GetIDmax() const
virtual Int_t GetStatus() const
virtual Double_t GetIdentification(Double_t ID_min, Double_t ID_max, Double_t &ID_quality, Double_t *par=0)