20#ifndef ROOT_Math_GenVector_CylindricalEta3D
21#define ROOT_Math_GenVector_CylindricalEta3D 1
67 template <
class CoordSystem >
145 :
fEta > etaMax<T>() ?
fEta - etaMax<T>() :
fEta < -etaMax<T>() ? -
fEta - etaMax<T>() : 0;
198 }
else if (
fEta > etaMax<T>() ) {
199 fEta = (
fEta-etaMax<T>())*
a + etaMax<T>();
200 }
else if (
fEta < -etaMax<T>() ) {
201 fEta = (
fEta+etaMax<T>())*
a - etaMax<T>();
218 template <
class CoordSystem >
242 T x()
const {
return X();}
243 T y()
const {
return Y();}
244 T z()
const {
return Z(); }
250#if defined(__MAKECINT__) || defined(G__DICTIONARY)
262 void SetTheta(
Scalar theta);
284#if defined(__MAKECINT__) || defined(G__DICTIONARY)
298#if defined(__MAKECINT__) || defined(G__DICTIONARY)
312void CylindricalEta3D<T>::SetY(
Scalar yy) {
313 GenVector_exception
e(
"CylindricalEta3D::SetY() is not supposed to be called");
315 Cartesian3D<Scalar>
v(*
this);
v.SetY(yy);
316 *
this = CylindricalEta3D<Scalar>(
v);
319void CylindricalEta3D<T>::SetZ(
Scalar zz) {
320 GenVector_exception
e(
"CylindricalEta3D::SetZ() is not supposed to be called");
322 Cartesian3D<Scalar>
v(*
this);
v.SetZ(zz);
323 *
this = CylindricalEta3D<Scalar>(
v);
326void CylindricalEta3D<T>::SetR(
Scalar r) {
327 GenVector_exception
e(
"CylindricalEta3D::SetR() is not supposed to be called");
329 Polar3D<Scalar>
v(*
this);
v.SetR(
r);
330 *
this = CylindricalEta3D<Scalar>(
v);
333void CylindricalEta3D<T>::SetTheta(
Scalar theta) {
334 GenVector_exception
e(
"CylindricalEta3D::SetTheta() is not supposed to be called");
336 Polar3D<Scalar>
v(*
this);
v.SetTheta(theta);
337 *
this = CylindricalEta3D<Scalar>(
v);
Class describing a cylindrical coordinate system based on eta (pseudorapidity) instead of z.
void SetEta(T eta)
set the eta coordinate value keeping rho and phi constant
CylindricalEta3D()
Default constructor with rho=eta=phi=0.
void SetXYZ(Scalar x, Scalar y, Scalar z)
set all values using cartesian coordinates
void SetCoordinates(const Scalar src[])
Set internal data based on an array of 3 Scalar numbers.
void SetCoordinates(Scalar rho, Scalar eta, Scalar phi)
Set internal data based on 3 Scalar numbers.
void GetCoordinates(Scalar dest[]) const
get internal data into an array of 3 Scalar numbers
void Negate()
negate the vector
CylindricalEta3D(const CoordSystem &v)
Construct from any Vector or coordinate system implementing Rho(), Eta() and Phi()
void Scale(T a)
scale by a scalar quantity a – for cylindrical eta coords, as long as a >= 0, only rho changes!
void GetCoordinates(Scalar &rho, Scalar &eta, Scalar &phi) const
get internal data into 3 Scalar numbers
void SetPhi(T phi)
set the phi coordinate value keeping rho and eta constant
CylindricalEta3D & operator=(const CylindricalEta3D &v)
assignment operator
CylindricalEta3D(const CylindricalEta3D &v)
copy constructor
void SetRho(T rho)
set the rho coordinate value keeping eta and phi constant
CylindricalEta3D(Scalar rho, Scalar eta, Scalar phi)
Construct from rho eta and phi values.
bool operator==(const CylindricalEta3D &rhs) const
Exact component-by-component equality Note: Peculiar representaions of the zero vector such as (0,...
bool operator!=(const CylindricalEta3D &rhs) const
Namespace for new Math classes and functions.
VecExpr< UnaryOp< Fabs< T >, VecExpr< A, T, D >, T >, T, D > fabs(const VecExpr< A, T, D > &rhs)
Rotation3D::Scalar Scalar
tbb::task_arena is an alias of tbb::interface7::task_arena, which doesn't allow to forward declare tb...
#define dest(otri, vertexptr)