Logo ROOT  
Reference Guide
 
Loading...
Searching...
No Matches
ROOT::Experimental::REveProjection Class Referenceabstract

REveProjection Base for specific classes that implement non-linear projections.

Definition at line 30 of file REveProjections.hxx.

Classes

struct  PreScaleEntry_t
 

Public Types

enum  EGeoMode_e { kGM_Unknown , kGM_Polygons , kGM_Segments }
 
enum  EPProc_e { kPP_Plane , kPP_Distort , kPP_Full }
 
enum  EPType_e {
  kPT_Unknown , kPT_RhoZ , kPT_RPhi , kPT_XZ ,
  kPT_YZ , kPT_ZX , kPT_ZY , kPT_3D ,
  kPT_End
}
 
typedef std::vector< PreScaleEntry_tvPreScale_t
 

Public Member Functions

 REveProjection ()
 Constructor.
 
virtual ~REveProjection ()
 
virtual Bool_t AcceptSegment (REveVector &, REveVector &, Float_t) const
 
void AddPreScaleEntry (Int_t coord, Float_t max_val, Float_t scale)
 Add new scaling range for given coordinate.
 
virtual void BisectBreakPoint (REveVector &vL, REveVector &vR, Bool_t project_result=kFALSE, Float_t depth=0)
 Find break-point on both sides of the discontinuity.
 
virtual void BisectBreakPoint (REveVector &vL, REveVector &vR, Float_t eps_sqr)
 Find break-point on both sides of the discontinuity.
 
void ChangePreScaleEntry (Int_t coord, Int_t entry, Float_t new_scale)
 Change scale for given entry and coordinate.
 
void ClearPreScales ()
 Clear all pre-scaling information.
 
Bool_t GetDisplaceOrigin () const
 
Float_t GetDistortion () const
 
Float_t GetFixR () const
 
Float_t GetFixZ () const
 
EGeoMode_e GetGeoMode () const
 
Float_t GetLimit (Int_t i, Bool_t pos)
 
Float_t GetMaxTrackStep () const
 
const char * GetName () const
 
REveVector GetOrthogonalCenter (int idx, REveVector &out)
 Get center ortogonal to given axis index.
 
Float_t GetPastFixRFac () const
 
Float_t GetPastFixZFac () const
 
virtual Float_tGetProjectedCenter ()
 Get projected center.
 
virtual Float_t GetScreenVal (Int_t ax, Float_t value)
 Project point on given axis and return projected value.
 
Float_t GetScreenVal (Int_t i, Float_t x, REveVector &dirVec, REveVector &oCenter)
 Project point on given axis and return projected value.
 
EPType_e GetType () const
 
Bool_t GetUsePreScale () const
 
virtual Float_t GetValForScreenPos (Int_t ax, Float_t value)
 Inverse projection.
 
virtual Bool_t HasSeveralSubSpaces () const
 
virtual Bool_t Is2D () const =0
 
virtual Bool_t Is3D () const =0
 
virtual Bool_t IsOnSubSpaceBoundrary (const REveVector &) const
 
void PreScalePoint (Float_t &x, Float_t &y)
 Pre-scale point (x, y) in projected coordinates for 2D projections:
 
void PreScalePoint (Float_t &x, Float_t &y, Float_t &z)
 Pre-scale point (x, y, z) in projected coordinates for 3D projection.
 
virtual void ProjectPoint (Float_t &x, Float_t &y, Float_t &z, Float_t d, EPProc_e p=kPP_Full)=0
 
void ProjectPointdv (const REveTrans *t, const Double_t *p, Double_t *v, Float_t d)
 Project double array, converting it to global coordinate system first if transformation matrix is set.
 
void ProjectPointdv (Double_t *v, Float_t d)
 Project double array.
 
void ProjectPointfv (const REveTrans *t, const Float_t *p, Float_t *v, Float_t d)
 Project float array, converting it to global coordinate system first if transformation matrix is set.
 
void ProjectPointfv (Float_t *v, Float_t d)
 Project float array.
 
void ProjectVector (const REveTrans *t, REveVector &v, Float_t d)
 Project REveVector, converting it to global coordinate system first if transformation matrix is set.
 
void ProjectVector (REveVector &v, Float_t d)
 Project REveVector.
 
const REveVectorRefCenter () const
 
virtual void SetCenter (REveVector &v)
 
virtual void SetDirectionalVector (Int_t screenAxis, REveVector &vec)
 Get vector for axis in a projected space.
 
void SetDisplaceOrigin (bool)
 Set flag to displace for center.
 
void SetDistortion (Float_t d)
 Set distortion.
 
void SetFixR (Float_t x)
 Set fixed radius.
 
void SetFixZ (Float_t x)
 Set fixed radius.
 
void SetGeoMode (EGeoMode_e m)
 
void SetMaxTrackStep (Float_t x)
 
void SetName (const char *txt)
 
void SetPastFixRFac (Float_t x)
 Set 2's-exponent for relative scaling beyond FixR.
 
void SetPastFixZFac (Float_t x)
 Set 2's-exponent for relative scaling beyond FixZ.
 
void SetType (EPType_e t)
 
void SetUsePreScale (Bool_t x)
 
virtual Int_t SubSpaceId (const REveVector &) const
 

Static Public Attributes

static Float_t fgEps = 0.005f
 
static Float_t fgEpsSqr = 0.000025f
 

Protected Member Functions

void PreScaleVariable (Int_t dim, Float_t &v)
 Pre-scale single variable with pre-scale entry dim.
 

Protected Attributes

REveVector fCenter
 
bool fDisplaceOrigin
 
Float_t fDistortion
 
Float_t fFixR
 
Float_t fFixZ
 
EGeoMode_e fGeoMode
 
Float_t fMaxTrackStep
 
std::string fName
 
Float_t fPastFixRFac
 
Float_t fPastFixRScale
 
Float_t fPastFixZFac
 
Float_t fPastFixZScale
 
vPreScale_t fPreScales [3]
 
Float_t fScaleR
 
Float_t fScaleZ
 
EPType_e fType
 
Bool_t fUsePreScale
 

#include <ROOT/REveProjections.hxx>

Inheritance diagram for ROOT::Experimental::REveProjection:
[legend]

Member Typedef Documentation

◆ vPreScale_t

Member Enumeration Documentation

◆ EGeoMode_e

Enumerator
kGM_Unknown 
kGM_Polygons 
kGM_Segments 

Definition at line 35 of file REveProjections.hxx.

◆ EPProc_e

Enumerator
kPP_Plane 
kPP_Distort 
kPP_Full 

Definition at line 34 of file REveProjections.hxx.

◆ EPType_e

Enumerator
kPT_Unknown 
kPT_RhoZ 
kPT_RPhi 
kPT_XZ 
kPT_YZ 
kPT_ZX 
kPT_ZY 
kPT_3D 
kPT_End 

Definition at line 32 of file REveProjections.hxx.

Constructor & Destructor Documentation

◆ REveProjection()

REveProjection::REveProjection ( )

Constructor.

Definition at line 36 of file REveProjections.cxx.

◆ ~REveProjection()

virtual ROOT::Experimental::REveProjection::~REveProjection ( )
inlinevirtual

Definition at line 79 of file REveProjections.hxx.

Member Function Documentation

◆ AcceptSegment()

virtual Bool_t ROOT::Experimental::REveProjection::AcceptSegment ( REveVector ,
REveVector ,
Float_t   
) const
inlinevirtual

Reimplemented in ROOT::Experimental::REveRhoZProjection.

Definition at line 133 of file REveProjections.hxx.

◆ AddPreScaleEntry()

void REveProjection::AddPreScaleEntry ( Int_t  coord,
Float_t  value,
Float_t  scale 
)

Add new scaling range for given coordinate.

Arguments:

  • coord 0 ~ x, 1 ~ y, 2 ~ z
  • value value of input coordinate from which to apply this scale;
  • scale the scale to apply from value onwards.

NOTE: If pre-scaling is combined with center-displaced then the scale of the central region should be 1. This limitation can be removed but will cost CPU.

Definition at line 180 of file REveProjections.cxx.

◆ BisectBreakPoint() [1/2]

void REveProjection::BisectBreakPoint ( REveVector vL,
REveVector vR,
Bool_t  project_result = kFALSE,
Float_t  depth = 0 
)
virtual

Find break-point on both sides of the discontinuity.

If project_result is true, the resulting break points will be projected with given depth value.

Definition at line 355 of file REveProjections.cxx.

◆ BisectBreakPoint() [2/2]

void REveProjection::BisectBreakPoint ( REveVector vL,
REveVector vR,
Float_t  eps_sqr 
)
virtual

Find break-point on both sides of the discontinuity.

They still need to be projected after the call. This is an obsolete version of the method that required manual specification of precision – this lead to (infrequent) infinite loops.

Definition at line 337 of file REveProjections.cxx.

◆ ChangePreScaleEntry()

void REveProjection::ChangePreScaleEntry ( Int_t  coord,
Int_t  entry,
Float_t  new_scale 
)

Change scale for given entry and coordinate.

NOTE: If the first entry you created used other value than 0, one entry (covering range from 0 to this value) was created automatically.

Definition at line 222 of file REveProjections.cxx.

◆ ClearPreScales()

void REveProjection::ClearPreScales ( )

Clear all pre-scaling information.

Definition at line 248 of file REveProjections.cxx.

◆ GetDisplaceOrigin()

Bool_t ROOT::Experimental::REveProjection::GetDisplaceOrigin ( ) const
inline

Definition at line 102 of file REveProjections.hxx.

◆ GetDistortion()

Float_t ROOT::Experimental::REveProjection::GetDistortion ( ) const
inline

Definition at line 120 of file REveProjections.hxx.

◆ GetFixR()

Float_t ROOT::Experimental::REveProjection::GetFixR ( ) const
inline

Definition at line 121 of file REveProjections.hxx.

◆ GetFixZ()

Float_t ROOT::Experimental::REveProjection::GetFixZ ( ) const
inline

Definition at line 122 of file REveProjections.hxx.

◆ GetGeoMode()

EGeoMode_e ROOT::Experimental::REveProjection::GetGeoMode ( ) const
inline

Definition at line 108 of file REveProjections.hxx.

◆ GetLimit()

Float_t ROOT::Experimental::REveProjection::GetLimit ( Int_t  i,
Bool_t  pos 
)

◆ GetMaxTrackStep()

Float_t ROOT::Experimental::REveProjection::GetMaxTrackStep ( ) const
inline

Definition at line 129 of file REveProjections.hxx.

◆ GetName()

const char * ROOT::Experimental::REveProjection::GetName ( ) const
inline

Definition at line 94 of file REveProjections.hxx.

◆ GetOrthogonalCenter()

REveVector REveProjection::GetOrthogonalCenter ( int  idx,
REveVector out 
)

Get center ortogonal to given axis index.

Definition at line 404 of file REveProjections.cxx.

◆ GetPastFixRFac()

Float_t ROOT::Experimental::REveProjection::GetPastFixRFac ( ) const
inline

Definition at line 125 of file REveProjections.hxx.

◆ GetPastFixZFac()

Float_t ROOT::Experimental::REveProjection::GetPastFixZFac ( ) const
inline

Definition at line 126 of file REveProjections.hxx.

◆ GetProjectedCenter()

◆ GetScreenVal() [1/2]

Float_t REveProjection::GetScreenVal ( Int_t  ax,
Float_t  value 
)
virtual

Project point on given axis and return projected value.

Definition at line 522 of file REveProjections.cxx.

◆ GetScreenVal() [2/2]

Float_t REveProjection::GetScreenVal ( Int_t  i,
Float_t  x,
REveVector dirVec,
REveVector oCenter 
)

Project point on given axis and return projected value.

Definition at line 507 of file REveProjections.cxx.

◆ GetType()

EPType_e ROOT::Experimental::REveProjection::GetType ( ) const
inline

Definition at line 105 of file REveProjections.hxx.

◆ GetUsePreScale()

Bool_t ROOT::Experimental::REveProjection::GetUsePreScale ( ) const
inline

Definition at line 110 of file REveProjections.hxx.

◆ GetValForScreenPos()

Float_t REveProjection::GetValForScreenPos ( Int_t  ax,
Float_t  value 
)
virtual

Inverse projection.

Definition at line 420 of file REveProjections.cxx.

◆ HasSeveralSubSpaces()

virtual Bool_t ROOT::Experimental::REveProjection::HasSeveralSubSpaces ( ) const
inlinevirtual

Reimplemented in ROOT::Experimental::REveRhoZProjection.

Definition at line 132 of file REveProjections.hxx.

◆ Is2D()

◆ Is3D()

◆ IsOnSubSpaceBoundrary()

virtual Bool_t ROOT::Experimental::REveProjection::IsOnSubSpaceBoundrary ( const REveVector ) const
inlinevirtual

Reimplemented in ROOT::Experimental::REveRhoZProjection.

Definition at line 135 of file REveProjections.hxx.

◆ PreScalePoint() [1/2]

void REveProjection::PreScalePoint ( Float_t x,
Float_t y 
)

Pre-scale point (x, y) in projected coordinates for 2D projections:

  • RhoZ ~ (rho, z)
  • RPhi ~ (r, phi), scaling phi doesn't make much sense.

Definition at line 153 of file REveProjections.cxx.

◆ PreScalePoint() [2/2]

void REveProjection::PreScalePoint ( Float_t x,
Float_t y,
Float_t z 
)

Pre-scale point (x, y, z) in projected coordinates for 3D projection.

Definition at line 162 of file REveProjections.cxx.

◆ PreScaleVariable()

void REveProjection::PreScaleVariable ( Int_t  dim,
Float_t v 
)
protected

Pre-scale single variable with pre-scale entry dim.

Definition at line 130 of file REveProjections.cxx.

◆ ProjectPoint()

◆ ProjectPointdv() [1/2]

void REveProjection::ProjectPointdv ( const REveTrans t,
const Double_t p,
Double_t v,
Float_t  d 
)

Project double array, converting it to global coordinate system first if transformation matrix is set.

This is a bit piggish as we convert the doubles to floats and back.

Definition at line 98 of file REveProjections.cxx.

◆ ProjectPointdv() [2/2]

void REveProjection::ProjectPointdv ( Double_t v,
Float_t  d 
)

Project double array.

This is a bit piggish as we convert the doubles to floats and back.

Definition at line 64 of file REveProjections.cxx.

◆ ProjectPointfv() [1/2]

void REveProjection::ProjectPointfv ( const REveTrans t,
const Float_t p,
Float_t v,
Float_t  d 
)

Project float array, converting it to global coordinate system first if transformation matrix is set.

Definition at line 83 of file REveProjections.cxx.

◆ ProjectPointfv() [2/2]

void REveProjection::ProjectPointfv ( Float_t v,
Float_t  d 
)

Project float array.

Definition at line 55 of file REveProjections.cxx.

◆ ProjectVector() [1/2]

void REveProjection::ProjectVector ( const REveTrans t,
REveVector v,
Float_t  d 
)

Project REveVector, converting it to global coordinate system first if transformation matrix is set.

Definition at line 118 of file REveProjections.cxx.

◆ ProjectVector() [2/2]

void REveProjection::ProjectVector ( REveVector v,
Float_t  d 
)

Project REveVector.

Definition at line 74 of file REveProjections.cxx.

◆ RefCenter()

const REveVector & ROOT::Experimental::REveProjection::RefCenter ( ) const
inline

Definition at line 97 of file REveProjections.hxx.

◆ SetCenter()

◆ SetDirectionalVector()

void REveProjection::SetDirectionalVector ( Int_t  screenAxis,
REveVector vec 
)
virtual

◆ SetDisplaceOrigin()

void REveProjection::SetDisplaceOrigin ( bool  x)

Set flag to displace for center.

This options is useful if want to have projected center at (0, 0) position in projected coordinates and want to dismiss gap around projected center in RhoZ projection.

Definition at line 315 of file REveProjections.cxx.

◆ SetDistortion()

void REveProjection::SetDistortion ( Float_t  d)

Set distortion.

Definition at line 258 of file REveProjections.cxx.

◆ SetFixR()

void REveProjection::SetFixR ( Float_t  x)

Set fixed radius.

Definition at line 270 of file REveProjections.cxx.

◆ SetFixZ()

void REveProjection::SetFixZ ( Float_t  x)

Set fixed radius.

Definition at line 280 of file REveProjections.cxx.

◆ SetGeoMode()

void ROOT::Experimental::REveProjection::SetGeoMode ( EGeoMode_e  m)
inline

Definition at line 107 of file REveProjections.hxx.

◆ SetMaxTrackStep()

void ROOT::Experimental::REveProjection::SetMaxTrackStep ( Float_t  x)
inline

Definition at line 130 of file REveProjections.hxx.

◆ SetName()

void ROOT::Experimental::REveProjection::SetName ( const char *  txt)
inline

Definition at line 95 of file REveProjections.hxx.

◆ SetPastFixRFac()

void REveProjection::SetPastFixRFac ( Float_t  x)

Set 2's-exponent for relative scaling beyond FixR.

Definition at line 290 of file REveProjections.cxx.

◆ SetPastFixZFac()

void REveProjection::SetPastFixZFac ( Float_t  x)

Set 2's-exponent for relative scaling beyond FixZ.

Definition at line 325 of file REveProjections.cxx.

◆ SetType()

void ROOT::Experimental::REveProjection::SetType ( EPType_e  t)
inline

Definition at line 104 of file REveProjections.hxx.

◆ SetUsePreScale()

void ROOT::Experimental::REveProjection::SetUsePreScale ( Bool_t  x)
inline

Definition at line 111 of file REveProjections.hxx.

◆ SubSpaceId()

virtual Int_t ROOT::Experimental::REveProjection::SubSpaceId ( const REveVector ) const
inlinevirtual

Reimplemented in ROOT::Experimental::REveRhoZProjection.

Definition at line 134 of file REveProjections.hxx.

Member Data Documentation

◆ fCenter

REveVector ROOT::Experimental::REveProjection::fCenter
protected

Definition at line 57 of file REveProjections.hxx.

◆ fDisplaceOrigin

bool ROOT::Experimental::REveProjection::fDisplaceOrigin
protected

Definition at line 59 of file REveProjections.hxx.

◆ fDistortion

Float_t ROOT::Experimental::REveProjection::fDistortion
protected

Definition at line 64 of file REveProjections.hxx.

◆ fFixR

Float_t ROOT::Experimental::REveProjection::fFixR
protected

Definition at line 65 of file REveProjections.hxx.

◆ fFixZ

Float_t ROOT::Experimental::REveProjection::fFixZ
protected

Definition at line 66 of file REveProjections.hxx.

◆ fGeoMode

EGeoMode_e ROOT::Experimental::REveProjection::fGeoMode
protected

Definition at line 54 of file REveProjections.hxx.

◆ fgEps

Float_t REveProjection::fgEps = 0.005f
static

Definition at line 147 of file REveProjections.hxx.

◆ fgEpsSqr

Float_t REveProjection::fgEpsSqr = 0.000025f
static

Definition at line 148 of file REveProjections.hxx.

◆ fMaxTrackStep

Float_t ROOT::Experimental::REveProjection::fMaxTrackStep
protected

Definition at line 73 of file REveProjections.hxx.

◆ fName

std::string ROOT::Experimental::REveProjection::fName
protected

Definition at line 55 of file REveProjections.hxx.

◆ fPastFixRFac

Float_t ROOT::Experimental::REveProjection::fPastFixRFac
protected

Definition at line 67 of file REveProjections.hxx.

◆ fPastFixRScale

Float_t ROOT::Experimental::REveProjection::fPastFixRScale
protected

Definition at line 71 of file REveProjections.hxx.

◆ fPastFixZFac

Float_t ROOT::Experimental::REveProjection::fPastFixZFac
protected

Definition at line 68 of file REveProjections.hxx.

◆ fPastFixZScale

Float_t ROOT::Experimental::REveProjection::fPastFixZScale
protected

Definition at line 72 of file REveProjections.hxx.

◆ fPreScales

vPreScale_t ROOT::Experimental::REveProjection::fPreScales[3]
protected

Definition at line 62 of file REveProjections.hxx.

◆ fScaleR

Float_t ROOT::Experimental::REveProjection::fScaleR
protected

Definition at line 69 of file REveProjections.hxx.

◆ fScaleZ

Float_t ROOT::Experimental::REveProjection::fScaleZ
protected

Definition at line 70 of file REveProjections.hxx.

◆ fType

EPType_e ROOT::Experimental::REveProjection::fType
protected

Definition at line 53 of file REveProjections.hxx.

◆ fUsePreScale

Bool_t ROOT::Experimental::REveProjection::fUsePreScale
protected

Definition at line 61 of file REveProjections.hxx.

Libraries for ROOT::Experimental::REveProjection:

The documentation for this class was generated from the following files: