11 #include "KVNucleus.h"
13 #include "TObjArray.h"
14 #include "TObjString.h"
15 #include "Riostream.h"
18 #include "KVParticleCondition.h"
19 #include "Riostream.h"
20 #include "TMethodCall.h"
21 #include "TPluginManager.h"
22 #include "KVNDTManager.h"
24 #include "KVLifeTime.h"
25 #include "KVMassExcess.h"
26 #include "KVAbundance.h"
27 #include "KVChargeRadius.h"
28 #include "KVSpinParity.h"
35 Double_t
KVNucleus::hbar = TMath::Hbarcgs() * TMath::Ccgs() / TMath::Qe();
50 #define MAXZ_ELEMENT_SYMBOL 118
52 "n",
"H",
"He",
"Li",
"Be",
"B",
"C",
"N",
"O",
53 "F",
"Ne",
"Na",
"Mg",
"Al",
"Si",
"P",
"S",
"Cl",
"Ar",
"K",
"Ca",
55 "Ti",
"V",
"Cr",
"Mn",
"Fe",
"Co",
"Ni",
"Cu",
"Zn",
"Ga",
"Ge",
"As",
57 "Kr",
"Rb",
"Sr",
"Y",
"Zr",
"Nb",
"Mo",
"Tc",
"Ru",
"Rh",
"Pd",
"Ag",
59 "In",
"Sn",
"Sb",
"Te",
"I",
"Xe",
"Cs",
"Ba",
"La",
"Ce",
"Pr",
"Nd",
61 "Sm",
"Eu",
"Gd",
"Tb",
"Dy",
"Ho",
"Er",
"Tm",
"Yb",
"Lu",
"Hf",
"Ta",
63 "Re",
"Os",
"Ir",
"Pt",
"Au",
"Hg",
"Tl",
"Pb",
"Bi",
"Po",
"At",
"Rn",
65 "Ra",
"Ac",
"Th",
"Pa",
"U",
"Np",
"Pu",
"Am",
"Cm",
"Bk",
"Cf",
"Es",
67 "No",
"Lr",
"Rf",
"Db",
"Sg",
"Bh",
"Hs",
"Mt",
"Ds",
"Rg",
"Cn",
"Ed",
91 TString& symname = (TString&)fSymbolName;
92 Bool_t Mpfx = strcmp(opt,
"EL");
93 if (0 <= GetZ() && GetZ() <= MAXZ_ELEMENT_SYMBOL) {
94 if (Mpfx) symname.Form(
"%d%s", a, fElements[z]);
95 else symname = fElements[z];
100 return symname.Data();
125 TString& symname = (TString&)fSymbolName;
126 if (0 <= GetZ() && GetZ() <= MAXZ_ELEMENT_SYMBOL) {
127 if (!strcmp(opt,
"ALL")) symname.Form(
"{}^{%d}_{%d}%s", a, z, fElements[z]);
128 else if (!strcmp(opt,
"EL")) GetSymbol(opt);
129 else symname.Form(
"^{%d}%s", a, fElements[z]);
134 return symname.Data();
158 TString tmp(isotope);
159 if (tmp.BeginsWith(
"nat"))
161 if (sscanf(tmp.Data(),
"%d%s", &A, name) == 2) {
163 Int_t z = GetZFromSymbol(name);
167 Int_t z = GetZFromSymbol(tmp);
189 TString tmp(isotope);
190 if (tmp.BeginsWith(
"nat"))
192 if (sscanf(tmp.Data(),
"%d%s", &A, name) == 2) {
194 if (SetZFromSymbol(name) > -1) SetA(A);
197 else if (sscanf(tmp.Data(),
"%s", name) == 1) {
199 if (SetZFromSymbol(name) == -1) MakeZombie();
213 for (
int i = 0; i <= MAXZ_ELEMENT_SYMBOL; i++) {
214 if (!strcmp(sym, fElements[i])) {
234 Int_t z = GetZFromSymbol(sym);
236 else Error(
"SetZFromSymbol",
"%s is unknown", sym);
259 fMassFormula = kBetaMass;
288 #if ROOT_VERSION_CODE >= ROOT_VERSION(3,4,0)
328 if (z != 0 && a == 0) {
404 KVNucleus::~KVNucleus()
486 A = (1.867 * Z + .016 * TMath::Power(Z, 2.) -
487 1.07E-4 * TMath::Power(Z, 3.));
491 A = (.2875 + 1.7622 * Z + .013879 * TMath::Power(Z, 2.) -
492 .000054875 * TMath::Power(Z, 3.));
496 A = (2.072 * Z + 2.32E-03 * TMath::Power(Z, 2.));
500 A = (2.045 * Z + 3.57E-03 * TMath::Power(Z, 2.));
670 fA = (UChar_t)(a - 255);
814 return ((Int_t)
fA + 255);
825 else if (type ==
knn)
return GetN() * (
GetN() - 1) / 2;
826 else if (type ==
kpp)
return GetZ() * (
GetZ() - 1) / 2;
832 #if ROOT_VERSION_CODE >= ROOT_VERSION(3,4,0)
845 ((
KVNucleus&) obj).SetMassFormula(fMassFormula);
857 if (z == -1) z =
GetZ();
858 if (a == -1) a =
GetA();
896 Double_t val = gNDTManager->
GetValue(z, a,
"MassExcess");
999 Double_t val = gNDTManager->
GetValue(z, a,
"SpinParity");
1002 return TMath::Abs(val);
1023 Double_t val = gNDTManager->
GetValue(z, a,
"SpinParity");
1026 return TMath::Sign(-1.0, val);
1062 return (life < 0. ? 1.e+100 : life);
1064 Double_t life = ((
hbar / TMath::Ccgs()) * 1.e-13) / lf->
GetValue();
1157 Double_t A = Double_t(a);
1159 Double_t rLD = 0.9542;
1161 Double_t re = 1.153;
1162 Double_t ee = 0.2938;
1164 Double_t r0 = 0.9071;
1165 Double_t r1 = 1.105;
1166 Double_t r2 = -0.548;
1171 R = rLD * TMath::Power(A, 1. / 3.);
1175 R = re * TMath::Power(A, ee);
1179 R = (r0 * TMath::Power(A, 1. / 3.) + r1 / TMath::Power(A, 1. / 3.) + r2 / A);
1222 return TMath::Max(0.0, gNDTManager->
GetValue(z, a,
"Abundance"));
1239 if (z == -1) z =
GetZ();
1244 Int_t a = ll.
Next();
1246 if (abund > abmax) {
1291 return gNDTManager->
IsInTable(z, a,
"MassExcess");
1357 if (a == 0)
return 0;
1407 if (zz == -1) zz =
GetZ();
1412 nla.
SetMinMax(TMath::Max(zz, 1), 6 * TMath::Max(zz, 1));
1415 while (!nla.
End()) {
1416 Int_t aa = nla.
Next();
1431 if (zz == -1) zz =
GetZ();
1436 nla.
SetMinMax(TMath::Max(zz, 1), 6 * TMath::Max(zz, 1));
1439 while (!nla.
End()) {
1440 Int_t aa = nla.
Next();
1466 for (Int_t zz = zmin; zz <= zmax; zz += 1) {
1469 while (!nla.
End()) {
1470 Int_t aa = nla.
Next();
1487 if (zz == -1) zz =
GetZ();
1492 while (!nla.
End()) {
1493 Int_t aa = nla.
Next();
1534 Int_t ztot = lhs.
GetZ() + rhs.
GetZ();
1538 Double_t etot = lhs.E() + rhs.E();
1540 TLorentzVector q(ptot, etot);
1566 Int_t zres = lhs.
GetZ() - rhs.
GetZ();
1568 Double_t eres = lhs.E() - rhs.E();
1571 if (zres < 0 || ares < 0 || eres < 0) {
1572 Warning(
"operator-(const KVNucleus &rhs)",
1573 "Cannot subtract nuclei, resulting Z=%d A=%d E=%lf", zres, ares, eres);
1580 TLorentzVector q(pres, eres);
1628 Double_t A = (Double_t) aa;
1629 Double_t Z = (Double_t) zz;
1630 Double_t AVOL = 15.776;
1631 Double_t ASUR = -17.22;
1632 Double_t AC = -10.24;
1634 Double_t XJJ = -30.03;
1635 Double_t QQ = -35.4;
1636 Double_t C1 = -.737;
1639 Double_t XNEU = A - Z;
1640 Double_t SI = (XNEU - Z) / A;
1641 Double_t X13 = TMath::Power(A, 1. / 3.);
1642 Double_t EE1 = C1 * Z * Z / X13;
1643 Double_t EE2 = C2 * Z * Z / A;
1644 Double_t AUX = 1. + (9. * XJJ / 4. / QQ / X13);
1645 Double_t EE3 = XJJ * A * SI * SI / AUX;
1647 AVOL * A + ASUR * TMath::Power(A, 2. / 3.) + AC * X13 + AZER;
1648 Double_t TOTA = EE1 + EE2 + EE3 + EE4;
1649 return (939.55 * XNEU + 938.77 * Z - TOTA);
1664 Double_t av = 1.531e+01;
1665 Double_t as = 1.654e+01;
1666 Double_t ac = 6.882e-01;
1667 Double_t aa = 2.225e+01;
1668 Double_t ap = 9.399e+00;
1669 Double_t kap = 6.056e-01;
1673 eb -= as * TMath::Power(
GetA(), 2. / 3.);
1674 eb -= ac *
GetZ() * (
GetZ() - 1) / TMath::Power(
GetA(), 1. / 3.);
1677 if (TMath::Even(
GetA()))
1678 eb += ap * (TMath::Power(-1,
GetN()) + TMath::Power(-1,
GetZ())) / TMath::Power(
GetA(), kap);
1773 if (ChargeState == 0) ChargeState =
GetZ();
1775 Double_t X = Brho * C_mparns * ChargeState;
1779 Double_t Result = TMath::Sqrt(MassIon * MassIon + X * X) - MassIon;
1793 if (!nuc)
return 0.;
1822 Double_t Ztot =
GetZ();
1823 Double_t Atot =
GetA();
1825 Ztot += nuc->
GetZ();
1826 Atot += nuc->
GetA();
1907 vrel = sqrt(2 * TKE / mu) *
C();
1922 return 0.755 * z1 * z2 / (pow(a1, 1 / 3.) + pow(a2, 1 / 3.)) + 7.3;
1933 Double_t za = pow(z, 2) / pow(a, 1. / 3.);
1934 return 0.1189 * za + 7.3;
1945 Double_t za = pow(z, 2) / pow(a, 1. / 3.);
1946 return 0.1071 * za + 22.2;
1962 Double_t za = pow(z, 2) / pow(a, 1. / 3.);
1965 return 0.104 * za + 24.3;
1979 return 39.43 + .085 * pow(zp + zt, 2) / pow(ap + at, 1. / 3.);
2048 Double_t Aeff = 0, wtot = 0;
2049 while (!isotopes.
End()) {
2051 int A = isotopes.
Next();
2053 if (abundance > 0.) {
2054 Aeff += A * abundance;
2059 if (wtot > 0) Aeff /= wtot;
2093 Double_t vel = GetVelocity().Mag();
2095 Double_t X = vel / ((3.6) * pow(GetZ(), 0.45));
2097 Double_t Q = GetZ() * (1 - exp(-1.25 * X + 0.32 * TMath::Power(X, 2.) - 0.11 * TMath::Power(X, 3.)));
2098 Q *= (1 - 0.0019 * (Ztarget - 6) * TMath::Sqrt(X) + 0.00001 * TMath::Power(Ztarget - 6, 2.) * X);
2112 return 0.04 *
GetZ();
2122 void KVNucleus::Streamer(TBuffer& R__b)
2129 if (R__b.IsReading()) {
2130 Version_t R__v = R__b.ReadVersion(&R__s, &R__c);
2131 R__b.ReadClassBuffer(KVNucleus::Class(),
this, R__v, R__s, R__c);
2139 R__b.WriteClassBuffer(KVNucleus::Class(),
this);
Value of the relative abundance of isotopes.
static void InitEnvironment()
Simple class for storing charge radius information of nuclei.
Simple class to store lifetime information of nucleus.
Bool_t IsAResonance() const
Simple class for store life time information of nucleus.
Nuclear Data Table manager.
Bool_t IsInTable(Int_t zz, Int_t aa, const Char_t *name) const
Double_t GetValue(Int_t zz, Int_t aa, const Char_t *name) const
KVNuclData * GetData(Int_t zz, Int_t aa, const Char_t *name) const
Double_t GetValue() const
Description of properties and kinematics of atomic nuclei.
UChar_t fZ
nuclear charge number (atomic number)
Double_t ShimaChargeStatePrecision() const
static Double_t hbar
hbar*c in MeV.fm
virtual void Clear(Option_t *opt="")
const Char_t * GetSymbol(Option_t *opt="") const
void SetExcitEnergy(Double_t e)
Double_t GetExtraChargeRadius(Int_t z=-1, Int_t a=-1, Int_t rct=2) const
static Double_t LiquidDrop_BrackGuet(UInt_t A, UInt_t Z)
KVNucleus operator-(const KVNucleus &rhs)
Double_t GetWidth() const
static Double_t TKE_Viola1985(Double_t z, Double_t a)
from: V. E. Viola, K. Kwiatkowski, and M. Walker, Physical Review C 31, 1550 (1985).
void CheckZAndA(Int_t &z, Int_t &a) const
static Int_t GetNFromZ(Double_t, Char_t mt)
Calculate neutron number from the element's atomic number Z.
UChar_t fA
nuclear mass number
Bool_t IsKnown(int z=-1, int a=-1) const
static Double_t GetRealAFromZ(Double_t, Char_t mt)
Double_t GetSpin(Int_t z=-1, Int_t a=-1) const
Double_t GetExcitEnergy() const
Int_t Compare(const TObject *obj) const
Double_t GetFissionTKE(const KVNucleus *nuc=0, Int_t formula=kDefaultFormula) const
Double_t GetMassExcess(Int_t z=-1, Int_t a=-1) const
KVMassExcess * GetMassExcessPtr(Int_t z=-1, Int_t a=-1) const
KVAbundance * GetAbundancePtr(Int_t z=-1, Int_t a=-1) const
static Double_t GetRealNFromZ(Double_t, Char_t mt)
KVNucleus operator+(const KVNucleus &rhs)
virtual void Print(Option_t *t="") const
Display nucleus parameters.
void SetZandN(Int_t z, Int_t n)
Set atomic number and mass number.
static Int_t IsMassGiven(const Char_t *)
KVNucleus & operator=(const KVNucleus &rhs)
KVNucleus assignment operator.
Double_t GetMassGS() const
static Double_t kMe
electron mass in MeV/c2
void SetZ(Int_t z, Char_t mt=-1)
Double_t LiquidDrop_Weizsacker()
Int_t GetMostAbundantA(Int_t z=-1) const
KVNucleus & operator+=(const KVNucleus &rhs)
KVNucleus addition and assignment operator.
Double_t GetNaturalA(Int_t zz=-1) const
Double_t GetFissionVelocity(KVNucleus *nuc=0, Int_t formula=kDefaultFormula)
static Double_t TKE_Itkis1998(Double_t z, Double_t a)
Int_t GetAWithMaxBindingEnergy(Int_t z=-1)
KVNumberList GetKnownARange(Int_t z=-1, Double_t tmin=0) const
Double_t GetExtraMassExcess(Int_t z=-1, Int_t a=-1) const
static Double_t e2
e^2/(4.pi.epsilon_0) in MeV.fm
Double_t GetRelativeVelocity(KVNucleus *nuc)
Return the reltive velocity between nuc and this in cm/ns.
const Char_t * GetIsotopesList(Int_t zmin, Int_t zmax, Double_t tmin=0) const
Double_t GetBindingEnergyPerNucleon(Int_t z=-1, Int_t a=-1) const
Returns binding energy in MeV/A for this nucleus.
virtual void Copy(TObject &) const
Copy this KVNucleus into the KVNucleus object referenced by "obj".
Int_t GetN() const
Return the number of neutron.
KVNucleus & operator-=(const KVNucleus &rhs)
KVNucleus subtraction and assignment operator.
KVSpinParity * GetSpinParityPtr(Int_t z=-1, Int_t a=-1) const
static UInt_t fNb_nuc
counts number of existing KVNucleus objects
Bool_t IsResonance() const
Double_t DeduceEincFromBrho(Double_t Brho, Int_t ChargeState=0)
TH2F* GetKnownNucleiChart(KVString method="GetBindingEnergyPerNucleon");.
Double_t ShimaChargeState(Int_t) const
static Double_t kAMU
atomic mass unit in MeV
int SetZFromSymbol(const Char_t *)
void SetZandA(Int_t z, Int_t a)
Set atomic number and mass number.
const Char_t * GetLatexSymbol(Option_t *opt="") const
Int_t GetNpairs(Int_t type=kNN) const
KVNumberList GetMeasuredARange(Int_t z=-1) const
returns range of a measured mass for a given element
void SetZAandE(Int_t z, Int_t a, Double_t ekin)
Set atomic number, mass number, and kinetic energy in MeV.
Double_t GetQFasymTKE(KVNucleus *target)
KVChargeRadius * GetChargeRadiusPtr(Int_t z=-1, Int_t a=-1) const
static Double_t TKE_Hinde1987(Double_t z1, Double_t a1, Double_t z2, Double_t a2)
Double_t GetAbundance(Int_t z=-1, Int_t a=-1) const
static Int_t GetZFromSymbol(const Char_t *)
KVLifeTime * GetLifeTimePtr(Int_t z=-1, Int_t a=-1) const
Double_t GetEnergyPerNucleon() const
static Char_t fElements[][3]
symbols of chemical elements
Double_t GetParity(Int_t z=-1, Int_t a=-1) const
static Int_t GetAFromZ(Double_t, Char_t mt)
Double_t GetAtomicMass(Int_t zz=-1, Int_t aa=-1) const
Bool_t IsStable(Double_t min_lifetime=1.0e+15) const
UChar_t fMassFormula
mass formula for calculating A from Z
Double_t GetBindingEnergy(Int_t z=-1, Int_t a=-1) const
Int_t GetZ() const
Return the number of proton / atomic number.
Double_t GetLiquidDropBindingEnergy(Int_t z=-1, Int_t a=-1) const
static Double_t TKE_Viola1966(Double_t z, Double_t a)
from: V. E. Viola, Jr., Nuclear Data Sheets. Section A 1, 391 (1965).
static Double_t TKE_Kozulin2014(Double_t zp, Double_t zt, Double_t ap, Double_t at)
Double_t GetChargeRadius(Int_t z=-1, Int_t a=-1) const
Double_t GetLifeTime(Int_t z=-1, Int_t a=-1) const
Strings used to represent a set of ranges of values.
void SetMinMax(Int_t min, Int_t max, Int_t pas=1)
Set list with all values from 'min' to 'max'.
void Add(Int_t)
Add value 'n' to the list.
Base class for relativistic kinematics of massive particles.
virtual void SetMass(Double_t m)
TVector3 GetMomentum() const
Double_t GetEnergy() const
void SetKE(Double_t ecin)
virtual void Clear(Option_t *opt="")
Reset particle properties i.e. before creating/reading a new event.
void SetMomentum(const TVector3 *v)
virtual void Copy(TObject &) const
void Set4Mom(const TLorentzVector &p)
virtual void Print(Option_t *t="") const
print out characteristics of particle
TVector3 GetVelocity() const
returns velocity vector in cm/ns units
Spin parity assignment of nuclear levels.
Extension of ROOT TString class which allows backwards compatibility with ROOT v3....