4 #include "KVFlowTensor.h"
5 #include "TMatrixDUtils.h"
6 #include "TMatrixDSymEigen.h"
19 SetName(
"KVFlowTensor");
20 SetTitle(
"Kinetic energy flow tensor of Gyulassy et al.");
81 if (&a !=
this) a.
Copy(*
this);
97 else if (wgt ==
"ONE" || wgt ==
"" || wgt ==
"1")
weight =
kONE;
152 return TMath::RadToDeg() *
e(1).Theta();
164 if (
f(3) <= 0.)
return -1.;
165 if (
f(1) <= 0.)
return -1.;
166 return TMath::Min(1
e+03, pow(
f(1) /
f(3), 0.5));
171 if (
f(3) <= 0.)
return -1.;
172 if (
f(2) <= 0.)
return -1.;
173 return TMath::Min(1
e+03, pow(
f(2) /
f(3), 0.5));
178 Double_t phi = TMath::RadToDeg() *
e(1).Phi();
179 return (phi < 0 ? 360 + phi : phi);
211 TMatrixDSymEigen diagonalize(
fTensor);
212 TMatrixD evectors = diagonalize.GetEigenVectors();
213 fEVal = diagonalize.GetEigenValues();
215 for (
int i = 0; i < 3; i++) {
216 TMatrixDColumn col(evectors, i);
217 fEVec[i].SetXYZ(col[0], col[1], col[2]);
223 if (
fEVec[0].Theta() > TMath::PiOver2()) {
246 TVector3 normReac =
e(1).Cross(TVector3(0, 0, 1));
247 Double_t angle = TMath::RadToDeg() *
e(2).Angle(normReac);
253 Double_t a = pow(
f(2), 0.5);
254 Double_t b = pow(
f(3), 0.5);
255 Double_t tan_t = -a / b * TMath::Tan(
fSqueezeAngle * TMath::DegToRad());
256 Double_t t0 = TMath::ATan(tan_t);
257 Double_t inPlane = a * cos(t0) * cos(
fSqueezeAngle * TMath::DegToRad()) - b * sin(t0) * sin(
fSqueezeAngle * TMath::DegToRad());
260 Double_t outOfPlane = a * cos(t0) * sin(
fSqueezeAngle * TMath::DegToRad()) + b * sin(t0) * cos(
fSqueezeAngle * TMath::DegToRad());
262 else fSqOutRatio = TMath::Min(1.e+03, outOfPlane / inPlane);
355 W = 1. / (n->
GetMass() * (1 + n->Gamma()));
363 for (
int i = 0; i < 3; i++) {
364 for (
int j = i; j < 3; j++) {
367 if (i != j)
fTensor(j, i) += xx;
439 std::cout <<
"Number of particles = " <<
fNParts << std::endl;
Kinetic energy flow tensor of Gyulassy et al and associated shape variables.
const TVector3 & e(int i) const
TVectorD fEVal
the 3 eigenvalues
Int_t fNParts
number of particles included in tensor
virtual ~KVFlowTensor(void)
Destructor.
KVFlowTensor & operator=(const KVFlowTensor &a)
Operateur =.
void Print(Option_t *="") const
if opt="tensor", just print contents of tensor
const TRotation & GetFlowReacPlaneRotation() const
virtual void Init()
Initialisation of internal variables, called once before beginning treatment.
Double_t getvalue_int(Int_t) const
KVFlowTensor()
Default constructor.
Double_t fSqOutRatio
Gutbrod squeeze-out ratio.
enum KVFlowTensor::@19 weight
Double_t fSqueezeAngle
Gutbrod squeeze angle.
TVector3 fEVec[3]
the 3 eigenvectors
void fill(const KVNucleus *n)
void Calculate()
Calculate eigenvalues & eigenvectors of tensor.
virtual void Reset()
Reset internal variables, called before treatment of each event.
virtual void Copy(TObject &obj) const
Copy properties of 'this' object into the KVVarGlob object referenced by 'a'.
const TRotation & GetAziReacPlaneRotation() const
TMatrixDSym fTensor
the tensor
TRotation fAziReacPlane
azimuthal rotation around beam axis to reaction plane
TRotation fFlowReacPlane
rotate XZ to reaction plane, then align Z with flow axis
Description of properties and kinematics of atomic nuclei.
TVector3 GetMomentum() const
Base class for all global variable implementations.
void SetOption(const Char_t *option, const Char_t *value)
void Print(Option_t *="") const
void Copy(TObject &obj) const
void SetNameIndex(const Char_t *name, Int_t index)
void SetMaxNumBranches(Int_t n)
TString GetOptionString(const Char_t *opt) const
Bool_t IsOptionGiven(const Char_t *opt)
void SetFrame(const Char_t *ref)
Int_t fType
type of variable global; = kOneBody, kTwoBody or kNBody