19 #include "Riostream.h"
20 #include "KVPosition.h"
21 #include "KVParticle.h"
23 #include "TRotation.h"
24 #include "TLorentzRotation.h"
25 #include "TObjString.h"
27 #include "KVKinematicalFrame.h"
40 KVParticle::
KVParticle() : fParameters("ParticleParameters", "Parameters associated with a particle in an event")
55 fGroups.SetOwner(kTRUE);
67 #if ROOT_VERSION_CODE >= ROOT_VERSION(3,4,0)
79 KVParticle::KVParticle(Double_t m,
const TVector3& p) : fParameters(
"ParticleParameters",
"Parameters associated with a particle in an event")
92 KVParticle::KVParticle(Double_t m, Double_t px, Double_t py, Double_t pz) : fParameters(
"ParticleParameters",
"Parameters associated with a particle in an event")
105 KVParticle::~KVParticle()
137 Double_t thmax, Double_t phmin,
138 Double_t phmax, Option_t* opt)
149 Double_t p = (T + M()) * (T + M()) - M2();
151 p = (TMath::Sqrt(p));
174 Double_t p = (T + M()) * (T + M()) - M2();
176 TVector3 unit_dir = dir.Unit();
178 p = (TMath::Sqrt(p));
198 cout << fmt <<
" " << frame->
GetName() <<
": ";
200 cout <<
" Theta=" << part->
GetTheta() <<
" Phi=" << part->
GetPhi()
201 <<
" KE=" << part->
GetKE() <<
" Vpar=" << part->
GetVpar() << endl;
216 cout <<
"KVParticle mass=" << M() <<
237 Double_t et = M() + ecin;
239 if (et * et > M2()) {
240 pmod = TMath::Sqrt(et * et - M2());
241 TVector3 newp(Px(), Py(), Pz());
242 if (pmod && newp.Mag()) {
246 newp.SetXYZ(0, 0, 1);
260 #if ROOT_VERSION_CODE >= ROOT_VERSION(3,4,0)
281 if (!fFrameCopyOnly) {
285 fParameters.Copy(((
KVParticle&) obj).fParameters);
325 return TestBit(
kIsOK);
357 TString nopt = option;
376 TLorentzVector::operator=((TLorentzVector&) rhs);
377 if (rhs.GetPInitial())
SetE0(rhs.GetPInitial());
444 TString sgroupname(groupname);
445 sgroupname.ToUpper();
474 while ((os = (TObjString*)no.Next())) {
515 TString sgroupname(groupname);
516 sgroupname.ToUpper();
518 if (sgroupname.IsNull())
return kTRUE;
521 if (
GetGroups()->FindObject(sgroupname.Data()))
return kTRUE;
534 TString sgroupname(groupname);
535 sgroupname.ToUpper();
562 cout <<
"Particle belongs to no groups" << endl;
566 cout <<
"----------------------------------------" << endl;
567 cout <<
"List of groups this particle belongs to:" << endl;
568 cout <<
"----------------------------------------" << endl;
572 while ((os = (TObjString*)no.Next())) cout <<
"\t" << os->GetName() << endl;
573 cout <<
"----------------------------------------" << endl;
631 if (!
fFrameName.CompareTo(newdef, TString::kIgnoreCase))
return;
633 TString _defname(defname);
635 if (_defname ==
"") _defname =
"default";
656 next_trans = f->GetTransform();
658 f->SetTransform(trans.Inverse());
663 TLorentzVector old_def_p(*
this);
665 Set4Mom(*(save_newdef->GetParticle()));
666 save_newdef->GetParticle()->
Set4Mom(old_def_p);
667 save_newdef->SetTransform(next_trans.Inverse());
668 save_newdef->
SetName(_defname);
804 if (!strcmp(frame,
""))
return;
806 if (!
fFrameName.CompareTo(frame, TString::kIgnoreCase)) {
822 tmp->ApplyTransform(
this, ft);
906 return f ? (
KVParticle const*)f->GetParticle() :
907 (warn_and_return_null_if_unknown ?
908 Warning(
"GetFrame(const Char_t*)",
"No frame \"%s\" defined for particle. 0x0 returned.",
932 f->ReapplyTransform(
this);
954 if (!
fBoosted.GetEntries() || !strcmp(frame,
"")) {
958 TString _frame(frame);
962 if (!_frame.CompareTo(p->GetName(), TString::kIgnoreCase))
break;
964 if ((f = p->GetParticle()->
get_frame(_frame)))
break;
979 if (!
fBoosted.GetEntries() || !strcmp(f,
"")) {
987 if (!_frame.CompareTo(p->GetName(), TString::kIgnoreCase))
return F;
1009 if (!
fFrameName.CompareTo(oldframe, TString::kIgnoreCase)) {
1018 Error(
"SetFrame(newframe,oldframe)",
"oldframe=%s does not exist!", oldframe);
1021 f->GetParticle()->
SetFrame(newframe, ft);
1038 beta.SetXYZ(0, 0, 0);
1054 return (
GetV().y() >= 0.0 ?
GetV().Perp() : -(
GetV().Perp()));
1073 if (!strcmp(
"spher", opt) || !strcmp(
"spherical", opt)) {
1074 TVector3 pvec(0., 0., 1.);
1076 pvec.SetTheta(TMath::Pi() * py / 180.);
1077 pvec.SetPhi(TMath::Pi() * pz / 180.);
1081 if (strcmp(
"cart", opt) && strcmp(
"cartesian", opt)) {
1082 Warning(
"SetMomentum(Double_t,Double_t,Double_t,Option_t*)",
1083 "Unkown coordinate system\n known system are :\n\t\"cartesian\" or \"cart\" (default)\n\t\"spherical\" or \"spher\"");
1084 Warning(
"SetMomentum(Double_t,Double_t,Double_t,Option_t*)",
1087 TVector3 pvec(px, py, pz);
1101 TVector3 p =
GetMass() * gamma * vel;
1112 void KVParticle::Streamer(TBuffer& R__b)
1118 if (R__b.IsReading()) {
1119 R__b.ReadClassBuffer(KVParticle::Class(),
this);
1123 R__b.WriteClassBuffer(KVParticle::Class(),
this);
1149 if (_f->GetParticle()->GetParentFrame() == parent) {
Kinematical representation of a particle in different reference frames.
virtual void Print(Option_t *opt="") const
virtual void Clear(Option_t *opt="")
const Char_t * GetStringValue(const Char_t *name) const
void AddAll(const TCollection *)
When all frames in a list are added to this one, this particle becomes the parent of all frames in th...
void Clear(Option_t *="")
When the frame list is cleared, this particle is no longer the parent of any frames in the list.
TObject * Remove(TObject *)
When a kinematical frame is removed, this particle is no longer the parent frame.
void Add(TObject *)
When a kinematical frame is added, this particle becomes the parent frame.
Base class for relativistic kinematics of massive particles.
Int_t GetNumberOfDefinedGroups() const
void AddGroups(KVUniqueNameList *un)
list of groups added to the current one
void SetIsOK(Bool_t flag=kTRUE)
TVector3 * GetPInitial() const
virtual void SetMass(Double_t m)
void RemoveGroup(const Char_t *groupname)
Remove group from list of groups.
void AddGroup(const Char_t *groupname, const Char_t *from="") const
const KVParticle * GetOriginal() const
TVector3 GetMomentum() const
void RemoveAllGroups()
Remove all groups.
KVUniqueNameList fGroups
list of momenta of the particle in different Lorentz-boosted frames
KVNameValueList * GetParameters() const
Double_t GetTheta() const
KVParticle & operator=(const KVParticle &rhs)
KVParticle assignment operator.
void SetVectM(const TVector3 &spatial, Double_t mass)
const Char_t * GetFrameName(void) const
void SetVelocity(const TVector3 &)
Set velocity of particle (in cm/ns units)
const Char_t * GetName() const
return the field fName
KVParticle * GetParentFrame() const
KVUniqueNameList * GetGroups() const
Bool_t IsDetected() const
void SetKE(Double_t ecin)
virtual void Clear(Option_t *opt="")
Reset particle properties i.e. before creating/reading a new event.
void ls(Option_t *option="") const
void init()
default initialisation
KVNameValueList fParameters
a general-purpose list of parameters associated with this particle
void SetMomentum(const TVector3 *v)
virtual void Copy(TObject &) const
void Set4Mom(const TLorentzVector &p)
KVKinematicalFrame * get_parent_frame(const Char_t *, KVKinematicalFrame *F=nullptr) const
virtual void Print(Option_t *t="") const
print out characteristics of particle
KVParticle InFrame(const KVFrameTransform &)
void SetE0(TVector3 *e=0)
TString fFrameName
non-persistent frame name field, sets when calling SetFrame method
void ListGroups() const
List all stored groups.
void SetFrameName(const Char_t *framename)
static Double_t kSpeedOfLight
speed of light in cm/ns
void SetParentFrame(KVParticle *p)
void SetXYZM(Double_t x, Double_t y, Double_t z, Double_t m)
void SetName(const Char_t *nom)
Set Name of the particle.
void SetFrame(const Char_t *frame, const KVFrameTransform &)
friend class KVKinematicalFrame
KVParticle const * GetFrame(const Char_t *frame, Bool_t warn_and_return_null_if_unknown=kTRUE) const
void ChangeFrame(const KVFrameTransform &, const KVString &="")
void SetOriginal(KVParticle *p)
void SetGroups(KVUniqueNameList *un)
Define for the particle a new list of groups.
Bool_t BelongsToGroup(const Char_t *groupname) const
TVector3 * fE0
the momentum of the particle before it is slowed/stopped by an absorber
void ChangeDefaultFrame(const Char_t *, const Char_t *defname="")
void SetRandomMomentum(Double_t T, Double_t thmin, Double_t thmax, Double_t phmin, Double_t phmax, Option_t *opt="isotropic")
TString fName
non-persistent name field - Is useful
KVKinematicalFrame * get_frame(const Char_t *) const
TVector3 GetVelocity() const
returns velocity vector in cm/ns units
Double_t GetVperp() const
const KVParticle * GetTopmostParentFrame() const
KVList * GetListOfFrames() const
Int_t _GetNumberOfDefinedFrames() const
used to inhibit full copying of particles in different kinematical frames
void print_frames(TString fmt="") const
recursive print out of all defined kinematical frames
Base class used for handling geometry in a multidetector array.
virtual TVector3 GetRandomDirection(Option_t *t="isotropic")
virtual void Clear(Option_t *option="")
virtual void Add(TObject *obj)
virtual TObject * Remove(TObject *obj)
Remove object from list.
virtual void Delete(Option_t *option="")
Extension of ROOT TString class which allows backwards compatibility with ROOT v3....
Optimised list in which named objects can only be placed once.
virtual void Add(TObject *obj)