TCutG
class description - source file - inheritance tree
public:
TCutG TCutG()
TCutG TCutG(const char* name, Int_t n)
TCutG TCutG(const char* name, Int_t n, Float_t* x, Float_t* y)
TCutG TCutG(const char* name, Int_t n, Double_t* x, Double_t* y)
TCutG TCutG(TCutG&)
virtual void ~TCutG()
static TClass* Class()
TObject* GetObjectX() const
TObject* GetObjectY() const
const char* GetVarX() const
const char* GetVarY() const
virtual TClass* IsA() const
virtual Int_t IsInside(Double_t x, Double_t y) const
virtual void SavePrimitive(ofstream& out, Option_t* option)
virtual void SetObjectX(TObject* obj)
virtual void SetObjectY(TObject* obj)
virtual void SetVarX(const char* varx)
virtual void SetVarY(const char* vary)
virtual void ShowMembers(TMemberInspector& insp, char* parent)
virtual void Streamer(TBuffer& b)
void StreamerNVirtual(TBuffer& b)
protected:
TString fVarX X variable
TString fVarY Y variable
TObject* fObjectX pointer to an object corresponding to X
TObject* fObjectY pointer to an object corresponding to Y
TCutG
A Graphical cut.
A TCutG object defines a closed polygon in a x,y plot.
It can be created via the graphics editor option "CutG"
or directly by invoking its constructor.
When it is created via the graphics editor, the TCutG object
is named "CUTG". It is recommended to immediatly change the name
by using the context menu item "SetName". //
When the graphics editor is used, the names of the variables X,Y
are automatically taken from the current pad title.
Example:
Assume a TTree object T and:
Root > T.Draw("abs(fMomemtum)%fEtot")
the TCutG members fVarX, fVary will be set to:
fVarx = fEtot
fVary = abs(fMomemtum)
A graphical cut can be used in a TTree selection expression:
Root > T.Draw("fEtot","cutg1")
where "cutg1" is the name of an existing graphical cut.
Note that, as shown in the example above, a graphical cut may be
used in a selection expression when drawing TTrees expressions
of 1-d, 2-d or 3-dimensions.
The TTree expressions may or may not reference the same variables
than in the fVarX, fVarY of the graphical cut.
When the TCutG object is created, it is added to the list of special
objects in the main TROOT object pointed by gROOT. To retrieve a
pointer to this object from the code or command line, do:
TCutG *mycutg;
mycutg = (TCutG*)gROOT->GetListOfSpecials()->FindObject("CUTG")
mycutg->SetName("mycutg");
A Graphical cut may be drawn via TGraph::Draw.
It can be edited like a normal TGraph.
A Graphical cut may be saved to a file via TCutG::Write. //
TCutG() : TGraph()
TCutG(const char *name, Int_t n)
:TGraph(n)
TCutG(const char *name, Int_t n, Float_t *x, Float_t *y)
:TGraph(n,x,y)
TCutG(const char *name, Int_t n, Double_t *x, Double_t *y)
:TGraph(n,x,y)
~TCutG()
Int_t IsInside(Double_t x, Double_t y) const
*. Function which returns 1 if point x,y lies inside the
*. polygon defined by the graph points
*. 0 otherwise
*.
*. The loop is executed with the end-point coordinates of a
*. line segment (X1,Y1)-(X2,Y2) and the Y-coordinate of a
*. horizontal line.
*. The counter inter is incremented if the line (X1,Y1)-(X2,Y2)
*. intersects the horizontal line.
*. In this case XINT is set to the X-coordinate of the
*. intersection point.
*. If inter is an odd number, then the point x,y is within
*. the polygon.
*.
*. This routine is based on an original algorithm
*. developed by R.Nierhaus.
*.
void SavePrimitive(ofstream &out, Option_t *option)
Save primitive as a C++ statement(s) on output stream out
void SetVarX(const char *varx)
void SetVarY(const char *vary)
void Streamer(TBuffer &R__b)
Stream an object of class TCutG.
Inline Functions
TObject* GetObjectX() const
TObject* GetObjectY() const
const char* GetVarX() const
const char* GetVarY() const
void SetObjectX(TObject* obj)
void SetObjectY(TObject* obj)
TClass* Class()
TClass* IsA() const
void ShowMembers(TMemberInspector& insp, char* parent)
void StreamerNVirtual(TBuffer& b)
TCutG TCutG(TCutG&)
Author: Rene Brun 16/05/97
Last update: root/graf:$Name: $:$Id: TCutG.cxx,v 1.7 2000/12/13 15:13:50 brun Exp $
Copyright (C) 1995-2000, Rene Brun and Fons Rademakers. *
ROOT page - Class index - Top of the page
This page has been automatically generated. If you have any comments or suggestions about the page layout send a mail to ROOT support, or contact the developers with any questions or problems regarding ROOT.