4 #include "KVNuclearChart.h"
6 #include "KVNucleusBox.h"
13 #include "KVLevelScheme.h"
20 KVNuclearChart::
KVNuclearChart(Int_t nMin, Int_t nMax, Int_t zMin, Int_t zMax, Double_t life): fNucleusBoxList(kTRUE), fMagicList(kTRUE), fSymbolList(kTRUE)
27 if ((fNmax < 0) || (fZmax < 0)) {
37 fShowMagicNumbers = kTRUE;
40 fSymbol =
new TPaveText(0.65, 0.16, 0.75, 0.01,
"NDC");
41 fSymbol->SetBorderSize(1);
42 fInfo =
new TPaveText(0.76, 0.16, 0.99, 0.01,
"NDC");
43 fInfo->SetTextAlign(12);
44 fInfo->SetFillColor(kWhite);
45 fInfo->SetLineColor(kBlack);
46 fInfo->SetTextColor(kBlack);
47 fInfo->SetBorderSize(1);
50 for (
int zz = fZmin; zz <= fZmax; zz++) {
57 if ((nn >= fNmin) && (nn <= fNmax)) {
61 fNucleusBoxList.Add(nb);
182 gStyle->SetOptStat(0);
185 Bool_t DrawSame = opt.Contains(
"same");
187 if (DrawSame && gPad) {
190 TIter next(gPad->GetListOfPrimitives());
191 while ((obj = next())) {
192 if (obj->InheritsFrom(
"TH2")) {
200 TPad* pp = (TPad*) cc->cd();
203 Double_t marging = 0.001;
204 pp->SetTopMargin(marging);
205 pp->SetRightMargin(marging);
206 pp->SetBottomMargin(marging);
207 pp->SetLeftMargin(marging);
213 ax->SetNdivisions(000);
215 ax->SetNdivisions(000);
220 if (gPad->GetCanvas()->InheritsFrom(
"KVCanvas")) {
222 cc->DisableClass(
"TLine");
223 cc->DisableClass(
"KVNucleusBox");
224 cc->DisableClass(
"TLatex");
226 cc->DisableObject(
fInfo);
249 fPad->GetListOfPrimitives()->Remove(
fInfo);
257 fInfo->AddText(Form(
"Z = %d N = %d", nuc->
GetZ(), nuc->
GetN()));
261 TAxis* ax =
fHisto->GetXaxis();
262 Int_t xmin = ax->FindBin(nuc->
GetN() - 0.5);
263 Int_t xmax = ax->FindBin(nuc->
GetN() + 0.5);
265 Int_t ymin = ax->FindBin(nuc->
GetZ() - 0.5);
266 Int_t ymax = ax->FindBin(nuc->
GetZ() + 0.5);
267 Int_t M =
fHisto->Integral(xmin, xmax, ymin, ymax);
268 fInfo->AddText(Form(
"M = %d", M));
270 fPad->GetListOfPrimitives()->Remove(
fInfo);
274 symbText.ReplaceAll(Form(
"%d", nuc->
GetA()), Form(
"^{%d}", nuc->
GetA()));
280 fSymbol->AddText(symbText.Data());
331 Double_t xx = ll.
First() - zz - (zz == 1 ? 1 : 2);
334 TLatex* label =
new TLatex(xx, yy, nuc.
GetSymbol(
"EL"));
335 label->SetTextAlign(22);
336 label->SetTextSize(0.025);
337 label->SetTextFont(42);
340 if (last && (last->GetX() > label->GetX())) last->SetX(label->GetX());
347 while ((obj = it())) obj->Draw();
401 for (
int i = 0; i < 7; i++) {
404 TLine* ll1 =
new TLine(num - 0.5, TMath::Max(
fZmin * 1.,
fZmMin[i]), num - 0.5, TMath::Min(
fZmax * 1.,
fZmMax[i]));
405 TLine* ll2 =
new TLine(num + 0.5, TMath::Max(
fZmin * 1.,
fZmMin[i]), num + 0.5, TMath::Min(
fZmax * 1.,
fZmMax[i]));
409 TLatex* label =
new TLatex(num * 1.,
fZmMin[i] - 1.5, Form(
"N=%d", num));
410 label->SetTextAlign(22);
411 label->SetTextSize(0.025);
412 label->SetTextFont(42);
418 for (
int i = 0; i < 7; i++) {
421 TLine* ll1 =
new TLine(TMath::Max(
fNmin * 1.,
fNmMin[i]), num - 0.5, TMath::Min(
fNmax * 1.,
fNmMax[i]), num - 0.5);
422 TLine* ll2 =
new TLine(TMath::Max(
fNmin * 1.,
fNmMin[i]), num + 0.5, TMath::Min(
fNmax * 1.,
fNmMax[i]), num + 0.5);
426 TLatex* label =
new TLatex(
fNmMin[i] - 1.5, num * 1., Form(
"Z=%d", num));
427 label->SetTextAlign(32);
428 label->SetTextSize(0.025);
429 label->SetTextFont(42);
Base class for KaliVeda framework.
virtual void Copy(TObject &) const
Make a copy of this object.
TCanvas with mouse-controlled dynamic zoom and pan & scan.
Tool to simulate nucleus multi-particle decay.
void DrawThreshold(const char *symb, Option_t *option="", double ex=0.)
void Draw(Option_t *option="")
Used to draw nuclear chart.
virtual ~KVNuclearChart()
void ShowNucleusInfo(KVNucleus *nuc)
void ShowLevelScheme(const char *decays)
void SetShowMagicNumbers(Int_t value=1)
void Copy(TObject &) const
KVNucleus * fShownNucleus
void SetBoxSymbolSize(Float_t size=0.02)
KVNuclearChart(Int_t nMin=0, Int_t nMax=-1, Int_t zMin=0, Int_t zMax=-1, Double_t life=1.e-06)
KVNuclearChart();.
void ShowBoxSymbols(Bool_t on=kTRUE)
draw name of isotope in each box
void SetShowSymbol(Int_t value=1)
void Draw(Option_t *option="")
A TBox representing a nucleus in a KVNuclearChart.
void SetShowSymbol(Bool_t value=kTRUE)
void SetSymbolSize(Float_t size=0.02)
void SetNuclearChart(KVNuclearChart *nuclearchart)
Description of properties and kinematics of atomic nuclei.
const Char_t * GetSymbol(Option_t *opt="") const
void SetZ(Int_t z, Char_t mt=-1)
KVNumberList GetKnownARange(Int_t z=-1, Double_t tmin=0) const
Int_t GetN() const
Return the number of neutron.
void SetZandA(Int_t z, Int_t a)
Set atomic number and mass number.
Bool_t IsStable(Double_t min_lifetime=1.0e+15) const
Int_t GetZ() const
Return the number of proton / atomic number.
Double_t GetLifeTime(Int_t z=-1, Int_t a=-1) const
Strings used to represent a set of ranges of values.
Int_t First() const
Returns smallest number included in list.
virtual void AddLast(TObject *obj)
virtual TObject * Last() const
virtual void Clear(Option_t *option="")
virtual void Execute(const char *method, const char *params, Int_t *error=0)
Extension of ROOT TString class which allows backwards compatibility with ROOT v3....
void Begin(TString delim) const
KVString Next(Bool_t strip_whitespace=kFALSE) const