Jpp  18.0.0-rc.4
the software that should make you happy
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
Public Member Functions | Protected Attributes | List of all members
JSIRENE::JVertex Struct Reference

Vertex of energy loss of muon. More...

#include <JSireneToolkit.hh>

Inheritance diagram for JSIRENE::JVertex:
JSIRENE::JPoint JGEOMETRY3D::JVersor3Z JGEOMETRY3D::JPosition3D JGEOMETRY3D::JTime JMATH::JMath< JFirst_t, JSecond_t > JGEOMETRY3D::JVector3D JMATH::JMath< JFirst_t, JSecond_t >

Public Member Functions

 JVertex ()
 Default constructor. More...
 
 JVertex (const double z, const double t, const double E)
 Constructor. More...
 
double getRange () const
 Get visible range of muon using default ionisation energy loss. More...
 
double getRange (double a) const
 Get visible range of muon using given ionisation energy loss. More...
 
double getRange (const JGeane &geane) const
 Get range of muon using given energy loss function. More...
 
void applyEloss (const JVersor3Z &Ts, const double Es)
 Apply shower energy loss. More...
 
JVertexstep (const double ds)
 Step using default ionisation energy loss. More...
 
JVertexstep (const double a, const double ds)
 Step using given ionisation energy loss. More...
 
JVertexstep (const JGeane &geane, const double ds)
 Step using given energy loss function. More...
 
double getE () const
 Get muon energy. More...
 
double getEs () const
 Get shower energy. More...
 
const JPosition3DgetPosition () const
 Get position. More...
 
JPosition3DgetPosition ()
 Get position. More...
 
void setPosition (const JVector3D &pos)
 Set position. More...
 
 operator JAngle3D () const
 Type conversion operator. More...
 
 operator JVersor3D () const
 Type conversion operator. More...
 
JPosition3Drotate (const JRotation3D &R)
 Rotate. More...
 
JPosition3Drotate (const JRotation3X &R)
 Rotate around X-axis. More...
 
JPosition3Drotate (const JRotation3Y &R)
 Rotate around Y-axis. More...
 
JPosition3Drotate (const JRotation3Z &R)
 Rotate around Z-axis. More...
 
JPosition3Drotate (const JQuaternion3D &Q)
 Rotate. More...
 
JPosition3Drotate_back (const JRotation3D &R)
 Rotate back. More...
 
JPosition3Drotate_back (const JRotation3X &R)
 Rotate back around X-axis. More...
 
JPosition3Drotate_back (const JRotation3Y &R)
 Rotate back around Y-axis. More...
 
JPosition3Drotate_back (const JRotation3Z &R)
 Rotate back around Z-axis. More...
 
JPosition3Drotate_back (const JQuaternion3D &Q)
 Rotate back. More...
 
void transform (const JRotation3D &R, const JVector3D &pos)
 Transform position. More...
 
JVector3Dtransform (const JMatrix3D &T)
 Transform. More...
 
void transform_back (const JRotation3D &R, const JVector3D &pos)
 Transform back position. More...
 
double getDot (const JAngle3D &angle) const
 Get dot product. More...
 
double getDot (const JVersor3D &dir) const
 Get dot product. More...
 
double getDot (const JVersor3Z &dir) const
 Get dot product. More...
 
double getDot (const JVector3D &vector) const
 Get dot product. More...
 
 operator JVector2D () const
 Type conversion operator. More...
 
double getX () const
 Get x position. More...
 
double getY () const
 Get y position. More...
 
double getZ () const
 Get z position. More...
 
JVector3Dnegate ()
 Negate vector. More...
 
JTimenegate ()
 Prefix unary minus. More...
 
JVector3Dadd (const JVector3D &vector)
 Add vector. More...
 
JTimeadd (const JTime &value)
 Addition operator. More...
 
JVector3Dsub (const JVector3D &vector)
 Subtract vector. More...
 
JTimesub (const JTime &value)
 Subtraction operator. More...
 
JVector3Dmul (const double factor)
 Scale vector. More...
 
JFirst_t & mul (const JSecond_t &object)
 Multiply with object. More...
 
JTimemul (const double value)
 Multiplication operator. More...
 
JVector3Ddiv (const double factor)
 Scale vector. More...
 
JTimediv (const double value)
 Division operator. More...
 
bool equals (const JVector3D &vector, const double precision=std::numeric_limits< double >::min()) const
 Check equality. More...
 
double getLengthSquared () const
 Get length squared. More...
 
double getLength () const
 Get length. More...
 
double getDistanceSquared (const JVector3D &pos) const
 Get squared of distance to point. More...
 
double getDistance (const JVector3D &pos) const
 Get distance to point. More...
 
JVector3DgetCross (const JVector3D &first, const JVector3D &second)
 Get cross product. More...
 
double getT () const
 Get time. More...
 
const JVersor3ZgetDirection () const
 Get direction. More...
 
JVersor3ZgetDirection ()
 Get direction. More...
 
void setDirection (const JVersor3Z &direction)
 Set direction. More...
 
 operator JAngle3D () const
 Get angle. More...
 
 operator JVector3D () const
 Type conversion operator. More...
 
 operator JVersor3D () const
 Type conversion operator. More...
 
double getDX () const
 Get x direction. More...
 
double getDY () const
 Get y direction. More...
 
double getDZ () const
 Get z direction. More...
 
JVersor3Znegate ()
 Prefix unary minus. More...
 
JVersor3Zadd (const JVersor3Z &value)
 Addition operator. More...
 
JVersor3Zsub (const JVersor3Z &value)
 Subtraction operator. More...
 
JVersor3Zmul (const double value)
 Multiplication operator. More...
 
JFirst_t & mul (const JSecond_t &object)
 Multiply with object. More...
 
JVersor3Zdiv (const double value)
 Division operator. More...
 
bool equals (const JVersor3D &versor, const double precision=std::numeric_limits< double >::min()) const
 Check equality. More...
 
double getDot (const JVersor3Z &dir) const
 Get dot product. More...
 
double getDot (const JAngle3D &angle) const
 Get dot product. More...
 
double getDot (const JVector3D &pos) const
 Get dot product. More...
 
double getDot (const JVersor3D &dir) const
 Get dot product. More...
 

Protected Attributes

double __E
 
double __Es
 
double __x
 
double __y
 
double __z
 
double __t
 
double __dx
 
double __dy
 

Detailed Description

Vertex of energy loss of muon.

Definition at line 334 of file JSireneToolkit.hh.

Constructor & Destructor Documentation

JSIRENE::JVertex::JVertex ( )
inline

Default constructor.

Definition at line 341 of file JSireneToolkit.hh.

341  :
342  JPoint(),
343  JVersor3Z()
344  {}
JPoint()
Default constructor.
JVersor3Z()
Default constructor.
Definition: JVersor3Z.hh:46
JSIRENE::JVertex::JVertex ( const double  z,
const double  t,
const double  E 
)
inline

Constructor.

Parameters
zposition [m]
ttime [ns]
Eenergy [GeV]

Definition at line 354 of file JSireneToolkit.hh.

356  :
357  JPoint(z, t, E),
358  JVersor3Z()
359  {}
then usage $script< input file >[option[primary[working directory]]] nWhere option can be E
Definition: JMuonPostfit.sh:40
JPoint()
Default constructor.
JVersor3Z()
Default constructor.
Definition: JVersor3Z.hh:46

Member Function Documentation

double JSIRENE::JVertex::getRange ( ) const
inline

Get visible range of muon using default ionisation energy loss.

This method applies only ionisation energy loss.

Returns
range [m]

Definition at line 368 of file JSireneToolkit.hh.

369  {
370  return getRange(gWater.getA());
371  }
static const JGeaneWater gWater
Function object for energy loss of muon in sea water.
Definition: JGeane.hh:381
double getRange() const
Get visible range of muon using default ionisation energy loss.
virtual double getA() const override
Get energy loss constant.
Definition: JGeane.hh:231
double JSIRENE::JVertex::getRange ( double  a) const
inline

Get visible range of muon using given ionisation energy loss.

This method applies only ionisation energy loss.

Parameters
aionization parameter [GeV/m]
Returns
range [m]

Definition at line 381 of file JSireneToolkit.hh.

382  {
383  static const double Ethreshold = MASS_MUON / getSinThetaC();
384 
385  if (__E > Ethreshold)
386  return (__E - Ethreshold) / a;
387  else
388  return 0.0;
389  }
static const double MASS_MUON
muon mass [GeV]
then JCalibrateToT a
Definition: JTuneHV.sh:116
double getSinThetaC()
Get average sine of Cherenkov angle of water corresponding to group velocity.
double JSIRENE::JVertex::getRange ( const JGeane geane) const
inline

Get range of muon using given energy loss function.

Parameters
geaneenergy loss function
Returns
range [m]

Definition at line 398 of file JSireneToolkit.hh.

399  {
400  return geane(__E);
401  }
void JSIRENE::JVertex::applyEloss ( const JVersor3Z Ts,
const double  Es 
)
inline

Apply shower energy loss.

Parameters
Tsscattering angles
Esshower energy [GeV]

Definition at line 410 of file JSireneToolkit.hh.

411  {
412  static_cast<JVersor3Z&>(*this).add(Ts);
413 
414  this->__E -= Es;
415  this->__Es = Es;
416  }
JVersor3Z()
Default constructor.
Definition: JVersor3Z.hh:46
JVertex& JSIRENE::JVertex::step ( const double  ds)
inline

Step using default ionisation energy loss.

This method applies only ionisation energy loss.

Parameters
dsstep [m]
Returns
this vertex

Definition at line 426 of file JSireneToolkit.hh.

427  {
428  return step(gWater.getA(), ds);
429  }
JVertex & step(const double ds)
Step using default ionisation energy loss.
static const JGeaneWater gWater
Function object for energy loss of muon in sea water.
Definition: JGeane.hh:381
virtual double getA() const override
Get energy loss constant.
Definition: JGeane.hh:231
JVertex& JSIRENE::JVertex::step ( const double  a,
const double  ds 
)
inline

Step using given ionisation energy loss.

This method applies only given ionisation energy loss.

Parameters
aionization parameter [GeV/m]
dsstep [m]
Returns
this vertex

Definition at line 440 of file JSireneToolkit.hh.

441  {
442  __x += this->getDX() * ds;
443  __y += this->getDY() * ds;
444  __z += this->getDZ() * ds;
445  __t += ds / getSpeedOfLight();
446  __E -= ds * a;
447 
448  return *this;
449  }
double getDY() const
Get y direction.
Definition: JVersor3Z.hh:158
then JCalibrateToT a
Definition: JTuneHV.sh:116
const double getSpeedOfLight()
Get speed of light.
double getDX() const
Get x direction.
Definition: JVersor3Z.hh:147
double getDZ() const
Get z direction.
Definition: JVersor3Z.hh:169
JVertex& JSIRENE::JVertex::step ( const JGeane geane,
const double  ds 
)
inline

Step using given energy loss function.

Parameters
geaneenergy loss function
dsstep [m]
Returns
this vertex

Definition at line 459 of file JSireneToolkit.hh.

460  {
461  __x += this->getDX() * ds;
462  __y += this->getDY() * ds;
463  __z += this->getDZ() * ds;
464  __t += ds / getSpeedOfLight();
465  __E = geane(__E, ds);
466 
467  return *this;
468  }
double getDY() const
Get y direction.
Definition: JVersor3Z.hh:158
const double getSpeedOfLight()
Get speed of light.
double getDX() const
Get x direction.
Definition: JVersor3Z.hh:147
double getDZ() const
Get z direction.
Definition: JVersor3Z.hh:169
double JSIRENE::JPoint::getE ( ) const
inlineinherited

Get muon energy.

Returns
energy [GeV]

Definition at line 222 of file JSireneToolkit.hh.

223  {
224  return __E;
225  }
double JSIRENE::JPoint::getEs ( ) const
inlineinherited

Get shower energy.

Returns
energy [GeV]

Definition at line 233 of file JSireneToolkit.hh.

234  {
235  return __Es;
236  }
const JPosition3D& JGEOMETRY3D::JPosition3D::getPosition ( ) const
inlineinherited

Get position.

Returns
position

Definition at line 130 of file JPosition3D.hh.

131  {
132  return static_cast<const JPosition3D&>(*this);
133  }
Data structure for position in three dimensions.
Definition: JPosition3D.hh:36
JPosition3D& JGEOMETRY3D::JPosition3D::getPosition ( )
inlineinherited

Get position.

Returns
position

Definition at line 141 of file JPosition3D.hh.

142  {
143  return static_cast<JPosition3D&>(*this);
144  }
Data structure for position in three dimensions.
Definition: JPosition3D.hh:36
void JGEOMETRY3D::JPosition3D::setPosition ( const JVector3D pos)
inlineinherited

Set position.

Parameters
posposition

Definition at line 152 of file JPosition3D.hh.

153  {
154  static_cast<JVector3D&>(*this) = pos;
155  }
Data structure for vector in three dimensions.
Definition: JVector3D.hh:34
JGEOMETRY3D::JPosition3D::operator JAngle3D ( ) const
inlineinherited

Type conversion operator.

Returns
angle

Definition at line 163 of file JPosition3D.hh.

164  {
165  return JAngle3D(getX(), getY(), getZ());
166  }
Data structure for angles in three dimensions.
Definition: JAngle3D.hh:33
double getY() const
Get y position.
Definition: JVector3D.hh:104
double getX() const
Get x position.
Definition: JVector3D.hh:94
double getZ() const
Get z position.
Definition: JVector3D.hh:115
JGEOMETRY3D::JPosition3D::operator JVersor3D ( ) const
inlineinherited

Type conversion operator.

Returns
direction

Definition at line 174 of file JPosition3D.hh.

175  {
176  return JVersor3D(getX(), getY(), getZ());
177  }
double getY() const
Get y position.
Definition: JVector3D.hh:104
double getX() const
Get x position.
Definition: JVector3D.hh:94
Data structure for normalised vector in three dimensions.
Definition: JVersor3D.hh:26
double getZ() const
Get z position.
Definition: JVector3D.hh:115
JPosition3D& JGEOMETRY3D::JPosition3D::rotate ( const JRotation3D R)
inlineinherited

Rotate.

Parameters
Rrotation matrix
Returns
this position

Definition at line 186 of file JPosition3D.hh.

187  {
188  R.rotate(__x, __y, __z);
189 
190  return *this;
191  }
void rotate(double &__x, double &__y, double &__z) const
Rotate.
Definition: JRotation3D.hh:336
JPosition3D& JGEOMETRY3D::JPosition3D::rotate ( const JRotation3X R)
inlineinherited

Rotate around X-axis.

Parameters
Rrotation matrix
Returns
this position

Definition at line 214 of file JPosition3D.hh.

215  {
216  R.rotate(__y, __z);
217 
218  return *this;
219  }
void rotate(double &__x, double &__y) const
Rotate.
Definition: JRotation2D.hh:96
JPosition3D& JGEOMETRY3D::JPosition3D::rotate ( const JRotation3Y R)
inlineinherited

Rotate around Y-axis.

Parameters
Rrotation matrix
Returns
this position

Definition at line 242 of file JPosition3D.hh.

243  {
244  R.rotate(__x, __z);
245 
246  return *this;
247  }
void rotate(double &__x, double &__y) const
Rotate.
Definition: JRotation2D.hh:96
JPosition3D& JGEOMETRY3D::JPosition3D::rotate ( const JRotation3Z R)
inlineinherited

Rotate around Z-axis.

Parameters
Rrotation matrix
Returns
this position

Definition at line 270 of file JPosition3D.hh.

271  {
272  R.rotate(__x, __y);
273 
274  return *this;
275  }
void rotate(double &__x, double &__y) const
Rotate.
Definition: JRotation2D.hh:96
JPosition3D& JGEOMETRY3D::JPosition3D::rotate ( const JQuaternion3D Q)
inlineinherited

Rotate.

Parameters
Qquaternion
Returns
this position

Definition at line 298 of file JPosition3D.hh.

299  {
300  Q.rotate(__x, __y, __z);
301 
302  return *this;
303  }
void rotate(double &__x, double &__y, double &__z) const
Rotate.
JPosition3D& JGEOMETRY3D::JPosition3D::rotate_back ( const JRotation3D R)
inlineinherited

Rotate back.

Parameters
Rrotation matrix
Returns
this position

Definition at line 200 of file JPosition3D.hh.

201  {
202  R.rotate_back(__x, __y, __z);
203 
204  return *this;
205  }
void rotate_back(double &__x, double &__y, double &__z) const
Rotate back.
Definition: JRotation3D.hh:355
JPosition3D& JGEOMETRY3D::JPosition3D::rotate_back ( const JRotation3X R)
inlineinherited

Rotate back around X-axis.

Parameters
Rrotation matrix
Returns
this position

Definition at line 228 of file JPosition3D.hh.

229  {
230  R.rotate_back(__y, __z);
231 
232  return *this;
233  }
void rotate_back(double &__x, double &__y) const
Rotate back.
Definition: JRotation2D.hh:112
JPosition3D& JGEOMETRY3D::JPosition3D::rotate_back ( const JRotation3Y R)
inlineinherited

Rotate back around Y-axis.

Parameters
Rrotation matrix
Returns
this position

Definition at line 256 of file JPosition3D.hh.

257  {
258  R.rotate_back(__x, __z);
259 
260  return *this;
261  }
void rotate_back(double &__x, double &__y) const
Rotate back.
Definition: JRotation2D.hh:112
JPosition3D& JGEOMETRY3D::JPosition3D::rotate_back ( const JRotation3Z R)
inlineinherited

Rotate back around Z-axis.

Parameters
Rrotation matrix
Returns
this position

Definition at line 284 of file JPosition3D.hh.

285  {
286  R.rotate_back(__x, __y);
287 
288  return *this;
289  }
void rotate_back(double &__x, double &__y) const
Rotate back.
Definition: JRotation2D.hh:112
JPosition3D& JGEOMETRY3D::JPosition3D::rotate_back ( const JQuaternion3D Q)
inlineinherited

Rotate back.

Parameters
Qquaternion
Returns
this position

Definition at line 312 of file JPosition3D.hh.

313  {
314  Q.rotate_back(__x, __y, __z);
315 
316  return *this;
317  }
void rotate_back(double &__x, double &__y, double &__z) const
Rotate back.
void JGEOMETRY3D::JPosition3D::transform ( const JRotation3D R,
const JVector3D pos 
)
inlineinherited

Transform position.

The final position is obtained as follows:

  1. rotation of the position according matrix R;
  2. offset position with pos;
  3. rotation of position around z-axis, such that final position lies in x-z plane;
Parameters
Rrotation matrix
posposition of origin (after rotation)

Definition at line 331 of file JPosition3D.hh.

333  {
334  // rotate geometry to system with particle direction along z-axis
335 
336  rotate(R);
337 
338  // offset with respect to origin
339 
340  sub(pos);
341 
342  // rotate geometry to x-z plane
343 
344  __x = sqrt(__x*__x + __y*__y);
345  __y = 0.0;
346  }
JVector3D & sub(const JVector3D &vector)
Subtract vector.
Definition: JVector3D.hh:158
JPosition3D & rotate(const JRotation3D &R)
Rotate.
Definition: JPosition3D.hh:186
JVector3D& JGEOMETRY3D::JVector3D::transform ( const JMatrix3D T)
inlineinherited

Transform.

Parameters
Tmatrix
Returns
this vector

Definition at line 206 of file JVector3D.hh.

207  {
208  T.transform(__x, __y, __z);
209 
210  return *this;
211  }
do set_variable OUTPUT_DIRECTORY $WORKDIR T
void JGEOMETRY3D::JPosition3D::transform_back ( const JRotation3D R,
const JVector3D pos 
)
inlineinherited

Transform back position.

The final position is obtained as follows:

  1. offset position with position pos;
  2. rotation of postion according matrix R;
Parameters
Rrotation matrix
posposition of origin (before rotation)

Definition at line 359 of file JPosition3D.hh.

361  {
362  // offset with respect to origin
363 
364  add(pos);
365 
366  // rotate back geometry to system with particle direction along z-axis
367 
368  rotate_back(R);
369  }
JPosition3D & rotate_back(const JRotation3D &R)
Rotate back.
Definition: JPosition3D.hh:200
JVector3D & add(const JVector3D &vector)
Add vector.
Definition: JVector3D.hh:142
double JGEOMETRY3D::JPosition3D::getDot ( const JAngle3D angle) const
inlineinherited

Get dot product.

Parameters
angleangle
Returns
dot product

Definition at line 378 of file JPosition3D.hh.

379  {
380  return
381  getX() * angle.getDX() +
382  getY() * angle.getDY() +
383  getZ() * angle.getDZ();
384  }
double getY() const
Get y position.
Definition: JVector3D.hh:104
double getX() const
Get x position.
Definition: JVector3D.hh:94
double getZ() const
Get z position.
Definition: JVector3D.hh:115
double getDX() const
Get x direction.
Definition: JAngle3D.hh:108
double getDZ() const
Get z direction.
Definition: JAngle3D.hh:130
double getDY() const
Get y direction.
Definition: JAngle3D.hh:119
double JGEOMETRY3D::JPosition3D::getDot ( const JVersor3D dir) const
inlineinherited

Get dot product.

Parameters
dirdirection
Returns
dot product

Definition at line 393 of file JPosition3D.hh.

394  {
395  return
396  getX() * dir.getDX() +
397  getY() * dir.getDY() +
398  getZ() * dir.getDZ();
399  }
double getDY() const
Get y direction.
Definition: JVersor3D.hh:106
double getDX() const
Get x direction.
Definition: JVersor3D.hh:95
double getY() const
Get y position.
Definition: JVector3D.hh:104
double getX() const
Get x position.
Definition: JVector3D.hh:94
double getZ() const
Get z position.
Definition: JVector3D.hh:115
double getDZ() const
Get z direction.
Definition: JVersor3D.hh:117
double JGEOMETRY3D::JPosition3D::getDot ( const JVersor3Z dir) const
inlineinherited

Get dot product.

Parameters
dirdirection
Returns
dot product

Definition at line 408 of file JPosition3D.hh.

409  {
410  return
411  getX() * dir.getDX() +
412  getY() * dir.getDY() +
413  getZ() * dir.getDZ();
414  }
double getDY() const
Get y direction.
Definition: JVersor3Z.hh:158
double getY() const
Get y position.
Definition: JVector3D.hh:104
double getDX() const
Get x direction.
Definition: JVersor3Z.hh:147
double getX() const
Get x position.
Definition: JVector3D.hh:94
double getDZ() const
Get z direction.
Definition: JVersor3Z.hh:169
double getZ() const
Get z position.
Definition: JVector3D.hh:115
double JGEOMETRY3D::JVector3D::getDot ( const JVector3D vector) const
inlineinherited

Get dot product.

Parameters
vectorvector
Returns
dot product

Definition at line 282 of file JVector3D.hh.

283  {
284  return
285  getX() * vector.getX() +
286  getY() * vector.getY() +
287  getZ() * vector.getZ();
288  }
double getY() const
Get y position.
Definition: JVector3D.hh:104
double getX() const
Get x position.
Definition: JVector3D.hh:94
double getZ() const
Get z position.
Definition: JVector3D.hh:115
JGEOMETRY3D::JVector3D::operator JVector2D ( ) const
inlineinherited

Type conversion operator.

Returns
JVector2D

Definition at line 83 of file JVector3D.hh.

84  {
85  return JVector2D(this->getX(), this->getY());
86  }
double getY() const
Get y position.
Definition: JVector3D.hh:104
double getX() const
Get x position.
Definition: JVector3D.hh:94
double JGEOMETRY3D::JVector3D::getX ( ) const
inlineinherited

Get x position.

Returns
x position

Definition at line 94 of file JVector3D.hh.

95  {
96  return __x;
97  }
double JGEOMETRY3D::JVector3D::getY ( ) const
inlineinherited

Get y position.

Returns
y position

Definition at line 104 of file JVector3D.hh.

105  {
106  return __y;
107  }
double JGEOMETRY3D::JVector3D::getZ ( ) const
inlineinherited

Get z position.

Returns
z position

Definition at line 115 of file JVector3D.hh.

116  {
117  return __z;
118  }
JVector3D& JGEOMETRY3D::JVector3D::negate ( )
inlineinherited

Negate vector.

Returns
this vector

Definition at line 126 of file JVector3D.hh.

127  {
128  __x = -__x;
129  __y = -__y;
130  __z = -__z;
131 
132  return *this;
133  }
JTime& JGEOMETRY3D::JTime::negate ( )
inlineinherited

Prefix unary minus.

Returns
time

Definition at line 53 of file JGeometry3D/JTime.hh.

54  {
55  __t = -__t;
56 
57  return *this;
58  }
JVector3D& JGEOMETRY3D::JVector3D::add ( const JVector3D vector)
inlineinherited

Add vector.

Parameters
vectorvector
Returns
this vector

Definition at line 142 of file JVector3D.hh.

143  {
144  __x += vector.getX();
145  __y += vector.getY();
146  __z += vector.getZ();
147 
148  return *this;
149  }
double getY() const
Get y position.
Definition: JVector3D.hh:104
double getX() const
Get x position.
Definition: JVector3D.hh:94
double getZ() const
Get z position.
Definition: JVector3D.hh:115
JTime& JGEOMETRY3D::JTime::add ( const JTime value)
inlineinherited

Addition operator.

Parameters
valuetime
Returns
time

Definition at line 67 of file JGeometry3D/JTime.hh.

68  {
69  __t += value.getT();
70 
71  return *this;
72  }
double getT() const
Get time.
JVector3D& JGEOMETRY3D::JVector3D::sub ( const JVector3D vector)
inlineinherited

Subtract vector.

Parameters
vectorvector
Returns
this vector

Definition at line 158 of file JVector3D.hh.

159  {
160  __x -= vector.getX();
161  __y -= vector.getY();
162  __z -= vector.getZ();
163 
164  return *this;
165  }
double getY() const
Get y position.
Definition: JVector3D.hh:104
double getX() const
Get x position.
Definition: JVector3D.hh:94
double getZ() const
Get z position.
Definition: JVector3D.hh:115
JTime& JGEOMETRY3D::JTime::sub ( const JTime value)
inlineinherited

Subtraction operator.

Parameters
valuetime
Returns
time

Definition at line 81 of file JGeometry3D/JTime.hh.

82  {
83  __t -= value.getT();
84 
85  return *this;
86  }
double getT() const
Get time.
JVector3D& JGEOMETRY3D::JVector3D::mul ( const double  factor)
inlineinherited

Scale vector.

Parameters
factormultiplication factor
Returns
this vector

Definition at line 174 of file JVector3D.hh.

175  {
176  __x *= factor;
177  __y *= factor;
178  __z *= factor;
179 
180  return *this;
181  }
template<class JFirst_t, class JSecond_t = JNullType>
JFirst_t& JMATH::JMath< JFirst_t, JSecond_t >::mul ( const JSecond_t &  object)
inlineinherited

Multiply with object.

Parameters
objectobject
Returns
result object

Definition at line 354 of file JMath.hh.

355  {
356  return static_cast<JFirst_t&>(*this) = JFirst_t().mul(static_cast<const JFirst_t&>(*this), object);
357  }
JTime& JGEOMETRY3D::JTime::mul ( const double  value)
inlineinherited

Multiplication operator.

Parameters
valuemultiplication factor
Returns
time

Definition at line 95 of file JGeometry3D/JTime.hh.

96  {
97  __t *= value;
98 
99  return *this;
100  }
JVector3D& JGEOMETRY3D::JVector3D::div ( const double  factor)
inlineinherited

Scale vector.

Parameters
factordivision factor
Returns
this vector

Definition at line 190 of file JVector3D.hh.

191  {
192  __x /= factor;
193  __y /= factor;
194  __z /= factor;
195 
196  return *this;
197  }
JTime& JGEOMETRY3D::JTime::div ( const double  value)
inlineinherited

Division operator.

Parameters
valuemultiplication factor
Returns
time

Definition at line 109 of file JGeometry3D/JTime.hh.

110  {
111  __t /= value;
112 
113  return *this;
114  }
bool JGEOMETRY3D::JVector3D::equals ( const JVector3D vector,
const double  precision = std::numeric_limits<double>::min() 
) const
inlineinherited

Check equality.

Parameters
vectorvector
precisionprecision
Returns
true if vectors are equal; else false

Definition at line 221 of file JVector3D.hh.

223  {
224  return (fabs(getX() - vector.getX()) <= precision &&
225  fabs(getY() - vector.getY()) <= precision &&
226  fabs(getZ() - vector.getZ()) <= precision);
227  }
double getY() const
Get y position.
Definition: JVector3D.hh:104
double getX() const
Get x position.
Definition: JVector3D.hh:94
double getZ() const
Get z position.
Definition: JVector3D.hh:115
double JGEOMETRY3D::JVector3D::getLengthSquared ( ) const
inlineinherited

Get length squared.

Returns
square of length

Definition at line 235 of file JVector3D.hh.

236  {
237  return getX()*getX() + getY()*getY() + getZ()*getZ();
238  }
double getY() const
Get y position.
Definition: JVector3D.hh:104
double getX() const
Get x position.
Definition: JVector3D.hh:94
double getZ() const
Get z position.
Definition: JVector3D.hh:115
double JGEOMETRY3D::JVector3D::getLength ( ) const
inlineinherited

Get length.

Returns
length

Definition at line 246 of file JVector3D.hh.

247  {
248  return sqrt(getLengthSquared());
249  }
double getLengthSquared() const
Get length squared.
Definition: JVector3D.hh:235
double JGEOMETRY3D::JVector3D::getDistanceSquared ( const JVector3D pos) const
inlineinherited

Get squared of distance to point.

Parameters
posposition
Returns
square of distance

Definition at line 258 of file JVector3D.hh.

259  {
260  return JVector3D(pos).sub(*this).getLengthSquared();
261  }
JVector3D()
Default constructor.
Definition: JVector3D.hh:41
double JGEOMETRY3D::JVector3D::getDistance ( const JVector3D pos) const
inlineinherited

Get distance to point.

Parameters
posposition
Returns
distance

Definition at line 270 of file JVector3D.hh.

271  {
272  return sqrt(getDistanceSquared(pos));
273  }
double getDistanceSquared(const JVector3D &pos) const
Get squared of distance to point.
Definition: JVector3D.hh:258
JVector3D& JGEOMETRY3D::JVector3D::getCross ( const JVector3D first,
const JVector3D second 
)
inlineinherited

Get cross product.

Note that this vector should not overlap with the first or second vector,

Parameters
firstfirst vector
secondsecond vector
Returns
this vector

Definition at line 299 of file JVector3D.hh.

301  {
302  __x = first .getY() * second.getZ() - second.getY() * first .getZ();
303  __y = second.getX() * first .getZ() - first .getX() * second.getZ();
304  __z = first .getX() * second.getY() - second.getX() * first .getY();
305 
306  return *this;
307  }
double getY() const
Get y position.
Definition: JVector3D.hh:104
double getX() const
Get x position.
Definition: JVector3D.hh:94
double getZ() const
Get z position.
Definition: JVector3D.hh:115
double JGEOMETRY3D::JTime::getT ( ) const
inlineinherited

Get time.

Returns
time

Definition at line 122 of file JGeometry3D/JTime.hh.

123  {
124  return __t;
125  }
const JVersor3Z& JGEOMETRY3D::JVersor3Z::getDirection ( ) const
inlineinherited

Get direction.

Returns
direction

Definition at line 81 of file JVersor3Z.hh.

82  {
83  return static_cast<const JVersor3Z&>(*this);
84  }
Data structure for normalised vector in positive z-direction.
Definition: JVersor3Z.hh:39
JVersor3Z& JGEOMETRY3D::JVersor3Z::getDirection ( )
inlineinherited

Get direction.

Returns
direction

Definition at line 92 of file JVersor3Z.hh.

93  {
94  return static_cast<JVersor3Z&>(*this);
95  }
Data structure for normalised vector in positive z-direction.
Definition: JVersor3Z.hh:39
void JGEOMETRY3D::JVersor3Z::setDirection ( const JVersor3Z direction)
inlineinherited

Set direction.

Parameters
directiondirection

Definition at line 103 of file JVersor3Z.hh.

104  {
105  static_cast<JVersor3Z&>(*this) = direction;
106  }
Data structure for normalised vector in positive z-direction.
Definition: JVersor3Z.hh:39
JGEOMETRY3D::JVersor3Z::operator JAngle3D ( ) const
inlineinherited

Get angle.

Returns
angle

Definition at line 114 of file JVersor3Z.hh.

115  {
116  return JAngle3D(getDX(), getDY(), getDZ());
117  }
Data structure for angles in three dimensions.
Definition: JAngle3D.hh:33
double getDY() const
Get y direction.
Definition: JVersor3Z.hh:158
double getDX() const
Get x direction.
Definition: JVersor3Z.hh:147
double getDZ() const
Get z direction.
Definition: JVersor3Z.hh:169
JGEOMETRY3D::JVersor3Z::operator JVector3D ( ) const
inlineinherited

Type conversion operator.

Returns
position

Definition at line 125 of file JVersor3Z.hh.

126  {
127  return JVector3D(getDX(), getDY(), getDZ());
128  }
double getDY() const
Get y direction.
Definition: JVersor3Z.hh:158
Data structure for vector in three dimensions.
Definition: JVector3D.hh:34
double getDX() const
Get x direction.
Definition: JVersor3Z.hh:147
double getDZ() const
Get z direction.
Definition: JVersor3Z.hh:169
JGEOMETRY3D::JVersor3Z::operator JVersor3D ( ) const
inlineinherited

Type conversion operator.

Returns
direction

Definition at line 136 of file JVersor3Z.hh.

137  {
138  return JVersor3D(getDX(), getDY(), getDZ());
139  }
double getDY() const
Get y direction.
Definition: JVersor3Z.hh:158
double getDX() const
Get x direction.
Definition: JVersor3Z.hh:147
double getDZ() const
Get z direction.
Definition: JVersor3Z.hh:169
Data structure for normalised vector in three dimensions.
Definition: JVersor3D.hh:26
double JGEOMETRY3D::JVersor3Z::getDX ( ) const
inlineinherited

Get x direction.

Returns
x direction

Definition at line 147 of file JVersor3Z.hh.

148  {
149  return __dx;
150  }
double JGEOMETRY3D::JVersor3Z::getDY ( ) const
inlineinherited

Get y direction.

Returns
y direction

Definition at line 158 of file JVersor3Z.hh.

159  {
160  return __dy;
161  }
double JGEOMETRY3D::JVersor3Z::getDZ ( ) const
inlineinherited

Get z direction.

Returns
z direction

Definition at line 169 of file JVersor3Z.hh.

170  {
171  const double v = getDX()*getDX() + getDY()*getDY();
172 
173  if (v <= 1.0)
174  return sqrt(1.0 - v);
175  else
176  return 0.0;
177  }
double getDY() const
Get y direction.
Definition: JVersor3Z.hh:158
double getDX() const
Get x direction.
Definition: JVersor3Z.hh:147
data_type v[N+1][M+1]
Definition: JPolint.hh:777
JVersor3Z& JGEOMETRY3D::JVersor3Z::negate ( )
inlineinherited

Prefix unary minus.

Returns
this versor

Definition at line 185 of file JVersor3Z.hh.

186  {
187  __dx = -__dx;
188  __dy = -__dy;
189 
190  return *this;
191  }
JVersor3Z& JGEOMETRY3D::JVersor3Z::add ( const JVersor3Z value)
inlineinherited

Addition operator.

Parameters
valueversor
Returns
this versor

Definition at line 200 of file JVersor3Z.hh.

201  {
202  __dx += value.getDX();
203  __dy += value.getDY();
204 
205  return *this;
206  }
double getDY() const
Get y direction.
Definition: JVersor3Z.hh:158
double getDX() const
Get x direction.
Definition: JVersor3Z.hh:147
JVersor3Z& JGEOMETRY3D::JVersor3Z::sub ( const JVersor3Z value)
inlineinherited

Subtraction operator.

Parameters
valueversor
Returns
this versor

Definition at line 215 of file JVersor3Z.hh.

216  {
217  __dx -= value.getDX();
218  __dy -= value.getDY();
219 
220  return *this;
221  }
double getDY() const
Get y direction.
Definition: JVersor3Z.hh:158
double getDX() const
Get x direction.
Definition: JVersor3Z.hh:147
JVersor3Z& JGEOMETRY3D::JVersor3Z::mul ( const double  value)
inlineinherited

Multiplication operator.

Parameters
valuemultiplication factor
Returns
this versor

Definition at line 230 of file JVersor3Z.hh.

231  {
232  __dx *= value;
233  __dy *= value;
234 
235  return *this;
236  }
template<class JFirst_t, class JSecond_t = JNullType>
JFirst_t& JMATH::JMath< JFirst_t, JSecond_t >::mul ( const JSecond_t &  object)
inlineinherited

Multiply with object.

Parameters
objectobject
Returns
result object

Definition at line 354 of file JMath.hh.

355  {
356  return static_cast<JFirst_t&>(*this) = JFirst_t().mul(static_cast<const JFirst_t&>(*this), object);
357  }
JVersor3Z& JGEOMETRY3D::JVersor3Z::div ( const double  value)
inlineinherited

Division operator.

Parameters
valuemultiplication factor
Returns
this versor

Definition at line 245 of file JVersor3Z.hh.

246  {
247  __dx /= value;
248  __dy /= value;
249 
250  return *this;
251  }
bool JGEOMETRY3D::JVersor3Z::equals ( const JVersor3D versor,
const double  precision = std::numeric_limits<double>::min() 
) const
inlineinherited

Check equality.

Parameters
versorversor
precisionprecision
Returns
true if versors are equal; else false

Definition at line 261 of file JVersor3Z.hh.

263  {
264  return (fabs(getDX() - versor.getDX()) <= precision &&
265  fabs(getDY() - versor.getDY()) <= precision);
266  }
double getDY() const
Get y direction.
Definition: JVersor3Z.hh:158
double getDY() const
Get y direction.
Definition: JVersor3D.hh:106
double getDX() const
Get x direction.
Definition: JVersor3D.hh:95
double getDX() const
Get x direction.
Definition: JVersor3Z.hh:147
double JGEOMETRY3D::JVersor3Z::getDot ( const JVersor3Z dir) const
inlineinherited

Get dot product.

Parameters
dirdirection
Returns
dot product

Definition at line 275 of file JVersor3Z.hh.

276  {
277  return
278  getDX() * dir.getDX() +
279  getDY() * dir.getDY() +
280  getDZ() * dir.getDZ();
281  }
double getDY() const
Get y direction.
Definition: JVersor3Z.hh:158
double getDX() const
Get x direction.
Definition: JVersor3Z.hh:147
double getDZ() const
Get z direction.
Definition: JVersor3Z.hh:169
double JGEOMETRY3D::JVersor3Z::getDot ( const JAngle3D angle) const
inlineinherited

Get dot product.

Parameters
angleangle
Returns
dot product

Definition at line 290 of file JVersor3Z.hh.

291  {
292  return
293  getDX() * angle.getDX() +
294  getDY() * angle.getDY() +
295  getDZ() * angle.getDZ();
296  }
double getDY() const
Get y direction.
Definition: JVersor3Z.hh:158
double getDX() const
Get x direction.
Definition: JVersor3Z.hh:147
double getDZ() const
Get z direction.
Definition: JVersor3Z.hh:169
double getDX() const
Get x direction.
Definition: JAngle3D.hh:108
double getDZ() const
Get z direction.
Definition: JAngle3D.hh:130
double getDY() const
Get y direction.
Definition: JAngle3D.hh:119
double JGEOMETRY3D::JVersor3Z::getDot ( const JVector3D pos) const
inlineinherited

Get dot product.

Parameters
posposition
Returns
dot product

Definition at line 305 of file JVersor3Z.hh.

306  {
307  return
308  getDX() * pos.getX() +
309  getDY() * pos.getY() +
310  getDZ() * pos.getZ();
311  }
double getDY() const
Get y direction.
Definition: JVersor3Z.hh:158
double getY() const
Get y position.
Definition: JVector3D.hh:104
double getDX() const
Get x direction.
Definition: JVersor3Z.hh:147
double getX() const
Get x position.
Definition: JVector3D.hh:94
double getDZ() const
Get z direction.
Definition: JVersor3Z.hh:169
double getZ() const
Get z position.
Definition: JVector3D.hh:115
double JGEOMETRY3D::JVersor3Z::getDot ( const JVersor3D dir) const
inlineinherited

Get dot product.

Parameters
dirdirection
Returns
dot product

Definition at line 320 of file JVersor3Z.hh.

321  {
322  return
323  getDX() * dir.getDX() +
324  getDY() * dir.getDY() +
325  getDZ() * dir.getDZ();
326  }
double getDY() const
Get y direction.
Definition: JVersor3Z.hh:158
double getDY() const
Get y direction.
Definition: JVersor3D.hh:106
double getDX() const
Get x direction.
Definition: JVersor3D.hh:95
double getDX() const
Get x direction.
Definition: JVersor3Z.hh:147
double getDZ() const
Get z direction.
Definition: JVersor3Z.hh:169
double getDZ() const
Get z direction.
Definition: JVersor3D.hh:117

Member Data Documentation

double JSIRENE::JPoint::__E
protectedinherited

Definition at line 239 of file JSireneToolkit.hh.

double JSIRENE::JPoint::__Es
protectedinherited

Definition at line 240 of file JSireneToolkit.hh.

double JGEOMETRY3D::JVector3D::__x
protectedinherited

Definition at line 310 of file JVector3D.hh.

double JGEOMETRY3D::JVector3D::__y
protectedinherited

Definition at line 311 of file JVector3D.hh.

double JGEOMETRY3D::JVector3D::__z
protectedinherited

Definition at line 312 of file JVector3D.hh.

double JGEOMETRY3D::JTime::__t
protectedinherited

Definition at line 191 of file JGeometry3D/JTime.hh.

double JGEOMETRY3D::JVersor3Z::__dx
protectedinherited

Definition at line 383 of file JVersor3Z.hh.

double JGEOMETRY3D::JVersor3Z::__dy
protectedinherited

Definition at line 384 of file JVersor3Z.hh.


The documentation for this struct was generated from the following file: