21 for (
int i = 0; i < N_Tracks; i++)
24 int pdg = 11 * (
r.Integer(2) > 0 ? 1 : -1);
26 p->SetProductionVertex(
r.Uniform(-
v,
v) + pos[0],
r.Uniform(-
v,
v) + pos[1],
r.Uniform(-
v,
v) + pos[2], 1);
27 p->SetMomentum(
r.Uniform(-
m,
m),
r.Uniform(-
m,
m),
r.Uniform(-
m,
m)*
r.Uniform(1, 3), 1);
30 track->SetMainColor(
kBlue);
31 track->SetName(
Form(
"Track_%d", i));
41 mng->SetProjection(t);
42 mng->ImportElements(el, eventScene);
49 auto eveMng = REveManager::Create();
50 float pos[3] = {1.46589e-06,-1.30522e-05,-1.98267e-05};
53 double a[16] = {1.46589e-01,-1.30522e-02,-1.98267e-02, 0,
54 -1.30522e-02, 4.22955e-02,-5.86628e-03, 0,
55 -1.98267e-02,-5.86628e-03, 2.12836e-01, 0,
61 for(
int i = 0; i < 3; i++)
62 for(
int j = 0; j < 3; j++)
64 xxx(i,j) = t(i+1,j+1);
69 xxxEig = xxxEig.
Sqrt();
73 for (
int i = 0; i < 3; ++i)
75 v[i].
Set(vecEig(0,i), vecEig(1,i), vecEig(2,i));
86 event->AddElement(ellipse);
90 ps->SetNextPoint(pos[0], pos[1], pos[2]);
91 ps->SetMarkerStyle(4);
94 for(
int i=0; i < 6; ++i)
95 ps->SetNextPoint(i*(rng/3) - rng, 0, 0);
96 event->AddElement(ps);
R__EXTERN TRandom * gRandom
char * Form(const char *fmt,...)
virtual void AddElement(REveElement *el)
Add el to the list of children.
virtual void InitMainTrans(Bool_t can_edit=kTRUE)
Initialize the main transformation to identity matrix.
virtual void SetMainColor(Color_t color)
Set main color of the element.
void SetBaseVectors(REveVector &v0, REveVector &v1, REveVector &v3)
Three defining base vectors of ellipse.
virtual void Outline()
Draw archade around base vectors.
REveMagFieldDuo Interface to magnetic field with two different values depending on radius.
REveScene * GetEventScene() const
REveScene * SpawnNewScene(const char *name, const char *title="")
Create a new scene.
REveViewer * SpawnNewViewer(const char *name, const char *title="")
Create a new GL viewer.
void Show(const RWebDisplayArgs &args="")
Show eve manager in specified browser.
REveProjectionManager Manager class for steering of projections and managing projected objects.
REveTrackPropagator Calculates path of a particle taking into account special path-marks and imposed ...
REveTrack Track with given vertex, momentum and optional referece-points (path-marks) along its path.
void SetFrom(Double_t *carr)
void Set(const Float_t *v)
virtual void AddScene(REveScene *scene)
Add 'scene' to the list of scenes.
virtual void SetLineWidth(Width_t lwidth)
Set the line width.
const TMatrixD & GetEigenVectors() const
const TMatrixD GetEigenValues() const
Computes the block diagonal eigenvalue matrix.
Description of the dynamic properties of a particle.
This is the base class for the ROOT Random number generators.
TVectorT< Element > & Sqrt()
Take square root of all elements.
ROOT::Experimental::REveManager * eveMng
void makeProjected(REveElement *el, const char *pname, REveProjection::EPType_e t)
void makeTracks(int N_Tracks, REveElement *trackHolder, float *pos)
R__EXTERN REveManager * gEve