4 #include "KVLevelScheme.h"
5 #include "KVFileReader.h"
33 fCompNuc->SetExcitEnergy(0);
39 fFuncErel->SetNpx(5000);
52 if (fFunc)
delete fFunc;
63 ReadLevels(Form(
"%s/%02d.dat", dir.Data(), fCompNuc->GetZ()));
80 if (npars == 0)
break;
90 if (aa != fCompNuc->GetA() || zz != fCompNuc->GetZ())
continue;
96 if (!tmp.EqualTo(
"")) de = tmp.Atof();
101 if (!tmp.EqualTo(
"")) {
103 jpi.ReplaceAll(
"GE",
"");
104 jpi.ReplaceAll(
" & ",
",");
105 jpi.ReplaceAll(
"LE",
"");
106 jpi.ReplaceAll(
"LT",
"");
107 jpi.ReplaceAll(
"AP",
"");
108 jpi.ReplaceAll(
" OR ",
"or");
109 jpi.ReplaceAll(
" TO ",
"to");
118 AddResonance(ee, jpi.Data(), gamma.Data());
130 ll->
set(ex, jpi, gam);
141 cout <<
" n." <<
" Jpi" <<
" E" <<
" T1/2" << endl;
143 for (Int_t ii = (
int)fLevels.GetSize() - 1; ii >= 0; ii--) {
145 cout << Form(
"%3d", ii) <<
".";
149 cout <<
" " << Form(
"%5s", fCompNuc->GetSymbol()) << endl;
160 for (Int_t ii = 0; ii < fLevels.GetSize(); ii++) {
164 yy *= TMath::Exp(-xx / tt);
175 if (unit.EqualTo(
"EV")) gam *= 1e-3;
176 else if (unit.EqualTo(
"KEV")) gam *= 1;
177 else if (unit.EqualTo(
"MEV")) gam *= 1e3;
178 else if (unit.Contains(
"S")) gam *= 1e-6;
188 jpi.ReplaceAll(
"(",
"");
189 jpi.ReplaceAll(
")",
"");
193 if (jpi.EqualTo(
""))
return 0;
194 if (jpi.EqualTo(
"GE"))
return 0;
196 if (jpi.Contains(
"-")) jpi = jpi(0, jpi.Index(
"-"));
197 if (jpi.Contains(
"+")) jpi = jpi(0, jpi.Index(
"+"));
198 if (jpi.Contains(
"/2")) jpi = jpi(0, jpi.Index(
"/"));
199 if (jpi.Contains(
",")) jpi = jpi(0, jpi.Index(
","));
211 if (il > (
int)fLevels.GetSize())
return 0;
221 if (il > (
int)fLevels.GetSize())
return 0;
231 if (il > (
int)fLevels.GetSize())
return 0;
241 if (il > (
int)fLevels.GetSize())
return 0;
251 if (il > (
int)fLevels.GetSize())
return "";
260 if (il > (
int)fLevels.GetSize())
return 0;
263 gam.ReplaceAll(
"-1.0",
"-");
264 return Form(
"%d (%s)", TMath::Nint(((
KVExcitedState*) fLevels.At(il))->fEnergy), gam.Data());
273 jpi.ReplaceAll(
"(",
"");
274 jpi.ReplaceAll(
")",
"");
279 if (jpi.EqualTo(
""))
return 0;
280 if (jpi.EqualTo(
"GE"))
return 0;
283 if ((jpi.Contains(
"-")) && (jpi.Contains(
"+"))) {
284 if (jpi.Index(
"+") < jpi.Index(
"-")) pi = 1;
287 else if (jpi.Contains(
"-")) pi = -1;
313 return func(xx - fQvalue * 1000, tt);
327 double e1 = (m2 / (m1 + m2)) * erel;
328 double e2 = (m1 / (m1 + m2)) * erel;
339 rr.SetXEulerAngles(gRandom->Rndm() * 2.*TMath::Pi(), TMath::ACos(gRandom->Rndm() * 2. - 1.), gRandom->Rndm() * 2.*TMath::Pi());
364 GetParticlesFromErel(nuc1, nuc2, erel + qq, randAngle, vsrc);
373 if (!fLevels.GetSize()) cout <<
"KVLevelScheme::GetRandomParticles: please initialize the level scheme firts..." << endl;
374 fFunc->SetParameter(0, T);
375 double excit = fFunc->GetRandom();
377 GetParticlesFromExci(n1, n2, excit, randAngle, vsrc);
402 for (
int ic = 0; ic < 20; ic++) cols[ic] = 0;
403 cols[0] = GetLevelEnergy(0);
405 for (
int ii = 0; ii < GetNLevels(); ii++) {
406 for (
int ic = 0; ic < TMath::Max(ii, 20); ic++) {
407 if ((GetLevelEnergy(ii) - cols[ic] > dy)) {
408 cols[ic] = GetLevelEnergy(ii);
410 if (icol + 1 > ncol) ncol = icol + 1;
416 double max = GetLevelEnergy(GetNLevels() - 1);
418 hh =
new TH2F(Form(
"dumhist%s", fCompNuc->GetSymbol()),
"", 1, 0, ncol * dx + 0.5 * dx, 1000, -200, max + 200);
421 gStyle->SetOptStat(0);
424 cc =
new TCanvas(Form(
"levels%s", fCompNuc->GetSymbol()), Form(
"levels%s", fCompNuc->GetSymbol()), (ncol) * (dx) * 0.4 * 400, 800);
427 cc->SetTopMargin(0.02);
428 cc->SetBottomMargin(0.02);
429 cc->SetRightMargin(0.02);
430 cc->SetLeftMargin(0.02);
432 hh->GetXaxis()->SetAxisColor(0);
433 hh->GetYaxis()->SetAxisColor(0);
435 hh->GetXaxis()->SetLabelSize(0);
436 hh->GetYaxis()->SetNdivisions(0);
441 for (
int ic = 0; ic < 20; ic++) cols[ic] = 0;
442 cols[0] = GetLevelEnergy(0);
445 for (
int ii = 0; ii < GetNLevels(); ii++) {
446 for (
int ic = 0; ic < TMath::Max(ii, 20); ic++) {
447 if ((GetLevelEnergy(ii) - cols[ic] > dy)) {
448 cols[ic] = GetLevelEnergy(ii);
454 TLine* ll =
new TLine(0.5 + dx * icol, GetLevelEnergy(ii), ddx + .5 + dx * icol, GetLevelEnergy(ii));
456 TString jpi = GetJPiStr(ii);
457 jpi.ReplaceAll(
"+",
"^{+}");
458 jpi.ReplaceAll(
"-",
"^{-}");
459 TLatex* tex =
new TLatex(.4 + dx * icol, GetLevelEnergy(ii), jpi.Data());
460 tex->SetTextAlign(32);
461 tex->SetTextFont(133);
462 tex->SetTextSize(txs);
465 tex =
new TLatex(ddx + .6 + dx * icol, GetLevelEnergy(ii), Form(
"%d", TMath::Nint(GetLevelEnergy(ii))));
466 tex->SetTextAlign(12);
467 tex->SetTextFont(133);
468 tex->SetTextSize(txs);
472 TLatex* tte =
new TLatex(0.5, 0.95, Form(
"^{%d}%s", fCompNuc->GetA(), fCompNuc->GetSymbol(
"EL")));
474 tte->SetTextAlign(23);
475 tte->SetTextFont(133);
476 tte->SetTextSize(txs);
479 hh->GetXaxis()->SetLimits(0, dx * (ncol + 0.5));
488 TString opt = option;
499 tte =
new TLatex(0.5 + (0.5 * ddx) + dx * (ncol - 1), qa * 1000 - 100, decay.Data());
500 tte->SetTextAlign(23);
501 tte->SetTextFont(133);
502 tte->SetTextSize(txs);
506 if (opt.Contains(
"l")) {
507 lq =
new TLine(0.5, qa * 1000, 0.5 + dx * (ncol - 1), qa * 1000);
508 lq->SetLineColor(kGray);
513 lq =
new TLine(0.5 + dx * (ncol - 1), qa * 1000, 0.5 + ddx + dx * (ncol - 1), qa * 1000);
516 tte =
new TLatex(ddx + .6 + dx * (ncol - 1), qa * 1000, Form(
"%d", TMath::Nint(1000 * qa)));
517 tte->SetTextAlign(12);
518 tte->SetTextFont(133);
519 tte->SetTextSize(txs);
527 if (opt.Contains(
"l")) {
528 lq =
new TLine(0.5, qa * 1000, 0.5 + dx * (ncol - 1), qa * 1000);
529 lq->SetLineColor(kGray);
534 lq =
new TLine(0.5 + dx * (ncol - 1), qa * 1000, 0.5 + ddx + dx * (ncol - 1), qa * 1000);
536 tte =
new TLatex(ddx + .6 + dx * (ncol - 1), qa * 1000, Form(
"%d", TMath::Nint(1000 * qa)));
537 tte->SetTextAlign(12);
538 tte->SetTextFont(133);
539 tte->SetTextSize(txs);
542 cc->SetWindowSize((ncol) * (dx) * 0.35 * 400, 800);
543 hh->GetXaxis()->SetLimits(0, dx * (ncol + 0.5));
552 if (!strcmp(outnuc,
"")) outnuc =
"1H";
static Bool_t SearchKVFile(const Char_t *name, TString &fullpath, const Char_t *kvsubdir="")
Excited state of atomic nucleus.
void set(Double_t ee, Double_t ww, Double_t jj, Int_t pi)
Double_t eval(Double_t excit)
Handle reading columns of numeric data in text files.
ReadStatus ReadLine(const KVString &pattern="")
Double_t GetDoubleReadPar(Int_t pos) const
Int_t GetIntReadPar(Int_t pos) const
Int_t GetNparRead() const
KVString GetReadPar(Int_t pos) const
Bool_t OpenFileToRead(const KVString &filename)
Tool to simulate nucleus multi-particle decay.
Int_t GetLevelParity(int il)
double EvaluateErel(double *x, double *p)
void SetDrawStyle(double deMin=300., double fullWidth=1.3, double lineWidth=0.6, int textSize=22)
const char * GetEGammaStr(int il)
void DrawThreshold(const char *symb, Option_t *option="", double ex=0.)
double GetThreshold(const char *outnuc="")
static void GetParticlesFromExci(KVNucleus *n1, KVNucleus *n2, double erel, bool randAngle=0, TVector3 *vsrc=0)
virtual ~KVLevelScheme()
Destructor.
static void GetParticlesFromErel(KVNucleus *n1, KVNucleus *n2, double erel, bool randAngle=0, TVector3 *vsrc=0)
Double_t GetLevelEnergy(int il)
Int_t GetLevelSpin(int il)
void SetDecayProduct(KVNucleus *nuc, double excit_energy=0)
void Draw(Option_t *option="")
void ReadLevels(const char *file)
double getWidth(double gam, TString unit)
double Evaluate(double *x, double *p)
const char * GetJPiStr(int il)
void AddResonance(Double_t ex, const char *jpi, const char *gam)
void GetRandomParticles(KVNucleus *n1, KVNucleus *n2, double T, bool randAngle=0, TVector3 *vsrc=0)
double func(double xx, double tt)
Double_t GetLevelWidth(int il)
Description of properties and kinematics of atomic nuclei.
const Char_t * GetSymbol(Option_t *opt="") const
void SetExcitEnergy(Double_t e)
Double_t GetExcitEnergy() const
Int_t GetZ() const
Return the number of proton / atomic number.
void SetTheta(Double_t theta)
void SetVelocity(const TVector3 &)
Set velocity of particle (in cm/ns units)
void SetKE(Double_t ecin)
void SetFrame(const Char_t *frame, const KVFrameTransform &)
KVParticle const * GetFrame(const Char_t *frame, Bool_t warn_and_return_null_if_unknown=kTRUE) const
TVector3 GetVelocity() const
returns velocity vector in cm/ns units
Extension of ROOT TString class which allows backwards compatibility with ROOT v3....
void RemoveAllExtraWhiteSpace()