TkN 2.5
Toolkit for Nuclei
Loading...
Searching...
No Matches
tklevel_scheme.cpp
1/********************************************************************************
2 * Copyright (c) : Université de Lyon 1, CNRS/IN2P3, UMR5822, *
3 * IP2I, F-69622 Villeurbanne Cedex, France *
4 * Normandie Université, ENSICAEN, UNICAEN, CNRS/IN2P3, *
5 * LPC Caen, F-14000 Caen, France *
6 * Contibutor(s) : *
7 * Jérémie Dudouet jeremie.dudouet@cnrs.fr [2020] *
8 * Diego Gruyer diego.gruyer@cnrs.fr [2020] *
9 * *
10 * Licensed under the MIT License <http://opensource.org/licenses/MIT>. *
11 * SPDX-License-Identifier: MIT *
12 ********************************************************************************/
13
14#ifdef HAS_DEBUG
15#include <algorithm>
16#include <chrono>
17#endif
18
19#include "tkdb_table.h"
20#include "tklevel_scheme.h"
21#include "tkstring.h"
22#include "tklog.h"
23#include "tkdatabase.h"
24#include "tkmanager.h"
25
26namespace tkn {
44}
45
46using namespace tkn;
47
48tklevel_scheme::tklevel_scheme(const tkstring &_nuc, int _zz, int _aa, bool _load_default_dataset) : fnucleus(_nuc), fA(_aa), fZ(_zz)
49{
50 if (fA < 0 || fZ < 0) return;
51 init(_load_default_dataset);
52}
53
71std::vector<shared_ptr<tklevel>> tklevel_scheme::get_levels(const std::function<bool(shared_ptr<tklevel>)> &_selection)
72{
73 vector<shared_ptr<tklevel>> res;
74 const auto &levels = get_levels();
75 std::copy_if(levels.begin(), levels.end(), std::back_inserter(res),
76 [&_selection](const auto &lvl) { return _selection(lvl); });
77 return res;
78}
79
94std::vector<shared_ptr<tkdecay>> tklevel_scheme::get_decays(const std::function<bool(shared_ptr<tkdecay>)> &_selection)
95{
96 vector<shared_ptr<tkdecay>> res;
97 const auto &decays = get_decays();
98 std::copy_if(decays.begin(), decays.end(), std::back_inserter(res),
99 [&_selection](const auto &dec) { return _selection(dec); });
100 return res;
101}
102
124void tklevel_scheme::print(const tkstring &_data, const tkstring &_option)
125{
126 if (_data.is_empty()) {
127 glog << info << " Level scheme of " << fnucleus << do_endl;
128 glog << info << " Options : 'dataset', 'level', 'decay'" << do_endl;
129 }
130 if (_data.contains("dataset")) {
131 auto print_group = [&](const tkstring &source_label) {
132 bool header_printed = false;
133 for (auto &dts : fmap_of_dataset) {
134 if (dts.second->get_source() != source_label) continue;
135 if (!header_printed) {
136 glog << info << "--- " << source_label << " ---" << do_endl;
137 header_printed = true;
138 }
139 glog << info << dts.second->get_name() << " (" << dts.first << ")";
140 if (dts.second->has_date()) glog << " [" << dts.second->get_date() << "]";
141 glog << do_endl;
142 if (_option.contains("com") && dts.second->has_comment()) {
143 const size_t comment_prefix_size = 13;
144 const size_t content_col = comment_prefix_size + 2;
145 glog << comment << " " << wrap_text(dts.second->get_comment(), content_col, content_col) << do_endl;
146 }
147 }
148 };
149 print_group("ENSDF");
150 print_group("XUNDL");
151 glog << comment << "Current dataset is '" << get_dataset()->get_name() << "'" << " (" << get_dataset()->get_id() << ")" << do_endl;
152 }
153 if (_data.contains("level") || _data.contains("decay")) {
154 fmap_of_dataset[fdatasetid]->print(_data, _option);
155 }
156 if (_data == "*") {
157 int _current_data_set = fdatasetid;
158 for (auto &dataset : fmap_of_dataset) {
159 glog << info << "dataset : " << dataset.second->get_name() << do_endl;
160 select_dataset(dataset.first);
161 dataset.second->print("leveldecay");
162 }
163 // to select back the current dataset
164 select_dataset(_current_data_set);
165 }
166}
167
168
172bool tklevel_scheme::select_dataset(const tkstring &_dataset_name)
173{
174 if (fmap_of_dataset_name_id.count(_dataset_name) == 0) {
175 glog << warning << "dataset '" << _dataset_name << "' do not exist for " << fnucleus << do_endl;
176 print("dataset");
177 return false;
178 }
179 fdatasetid = fmap_of_dataset_name_id[_dataset_name];
180 return select_dataset(fdatasetid);
181}
182
183/**
184 * @param _dataset_id id of the dataset to be selected
185 * @details to list the available datasets, use tkn::tklevel_scheme::print("dataset")
186 */
187bool tklevel_scheme::select_dataset(int _dataset_id)
188{
189 if (fmap_of_dataset.count(_dataset_id) == 0) {
190 glog << warning << "dataset with id '" << _dataset_id << "' do not exist for " << fnucleus << do_endl;
191 print("dataset");
192 return false;
193 }
194
195 fdatasetid = _dataset_id;
196 fmap_of_dataset[fdatasetid]->load_dataset();
197 return true;
198}
199
212shared_ptr<tklevel> tklevel_scheme::get_level(const tkstring &_name, bool _exact)
214 // get a specific level [spin][parity][rank] (ex: 0+1 for the first 0+ state)
215 string spin;
216 int rank;
217
218 const char *sep = "";
219 if (_name.contains("+")) {
220 sep = "+";
221 } else if (_name.contains("-")) {
222 sep = "-";
223 }
224
225 auto array = _name.tokenize(sep);
226 if (array.size() != 2) {
227 glog << error << " <nuclear_level_scheme::get_level_energy()> invalid argument '" << _name << "'. Syntax: '[spin][parity][rank]'." << do_endl;
228 return nullptr;
229 }
230
231 spin = array.at(0);
232 rank = array.at(1).atoi();
233
234 int idx = 0;
235 for (const auto &lvlp : get_levels([](auto lvl) { return (lvl->get_spin_parity() != nullptr); })) {
236 auto jpistr = lvlp->get_spin_parity()->get_jpi_str();
237 bool ok = false;
238 if (!_exact) {
239 if (jpistr.equal_to(tkstring::form("%s%s", spin.data(), sep)) ||
240 jpistr.equal_to(tkstring::form("(%s%s)", spin.data(), sep)) ||
241 jpistr.equal_to(tkstring::form("(%s)%s", spin.data(), sep)) ||
242 jpistr.equal_to(tkstring::form("%s(%s)", spin.data(), sep))) {
243 ok = true;
244 }
245 } else if (jpistr.equal_to(tkstring::form("%s%s", spin.data(), sep))) {
246 ok = true;
247 }
248 if (ok) {
249 idx++;
250 if (idx == rank) return lvlp;
251 }
252 }
253 return nullptr;
254}
255
256
261 * if offset is set to *, all offset values will be considered.
262 * if offset contains "dec", only levels that have known decays will be considered
263 */
264shared_ptr<tklevel> tklevel_scheme::get_level(double _energy, tkstring _offset)
265{
266 shared_ptr<tklevel> clostest_lev;
267 double best_ediff = 1e6;
268 for (const auto &lev : get_levels()) {
269 if (!_offset.is_empty() && !_offset.contains("*")) {
270 if (_offset != lev->get_offset_bandhead()) continue;
271 }
272 if (_offset.is_empty() && !lev->get_offset_bandhead().is_empty()) continue;
273 if (_offset.contains("dec") && lev->get_decays_down().size() == 0) continue;
274 double ediff = abs(lev->get_energy(tkunit_manager::units_keys::keV, true) - _energy);
275 if (ediff < best_ediff) {
276 best_ediff = ediff;
277 clostest_lev = lev;
278 }
279 }
280 return clostest_lev;
281}
282
283void tklevel_scheme::init(bool _load_default_dataset)
284{
285 gdatabase->begin("DISTINCT dataset.dataset_id, dataset.dataset_name, dataset.dataset_comment, dataset.dataset_date, dataset.dataset_source", "level INNER JOIN dataset on level.dataset_id=dataset.dataset_id INNER JOIN isotope on level.isotope_id=isotope.isotope_id INNER JOIN element on isotope.element_id=element.element_id", tkstring::form("element.charge=%d AND isotope.mass=%d", fZ, fA), tkstring::form("read_dataset_%s", fnucleus.data()));
286
287 while (gdatabase->next(tkstring::form("read_dataset_%s", fnucleus.data()))) {
288 tkdb_table &datasets = (*gdatabase)["DATASET"];
289 int ds_id = datasets["dataset_id"].get_value().atoi();
290 fmap_of_dataset_name_id[datasets["dataset_name"].get_value()] = ds_id;
291 auto ds = make_shared<tkdataset>(tkdataset(fnucleus, fZ, fA, datasets["dataset_name"].get_value(), ds_id));
292 if (!datasets["dataset_comment"].is_empty()) ds->fdataset_comment = datasets["dataset_comment"].get_value();
293 if (!datasets["dataset_date"].is_empty()) ds->fdataset_date = datasets["dataset_date"].get_value();
294 if (!datasets["dataset_source"].is_empty()) ds->fdataset_source = datasets["dataset_source"].get_value();
295 fmap_of_dataset[ds_id] = ds;
296 }
297 tkstring default_dataset = fnucleus.data();
298 default_dataset += " : ADOPTED LEVELS, GAMMAS";
299 gdebug << "looking for dataset : " << default_dataset << do_endl;
300 bool found = (fmap_of_dataset_name_id.count(default_dataset) > 0);
301 gdebug << (found ? "" : "not ") << "found " << (found ? fmap_of_dataset_name_id[default_dataset.data()] : -1) << do_endl;
302
303 if (found) {
304 fdatasetid = fmap_of_dataset_name_id[default_dataset.data()];
305 if (_load_default_dataset) select_dataset(fdatasetid);
306 } else {
307 for (const auto &dts : fmap_of_dataset) {
308 glog << warning << tkstring::form("%5s", fnucleus.data()) << " -- no 'ADOPTED LEVELS' dataset : '" << dts.second->get_name() << "' used instead." << do_endl;
309 fdatasetid = dts.first;
310 if (_load_default_dataset) select_dataset(fdatasetid);
311 break;
312 }
313 }
314 if (fmap_of_dataset.empty()) {
315 tkstring datasetname = "EMPTY";
316 fdatasetid = 0;
317 fmap_of_dataset_name_id[datasetname] = fdatasetid;
318 fmap_of_dataset[fdatasetid] = make_shared<tkdataset>(tkdataset(fnucleus, fZ, fA, datasetname, fdatasetid));
319 }
320
321 floaded = true;
322}
323
324void tkdataset::check_yrast(shared_ptr<tklevel> _lvl)
325{
326 // check Yrast
327 if (_lvl->get_spin_parity()->get_spin().is_known()) {
328 int TwoJ = (int)(_lvl->get_spin_parity()->get_spin().get_value() * 2 + 0.5);
329 if (!fyrastmap_exact.count(TwoJ)) {
330 fyrastmap_exact[TwoJ] = _lvl;
331 _lvl->fisYrast_exact = true;
332 // cout<<"exact yrast: 2J:"<<TwoJ<<" "<<lvl->get_spin_parity_str()<<" "<<lvl->get_energy()<<endl;
333 }
334 if (!fyrastmap_uncertain.count(TwoJ)) {
335 fyrastmap_uncertain[TwoJ] = _lvl;
336 _lvl->fisYrast_uncertain = true;
337 // cout<<"uncertain yrast: 2J:"<<TwoJ<<" "<<lvl->get_spin_parity_str()<<" "<<lvl->get_energy()<<endl;
338 }
339 } else if (!_lvl->get_spin_parity_str().is_empty() && !_lvl->get_spin_parity_str().contains(",")) {
340 tkstring tmp = _lvl->get_spin_parity_str().copy().remove_all("(").remove_all(")").remove_all("+").remove_all("-");
341 int TwoJ;
342 if (tmp.contains("/2"))
343 TwoJ = tmp.remove_all("/2").atoi();
344 else
345 TwoJ = tmp.atoi() * 2;
346 if (!fyrastmap_uncertain.count(TwoJ)) {
347 fyrastmap_uncertain[TwoJ] = _lvl;
348 _lvl->fisYrast_uncertain = true;
349 // cout<<"uncertain yrast: 2J:"<<TwoJ<<" "<<lvl->get_spin_parity_str()<<" "<<lvl->get_energy()<<endl;
350 }
351 }
352}
354void tkdataset::load_dataset()
355{
356 if (floaded) return;
357
358#ifdef HAS_DEBUG
359 auto t_0 = std::chrono::high_resolution_clock::now();
360 gdebug << "loading levels for dataset '" << fname << "' of " << fnucleus << do_endl;
361#endif
362
363 gdatabase->begin("DISTINCT level.*", "level", tkstring::form("dataset_id=%d", fid));
364
365 while (gdatabase->next()) {
366 tkdb_table *levels = &(*gdatabase)["LEVEL"];
367 tkdb_column *col = &(*levels)["level_id"];
368 int id = col->get_value().atoi();
369
370 gmanager->set_max_level_id(id);
371
373 levels->read_measure(energy_struc, "level_energy");
374
375 shared_ptr<tklevel> lvl = make_shared<tklevel>(id, energy_struc);
376 lvl->fbelongs_to_nucleus = fnucleus;
377
378 double spin = -1.;
379 int parity = -1.;
380 tkstring spin_parity_str = "";
381
382 col = &(*levels)["level_spin_parity"];
383 if (!col->is_empty()) spin_parity_str = col->get_value();
384 col = &(*levels)["level_spin"];
385 if (!col->is_empty()) spin = col->get_value().atof();
386 col = &(*levels)["level_parity"];
387 if (!col->is_empty()) parity = col->get_value().atoi();
388
389 if (!spin_parity_str.is_empty()) lvl->set_jpi(spin, parity, spin_parity_str);
390
391 tkdb_table::measure_data_struct lifetime_struc;
392 levels->read_measure(lifetime_struc, "level_lifetime");
393 if (lifetime_struc.filled) lvl->set_lifetime(lifetime_struc);
394
395 col = &(*levels)["level_comment"];
396 if (!col->is_empty()) lvl->set_comment(col->get_value());
397 col = &(*levels)["level_uncertain"];
398 if (!col->is_empty()) lvl->set_uncertain_level(col->get_value());
399
400 flevels.push_back(lvl);
401
402 check_yrast(lvl);
403 }
404 for (const auto &lvl : flevels) {
405 fmapoflevels[lvl->get_id()] = lvl;
406 }
407
408#ifdef HAS_DEBUG
409 auto t_1 = std::chrono::high_resolution_clock::now();
410 gdebug << "loading decays for dataset '" << fname << "' of " << fnucleus << do_endl;
411#endif
412
413 gdatabase->begin("DISTINCT decay.*", "decay INNER JOIN level on decay.level_from_id=level.level_id ", tkstring::form("dataset_id=%d", fid));
414
415 while (gdatabase->next()) {
416 int dectype = -1;
417 int level_from = -1.;
418 int level_to = -1.;
419
420 tkdb_table *decay = &(*gdatabase)["DECAY"];
421 tkdb_column *col = &(*decay)["decay_id"];
422 int id = col->get_value().atoi();
423
424 gmanager->set_max_decay_id(id);
425
426 col = &(*decay)["decay_type"];
427 if (!col->is_empty()) dectype = col->get_value().atoi();
428 col = &(*decay)["level_from_id"];
429 if (!col->is_empty()) level_from = col->get_value().atoi();
430 col = &(*decay)["level_to_id"];
431 if (!col->is_empty()) level_to = col->get_value().atoi();
432
433 shared_ptr<tkdecay> dec = nullptr;
434
436 decay->read_measure(energy_struc, "decay_energy");
437
438 if (dectype == tkdecay::kgamma) {
439 dec = make_shared<tkgammadecay>(id, level_from, level_to, energy_struc);
440 shared_ptr<tkgammadecay> gamma = dynamic_pointer_cast<tkgammadecay>(dec);
441
442 tkdb_table::measure_data_struct relative_intensity_struc;
443 decay->read_measure(relative_intensity_struc, "decay_relative_intensity");
444 if (relative_intensity_struc.filled) gamma->set_relative_intensity(relative_intensity_struc);
445
446 col = &(*decay)["decay_multipolarity"];
447 if (!col->is_empty()) gamma->set_multipolarity(col->get_value());
448
449 tkdb_table::measure_data_struct mixing_ratio_struc;
450 decay->read_measure(mixing_ratio_struc, "decay_mixing_ratio");
451 if (mixing_ratio_struc.filled) gamma->set_mixing_ratio(mixing_ratio_struc);
452
453 tkdb_table::measure_data_struct conv_coeff_struc;
454 decay->read_measure(conv_coeff_struc, "decay_conv_coeff");
455 if (conv_coeff_struc.filled) gamma->set_conv_coeff(conv_coeff_struc);
456
457 // transition probabilities
458 tkdb_table::measure_data_struct transprob_struc;
459 decay->read_measure(transprob_struc, "decay_BE");
460 if (transprob_struc.filled) gamma->set_transition_probability(transprob_struc);
461 transprob_struc.clear();
462 decay->read_measure(transprob_struc, "decay_BEW");
463 if (transprob_struc.filled) gamma->set_transition_probability(transprob_struc);
464 transprob_struc.clear();
465 decay->read_measure(transprob_struc, "decay_BM");
466 if (transprob_struc.filled) gamma->set_transition_probability(transprob_struc);
467 transprob_struc.clear();
468 decay->read_measure(transprob_struc, "decay_BMW");
469 if (transprob_struc.filled) gamma->set_transition_probability(transprob_struc);
470 } else
471 continue;
472
473 col = &(*decay)["decay_comment"];
474 if (!col->is_empty()) dec->set_comment(col->get_value());
475 col = &(*decay)["decay_uncertain"];
476 if (!col->is_empty()) dec->set_uncertain_decay(col->get_value());
477
478 fdecays.push_back(dec);
479 fdecays.back()->set_levels(fmapoflevels.at(level_from), fmapoflevels.at(level_to));
480 }
481 for (auto &dec : fdecays) {
482 fmapoflevels.at(dec->get_level_from_id())->add_decay_down(dec);
483 fmapoflevels.at(dec->get_level_to_id())->add_decay_up(dec);
484 }
485
486#ifdef HAS_DEBUG
487 auto t_2 = std::chrono::high_resolution_clock::now();
488
489 auto dt01 = std::chrono::duration<double, std::milli>(t_1 - t_0).count() * 0.001; // open db time
490 auto dt12 = std::chrono::duration<double, std::milli>(t_2 - t_1).count() * 0.001; // first read loop with views
491
492 gdebug << std::fixed << std::setprecision(4) << "time level: "
493 << dt01
494 << " s" << do_endl;
495
496 gdebug << std::fixed << std::setprecision(4) << "time decays: "
497 << dt12
498 << " s" << do_endl;
499#endif
500
501 floaded = true;
502}
503
508void tkdataset::print(const tkstring &_data, const tkstring &_option)
509{
510 if (_data.contains("level") && _data.contains("decay")) {
511 glog << info << "dataset '" << fname << "' contains " << flevels.size() << " levels" << do_endl;
512 glog << info << "dataset '" << fname << "' contains " << fdecays.size() << " decays" << do_endl;
513 bool first_level_printed = false;
514 for (auto &lev : flevels) {
515 if (_option.contains("yrastt") && !lev->is_yrast(true))
516 continue;
517 else if (_option.contains("yrast") && !_option.contains("yrastt") && !lev->is_yrast())
518 continue;
519 if (first_level_printed) cout << std::endl;
520 first_level_printed = true;
521 lev->print(_option);
522 for (auto &dec : lev->get_decays_down()) {
523 tkstring decay_option = "quiet;levto";
524 if (_option.contains("com")) decay_option += ";com";
525 cout << setw(13) << "" << "-> ";
526 dec->print(decay_option);
527 }
528 }
529 } else if (_data.contains("level")) {
530 if (_option.contains("tab")) {
531 std::cout << std::setw(15) << left << "symbol" << std::setw(15) << "levelid"
532 << std::setw(15) << left << "energy (keV)"
533 << std::setw(15) << left << "energy error"
534 << std::setw(15) << left << "spin parity"
535 << std::setw(15) << left << "t1/2"
536 << std::setw(15) << left << "t1/2 error"
537 << std::setw(15) << left << "t1/2 unit" << std::endl;
538 } else
539 glog << info << "dataset '" << fname << "' contains " << flevels.size() << " levels:" << do_endl;
540 for (auto &lev : flevels) {
541 if (_option.contains("yrastt") && !lev->is_yrast(true))
542 continue;
543 else if (_option.contains("yrast") && !_option.contains("yrastt") && !lev->is_yrast())
544 continue;
545 if (_option.contains("tab")) std::cout << std::setw(15) << left << fnucleus;
546 lev->print(_option);
547 }
548 } else if (_data.contains("decay")) {
549 if (_option.contains("tab"))
550 std::cout << std::setw(15) << left << "symbol" << std::setw(15) << left << "decayid" << std::setw(15) << left << "energy (keV)" << std::setw(15) << left << "energy error (keV)" << std::endl;
551 else
552 glog << info << "dataset '" << fname << "' contains " << fdecays.size() << " decays:" << do_endl;
553 for (auto &dec : fdecays) {
554 if (_option.contains("tab")) std::cout << std::setw(15) << left << fnucleus;
555 dec->print(_option);
556 }
557 }
558}
559
572shared_ptr<tklevel> tkdataset::add_level(double _ener, double _unc, tkstring _unit, tkstring _jpistr)
573{
574 tkspin spin;
575 tkparity parity;
576 double spin_val = -1.;
577 int parity_val = -1.;
578
579 tkdb_table::measure_data_struct lvl_properties{_ener, _unc, 0, 0, _unit};
580 shared_ptr<tklevel> lvl = make_shared<tklevel>(gmanager->get_new_level_id(), lvl_properties);
581
582 spin.set(_jpistr);
583 parity.set(_jpistr);
584 if (spin.is_known()) spin_val = spin.get_value();
585 if (parity.is_known()) parity_val = (parity.is_parity(tkparity::eparity::kParityMinus));
586
587 lvl->set_jpi(spin_val, parity_val, _jpistr);
588
589 // needs to generate a unique id for the level
590 lvl->fbelongs_to_nucleus = fnucleus;
591
592 // find the good position in the vector to be sorted by energy
593 auto it = std::lower_bound(flevels.begin(), flevels.end(), lvl,
594 [](const std::shared_ptr<tklevel> &a, const std::shared_ptr<tklevel> &b) {
595 return a->get_energy() < b->get_energy();
596 });
597 flevels.insert(it, lvl);
598
599 check_yrast(lvl);
600 fmapoflevels[lvl->get_id()] = lvl;
601
602 return lvl;
603}
604
622shared_ptr<tkgammadecay> tkdataset::add_gamma_decay(shared_ptr<tklevel> _lvlfrom, shared_ptr<tklevel> _lvlto, double _ener, double _unc)
623{
624 if (_ener == 0.) _ener = _lvlfrom->get_energy() - _lvlto->get_energy();
625
626 tkdb_table::measure_data_struct energy_struc{_ener, _unc, 0., 0., "keV"};
627
628 shared_ptr<tkgammadecay> decay = make_shared<tkgammadecay>(gmanager->get_new_decay_id(), _lvlfrom->get_id(), _lvlto->get_id(), energy_struc);
629 decay->set_levels(_lvlfrom, _lvlto);
630 fdecays.push_back(decay);
631 _lvlfrom->add_decay_down(decay);
632 _lvlto->add_decay_up(decay);
633
634 return decay;
635}
636
637#ifdef HAS_ROOT
638ClassImp(tklevel_scheme);
639#endif
shared_ptr< tklevel > add_level(double _ener, double _unc, tkstring _unit, tkstring _jpistr)
manually add a new level to the dataset
shared_ptr< tkgammadecay > add_gamma_decay(shared_ptr< tklevel > _lvlfrom, shared_ptr< tklevel > _lvlto, double _ener=0., double _unc=0.)
add a new decay between two levels to the dataset
Simple structure to store a table column.
Definition tkdb_column.h:26
tkstring get_value() const
Definition tkdb_column.h:38
Representaiton of a sqlite data table.
Definition tkdb_table.h:29
void read_measure(measure_data_struct &_struct, const tkstring &_col_base_name)
Manages the available datasets for a given nucleus.
void print(const tkstring &_data="", const tkstring &_option="")
print the level scheme information
const std::vector< shared_ptr< tklevel > > & get_levels()
get the vector containing all the levels
bool select_dataset(const tkstring &_dataset_name)
select a dataset using its name
const shared_ptr< tkdataset > & get_dataset()
returns the current dataset
shared_ptr< tklevel > get_level(const tkstring &_name, bool _exact=true)
get the level corresponding to the given name
tklevel_scheme(const tkstring &_nuc, int _zz, int _aa, bool _load_default_dataset=true)
const std::vector< shared_ptr< tkdecay > > & get_decays()
get the vector containing all the decays
virtual bool is_parity(tkparity::eparity _parity)
test the parity value
virtual void set(const tkstring &_st)
define the parity from a string
bool is_known() const
to get some information about this data
Definition tkproperty.h:68
double get_value()
To get the spin as a double.
void set(int n, int d=1)
define the spin value
std::string with usefull tricks from TString (ROOT) and KVString (KaliVeda) and more....
Definition tkstring.h:32
static const char * form(const char *_format,...)
Definition tkstring.cpp:452
std::vector< tkstring > tokenize(const tkstring &_delim=" ") const
Create a vector of string separated by at least one delimiter.
Definition tkstring.cpp:275
bool is_empty() const
Definition tkstring.h:141
tkstring & remove_all(const tkstring &_s1)
Definition tkstring.h:193
int atoi() const
Converts a string to integer value.
Definition tkstring.cpp:196
bool contains(const char *_pat, ECaseCompare _cmp=kExact) const
Definition tkstring.h:175
double atof() const
Converts a string to double value.
Definition tkstring.cpp:212
Definition tklog.cpp:16
std::string wrap_text(const tkstring &_text, size_t _first_content_col, size_t _continuation_col, size_t _max_line_width=80)
Definition tkstring.cpp:37
tklog & info(tklog &log)
Definition tklog.h:313
tklog & error(tklog &log)
Definition tklog.h:344
tklog & do_endl(tklog &log)
Definition tklog.h:212
tklog & warning(tklog &log)
Definition tklog.h:331
tklog & comment(tklog &log)
Definition tklog.h:319
data structure used to fill a tkmeasure object from the sqlite database
Definition tkdb_table.h:49