21 #include "KVIDZAGrid.h"
22 #include "KVIDZALine.h"
23 #include "KVIDCutLine.h"
26 #include "KVIdentificationResult.h"
44 KVIDZAGrid::~KVIDZAGrid()
105 gROOT->ProcessLine(
"if(gROOT->FindObject(\"gIDGridEditorCanvas\")) gIDGridEditor->Clear()");
115 TIter next_id(tmplist);
161 UInt_t idx_max = nlines - 1;
164 UInt_t idx = ((UInt_t) z - 1 > idx_max ? idx_max : (UInt_t) z - 1);
166 while (idx_max > idx_min + 1) {
169 Int_t zline = line->
GetZ();
180 idx += (Int_t)((idx_max - idx) / 2 + 0.5);
185 idx -= (Int_t)((idx - idx_min) / 2 + 0.5);
190 if (line->
GetZ() == z) {
195 if (line->
GetZ() == z) {
226 if (line->
GetA() == a) {
231 if (a > line->
GetA()) {
234 if (line->
GetZ() != z)
236 if (line->
GetA() == a) {
244 else if (a < line->GetA()) {
245 for (
int i = idx; i > 0; i--) {
247 if (line->
GetZ() != z)
249 if (line->
GetA() == a) {
317 if (!obj->InheritsFrom(
"KVIDZALine"))
continue;
327 Int_t Z = _line->
GetZ();
339 i_other = (Zhi > -1 ? i + 1 : (Zlo > -1 ? i - 1 : -1));
343 i_other = (Zhi == Z ? i + 1 : (Zlo == Z ? i - 1 : -1));
346 i_other = (Zhi > -1 ? i + 1 : (Zlo > -1 ? i - 1 : -1));
394 Double_t oldD_L = D_L;
401 D_L = TMath::Abs(TMath::Max(D_L, oldD_L));
433 Double_t oldD_R = D_R;
440 D_R = TMath::Abs(TMath::Max(D_R, oldD_R));
470 if (!gPad->GetListOfPrimitives()->GetSize()) {
564 if (
fLinf->InheritsFrom(
"KVIDZALine")) {
571 if (
fLsup->InheritsFrom(
"KVIDZALine")) {
582 if (
fLsup->InheritsFrom(
"KVIDZALine")) {
589 if (
fLinf->InheritsFrom(
"KVIDZALine")) {
597 Error(
"FindFourEmbracingLines",
598 "I do not understand the result of FindNearestEmbracingIDLine!!!");
610 if (
fLinfi->InheritsFrom(
"KVIDZALine")) {
624 if (
fLsups->InheritsFrom(
"KVIDZALine")) {
673 Double_t dist = dt / dA;
691 x2 = 0.5 * TMath::Max(x2, dist);
692 y2 = TMath::Min(y2, x2);
698 y2 = 0.5 * TMath::Max(y2, dist);
720 x1 = 0.5 * TMath::Max(x1, dist);
721 y1 = -TMath::Min(y1, x1);
727 y1 = -0.5 * TMath::Max(y1, dist);
750 Double_t x1 = y2 / ix2 / 2.;
751 y1 = TMath::Max(y1, x1);
752 y1 = -TMath::Min(y1, dt / 2.);
758 y2 = TMath::Min(y1, y2);
760 y1 = -TMath::Min(y1, dt / 2.);
768 y1 = -TMath::Min(y1, dt / 2.);
785 Double_t x2 = -y1 / ix1 / 2.;
786 y2 = TMath::Max(y2, x2);
787 y2 = TMath::Min(y2, dt / 2.);
792 y1 = -TMath::Min(y2, y1 / 2.);
794 y2 = TMath::Min(y2, dt / 2.);
801 y2 = TMath::Min(y2, dt / 2.);
821 Double_t x1 = y2 / ix2 / 2.;
822 y1 = -TMath::Max(y1, x1);
828 y2 = TMath::Min(y1, y2);
852 else if (
kinf > -1) {
868 Double_t x2 = -y1 / ix1 / 2.;
869 y2 = TMath::Max(y2, x2);
874 y1 = -TMath::Min(y2, y1 / 2.);
909 Double_t deltaA = 0.;
911 Double_t dt, dist = y1 * y2;
915 dt = -(y1 + y2) / dist;
922 else if (ix2 == -ix1 * 2) {
923 Double_t tmp = y1 * y1 - 4. * dist;
924 if (tmp > 0 && dist != 0) {
925 dt = -(y1 + 2. * y2 -
926 TMath::Sqrt(tmp)) / dist / 2.;
933 else if (ix1 == -ix2 * 2) {
934 Double_t tmp = y2 * y2 - 4. * dist;
935 if (tmp > 0 && dist != 0) {
936 dt = -(y2 + 2. * y1 +
937 TMath::Sqrt(tmp)) / dist / 2.;
946 if (TMath::Abs(dist) < 0.001) {
948 deltaA = yy * ix2 / y2 / 2.;
954 if (dist > -1. && dt * yy > -1.)
955 deltaA = ix2 / 2. / TMath::Log(1. + dist) * TMath::Log(1. + dt * yy);
973 if (nextline->
GetZ() == Z
974 && !((
KVIDLine*)nextline)->IsBetweenEndPoints(x, y,
"x")) {
986 if (idx > -1 && --idx >= 0) {
988 if (nextline->
GetZ() == Z
989 && !((
KVIDLine*)nextline)->IsBetweenEndPoints(x, y,
"x")) {
1047 da += das * TMath::Sqrt(Z);
1049 int aa = TMath::Nint(A);
1093 Double_t yy, y1, y2;
1105 Double_t dist = dt / (1.0 * dZ);
1124 y2 = 0.5 * TMath::Max(y2, dist);
1148 y1 = -0.5 * TMath::Max(y1, dist);
1171 Double_t x1 = y2 / ix2 / 2.;
1172 y1 = -TMath::Max(y1, x1);
1193 else if (
kinf > -1) {
1208 Double_t x2 = -y1 / ix1 / 2.;
1209 y2 = TMath::Max(y2, x2);
1248 Double_t deltaZ = 0.;
1250 Double_t dt, dist = y1 * y2;
1254 dt = -(y1 + y2) / dist;
1261 else if (ix2 == -ix1 * 2) {
1262 Double_t tmp = y1 * y1 - 4. * dist;
1263 if (tmp > 0. && dist != 0) {
1264 dt = -(y1 + 2. * y2 -
1265 TMath::Sqrt(tmp)) / dist / 2.;
1272 else if (ix1 == -ix2 * 2) {
1273 Double_t tmp = y2 * y2 - 4. * dist;
1274 if (tmp > 0. && dist != 0) {
1275 dt = -(y2 + 2. * y1 +
1276 TMath::Sqrt(tmp)) / dist / 2.;
1285 if (TMath::Abs(dist) < 0.001) {
1287 deltaZ = yy * ix2 / y2 / 2.;
1293 if (dist > -1. && dt * yy > -1.)
1294 deltaZ = ix2 / 2. / TMath::Log(1. + dist) * TMath::Log(1. + dt * yy);
1326 if (idx > -1 && --idx >= 0) {
1403 idr->
SetComment(
"no identification: (x,y) out of range covered by grid");
1425 idr->
SetComment(
"slight ambiguity of Z, which could be larger");
1428 idr->
SetComment(
"slight ambiguity of Z, which could be smaller");
1431 idr->
SetComment(
"slight ambiguity of Z, which could be larger or smaller");
1434 idr->
SetComment(
"point is in between two lines of different Z, too far from either to be considered well-identified");
1437 idr->
SetComment(
"point is in between two lines of different Z, too far from either to be considered well-identified");
1440 idr->
SetComment(
"(x,y) is below first line in grid");
1443 idr->
SetComment(
"(x,y) is above last line in grid");
1446 idr->
SetComment(
"no identification: (x,y) out of range covered by grid");
1471 idr->
SetComment(
"slight ambiguity of A, which could be larger");
1474 idr->
SetComment(
"slight ambiguity of A, which could be smaller");
1477 idr->
SetComment(
"slight ambiguity of A, which could be larger or smaller");
1480 idr->
SetComment(
"point is in between two isotopes of different Z, too far from either to be considered well-identified");
1483 idr->
SetComment(
"point is in between two isotopes of different Z, too far from either to be considered well-identified");
1486 idr->
SetComment(
"(x,y) is below first line in grid");
1489 idr->
SetComment(
"(x,y) is above last line in grid");
1492 idr->
SetComment(
"no identification: (x,y) out of range covered by grid");
1529 void KVIDZAGrid::Streamer(TBuffer& R__b)
1534 if (R__b.IsReading()) {
1535 Version_t R__v = R__b.ReadVersion(&R__s, &R__c);
1537 R__v = R__b.ReadVersion(&R__s, &R__c);
1539 Warning(
"Streamer",
"Reading KVIDZGrid with version=%d", R__v);
1541 KVIDGrid::Streamer(R__b);
1545 R__b.ReadClassBuffer(KVIDZAGrid::Class(),
this, R__v, R__s, R__c);
1549 R__b.WriteClassBuffer(KVIDZAGrid::Class(),
this);
1680 if (!graph_class) graph_class = IsA();
1681 if (!graph_class->InheritsFrom(
"KVIDGraph")) {
1682 Error(
"MakeSubsetGraph",
"Called with graph class %s, does not derive from KVIDGraph",
1683 graph_class->GetName());
1690 new_graph->
SetVarX(GetVarX());
1691 new_graph->
SetVarY(GetVarY());
1724 TList* lines =
new TList;
1728 if (l->
GetZ() >= Zmin && l->
GetZ() <= Zmax) lines->Add(l);
1731 if (strcmp(graph_class,
"")) cl = TClass::GetClass(graph_class);
1752 void KVIDZGrid::Streamer(TBuffer& R__b)
1757 if (R__b.IsReading()) {
1758 Version_t R__v = R__b.ReadVersion(&R__s, &R__c);
1760 Warning(
"Streamer",
"Reading KVIDZGrid with version=%d", R__v);
1762 KVIDGrid::Streamer(R__b);
Base class for particle identification in a 2D map.
virtual void SetVarX(const char *v)
void RemoveIdentifier(KVIDentifier *)
Remove and destroy identifier.
KVList fIdentifiers
list of identification objects
void Draw(Option_t *opt="")
Int_t GetNumberOfIdentifiers() const
virtual void Copy(TObject &) const
Copy this to 'obj'.
Int_t GetMassFormula() const
const KVList * GetCuts() const
KVIDentifier * GetIdentifierAt(Int_t index) const
const KVNumberList & GetRuns() const
void FindAxisLimits()
Calculate X/Y min/max of all objects in graph.
virtual void SetVarY(const char *v)
const KVNameValueList * GetParameters() const
void SetMassFormula(Int_t)
const Char_t * GetName() const
TList fTelescopes
ID telescopes for which grid is valid.
virtual KVIDentifier * New(const Char_t *)
Create new object of class "id_class" which derives from KVIDentifier.
void AddIDTelescopes(const TList *)
Associate this graph with all ID telescopes in list.
virtual void AddIdentifier(KVIDentifier *id)
virtual void SetInfos(Double_t, Double_t, KVIdentificationResult *) const
loop over KVIDGraph::fInfoZones to set flags in KVIdentificationResult
void SetRuns(const KVNumberList &nl)
Set list of runs for which grid is valid.
virtual void SetOnlyZId(Bool_t yes=kTRUE)
const KVList * GetIdentifiers() const
KVIDLine * FindNearestEmbracingIDLine(Double_t x, Double_t y, const Char_t *position, const Char_t *axis, Int_t &idx, Int_t &idx_min, Int_t &idx_max, Double_t &dist, Double_t &dist_min, Double_t &dist_max) const
KVIDLine * FindNextEmbracingLine(Int_t &index, Int_t inc_index, Double_t x, Double_t y, const Char_t *axis) const
Base class for lines/cuts used for particle identification in 2D data maps.
Double_t DistanceToLine(Double_t px, Double_t py, Int_t &)
void GetStartPoint(Double_t &x, Double_t &y) const
Bool_t IsBetweenEndPoints(Double_t x, Double_t y, const Char_t *axis="") const
void GetEndPoint(Double_t &x, Double_t &y) const
Identification grid with lines corresponding to different nuclear isotopes (KVIDZALine)
Double_t fDistanceClosest
distance from point to closest line
virtual void CalculateLineWidths()
void init()
initialisation
KVIDLine * fClosest
closest line to last-identified point
void ReCheckQuality(Int_t &Z, Double_t &A)
virtual KVIDZALine * GetZLine(Int_t z, Int_t &) const
virtual void Copy(TObject &) const
Copy this to 'obj'.
void DrawLinesWithWidth()
void RemoveZLines(const Char_t *ZList)
Remove and destroy identifiers.
virtual void IdentZ(Double_t x, Double_t y, Double_t &Z)
virtual void Identify(Double_t x, Double_t y, KVIdentificationResult *) const
KVIDZALine * fZMaxLine
line with biggest Z and A
Int_t ksups
used by IdentZA and IdentZ
virtual void Initialize()
UShort_t fZMax
largest Z of lines in grid
KVIDZAGrid()
default ctor.
virtual void IdentZA(Double_t x, Double_t y, Int_t &Z, Double_t &A)
Int_t fIdxClosest
index of closest line in main list fIdentifiers
Int_t fICode
code de retour
Int_t Zint
Z of line used to identify particle.
void SetManualWidth(Double_t manual_width=.3, Double_t manual_width_scaling=0.05)
KVIDGraph * MakeSubsetGraph(Int_t Zmin, Int_t Zmax, const Char_t *="")
virtual void MakeEDeltaEZGrid(Int_t Zmin, Int_t Zmax, Int_t npoints=20, Double_t gamma = 2);//*MENU*
virtual Bool_t FindFourEmbracingLines(Double_t x, Double_t y, const Char_t *position)
Int_t Aint
mass of line used to identify particle
void RemoveLine(Int_t Z, Int_t A=-1)
Remove and destroy identifier.
virtual KVIDZALine * GetZALine(Int_t z, Int_t a, Int_t &) const
Base class for identification ridge lines corresponding to different nuclear species.
virtual void SetAsymWidth(Double_t d_l, Double_t d_r)
TGraphErrors * GetLineWithWidth()
void SetWidth(Double_t w)
Base class for graphical cuts used in particle identification.
virtual Int_t GetA() const
virtual Int_t GetZ() const
Full result of one attempted particle identification.
Bool_t IDOK
general quality of identification, =kTRUE if acceptable identification made
void SetComment(const Char_t *c)
Bool_t Aident
= kTRUE if A of particle established
Double_t PID
= "real" Z if Zident==kTRUE and Aident==kFALSE, "real" A if Zident==Aident==kTRUE
Int_t A
A of particle found (if Aident==kTRUE)
Int_t Z
Z of particle found (if Zident==kTRUE)
Int_t IDquality
specific quality code returned by identification procedure
Bool_t Zident
=kTRUE if Z of particle established
Extended TList class which owns its objects by default.
Double_t GetDoubleValue(const Char_t *name) const
void SetValue(const Char_t *name, value_type value)
Description of properties and kinematics of atomic nuclei.
Double_t GetLifeTime(Int_t z=-1, Int_t a=-1) const
Strings used to represent a set of ranges of values.
KVSeqCollection * GetSubListWithMethod(const Char_t *retvalue, const Char_t *method) const
virtual TObject * Last() const