1 /******************************************************************************
2 * T H E R M I N A T O R *
3 * THERMal heavy-IoN generATOR *
6 * Authors of the model: Wojciech Broniowski, Wojciech.Broniowski@ifj.edu.pl, *
7 * Wojciech Florkowski, Wojciech.Florkowski@ifj.edu.pl *
8 * Authors of the code: Adam Kisiel, kisiel@if.pw.edu.pl *
9 * Tomasz Taluc, ttaluc@if.pw.edu.pl *
10 * Code designers: Adam Kisiel, Tomasz Taluc, Wojciech Broniowski, *
11 * Wojciech Florkowski *
13 * For the detailed description of the program and furhter references *
14 * to the description of the model plesase refer to: nucl-th/0504047, *
15 * accessibile at: http://www.arxiv.org/nucl-th/0504047 *
17 * Homepage: http://hirg.if.pw.edu.pl/en/therminator/ *
19 * This code can be freely used and redistributed. However if you decide to *
20 * make modifications to the code, please contact the authors, especially *
21 * if you plan to publish the results obtained with such modified code. *
22 * Any publication of results obtained using this code must include the *
23 * reference to nucl-th/0504047 and the published version of it, when *
26 *****************************************************************************/
27 #include "ParticleType.h"
28 #include "DecayTable.h"
30 ParticleType::ParticleType()
42 mDecayChannelCount2=0;
43 mDecayChannelCount3=0;
44 mTable = new DecayTable();
49 ParticleType::ParticleType(const ParticleType& aParticleType)
51 mName = aParticleType.GetName();
52 mNumber = aParticleType.GetNumber();
53 mMass = aParticleType.GetMass();
54 mStrangeness = aParticleType.GetStrangeness();
55 mBarionN=aParticleType.GetBarionN();
56 mCharmN=aParticleType.GetCharmN();
57 mSpin=aParticleType.GetSpin();
58 mI=aParticleType.GetI();
59 mI3=aParticleType.GetI3();
60 mGamma=aParticleType.GetGamma();
61 mDecayChannelCount2=aParticleType.GetDecayChannelCount2();
62 mDecayChannelCount3=aParticleType.GetDecayChannelCount3();
63 mPDGCode = aParticleType.GetPDGCode();
64 mFMax = aParticleType.GetFMax();
65 mTable = new DecayTable(*(aParticleType.GetTable()));
68 ParticleType& ParticleType::operator=(const ParticleType& aParticleType)
70 if (this != &aParticleType) {
71 mName = aParticleType.GetName();
72 mNumber = aParticleType.GetNumber();
73 mMass = aParticleType.GetMass();
74 mStrangeness = aParticleType.GetStrangeness();
75 mBarionN=aParticleType.GetBarionN();
76 mCharmN=aParticleType.GetCharmN();
77 mSpin=aParticleType.GetSpin();
78 mI=aParticleType.GetI();
79 mI3=aParticleType.GetI3();
80 mGamma=aParticleType.GetGamma();
81 mDecayChannelCount2=aParticleType.GetDecayChannelCount2();
82 mDecayChannelCount3=aParticleType.GetDecayChannelCount3();
83 mPDGCode = aParticleType.GetPDGCode();
84 mFMax = aParticleType.GetFMax();
86 mTable = new DecayTable(*(aParticleType.GetTable()));
93 ParticleType::~ParticleType()
99 void ParticleType::WriteParticle(int /*i*/)
109 int ParticleType::GetNumber() const { return mNumber; }
110 float ParticleType::GetMass() const { return mMass; }
111 int ParticleType::GetStrangeness() const { return mStrangeness; }
112 int ParticleType::GetBarionN() const { return mBarionN; }
113 int ParticleType::GetCharmN() const { return mCharmN; }
114 float ParticleType::GetSpin() const { return mSpin; }
115 float ParticleType::GetI() const { return mI; }
116 float ParticleType::GetI3() const { return mI3; }
117 float ParticleType::GetGamma() const { return mGamma; }
118 std::string ParticleType::GetName() const { return mName; }
119 int ParticleType::GetDecayChannelCount2() const { return mDecayChannelCount2; }
120 int ParticleType::GetDecayChannelCount3() const { return mDecayChannelCount3; }
121 int ParticleType::GetCharge() { return int(mI3+(mBarionN+mStrangeness)/2.); } /*MCH int() added */
122 int ParticleType::GetPDGCode() const { return mPDGCode; }
126 void ParticleType::SetNumber(int aNumber) { mNumber = aNumber; }
127 void ParticleType::SetMass(float aMass) { mMass = aMass; }
128 void ParticleType::SetStrangeness(int aStrangeness) { mStrangeness = aStrangeness; }
129 void ParticleType::SetBarionN(int aBarionN) { mBarionN = aBarionN; }
130 void ParticleType::SetCharmN(int aCharmN) { mCharmN = aCharmN; }
131 void ParticleType::SetSpin(float aSpin) { mSpin = aSpin; }
132 void ParticleType::SetI(float aI) { mI = aI; }
133 void ParticleType::SetI3(float aI3) { mI3 = aI3; }
134 void ParticleType::SetGamma(float aGamma) { mGamma = aGamma; }
135 void ParticleType::SetName(char *aName) { mName = aName; }
136 void ParticleType::SetDecayChannelCount2(int aDCCount2) { mDecayChannelCount2 = aDCCount2; }
137 void ParticleType::SetDecayChannelCount3(int aDCCount3) { mDecayChannelCount3 = aDCCount3; }
138 void ParticleType::SetPDGCode(int aCode) { mPDGCode = aCode; }
141 ParticleType::GetTable() const
150 ParticleType::AddDecayChannel(DecayChannel aChannel)
153 mTable = new DecayTable();
154 mTable->AddDecayChannel(aChannel);
158 ParticleType::GetFMax() const
164 ParticleType::SetFMax(float aFMax)