Logo ROOT  
Reference Guide
 
Loading...
Searching...
No Matches
TEveTrackPropagator Class Reference

Holding structure for a number of track rendering parameters.

Calculates path taking into account the parameters.

NOTE: Magnetic field direction convention is inverted.

This is decoupled from TEveTrack/TEveTrackList to allow sharing of the Propagator among several instances. Back references are kept so the tracks can be recreated when the parameters change.

TEveTrackList has Get/Set methods for RnrStlye. TEveTrackEditor and TEveTrackListEditor provide editor access.

Enum EProjTrackBreaking_e and member fProjTrackBreaking specify whether 2D projected tracks get broken into several segments when the projected space consists of separate domains (like Rho-Z). The track-breaking is enabled by default.

Definition at line 121 of file TEveTrackPropagator.h.

Classes

struct  Helix_t
 

Public Types

enum  EProjTrackBreaking_e { kPTB_Break , kPTB_UseFirstPointPos , kPTB_UseLastPointPos }
 
enum  EStepper_e { kHelix , kRungeKutta }
 
- Public Types inherited from TEveElement
enum  EChangeBits { kCBColorSelection = (1ULL << ( 0 )) , kCBTransBBox = (1ULL << ( 1 )) , kCBObjProps = (1ULL << ( 2 )) , kCBVisibility = (1ULL << ( 3 )) }
 
typedef void(TEveElement::* ImplySelect_foo) ()
 
typedef List_t::const_iterator List_ci
 
typedef List_t::iterator List_i
 
typedef std::list< TEveElement * > List_t
 
typedef void(TEveElement::* Select_foo) (Bool_t)
 
typedef Set_t::const_iterator Set_ci
 
typedef Set_t::iterator Set_i
 
typedef std::set< TEveElement * > Set_t
 
typedef sLTI_t::iterator sLTI_i
 
typedef sLTI_t::reverse_iterator sLTI_ri
 
typedef std::set< TEveListTreeInfosLTI_t
 
- Public Types inherited from TObject
enum  {
  kIsOnHeap = 0x01000000 , kNotDeleted = 0x02000000 , kZombie = 0x04000000 , kInconsistent = 0x08000000 ,
  kBitMask = 0x00ffffff
}
 
enum  { kSingleKey = (1ULL << ( 0 )) , kOverwrite = (1ULL << ( 1 )) , kWriteDelete = (1ULL << ( 2 )) }
 
enum  EDeprecatedStatusBits { kObjInCanvas = (1ULL << ( 3 )) }
 
enum  EStatusBits {
  kCanDelete = (1ULL << ( 0 )) , kMustCleanup = (1ULL << ( 3 )) , kIsReferenced = (1ULL << ( 4 )) , kHasUUID = (1ULL << ( 5 )) ,
  kCannotPick = (1ULL << ( 6 )) , kNoContextMenu = (1ULL << ( 8 )) , kInvalidObject = (1ULL << ( 13 ))
}
 
- Public Types inherited from TEveProjectable
typedef std::list< TEveProjected * >::iterator ProjList_i
 
typedef std::list< TEveProjected * > ProjList_t
 

Public Member Functions

 TEveTrackPropagator (const char *n="TEveTrackPropagator", const char *t="", TEveMagField *field=nullptr, Bool_t own_field=kTRUE)
 Default constructor.
 
 ~TEveTrackPropagator () override
 Destructor.
 
void CheckReferenceCount (const TEveException &eh="TEveElement::CheckReferenceCount ") override
 Check reference count - virtual from TEveElement.
 
void ElementChanged (Bool_t update_scenes=kTRUE, Bool_t redraw=kFALSE) override
 Element-change notification.
 
void FillPointSet (TEvePointSet *ps) const
 Reset ps and populate it with points in propagation cache.
 
Int_t GetCurrentPoint () const
 Get index of current point on track.
 
Double_t GetDelta () const
 
Bool_t GetEditPathMarks () const
 
Bool_t GetFitCluster2Ds () const
 
Bool_t GetFitDaughters () const
 
Bool_t GetFitDecay () const
 
Bool_t GetFitLineSegments () const
 
Bool_t GetFitReferences () const
 
const std::vector< TEveVector4D > & GetLastPoints () const
 
TEveVectorD GetMagField (Double_t x, Double_t y, Double_t z)
 
Double_t GetMaxAng () const
 
Double_t GetMaxOrbs () const
 
Double_t GetMaxR () const
 
Double_t GetMaxStep () const
 
Double_t GetMaxZ () const
 
Double_t GetMinAng () const
 Get maximum step angle.
 
UChar_t GetProjTrackBreaking () const
 
Bool_t GetRnrCluster2Ds () const
 
Bool_t GetRnrDaughters () const
 
Bool_t GetRnrDecay () const
 
Bool_t GetRnrFV () const
 
Bool_t GetRnrPTBMarkers () const
 
Bool_t GetRnrReferences () const
 
EStepper_e GetStepper () const
 
Double_t GetTrackLength (Int_t start_point=0, Int_t end_point=-1) const
 Calculate track length from start_point to end_point.
 
virtual void GoToBounds (TEveVectorD &p)
 Propagate particle to bounds.
 
void GoToBounds (TEveVectorF &p)
 TEveVectorF wrapper.
 
virtual Bool_t GoToLineSegment (const TEveVectorD &s, const TEveVectorD &r, TEveVectorD &p)
 Propagate particle with momentum p to line with start point s and vector r to the second point.
 
Bool_t GoToLineSegment (const TEveVectorF &s, const TEveVectorF &r, TEveVectorF &p)
 TEveVectorF wrapper.
 
virtual Bool_t GoToVertex (TEveVectorD &v, TEveVectorD &p)
 Propagate particle with momentum p to vertex v.
 
Bool_t GoToVertex (TEveVectorF &v, TEveVectorF &p)
 TEveVectorF wrapper.
 
void InitTrack (const TEveVectorD &v, Int_t charge)
 Initialize internal data-members for given particle parameters.
 
void InitTrack (const TEveVectorF &v, Int_t charge)
 TEveVectorF wrapper.
 
Bool_t IntersectPlane (const TEveVectorD &p, const TEveVectorD &point, const TEveVectorD &normal, TEveVectorD &itsect)
 Find intersection of currently propagated track with a plane.
 
TClassIsA () const override
 
void OnZeroRefCount () override
 Virtual from TEveRefBackPtr - track reference count has reached zero.
 
void PrintMagField (Double_t x, Double_t y, Double_t z) const
 
TMarkerRefFVAtt ()
 
TMarkerRefPMAtt ()
 
TMarkerRefPTBAtt ()
 
void ResetTrack ()
 Reset cache holding particle trajectory.
 
void SetDelta (Double_t x)
 Set maximum error and rebuild tracks.
 
void SetEditPathMarks (Bool_t x)
 
void SetFitCluster2Ds (Bool_t x)
 Set 2D-cluster fitting and rebuild tracks.
 
void SetFitDaughters (Bool_t x)
 Set daughter creation point fitting and rebuild tracks.
 
void SetFitDecay (Bool_t x)
 Set decay fitting and rebuild tracks.
 
void SetFitLineSegments (Bool_t x)
 Set line segment fitting and rebuild tracks.
 
void SetFitReferences (Bool_t x)
 Set track-reference fitting and rebuild tracks.
 
void SetMagField (Double_t b)
 
void SetMagField (Double_t bX, Double_t bY, Double_t bZ)
 Set constant magnetic field and rebuild tracks.
 
void SetMagFieldObj (TEveMagField *field, Bool_t own_field=kTRUE)
 Set constant magnetic field and rebuild tracks.
 
void SetMaxAng (Double_t x)
 Set maximum step angle and rebuild tracks.
 
void SetMaxOrbs (Double_t x)
 Set maximum number of orbits and rebuild tracks.
 
void SetMaxR (Double_t x)
 Set maximum radius and rebuild tracks.
 
void SetMaxStep (Double_t x)
 Set maximum step-size and rebuild tracks.
 
void SetMaxZ (Double_t x)
 Set maximum z and rebuild tracks.
 
void SetMinAng (Double_t x)
 Set maximum step angle and rebuild tracks.
 
void SetProjTrackBreaking (UChar_t x)
 Set projection break-point mode and rebuild tracks.
 
void SetRnrCluster2Ds (Bool_t x)
 Set rendering of 2D-clusters and rebuild tracks.
 
void SetRnrDaughters (Bool_t x)
 Set daughter rendering and rebuild tracks.
 
void SetRnrDecay (Bool_t x)
 Set decay rendering and rebuild tracks.
 
void SetRnrFV (Bool_t x)
 Set first-vertex rendering and rebuild tracks.
 
void SetRnrPTBMarkers (Bool_t x)
 Set projection break-point rendering and rebuild tracks.
 
void SetRnrReferences (Bool_t x)
 Set track-reference rendering and rebuild tracks.
 
void SetStepper (EStepper_e s)
 
void Streamer (TBuffer &) override
 
void StreamerNVirtual (TBuffer &ClassDef_StreamerNVirtual_b)
 
- Public Member Functions inherited from TEveElementList
 TEveElementList (const char *n="TEveElementList", const char *t="", Bool_t doColor=kFALSE, Bool_t doTransparency=kFALSE)
 Constructor.
 
 TEveElementList (const TEveElementList &e)
 Copy constructor.
 
 ~TEveElementList () override
 
Bool_t AcceptElement (TEveElement *el) override
 Check if TEveElement el is inherited from fChildClass.
 
TEveElementListCloneElement () const override
 Clone the element via copy constructor.
 
TClassGetChildClass () const
 
const char * GetElementName () const override
 Virtual function for retrieving name of the element.
 
const char * GetElementTitle () const override
 Virtual function for retrieving title of the render-element.
 
TObjectGetObject (const TEveException &="TEveElementList::GetObject ") const override
 Get a TObject associated with this render-element.
 
TClassProjectedClass (const TEveProjection *p) const override
 Virtual from TEveProjectable, returns TEveCompoundProjected class.
 
void SetChildClass (TClass *c)
 
void SetElementName (const char *name) override
 Virtual function for setting of name of an element.
 
void SetElementNameTitle (const char *name, const char *title) override
 Virtual function for setting of name and title of render element.
 
void SetElementTitle (const char *title) override
 Virtual function for setting of title of an element.
 
void StreamerNVirtual (TBuffer &ClassDef_StreamerNVirtual_b)
 
- Public Member Functions inherited from TEveElement
 TEveElement ()
 Default constructor.
 
 TEveElement (Color_t &main_color)
 Constructor.
 
 TEveElement (const TEveElement &e)
 Copy constructor.
 
virtual ~TEveElement ()
 Destructor.
 
virtual void AddElement (TEveElement *el)
 Add el to the list of children.
 
virtual TGListTreeItemAddIntoListTree (TGListTree *ltree, TEveElement *parent)
 Add this render element into ltree to all items belonging to parent.
 
virtual TGListTreeItemAddIntoListTree (TGListTree *ltree, TGListTreeItem *parent_lti)
 Add this element into ltree to an already existing item parent_lti.
 
virtual TGListTreeItemAddIntoListTrees (TEveElement *parent)
 Add this render element into all list-trees and all items belonging to parent.
 
virtual void AddParent (TEveElement *re)
 Add re into the list parents.
 
virtual void AddStamp (UChar_t bits)
 Add (bitwise or) given stamps to fChangeBits.
 
virtual void Annihilate ()
 Optimized destruction without check of reference-count.
 
virtual void AnnihilateElements ()
 Annihilate elements.
 
Bool_t ApplyVizTag (const TString &tag, const TString &fallback_tag="")
 Set the VizTag, find model-element from the VizDB and copy visualization-parameters from it.
 
List_i BeginChildren ()
 
List_ci BeginChildren () const
 
List_i BeginParents ()
 
List_ci BeginParents () const
 
virtual Bool_t CanEditElement () const
 
virtual Bool_t CanEditMainColor () const
 
virtual Bool_t CanEditMainTrans () const
 
virtual Bool_t CanEditMainTransparency () const
 
virtual void ClearStamps ()
 
virtual void CloneChildrenRecurse (TEveElement *dest, Int_t level=0) const
 Clone children and attach them to the dest element.
 
virtual TEveElementCloneElementRecurse (Int_t level=0) const
 Clone elements and recurse 'level' deep over children.
 
virtual void CollectSceneParents (List_t &scenes)
 Collect all parents of class TEveScene.
 
virtual void CollectSceneParentsFromChildren (List_t &scenes, TEveElement *parent)
 Collect scene-parents from all children.
 
virtual void CopyVizParams (const TEveElement *el)
 Copy visualization parameters from element el.
 
virtual void CopyVizParamsFromDB ()
 Copy visualization parameters from the model-element fVizModel.
 
void CSCApplyMainColorToAllChildren ()
 
void CSCApplyMainColorToMatchingChildren ()
 
void CSCApplyMainTransparencyToAllChildren ()
 
void CSCApplyMainTransparencyToMatchingChildren ()
 
void CSCImplySelectAllChildren ()
 
void CSCTakeAnyParentAsMaster ()
 
void DecDenyDestroy ()
 Decreases the deny-destroy count of the element.
 
virtual void DecImpliedHighlighted ()
 Decrease element's implied-highlight count. Stamp appropriately.
 
virtual void DecImpliedSelected ()
 Decrease element's implied-selection count. Stamp appropriately.
 
void DecParentIgnoreCnt ()
 Decrease number of parents ignored in reference-counting.
 
virtual void Destroy ()
 Destroy this element.
 
virtual void DestroyElements ()
 Destroy all children of this element.
 
virtual void DestroyListSubTree (TGListTree *ltree, TGListTreeItem *parent)
 Destroy sub-tree under item 'parent' in list-tree 'ltree'.
 
virtual void DestroyMainTrans ()
 Destroy the main transformation matrix, it will always be taken as identity.
 
virtual void DestroyOrWarn ()
 Destroy this element. Prints a warning if deny-destroy is in force.
 
void DisableListElements (Bool_t rnr_self=kFALSE, Bool_t rnr_children=kFALSE)
 Disable rendering of children and their list contents.
 
void DumpSourceObject () const
 Call Dump() on source object.
 
void EnableListElements (Bool_t rnr_self=kTRUE, Bool_t rnr_children=kTRUE)
 Enable rendering of children and their list contents.
 
List_i EndChildren ()
 
List_ci EndChildren () const
 
List_i EndParents ()
 
List_ci EndParents () const
 
virtual void ExpandIntoListTree (TGListTree *ltree, TGListTreeItem *parent)
 Populates parent with elements.
 
void ExportSourceObjectToCINT (char *var_name) const
 Export source object to CINT with given name for the variable.
 
virtual void ExportToCINT (char *var_name)
 Export render-element to CINT with variable name var_name.
 
virtual void FillImpliedSelectedSet (Set_t &impSelSet)
 Populate set impSelSet with derived / dependant elements.
 
TEveElementFindChild (const TString &name, const TClass *cls=nullptr)
 Find the first child with given name.
 
TEveElementFindChild (TPRegexp &regexp, const TClass *cls=nullptr)
 Find the first child whose name matches regexp.
 
Int_t FindChildren (List_t &matches, const TString &name, const TClass *cls=nullptr)
 Find all children with given name and append them to matches list.
 
Int_t FindChildren (List_t &matches, TPRegexp &regexp, const TClass *cls=nullptr)
 Find all children whose name matches regexp and append them to matches list.
 
virtual sLTI_i FindItem (TGListTree *ltree)
 Find any list-tree-item of this element in list-tree 'ltree'.
 
virtual sLTI_i FindItem (TGListTree *ltree, TGListTreeItem *parent_lti)
 Find list-tree-item of this element with given parent list-tree-item.
 
virtual TGListTreeItemFindListTreeItem (TGListTree *ltree)
 Find any list-tree-item of this element in list-tree 'ltree'.
 
virtual TGListTreeItemFindListTreeItem (TGListTree *ltree, TGListTreeItem *parent_lti)
 Find list-tree-item of this element with given parent list-tree-item.
 
Bool_t FindVizModel ()
 Find model element in VizDB that corresponds to previously assigned fVizTag and set fVizModel accordingly.
 
TEveElementFirstChild () const
 Returns the first child element or 0 if the list is empty.
 
virtual TEveElementForwardEdit ()
 Returns element to be displayed in GUI editor on click.
 
virtual TEveElementForwardSelection ()
 Returns element to be selected on click.
 
UChar_t GetChangeBits () const
 
TEveCompoundGetCompound ()
 
Int_t GetDenyDestroy () const
 Returns the number of times deny-destroy has been requested on the element.
 
Bool_t GetDestroyOnZeroRefCnt () const
 Returns state of flag determining if the element will be destroyed when reference count reaches zero.
 
virtual TObjectGetEditorObject (const TEveException &eh) const
 
virtual TString GetHighlightTooltip ()
 
virtual const TGPictureGetListTreeCheckBoxIcon ()
 Returns list-tree-item check-box picture appropriate for given rendering state.
 
virtual const TGPictureGetListTreeIcon (Bool_t open=kFALSE)
 Returns pointer to first listtreeicon.
 
virtual Color_t GetMainColor () const
 
Color_tGetMainColorPtr () const
 
virtual Char_t GetMainTransparency () const
 
TEveElementGetMaster ()
 Returns the master element - that is:
 
virtual Int_t GetNItems () const
 
Int_t GetParentIgnoreCnt () const
 Get number of parents that should be ignored in doing reference-counting.
 
virtual TObjectGetRenderObject (const TEveException &eh) const
 
virtual Bool_t GetRnrAnything () const
 
virtual Bool_t GetRnrChildren () const
 
virtual Bool_t GetRnrSelf () const
 
virtual Bool_t GetRnrState () const
 
virtual UChar_t GetSelectedLevel () const
 Get selection level, needed for rendering selection and highlight feedback.
 
TRefGetSource ()
 
TObjectGetSourceObject () const
 
void * GetUserData () const
 
TEveElementGetVizModel () const
 
const TStringGetVizTag () const
 
virtual Bool_t HandleElementPaste (TEveElement *el)
 React to element being pasted or dnd-ed.
 
Bool_t HasChild (TEveElement *el)
 Check if element el is a child of this element.
 
Bool_t HasChildren () const
 
virtual Bool_t HasMainColor () const
 
virtual Bool_t HasMainTrans () const
 
Bool_t HasParents () const
 
virtual void HighlightElement (Bool_t state)
 Set element's highlight state. Stamp appropriately.
 
void IncDenyDestroy ()
 Increases the deny-destroy count of the element.
 
virtual void IncImpliedHighlighted ()
 Increase element's implied-highlight count. Stamp appropriately.
 
virtual void IncImpliedSelected ()
 Increase element's implied-selection count. Stamp appropriately.
 
void IncParentIgnoreCnt ()
 Increase number of parents ignored in reference-counting.
 
virtual void InitMainTrans (Bool_t can_edit=kTRUE)
 Initialize the main transformation to identity matrix.
 
Bool_t IsPickable () const
 
TEveElementLastChild () const
 Returns the last child element or 0 if the list is empty.
 
virtual void NameTitleChanged ()
 Virtual function called when a name or title of the element has been changed.
 
Int_t NumChildren () const
 
Int_t NumParents () const
 
virtual void PadPaint (Option_t *option)
 Paint self and/or children into currently active pad.
 
virtual void PaintStandard (TObject *id)
 Paint object – a generic implementation for EVE elements.
 
void PrintSourceObject () const
 Call Print() on source object.
 
virtual void ProjectAllChildren (Bool_t same_depth=kTRUE)
 If this is a projectable, loop over all projected replicas and add the projected image of all children there.
 
virtual void ProjectChild (TEveElement *el, Bool_t same_depth=kTRUE)
 If this is a projectable, loop over all projected replicas and add the projected image of child 'el' there.
 
virtual void PropagateMainColorToProjecteds (Color_t color, Color_t old_color)
 Propagate color to projected elements.
 
virtual void PropagateMainTransparencyToProjecteds (Char_t t, Char_t old_t)
 Propagate transparency to projected elements.
 
virtual void PropagateRnrStateToProjecteds ()
 Propagate render state to the projected replicas of this element.
 
virtual void PropagateVizParamsToElements (TEveElement *el=nullptr)
 Propagate visualization parameters from element el (defaulting to this) to all elements (children).
 
virtual void PropagateVizParamsToProjecteds ()
 Propagate visualization parameters to dependent elements.
 
virtual TEveTransPtrMainTrans (Bool_t create=kTRUE)
 Return pointer to main transformation.
 
void RecheckImpliedSelections ()
 Call this if it is possible that implied-selection or highlight has changed for this element or for implied-selection this element is member of and you want to maintain consistent selection state.
 
const List_tRefChildren () const
 
virtual TEveTransRefMainTrans ()
 Return reference to main transformation.
 
virtual void RemoveElement (TEveElement *el)
 Remove el from the list of children.
 
virtual void RemoveElementLocal (TEveElement *el)
 Perform additional local removal of el.
 
virtual void RemoveElements ()
 Remove all elements.
 
virtual void RemoveElementsLocal ()
 Perform additional local removal of all elements.
 
virtual Bool_t RemoveFromListTree (TGListTree *ltree, TGListTreeItem *parent_lti)
 Remove element from list-tree 'ltree' where its parent item is 'parent_lti'.
 
virtual Int_t RemoveFromListTrees (TEveElement *parent)
 Remove element from all list-trees where 'parent' is the user-data of the parent list-tree-item.
 
virtual void RemoveParent (TEveElement *re)
 Remove re from the list of parents.
 
void ResetAllCSCBits ()
 
void ResetCSCBits (UChar_t f)
 
void SaveVizParams (std::ostream &out, const TString &tag, const TString &var)
 Save visualization parameters for this element with given tag.
 
virtual void SelectElement (Bool_t state)
 Set element's selection state. Stamp appropriately.
 
void SetCompound (TEveCompound *c)
 
void SetCSCBits (UChar_t f)
 
void SetDestroyOnZeroRefCnt (Bool_t d)
 Sets the state of flag determining if the element will be destroyed when reference count reaches zero.
 
void SetEditMainColor (Bool_t x)
 
void SetEditMainTransparency (Bool_t x)
 
void SetMainAlpha (Float_t alpha)
 Set main-transparency via float alpha variable.
 
virtual void SetMainColor (Color_t color)
 Set main color of the element.
 
void SetMainColorPixel (Pixel_t pixel)
 Convert pixel to Color_t and call SetMainColor().
 
void SetMainColorPtr (Color_t *color)
 
void SetMainColorRGB (Float_t r, Float_t g, Float_t b)
 Convert RGB values to Color_t and call SetMainColor.
 
void SetMainColorRGB (UChar_t r, UChar_t g, UChar_t b)
 Convert RGB values to Color_t and call SetMainColor.
 
virtual void SetMainTransparency (Char_t t)
 Set main-transparency.
 
void SetPickable (Bool_t p)
 
void SetPickableRecursively (Bool_t p)
 Set pickable state on the element and all its children.
 
virtual Bool_t SetRnrChildren (Bool_t rnr)
 Set render state of this element's children, i.e.
 
virtual Bool_t SetRnrSelf (Bool_t rnr)
 Set render state of this element, i.e.
 
virtual Bool_t SetRnrSelfChildren (Bool_t rnr_self, Bool_t rnr_children)
 Set state for rendering of this element and its children.
 
virtual Bool_t SetRnrState (Bool_t rnr)
 Set render state of this element and of its children to the same value.
 
void SetSourceObject (TObject *o)
 
virtual void SetTransMatrix (const TGeoMatrix &mat)
 Set transformation matrix from TGeo's matrix.
 
virtual void SetTransMatrix (Double_t *carr)
 Set transformation matrix from column-major array.
 
void SetUserData (void *ud)
 
void SetVizModel (TEveElement *model)
 Set visualization-parameter model element.
 
void SetVizTag (const TString &tag)
 
virtual Bool_t SingleRnrState () const
 
void SpawnEditor ()
 Show GUI editor for this object.
 
void StampColorSelection ()
 
void StampObjProps ()
 
void StampTransBBox ()
 
void StampVisibility ()
 
void StreamerNVirtual (TBuffer &ClassDef_StreamerNVirtual_b)
 
Bool_t TestCSCBits (UChar_t f) const
 
virtual void UnHighlighted ()
 Virtual function called when both fHighlighted is false and fImpliedHighlighted is 0.
 
virtual void UnSelected ()
 Virtual function called when both fSelected is false and fImpliedSelected is 0.
 
void VizDB_Apply (const char *tag)
 Set visual parameters for this object for given tag.
 
void VizDB_Insert (const char *tag, Bool_t replace=kTRUE, Bool_t update=kTRUE)
 Create a replica of element and insert it into VizDB with given tag.
 
void VizDB_Reapply ()
 Reset visual parameters for this object from VizDB.
 
void VizDB_UpdateModel (Bool_t update=kTRUE)
 Copy visual parameters from this element to viz-db model.
 
virtual void WriteVizParams (std::ostream &out, const TString &var)
 Write-out visual parameters for this object.
 
- Public Member Functions inherited from TNamed
 TNamed ()
 
 TNamed (const char *name, const char *title)
 
 TNamed (const TNamed &named)
 TNamed copy ctor.
 
 TNamed (const TString &name, const TString &title)
 
virtual ~TNamed ()
 TNamed destructor.
 
void Clear (Option_t *option="") override
 Set name and title to empty strings ("").
 
TObjectClone (const char *newname="") const override
 Make a clone of an object using the Streamer facility.
 
Int_t Compare (const TObject *obj) const override
 Compare two TNamed objects.
 
void Copy (TObject &named) const override
 Copy this to obj.
 
virtual void FillBuffer (char *&buffer)
 Encode TNamed into output buffer.
 
const char * GetName () const override
 Returns name of object.
 
const char * GetTitle () const override
 Returns title of object.
 
ULong_t Hash () const override
 Return hash value for this object.
 
TClassIsA () const override
 
Bool_t IsSortable () const override
 
void ls (Option_t *option="") const override
 List TNamed name and title.
 
TNamedoperator= (const TNamed &rhs)
 TNamed assignment operator.
 
void Print (Option_t *option="") const override
 Print TNamed name and title.
 
virtual void SetName (const char *name)
 Set the name of the TNamed.
 
virtual void SetNameTitle (const char *name, const char *title)
 Set all the TNamed parameters (name and title).
 
virtual void SetTitle (const char *title="")
 Set the title of the TNamed.
 
virtual Int_t Sizeof () const
 Return size of the TNamed part of the TObject.
 
void Streamer (TBuffer &) override
 Stream an object of class TObject.
 
void StreamerNVirtual (TBuffer &ClassDef_StreamerNVirtual_b)
 
- Public Member Functions inherited from TObject
 TObject ()
 TObject constructor.
 
 TObject (const TObject &object)
 TObject copy ctor.
 
virtual ~TObject ()
 TObject destructor.
 
void AbstractMethod (const char *method) const
 Use this method to implement an "abstract" method that you don't want to leave purely abstract.
 
virtual void AppendPad (Option_t *option="")
 Append graphics object to current pad.
 
virtual void Browse (TBrowser *b)
 Browse object. May be overridden for another default action.
 
ULong_t CheckedHash ()
 Check and record whether this class has a consistent Hash/RecursiveRemove setup (*) and then return the regular Hash value for this object.
 
virtual const char * ClassName () const
 Returns name of class to which the object belongs.
 
virtual void Delete (Option_t *option="")
 Delete this object.
 
virtual Int_t DistancetoPrimitive (Int_t px, Int_t py)
 Computes distance from point (px,py) to the object.
 
virtual void Draw (Option_t *option="")
 Default Draw method for all objects.
 
virtual void DrawClass () const
 Draw class inheritance tree of the class to which this object belongs.
 
virtual TObjectDrawClone (Option_t *option="") const
 Draw a clone of this object in the current selected pad with: gROOT->SetSelectedPad(c1).
 
virtual void Dump () const
 Dump contents of object on stdout.
 
virtual void Error (const char *method, const char *msgfmt,...) const
 Issue error message.
 
virtual void Execute (const char *method, const char *params, Int_t *error=nullptr)
 Execute method on this object with the given parameter string, e.g.
 
virtual void Execute (TMethod *method, TObjArray *params, Int_t *error=nullptr)
 Execute method on this object with parameters stored in the TObjArray.
 
virtual void ExecuteEvent (Int_t event, Int_t px, Int_t py)
 Execute action corresponding to an event at (px,py).
 
virtual void Fatal (const char *method, const char *msgfmt,...) const
 Issue fatal error message.
 
virtual TObjectFindObject (const char *name) const
 Must be redefined in derived classes.
 
virtual TObjectFindObject (const TObject *obj) const
 Must be redefined in derived classes.
 
virtual Option_tGetDrawOption () const
 Get option used by the graphics system to draw this object.
 
virtual const char * GetIconName () const
 Returns mime type name of object.
 
virtual char * GetObjectInfo (Int_t px, Int_t py) const
 Returns string containing info about the object at position (px,py).
 
virtual Option_tGetOption () const
 
virtual UInt_t GetUniqueID () const
 Return the unique object id.
 
virtual Bool_t HandleTimer (TTimer *timer)
 Execute action in response of a timer timing out.
 
Bool_t HasInconsistentHash () const
 Return true is the type of this object is known to have an inconsistent setup for Hash and RecursiveRemove (i.e.
 
virtual void Info (const char *method, const char *msgfmt,...) const
 Issue info message.
 
virtual Bool_t InheritsFrom (const char *classname) const
 Returns kTRUE if object inherits from class "classname".
 
virtual Bool_t InheritsFrom (const TClass *cl) const
 Returns kTRUE if object inherits from TClass cl.
 
virtual void Inspect () const
 Dump contents of this object in a graphics canvas.
 
void InvertBit (UInt_t f)
 
Bool_t IsDestructed () const
 IsDestructed.
 
virtual Bool_t IsEqual (const TObject *obj) const
 Default equal comparison (objects are equal if they have the same address in memory).
 
virtual Bool_t IsFolder () const
 Returns kTRUE in case object contains browsable objects (like containers or lists of other objects).
 
R__ALWAYS_INLINE Bool_t IsOnHeap () const
 
R__ALWAYS_INLINE Bool_t IsZombie () const
 
void MayNotUse (const char *method) const
 Use this method to signal that a method (defined in a base class) may not be called in a derived class (in principle against good design since a child class should not provide less functionality than its parent, however, sometimes it is necessary).
 
virtual Bool_t Notify ()
 This method must be overridden to handle object notification (the base implementation is no-op).
 
void Obsolete (const char *method, const char *asOfVers, const char *removedFromVers) const
 Use this method to declare a method obsolete.
 
void operator delete (void *ptr)
 Operator delete.
 
void operator delete (void *ptr, void *vp)
 Only called by placement new when throwing an exception.
 
void operator delete[] (void *ptr)
 Operator delete [].
 
void operator delete[] (void *ptr, void *vp)
 Only called by placement new[] when throwing an exception.
 
void * operator new (size_t sz)
 
void * operator new (size_t sz, void *vp)
 
void * operator new[] (size_t sz)
 
void * operator new[] (size_t sz, void *vp)
 
TObjectoperator= (const TObject &rhs)
 TObject assignment operator.
 
virtual void Paint (Option_t *option="")
 This method must be overridden if a class wants to paint itself.
 
virtual void Pop ()
 Pop on object drawn in a pad to the top of the display list.
 
virtual Int_t Read (const char *name)
 Read contents of object with specified name from the current directory.
 
virtual void RecursiveRemove (TObject *obj)
 Recursively remove this object from a list.
 
void ResetBit (UInt_t f)
 
virtual void SaveAs (const char *filename="", Option_t *option="") const
 Save this object in the file specified by filename.
 
virtual void SavePrimitive (std::ostream &out, Option_t *option="")
 Save a primitive as a C++ statement(s) on output stream "out".
 
void SetBit (UInt_t f)
 
void SetBit (UInt_t f, Bool_t set)
 Set or unset the user status bits as specified in f.
 
virtual void SetDrawOption (Option_t *option="")
 Set drawing option for object.
 
virtual void SetUniqueID (UInt_t uid)
 Set the unique object id.
 
void StreamerNVirtual (TBuffer &ClassDef_StreamerNVirtual_b)
 
virtual void SysError (const char *method, const char *msgfmt,...) const
 Issue system error message.
 
R__ALWAYS_INLINE Bool_t TestBit (UInt_t f) const
 
Int_t TestBits (UInt_t f) const
 
virtual void UseCurrentStyle ()
 Set current style settings in this object This function is called when either TCanvas::UseCurrentStyle or TROOT::ForceStyle have been invoked.
 
virtual void Warning (const char *method, const char *msgfmt,...) const
 Issue warning message.
 
virtual Int_t Write (const char *name=nullptr, Int_t option=0, Int_t bufsize=0)
 Write this object to the current directory.
 
virtual Int_t Write (const char *name=nullptr, Int_t option=0, Int_t bufsize=0) const
 Write this object to the current directory.
 
- Public Member Functions inherited from TEveProjectable
 TEveProjectable ()
 Constructor.
 
virtual ~TEveProjectable ()
 Destructor.
 
virtual void AddProjected (TEveProjected *p)
 
virtual void AddProjectedsToSet (std::set< TEveElement * > &set)
 Add the projected elements to the set, dyn-casting them to TEveElement.
 
virtual void AnnihilateProjecteds ()
 Optimized destroy of projected elements with condition there is only one parent for projected element.
 
ProjList_i BeginProjecteds ()
 
virtual void ClearProjectedList ()
 
ProjList_i EndProjecteds ()
 
virtual Bool_t HasProjecteds () const
 
virtual void PropagateMainColor (Color_t color, Color_t old_color)
 Set main color of projecteds if their color is the same as old_color.
 
virtual void PropagateMainTransparency (Char_t t, Char_t old_t)
 Set main transparency of projecteds if their transparency is the same as the old one.
 
virtual void PropagateRenderState (Bool_t rnr_self, Bool_t rnr_children)
 Set render state of projecteds.
 
virtual void PropagateVizParams (TEveElement *el=nullptr)
 Set visualization parameters of projecteds.
 
virtual void RemoveProjected (TEveProjected *p)
 
void StreamerNVirtual (TBuffer &ClassDef_StreamerNVirtual_b)
 
- Public Member Functions inherited from TEveRefBackPtr
 TEveRefBackPtr ()
 Default constructor.
 
 TEveRefBackPtr (const TEveRefBackPtr &)
 Copy constructor.
 
 ~TEveRefBackPtr () override
 Destructor. Noop, should complain if back-ref list is not empty.
 
void DecRefCount ()
 
virtual void DecRefCount (TEveElement *re)
 Decrease reference count and remove re from the list of back-references.
 
void IncRefCount ()
 
virtual void IncRefCount (TEveElement *re)
 Increase reference count and add re to the list of back-references.
 
TEveRefBackPtroperator= (const TEveRefBackPtr &)
 Assignment operator.
 
virtual void StampBackPtrElements (UChar_t stamps)
 Add given stamps to elements in the list of reverse references.
 
void StreamerNVirtual (TBuffer &ClassDef_StreamerNVirtual_b)
 
- Public Member Functions inherited from TEveRefCnt
 TEveRefCnt ()
 
 TEveRefCnt (const TEveRefCnt &)
 
virtual ~TEveRefCnt ()
 
void DecRefCount ()
 
void IncRefCount ()
 
TEveRefCntoperator= (const TEveRefCnt &)
 
void StreamerNVirtual (TBuffer &ClassDef_StreamerNVirtual_b)
 

Static Public Member Functions

static TClassClass ()
 
static const char * Class_Name ()
 
static constexpr Version_t Class_Version ()
 
static const char * DeclFileName ()
 
static Bool_t IsOutsideBounds (const TEveVectorD &point, Double_t maxRsqr, Double_t maxZ)
 
- Static Public Member Functions inherited from TEveElementList
static TClassClass ()
 
static const char * Class_Name ()
 
static constexpr Version_t Class_Version ()
 
static const char * DeclFileName ()
 
- Static Public Member Functions inherited from TEveElement
static TClassClass ()
 
static const char * Class_Name ()
 
static constexpr Version_t Class_Version ()
 
static const char * DeclFileName ()
 
- Static Public Member Functions inherited from TNamed
static TClassClass ()
 
static const char * Class_Name ()
 
static constexpr Version_t Class_Version ()
 
static const char * DeclFileName ()
 
- Static Public Member Functions inherited from TObject
static TClassClass ()
 
static const char * Class_Name ()
 
static constexpr Version_t Class_Version ()
 
static const char * DeclFileName ()
 
static Longptr_t GetDtorOnly ()
 Return destructor only flag.
 
static Bool_t GetObjectStat ()
 Get status of object stat flag.
 
static void SetDtorOnly (void *obj)
 Set destructor only flag.
 
static void SetObjectStat (Bool_t stat)
 Turn on/off tracking of objects in the TObjectTable.
 
- Static Public Member Functions inherited from TEveProjectable
static TClassClass ()
 
static const char * Class_Name ()
 
static constexpr Version_t Class_Version ()
 
static const char * DeclFileName ()
 
- Static Public Member Functions inherited from TEveRefBackPtr
static TClassClass ()
 
static const char * Class_Name ()
 
static constexpr Version_t Class_Version ()
 
static const char * DeclFileName ()
 
- Static Public Member Functions inherited from TEveRefCnt
static TClassClass ()
 
static const char * Class_Name ()
 
static constexpr Version_t Class_Version ()
 
static const char * DeclFileName ()
 

Static Public Attributes

static TEveTrackPropagator fgDefault
 
static Double_t fgDefMagField = 0.5
 
static Double_t fgEditorMaxR = 2000
 
static Double_t fgEditorMaxZ = 4000
 
static const Double_t fgkB2C = 0.299792458e-2
 
- Static Public Attributes inherited from TEveElement
static const TGPicturefgListTreeIcons [9] = { 0 }
 
static const TGPicturefgRnrIcons [4] = { 0 }
 

Protected Member Functions

Bool_t ClosestPointBetweenLines (const TEveVectorD &, const TEveVectorD &, const TEveVectorD &, const TEveVectorD &, TEveVectorD &out)
 Get closest point on line defined with vector p0 and u.
 
void ClosestPointFromVertexToLineSegment (const TEveVectorD &v, const TEveVectorD &s, const TEveVectorD &r, Double_t rMagInv, TEveVectorD &c)
 Get closest point from given vertex v to line segment defined with s and r.
 
Bool_t HelixIntersectPlane (const TEveVectorD &p, const TEveVectorD &point, const TEveVectorD &normal, TEveVectorD &itsect)
 Intersect helix with a plane.
 
Bool_t LineIntersectPlane (const TEveVectorD &p, const TEveVectorD &point, const TEveVectorD &normal, TEveVectorD &itsect)
 Intersect line with a plane.
 
void LineToBounds (TEveVectorD &p)
 Propagate neutral particle with momentum p to bounds.
 
Bool_t LineToVertex (TEveVectorD &v)
 Propagate neutral particle to vertex v.
 
void LoopToBounds (TEveVectorD &p)
 Propagate charged particle with momentum p to bounds.
 
Bool_t LoopToLineSegment (const TEveVectorD &s, const TEveVectorD &r, TEveVectorD &p)
 Propagate charged particle with momentum p to line segment with point s and vector r to the second point.
 
Bool_t LoopToVertex (TEveVectorD &v, TEveVectorD &p)
 Propagate charged particle with momentum p to vertex v.
 
Bool_t PointOverVertex (const TEveVector4D &v0, const TEveVector4D &v, Double_t *p=nullptr)
 
void RebuildTracks ()
 Rebuild all tracks using this render-style.
 
void Step (const TEveVector4D &v, const TEveVectorD &p, TEveVector4D &vOut, TEveVectorD &pOut)
 Wrapper to step helix.
 
void StepRungeKutta (Double_t step, Double_t *vect, Double_t *vout)
 Wrapper to step with method RungeKutta.
 
void Update (const TEveVector4D &v, const TEveVectorD &p, Bool_t full_update=kFALSE, Bool_t enforce_max_step=kFALSE)
 Update helix / B-field projection state.
 
- Protected Member Functions inherited from TEveElement
virtual void AnnihilateRecursively ()
 Protected member function called from TEveElement::Annihilate().
 
virtual void PreDeleteElement ()
 Externally assigned and controlled user data.
 
virtual void RemoveElementsInternal ()
 Remove all elements.
 
- Protected Member Functions inherited from TObject
virtual void DoError (int level, const char *location, const char *fmt, va_list va) const
 Interface to ErrorHandler (protected).
 
void MakeZombie ()
 

Protected Attributes

Bool_t fEditPathMarks
 
Bool_t fFitCluster2Ds
 
Bool_t fFitDaughters
 
Bool_t fFitDecay
 
Bool_t fFitLineSegments
 
Bool_t fFitReferences
 
TMarker fFVAtt
 
Helix_t fH
 
std::vector< TEveVector4DfLastPoints
 
TEveMagFieldfMagFieldObj
 
Double_t fMaxOrbs
 
Double_t fMaxR
 
Double_t fMaxZ
 
Int_t fNMax
 
Bool_t fOwnMagFiledObj
 
TMarker fPMAtt
 
std::vector< TEveVector4DfPoints
 
UChar_t fProjTrackBreaking
 
TMarker fPTBAtt
 
Bool_t fRnrCluster2Ds
 
Bool_t fRnrDaughters
 
Bool_t fRnrDecay
 
Bool_t fRnrFV
 
Bool_t fRnrPTBMarkers
 
Bool_t fRnrReferences
 
EStepper_e fStepper
 
TEveVectorD fV
 
- Protected Attributes inherited from TEveElementList
TClassfChildClass
 
Color_t fColor
 
- Protected Attributes inherited from TEveElement
Bool_t fCanEditMainColor
 
Bool_t fCanEditMainTrans
 
Bool_t fCanEditMainTransparency
 
UChar_t fChangeBits
 
List_t fChildren
 
TEveCompoundfCompound
 
UChar_t fCSCBits
 
Int_t fDenyDestroy
 Counter for top-level list-tree items that prevent automatic destruction.
 
Bool_t fDestroyOnZeroRefCnt
 Deny-destroy count.
 
Char_t fDestructing
 
Bool_t fHighlighted
 
Short_t fImpliedHighlighted
 
Short_t fImpliedSelected
 
sLTI_t fItems
 
Color_tfMainColorPtr
 
TEveTransfMainTrans
 
Char_t fMainTransparency
 
Int_t fNumChildren
 
Int_t fParentIgnoreCnt
 
List_t fParents
 
Bool_t fPickable
 
Bool_t fRnrChildren
 
Bool_t fRnrSelf
 
Bool_t fSelected
 
TRef fSource
 Set of list-tree-items.
 
Int_t fTopItemCnt
 Counter for parents that are ignored in ref-counting.
 
void * fUserData
 
TEveElementfVizModel
 
TString fVizTag
 Element used as model from VizDB.
 
- Protected Attributes inherited from TNamed
TString fName
 
TString fTitle
 
- Protected Attributes inherited from TEveProjectable
ProjList_t fProjectedList
 
- Protected Attributes inherited from TEveRefBackPtr
RefMap_t fBackRefs
 
- Protected Attributes inherited from TEveRefCnt
Int_t fRefCount
 

Private Member Functions

 TEveTrackPropagator (const TEveTrackPropagator &)
 
void DistributeOffset (const TEveVectorD &off, Int_t first_point, Int_t np, TEveVectorD &p)
 Distribute offset between first and last point index and rotate momentum.
 
TEveTrackPropagatoroperator= (const TEveTrackPropagator &)
 

Friends

class TEveTrackPropagatorSubEditor
 

Additional Inherited Members

- Protected Types inherited from TEveElement
enum  ECompoundSelectionColorBits {
  kCSCBImplySelectAllChildren = (1ULL << ( 0 )) , kCSCBTakeAnyParentAsMaster = (1ULL << ( 1 )) , kCSCBApplyMainColorToAllChildren = (1ULL << ( 2 )) , kCSCBApplyMainColorToMatchingChildren = (1ULL << ( 3 )) ,
  kCSCBApplyMainTransparencyToAllChildren = (1ULL << ( 4 )) , kCSCBApplyMainTransparencyToMatchingChildren = (1ULL << ( 5 ))
}
 
enum  EDestruct { kNone , kStandard , kAnnihilate }
 
- Protected Types inherited from TObject
enum  { kOnlyPrepStep = (1ULL << ( 3 )) }
 
- Protected Types inherited from TEveRefBackPtr
typedef RefMap_t::iterator RefMap_i
 
typedef std::map< TEveElement *, Int_tRefMap_t
 
- Static Protected Member Functions inherited from TEveElement
static const char * ToString (Bool_t b)
 Convert Bool_t to string - kTRUE or kFALSE.
 

#include <TEveTrackPropagator.h>

Inheritance diagram for TEveTrackPropagator:
[legend]

Member Enumeration Documentation

◆ EProjTrackBreaking_e

Enumerator
kPTB_Break 
kPTB_UseFirstPointPos 
kPTB_UseLastPointPos 

Definition at line 129 of file TEveTrackPropagator.h.

◆ EStepper_e

Enumerator
kHelix 
kRungeKutta 

Definition at line 127 of file TEveTrackPropagator.h.

Constructor & Destructor Documentation

◆ TEveTrackPropagator() [1/2]

TEveTrackPropagator::TEveTrackPropagator ( const TEveTrackPropagator )
private

◆ TEveTrackPropagator() [2/2]

TEveTrackPropagator::TEveTrackPropagator ( const char *  n = "TEveTrackPropagator",
const char *  t = "",
TEveMagField field = nullptr,
Bool_t  own_field = kTRUE 
)

Default constructor.

Definition at line 229 of file TEveTrackPropagator.cxx.

◆ ~TEveTrackPropagator()

TEveTrackPropagator::~TEveTrackPropagator ( )
override

Destructor.

Definition at line 275 of file TEveTrackPropagator.cxx.

Member Function Documentation

◆ CheckReferenceCount()

void TEveTrackPropagator::CheckReferenceCount ( const TEveException eh = "TEveElement::CheckReferenceCount ")
overridevirtual

Check reference count - virtual from TEveElement.

Must also take into account references from TEveRefBackPtr.

Reimplemented from TEveElement.

Definition at line 295 of file TEveTrackPropagator.cxx.

◆ Class()

static TClass * TEveTrackPropagator::Class ( )
static
Returns
TClass describing this class

◆ Class_Name()

static const char * TEveTrackPropagator::Class_Name ( )
static
Returns
Name of this class

◆ Class_Version()

static constexpr Version_t TEveTrackPropagator::Class_Version ( )
inlinestaticconstexpr
Returns
Version of this class

Definition at line 348 of file TEveTrackPropagator.h.

◆ ClosestPointBetweenLines()

Bool_t TEveTrackPropagator::ClosestPointBetweenLines ( const TEveVectorD p0,
const TEveVectorD u,
const TEveVectorD q0,
const TEveVectorD v,
TEveVectorD out 
)
protected

Get closest point on line defined with vector p0 and u.

Return false if the point is forced on the line segment.

Definition at line 983 of file TEveTrackPropagator.cxx.

◆ ClosestPointFromVertexToLineSegment()

void TEveTrackPropagator::ClosestPointFromVertexToLineSegment ( const TEveVectorD v,
const TEveVectorD s,
const TEveVectorD r,
Double_t  rMagInv,
TEveVectorD c 
)
protected

Get closest point from given vertex v to line segment defined with s and r.

Argument rMagInv is cached. rMagInv= 1./rMag()

Definition at line 956 of file TEveTrackPropagator.cxx.

◆ DeclFileName()

static const char * TEveTrackPropagator::DeclFileName ( )
inlinestatic
Returns
Name of the file containing the class declaration

Definition at line 348 of file TEveTrackPropagator.h.

◆ DistributeOffset()

void TEveTrackPropagator::DistributeOffset ( const TEveVectorD off,
Int_t  first_point,
Int_t  np,
TEveVectorD p 
)
private

Distribute offset between first and last point index and rotate momentum.

Definition at line 777 of file TEveTrackPropagator.cxx.

◆ ElementChanged()

void TEveTrackPropagator::ElementChanged ( Bool_t  update_scenes = kTRUE,
Bool_t  redraw = kFALSE 
)
overridevirtual

Element-change notification.

Stamp all tracks as requiring display-list regeneration. Virtual from TEveElement.

Reimplemented from TEveElement.

Definition at line 308 of file TEveTrackPropagator.cxx.

◆ FillPointSet()

void TEveTrackPropagator::FillPointSet ( TEvePointSet ps) const

Reset ps and populate it with points in propagation cache.

Definition at line 1005 of file TEveTrackPropagator.cxx.

◆ GetCurrentPoint()

Int_t TEveTrackPropagator::GetCurrentPoint ( ) const

Get index of current point on track.

Definition at line 358 of file TEveTrackPropagator.cxx.

◆ GetDelta()

Double_t TEveTrackPropagator::GetDelta ( ) const
inline

Definition at line 317 of file TEveTrackPropagator.h.

◆ GetEditPathMarks()

Bool_t TEveTrackPropagator::GetEditPathMarks ( ) const
inline

Definition at line 319 of file TEveTrackPropagator.h.

◆ GetFitCluster2Ds()

Bool_t TEveTrackPropagator::GetFitCluster2Ds ( ) const
inline

Definition at line 327 of file TEveTrackPropagator.h.

◆ GetFitDaughters()

Bool_t TEveTrackPropagator::GetFitDaughters ( ) const
inline

Definition at line 324 of file TEveTrackPropagator.h.

◆ GetFitDecay()

Bool_t TEveTrackPropagator::GetFitDecay ( ) const
inline

Definition at line 326 of file TEveTrackPropagator.h.

◆ GetFitLineSegments()

Bool_t TEveTrackPropagator::GetFitLineSegments ( ) const
inline

Definition at line 328 of file TEveTrackPropagator.h.

◆ GetFitReferences()

Bool_t TEveTrackPropagator::GetFitReferences ( ) const
inline

Definition at line 325 of file TEveTrackPropagator.h.

◆ GetLastPoints()

const std::vector< TEveVector4D > & TEveTrackPropagator::GetLastPoints ( ) const
inline

Definition at line 337 of file TEveTrackPropagator.h.

◆ GetMagField()

TEveVectorD TEveTrackPropagator::GetMagField ( Double_t  x,
Double_t  y,
Double_t  z 
)
inline

Definition at line 306 of file TEveTrackPropagator.h.

◆ GetMaxAng()

Double_t TEveTrackPropagator::GetMaxAng ( ) const
inline

Definition at line 315 of file TEveTrackPropagator.h.

◆ GetMaxOrbs()

Double_t TEveTrackPropagator::GetMaxOrbs ( ) const
inline

Definition at line 313 of file TEveTrackPropagator.h.

◆ GetMaxR()

Double_t TEveTrackPropagator::GetMaxR ( ) const
inline

Definition at line 311 of file TEveTrackPropagator.h.

◆ GetMaxStep()

Double_t TEveTrackPropagator::GetMaxStep ( ) const
inline

Definition at line 316 of file TEveTrackPropagator.h.

◆ GetMaxZ()

Double_t TEveTrackPropagator::GetMaxZ ( ) const
inline

Definition at line 312 of file TEveTrackPropagator.h.

◆ GetMinAng()

Double_t TEveTrackPropagator::GetMinAng ( ) const

Get maximum step angle.

WARNING – this method / variable was mis-named.

Definition at line 1100 of file TEveTrackPropagator.cxx.

◆ GetProjTrackBreaking()

UChar_t TEveTrackPropagator::GetProjTrackBreaking ( ) const
inline

Definition at line 330 of file TEveTrackPropagator.h.

◆ GetRnrCluster2Ds()

Bool_t TEveTrackPropagator::GetRnrCluster2Ds ( ) const
inline

Definition at line 323 of file TEveTrackPropagator.h.

◆ GetRnrDaughters()

Bool_t TEveTrackPropagator::GetRnrDaughters ( ) const
inline

Definition at line 320 of file TEveTrackPropagator.h.

◆ GetRnrDecay()

Bool_t TEveTrackPropagator::GetRnrDecay ( ) const
inline

Definition at line 322 of file TEveTrackPropagator.h.

◆ GetRnrFV()

Bool_t TEveTrackPropagator::GetRnrFV ( ) const
inline

Definition at line 329 of file TEveTrackPropagator.h.

◆ GetRnrPTBMarkers()

Bool_t TEveTrackPropagator::GetRnrPTBMarkers ( ) const
inline

Definition at line 331 of file TEveTrackPropagator.h.

◆ GetRnrReferences()

Bool_t TEveTrackPropagator::GetRnrReferences ( ) const
inline

Definition at line 321 of file TEveTrackPropagator.h.

◆ GetStepper()

EStepper_e TEveTrackPropagator::GetStepper ( ) const
inline

Definition at line 309 of file TEveTrackPropagator.h.

◆ GetTrackLength()

Double_t TEveTrackPropagator::GetTrackLength ( Int_t  start_point = 0,
Int_t  end_point = -1 
) const

Calculate track length from start_point to end_point.

If end_point is less than 0, distance to the end is returned.

Definition at line 367 of file TEveTrackPropagator.cxx.

◆ GoToBounds() [1/2]

void TEveTrackPropagator::GoToBounds ( TEveVectorD p)
virtual

Propagate particle to bounds.

Return TRUE if hit bounds.

Definition at line 442 of file TEveTrackPropagator.cxx.

◆ GoToBounds() [2/2]

void TEveTrackPropagator::GoToBounds ( TEveVectorF p)

TEveVectorF wrapper.

Definition at line 452 of file TEveTrackPropagator.cxx.

◆ GoToLineSegment() [1/2]

Bool_t TEveTrackPropagator::GoToLineSegment ( const TEveVectorD s,
const TEveVectorD r,
TEveVectorD p 
)
virtual

Propagate particle with momentum p to line with start point s and vector r to the second point.

Definition at line 399 of file TEveTrackPropagator.cxx.

◆ GoToLineSegment() [2/2]

Bool_t TEveTrackPropagator::GoToLineSegment ( const TEveVectorF s,
const TEveVectorF r,
TEveVectorF p 
)

TEveVectorF wrapper.

Definition at line 430 of file TEveTrackPropagator.cxx.

◆ GoToVertex() [1/2]

Bool_t TEveTrackPropagator::GoToVertex ( TEveVectorD v,
TEveVectorD p 
)
virtual

Propagate particle with momentum p to vertex v.

Definition at line 382 of file TEveTrackPropagator.cxx.

◆ GoToVertex() [2/2]

Bool_t TEveTrackPropagator::GoToVertex ( TEveVectorF v,
TEveVectorF p 
)

TEveVectorF wrapper.

Definition at line 419 of file TEveTrackPropagator.cxx.

◆ HelixIntersectPlane()

Bool_t TEveTrackPropagator::HelixIntersectPlane ( const TEveVectorD p,
const TEveVectorD point,
const TEveVectorD normal,
TEveVectorD itsect 
)
protected

Intersect helix with a plane.

Current position and argument p define the helix.

Definition at line 859 of file TEveTrackPropagator.cxx.

◆ InitTrack() [1/2]

void TEveTrackPropagator::InitTrack ( const TEveVectorD v,
Int_t  charge 
)

Initialize internal data-members for given particle parameters.

Definition at line 324 of file TEveTrackPropagator.cxx.

◆ InitTrack() [2/2]

void TEveTrackPropagator::InitTrack ( const TEveVectorF v,
Int_t  charge 
)

TEveVectorF wrapper.

Definition at line 337 of file TEveTrackPropagator.cxx.

◆ IntersectPlane()

Bool_t TEveTrackPropagator::IntersectPlane ( const TEveVectorD p,
const TEveVectorD point,
const TEveVectorD normal,
TEveVectorD itsect 
)

Find intersection of currently propagated track with a plane.

Current track position is used as starting point.

Args:

  • p - track momentum to use for extrapolation
  • point - a point on a plane
  • normal - normal of the plane
  • itsect - output, point of intersection Returns:
  • kFALSE if intersection can not be found, kTRUE otherwise.

Definition at line 941 of file TEveTrackPropagator.cxx.

◆ IsA()

TClass * TEveTrackPropagator::IsA ( ) const
inlineoverridevirtual
Returns
TClass describing current object

Reimplemented from TEveElementList.

Definition at line 348 of file TEveTrackPropagator.h.

◆ IsOutsideBounds()

Bool_t TEveTrackPropagator::IsOutsideBounds ( const TEveVectorD point,
Double_t  maxRsqr,
Double_t  maxZ 
)
inlinestatic

Definition at line 352 of file TEveTrackPropagator.h.

◆ LineIntersectPlane()

Bool_t TEveTrackPropagator::LineIntersectPlane ( const TEveVectorD p,
const TEveVectorD point,
const TEveVectorD normal,
TEveVectorD itsect 
)
protected

Intersect line with a plane.

Current position and argument p define the line.

Definition at line 907 of file TEveTrackPropagator.cxx.

◆ LineToBounds()

void TEveTrackPropagator::LineToBounds ( TEveVectorD p)
protected

Propagate neutral particle with momentum p to bounds.

Definition at line 824 of file TEveTrackPropagator.cxx.

◆ LineToVertex()

Bool_t TEveTrackPropagator::LineToVertex ( TEveVectorD v)
protected

Propagate neutral particle to vertex v.

Definition at line 808 of file TEveTrackPropagator.cxx.

◆ LoopToBounds()

void TEveTrackPropagator::LoopToBounds ( TEveVectorD p)
protected

Propagate charged particle with momentum p to bounds.

It is expected that Update() with full-update was called before.

Definition at line 547 of file TEveTrackPropagator.cxx.

◆ LoopToLineSegment()

Bool_t TEveTrackPropagator::LoopToLineSegment ( const TEveVectorD s,
const TEveVectorD r,
TEveVectorD p 
)
protected

Propagate charged particle with momentum p to line segment with point s and vector r to the second point.

It is expected that Update() with full-update was called before. Returns kFALSE if hits bounds.

Definition at line 687 of file TEveTrackPropagator.cxx.

◆ LoopToVertex()

Bool_t TEveTrackPropagator::LoopToVertex ( TEveVectorD v,
TEveVectorD p 
)
protected

Propagate charged particle with momentum p to vertex v.

It is expected that Update() with full-update was called before.

Definition at line 610 of file TEveTrackPropagator.cxx.

◆ OnZeroRefCount()

void TEveTrackPropagator::OnZeroRefCount ( )
overridevirtual

Virtual from TEveRefBackPtr - track reference count has reached zero.

Reimplemented from TEveRefCnt.

Definition at line 286 of file TEveTrackPropagator.cxx.

◆ operator=()

TEveTrackPropagator & TEveTrackPropagator::operator= ( const TEveTrackPropagator )
private

◆ PointOverVertex()

Bool_t TEveTrackPropagator::PointOverVertex ( const TEveVector4D v0,
const TEveVector4D v,
Double_t p = nullptr 
)
inlineprotected

Definition at line 364 of file TEveTrackPropagator.h.

◆ PrintMagField()

void TEveTrackPropagator::PrintMagField ( Double_t  x,
Double_t  y,
Double_t  z 
) const

Definition at line 1055 of file TEveTrackPropagator.cxx.

◆ RebuildTracks()

void TEveTrackPropagator::RebuildTracks ( )
protected

Rebuild all tracks using this render-style.

Definition at line 1019 of file TEveTrackPropagator.cxx.

◆ RefFVAtt()

TMarker & TEveTrackPropagator::RefFVAtt ( )
inline

Definition at line 334 of file TEveTrackPropagator.h.

◆ RefPMAtt()

TMarker & TEveTrackPropagator::RefPMAtt ( )
inline

Definition at line 333 of file TEveTrackPropagator.h.

◆ RefPTBAtt()

TMarker & TEveTrackPropagator::RefPTBAtt ( )
inline

Definition at line 335 of file TEveTrackPropagator.h.

◆ ResetTrack()

void TEveTrackPropagator::ResetTrack ( )

Reset cache holding particle trajectory.

Definition at line 346 of file TEveTrackPropagator.cxx.

◆ SetDelta()

void TEveTrackPropagator::SetDelta ( Double_t  x)

Set maximum error and rebuild tracks.

Definition at line 1127 of file TEveTrackPropagator.cxx.

◆ SetEditPathMarks()

void TEveTrackPropagator::SetEditPathMarks ( Bool_t  x)
inline

Definition at line 292 of file TEveTrackPropagator.h.

◆ SetFitCluster2Ds()

void TEveTrackPropagator::SetFitCluster2Ds ( Bool_t  x)

Set 2D-cluster fitting and rebuild tracks.

Definition at line 1172 of file TEveTrackPropagator.cxx.

◆ SetFitDaughters()

void TEveTrackPropagator::SetFitDaughters ( Bool_t  x)

Set daughter creation point fitting and rebuild tracks.

Definition at line 1136 of file TEveTrackPropagator.cxx.

◆ SetFitDecay()

void TEveTrackPropagator::SetFitDecay ( Bool_t  x)

Set decay fitting and rebuild tracks.

Definition at line 1154 of file TEveTrackPropagator.cxx.

◆ SetFitLineSegments()

void TEveTrackPropagator::SetFitLineSegments ( Bool_t  x)

Set line segment fitting and rebuild tracks.

Definition at line 1163 of file TEveTrackPropagator.cxx.

◆ SetFitReferences()

void TEveTrackPropagator::SetFitReferences ( Bool_t  x)

Set track-reference fitting and rebuild tracks.

Definition at line 1145 of file TEveTrackPropagator.cxx.

◆ SetMagField() [1/2]

void TEveTrackPropagator::SetMagField ( Double_t  b)
inline

Definition at line 281 of file TEveTrackPropagator.h.

◆ SetMagField() [2/2]

void TEveTrackPropagator::SetMagField ( Double_t  bX,
Double_t  bY,
Double_t  bZ 
)

Set constant magnetic field and rebuild tracks.

Definition at line 1035 of file TEveTrackPropagator.cxx.

◆ SetMagFieldObj()

void TEveTrackPropagator::SetMagFieldObj ( TEveMagField field,
Bool_t  own_field = kTRUE 
)

Set constant magnetic field and rebuild tracks.

Definition at line 1043 of file TEveTrackPropagator.cxx.

◆ SetMaxAng()

void TEveTrackPropagator::SetMaxAng ( Double_t  x)

Set maximum step angle and rebuild tracks.

Definition at line 1109 of file TEveTrackPropagator.cxx.

◆ SetMaxOrbs()

void TEveTrackPropagator::SetMaxOrbs ( Double_t  x)

Set maximum number of orbits and rebuild tracks.

Definition at line 1081 of file TEveTrackPropagator.cxx.

◆ SetMaxR()

void TEveTrackPropagator::SetMaxR ( Double_t  x)

Set maximum radius and rebuild tracks.

Definition at line 1063 of file TEveTrackPropagator.cxx.

◆ SetMaxStep()

void TEveTrackPropagator::SetMaxStep ( Double_t  x)

Set maximum step-size and rebuild tracks.

Definition at line 1118 of file TEveTrackPropagator.cxx.

◆ SetMaxZ()

void TEveTrackPropagator::SetMaxZ ( Double_t  x)

Set maximum z and rebuild tracks.

Definition at line 1072 of file TEveTrackPropagator.cxx.

◆ SetMinAng()

void TEveTrackPropagator::SetMinAng ( Double_t  x)

Set maximum step angle and rebuild tracks.

WARNING – this method / variable was mis-named.

Definition at line 1091 of file TEveTrackPropagator.cxx.

◆ SetProjTrackBreaking()

void TEveTrackPropagator::SetProjTrackBreaking ( UChar_t  x)

Set projection break-point mode and rebuild tracks.

Definition at line 1226 of file TEveTrackPropagator.cxx.

◆ SetRnrCluster2Ds()

void TEveTrackPropagator::SetRnrCluster2Ds ( Bool_t  x)

Set rendering of 2D-clusters and rebuild tracks.

Definition at line 1190 of file TEveTrackPropagator.cxx.

◆ SetRnrDaughters()

void TEveTrackPropagator::SetRnrDaughters ( Bool_t  x)

Set daughter rendering and rebuild tracks.

Definition at line 1199 of file TEveTrackPropagator.cxx.

◆ SetRnrDecay()

void TEveTrackPropagator::SetRnrDecay ( Bool_t  x)

Set decay rendering and rebuild tracks.

Definition at line 1181 of file TEveTrackPropagator.cxx.

◆ SetRnrFV()

void TEveTrackPropagator::SetRnrFV ( Bool_t  x)

Set first-vertex rendering and rebuild tracks.

Definition at line 1217 of file TEveTrackPropagator.cxx.

◆ SetRnrPTBMarkers()

void TEveTrackPropagator::SetRnrPTBMarkers ( Bool_t  x)

Set projection break-point rendering and rebuild tracks.

Definition at line 1235 of file TEveTrackPropagator.cxx.

◆ SetRnrReferences()

void TEveTrackPropagator::SetRnrReferences ( Bool_t  x)

Set track-reference rendering and rebuild tracks.

Definition at line 1208 of file TEveTrackPropagator.cxx.

◆ SetStepper()

void TEveTrackPropagator::SetStepper ( EStepper_e  s)
inline

Definition at line 278 of file TEveTrackPropagator.h.

◆ Step()

void TEveTrackPropagator::Step ( const TEveVector4D v,
const TEveVectorD p,
TEveVector4D vOut,
TEveVectorD pOut 
)
protected

Wrapper to step helix.

Definition at line 510 of file TEveTrackPropagator.cxx.

◆ StepRungeKutta()

void TEveTrackPropagator::StepRungeKutta ( Double_t  step,
Double_t vect,
Double_t vout 
)
protected

Wrapper to step with method RungeKutta.

Definition at line 1244 of file TEveTrackPropagator.cxx.

◆ Streamer()

void TEveTrackPropagator::Streamer ( TBuffer )
overridevirtual

Reimplemented from TEveElementList.

◆ StreamerNVirtual()

void TEveTrackPropagator::StreamerNVirtual ( TBuffer ClassDef_StreamerNVirtual_b)
inline

Definition at line 348 of file TEveTrackPropagator.h.

◆ Update()

void TEveTrackPropagator::Update ( const TEveVector4D v,
const TEveVectorD p,
Bool_t  full_update = kFALSE,
Bool_t  enforce_max_step = kFALSE 
)
protected

Update helix / B-field projection state.

Definition at line 462 of file TEveTrackPropagator.cxx.

Friends And Related Symbol Documentation

◆ TEveTrackPropagatorSubEditor

friend class TEveTrackPropagatorSubEditor
friend

Definition at line 124 of file TEveTrackPropagator.h.

Member Data Documentation

◆ fEditPathMarks

Bool_t TEveTrackPropagator::fEditPathMarks
protected

Definition at line 196 of file TEveTrackPropagator.h.

◆ fFitCluster2Ds

Bool_t TEveTrackPropagator::fFitCluster2Ds
protected

Definition at line 200 of file TEveTrackPropagator.h.

◆ fFitDaughters

Bool_t TEveTrackPropagator::fFitDaughters
protected

Definition at line 197 of file TEveTrackPropagator.h.

◆ fFitDecay

Bool_t TEveTrackPropagator::fFitDecay
protected

Definition at line 199 of file TEveTrackPropagator.h.

◆ fFitLineSegments

Bool_t TEveTrackPropagator::fFitLineSegments
protected

Definition at line 201 of file TEveTrackPropagator.h.

◆ fFitReferences

Bool_t TEveTrackPropagator::fFitReferences
protected

Definition at line 198 of file TEveTrackPropagator.h.

◆ fFVAtt

TMarker TEveTrackPropagator::fFVAtt
protected

Definition at line 208 of file TEveTrackPropagator.h.

◆ fgDefault

TEveTrackPropagator TEveTrackPropagator::fgDefault
static

Definition at line 343 of file TEveTrackPropagator.h.

◆ fgDefMagField

Double_t TEveTrackPropagator::fgDefMagField = 0.5
static

Definition at line 341 of file TEveTrackPropagator.h.

◆ fgEditorMaxR

Double_t TEveTrackPropagator::fgEditorMaxR = 2000
static

Definition at line 345 of file TEveTrackPropagator.h.

◆ fgEditorMaxZ

Double_t TEveTrackPropagator::fgEditorMaxZ = 4000
static

Definition at line 346 of file TEveTrackPropagator.h.

◆ fgkB2C

const Double_t TEveTrackPropagator::fgkB2C = 0.299792458e-2
static

Definition at line 342 of file TEveTrackPropagator.h.

◆ fH

Helix_t TEveTrackPropagator::fH
protected

Definition at line 221 of file TEveTrackPropagator.h.

◆ fLastPoints

std::vector<TEveVector4D> TEveTrackPropagator::fLastPoints
protected

Definition at line 219 of file TEveTrackPropagator.h.

◆ fMagFieldObj

TEveMagField* TEveTrackPropagator::fMagFieldObj
protected

Definition at line 185 of file TEveTrackPropagator.h.

◆ fMaxOrbs

Double_t TEveTrackPropagator::fMaxOrbs
protected

Definition at line 193 of file TEveTrackPropagator.h.

◆ fMaxR

Double_t TEveTrackPropagator::fMaxR
protected

Definition at line 189 of file TEveTrackPropagator.h.

◆ fMaxZ

Double_t TEveTrackPropagator::fMaxZ
protected

Definition at line 190 of file TEveTrackPropagator.h.

◆ fNMax

Int_t TEveTrackPropagator::fNMax
protected

Definition at line 191 of file TEveTrackPropagator.h.

◆ fOwnMagFiledObj

Bool_t TEveTrackPropagator::fOwnMagFiledObj
protected

Definition at line 186 of file TEveTrackPropagator.h.

◆ fPMAtt

TMarker TEveTrackPropagator::fPMAtt
protected

Definition at line 207 of file TEveTrackPropagator.h.

◆ fPoints

std::vector<TEveVector4D> TEveTrackPropagator::fPoints
protected

Definition at line 218 of file TEveTrackPropagator.h.

◆ fProjTrackBreaking

UChar_t TEveTrackPropagator::fProjTrackBreaking
protected

Definition at line 211 of file TEveTrackPropagator.h.

◆ fPTBAtt

TMarker TEveTrackPropagator::fPTBAtt
protected

Definition at line 213 of file TEveTrackPropagator.h.

◆ fRnrCluster2Ds

Bool_t TEveTrackPropagator::fRnrCluster2Ds
protected

Definition at line 205 of file TEveTrackPropagator.h.

◆ fRnrDaughters

Bool_t TEveTrackPropagator::fRnrDaughters
protected

Definition at line 202 of file TEveTrackPropagator.h.

◆ fRnrDecay

Bool_t TEveTrackPropagator::fRnrDecay
protected

Definition at line 204 of file TEveTrackPropagator.h.

◆ fRnrFV

Bool_t TEveTrackPropagator::fRnrFV
protected

Definition at line 206 of file TEveTrackPropagator.h.

◆ fRnrPTBMarkers

Bool_t TEveTrackPropagator::fRnrPTBMarkers
protected

Definition at line 212 of file TEveTrackPropagator.h.

◆ fRnrReferences

Bool_t TEveTrackPropagator::fRnrReferences
protected

Definition at line 203 of file TEveTrackPropagator.h.

◆ fStepper

EStepper_e TEveTrackPropagator::fStepper
protected

Definition at line 183 of file TEveTrackPropagator.h.

◆ fV

TEveVectorD TEveTrackPropagator::fV
protected

Definition at line 220 of file TEveTrackPropagator.h.

Libraries for TEveTrackPropagator:

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