Berkeley Nuclear Data Software
|
#include <TALYSUtils.h>
Public Member Functions | |
TALYSUtils () | |
TALYSUtils (int a_ZID, int a_AID, std::string a_talysPath) | |
void | setTALYSEnergies (vector< double > a_talysEnergies) |
void | setRunECIS (bool a_runECIS) |
perform ECIS-06 calculation - if yes, will also save ECIS results More... | |
int | setLDModel (int a_ldmodel) |
set the Level Density model More... | |
void | setTALYSPath (std::string a_talysPath) |
void | setZID (int a_ZID) |
void | setAID (int a_AID) |
void | setBashScriptName (std::string a_fileName) |
int | readTALYSParams (std::string a_paramFileName) |
int | setTALYSParams (std::map< std::string, double > a_params) |
void | readTALYSKeywords (std::string a_fileName) |
reads in TALYS keyword map More... | |
vector< std::string > | getTALYSKeywords (std::string a_keyword) |
vector< std::string > | getAllTALYSKeywords () |
returns string of keys of m_keywords More... | |
void | clearAdvancedParamList () |
clears m_params More... | |
int | runDefaultTALYSCalc () |
int | runTALYSCalc () |
int | getNumAdvancedParams () |
returns number of parameters that minimizer will try to fit More... | |
map< std::string, double > | getAdvancedParamVals () |
vector< double > | getAdvancedParamLimits (std::string a_paramName) |
map< std::string, int > | setupTALYSMinimizer (ROOT::Math::Minimizer *a_minimizer, bool a_useScaler=true) |
int | processTALYSOutput (int a_verbose=0, bool a_writeGammaLevelMap=false) |
Eigen::VectorXf | readTALYSCrossSection (int a_initialLevel, int a_finalLevel, double a_thresholdAdder=0) |
Eigen::VectorXf | readTALYSCrossSection (std::string a_initialLevel, std::string a_finalLevel, double a_thresholdAdder=0) |
Eigen::VectorXf | drawGammaProduction (std::string a_initialLevel, std::string a_finalLevel) |
draws a cross section More... | |
Eigen::VectorXf | drawGammaProduction (int a_initialLevel, int a_finalLevel) |
TGraph2D * | drawDiscreteInelNeutronAngDist (int a_levelNumber, int a_component=0) |
Eigen::MatrixXf | drawElasticAngDist () |
2D hist incoming energy vs outgoing angle More... | |
TH2F * | drawOutEnergyAngle2D (double a_incidentE, int a_component=0) |
vector< vector< float > > | drawInEnerOutEner (double a_angle, bool a_draw=false, int a_component=0) |
vector< vector< float > > | drawOutEner (double a_angle, double a_inEner, int a_component=0) |
outgoing energy distribution at a given incident energy and outgoing angle More... | |
TH2F * | drawInEnerOutAngle (double a_outEnergy, int a_component=0) |
Eigen::VectorXf | drawElasticXSec () |
vector< float > | getOutEnergies (double a_angle) |
returns the energies More... | |
Eigen::VectorXf | drawLevelXSec (int a_level, int a_component=2) |
void | plotChannelIntegratedXSec () |
vector< float > | getBeamEnergies () |
vector< std::string > | getInitAndFinalLevel (float a_gammaEnergy) |
float | getGammaProdThreshold (float a_gammaEnergy) |
Eigen::VectorXf | plotExclusiveCrossSection (std::string a_rxnType="(n,2n)") |
Public Attributes | |
vector< TALYSoutputInfo > | m_outputInfo |
holds information parsed from TALYS "output" file More... | |
TALYSUtils::TALYSUtils | ( | ) |
default constructor Z = 1, A = 1, talysPath = "talysOutput/"
TALYSUtils::TALYSUtils | ( | int | a_ZID, |
int | a_AID, | ||
std::string | a_talysPath | ||
) |
constructor that takes: (Z,A) of desired isotope path to directory where TALYS will be run e.g. "talysOutput/"
void TALYSUtils::clearAdvancedParamList | ( | ) |
clears m_params
TGraph2D * TALYSUtils::drawDiscreteInelNeutronAngDist | ( | int | a_levelNumber, |
int | a_component = 0 |
||
) |
2D hist incoming energy vs outgoing angle a_component = 0 --> total a_component = 1 --> direct a_component = 2 --> compound
Eigen::MatrixXf TALYSUtils::drawElasticAngDist | ( | ) |
2D hist incoming energy vs outgoing angle
Eigen::VectorXf TALYSUtils::drawElasticXSec | ( | ) |
Eigen::VectorXf TALYSUtils::drawGammaProduction | ( | int | a_initialLevel, |
int | a_finalLevel | ||
) |
Eigen::VectorXf TALYSUtils::drawGammaProduction | ( | std::string | a_initialLevel, |
std::string | a_finalLevel | ||
) |
draws a cross section
read in talys production cross section
TH2F * TALYSUtils::drawInEnerOutAngle | ( | double | a_outEnergy, |
int | a_component = 0 |
||
) |
a_component = 0 --> total a_component = 1 --> direct a_component = 4 --> compound
vector< vector< float > > TALYSUtils::drawInEnerOutEner | ( | double | a_angle, |
bool | a_draw = false , |
||
int | a_component = 0 |
||
) |
vector {energy in, energy out, cross section} same components as above
Eigen::VectorXf TALYSUtils::drawLevelXSec | ( | int | a_level, |
int | a_component = 2 |
||
) |
comp 0 = direct comp 1 = compound comp 2 = total
vector< vector< float > > TALYSUtils::drawOutEner | ( | double | a_angle, |
double | a_inEner, | ||
int | a_component = 0 |
||
) |
outgoing energy distribution at a given incident energy and outgoing angle
TH2F * TALYSUtils::drawOutEnergyAngle2D | ( | double | a_incidentE, |
int | a_component = 0 |
||
) |
a_component = 0 --> total a_component = 1 --> direct a_component = 4 --> compound
vector< double > TALYSUtils::getAdvancedParamLimits | ( | std::string | a_paramName | ) |
map< std::string, double > TALYSUtils::getAdvancedParamVals | ( | ) |
vector< std::string > TALYSUtils::getAllTALYSKeywords | ( | ) |
returns string of keys of m_keywords
vector< float > TALYSUtils::getBeamEnergies | ( | ) |
float TALYSUtils::getGammaProdThreshold | ( | float | a_gammaEnergy | ) |
vector< std::string > TALYSUtils::getInitAndFinalLevel | ( | float | a_gammaEnergy | ) |
int TALYSUtils::getNumAdvancedParams | ( | ) |
returns number of parameters that minimizer will try to fit
vector< float > TALYSUtils::getOutEnergies | ( | double | a_angle | ) |
returns the energies
vector< std::string > TALYSUtils::getTALYSKeywords | ( | std::string | a_keyword | ) |
returns string formatted for TALYS input file only handles class 1,2,3,6,7,9 for Z,A keywords, looks at (a_Z,a_A),(a_Z,a_A+1) i.e. a_keyword = T, Z=26, A=56: returns {"T 26 56","T 26 57"} for class 3, only does ground state barrier for parType, only does 'n' for neutron
void TALYSUtils::plotChannelIntegratedXSec | ( | ) |
Eigen::VectorXf TALYSUtils::plotExclusiveCrossSection | ( | std::string | a_rxnType = "(n,2n)" | ) |
int TALYSUtils::processTALYSOutput | ( | int | a_verbose = 0 , |
bool | a_writeGammaLevelMap = false |
||
) |
parses the "output" file to extract various cross sections W.I.P. -> original focus on secondary neutron energy/angle dists still need to add sections:
total xsecs
end of file
excitation functions 5 -> (n,g) then (n,n') 7 -> gamma ray productions
legendre elastic
skip the table header
loop over all the legendre polynomials factors
inelastic legendre
angle elastic
inelastic angle
Binary reactions to discrete levels and continuum
parameters
total outgoing neutron energy spectrum
DDX mode 3
DDX for outgoing neutron energy -> angle
DDX for outoing neutron angle -> energy
DDX for outgoing neutron energy -> angle
Eigen::VectorXf TALYSUtils::readTALYSCrossSection | ( | int | a_initialLevel, |
int | a_finalLevel, | ||
double | a_thresholdAdder = 0 |
||
) |
reads gamma-ray production cross section for a given transition from outputs generated with outgamdis y e.g. for transition from 1st excited to g.s.: a_initialLevel = 1, a_finalLevel = 0 a_thresholdAdder increases reaction threshold i.e. if a_thresholdAdder = 1 [MeV] and reaction threshold is 2 MeV first element in output will be cross section at 3 MeV returns vector of cross section
Eigen::VectorXf TALYSUtils::readTALYSCrossSection | ( | std::string | a_initialLevel, |
std::string | a_finalLevel, | ||
double | a_thresholdAdder = 0 |
||
) |
same as above e.g. for transition from 1st excited to g.s.: a_initialLevel = "01", a_finalLevel = "00"
read in talys production cross section
void TALYSUtils::readTALYSKeywords | ( | std::string | a_fileName | ) |
reads in TALYS keyword map
int TALYSUtils::readTALYSParams | ( | std::string | a_paramFileName | ) |
reads in TALYS parameters from json file "basicSetup" includes parameters there are immutable these parameters are included automatically and don't need to be in the json projectile (n) element (m_ZID) mass (A_ZID) ejectiles (g) outgamdis (y) energy (default: energySpecrum.txt) "advancedSetup" includes parameters that you may want to minimize requires an initial value and the range of values the parameter can take which can be found in the TALYS manual "basicSetup" params are stored in m_basicParams "advancedSetup" params are stored in m_params clears previously stored parameters example of the json is misc/Fe56TalysParams.json
int TALYSUtils::runDefaultTALYSCalc | ( | ) |
writes new input file only using 'best' and m_ldmodel expecting m_bashScriptName file in m_talysPath directory that at least contains command to run TALYS i.e.
talys <input> output
int TALYSUtils::runTALYSCalc | ( | ) |
writes input file with default + m_params expecting m_bashScriptName file in m_talysPath directory that at least contains command to run TALYS i.e.
talys <input> output
void TALYSUtils::setAID | ( | int | a_AID | ) |
void TALYSUtils::setBashScriptName | ( | std::string | a_fileName | ) |
set the name for the bash script that contains the command: save as m_bashScriptName talys <input> output default is runTalys.sh
int TALYSUtils::setLDModel | ( | int | a_ldmodel | ) |
set the Level Density model
void TALYSUtils::setRunECIS | ( | bool | a_runECIS | ) |
perform ECIS-06 calculation - if yes, will also save ECIS results
void TALYSUtils::setTALYSEnergies | ( | vector< double > | a_talysEnergies | ) |
energies to run TALYS calculations for writes file called "energySpectrum.txt" in m_talysPath directory
int TALYSUtils::setTALYSParams | ( | std::map< std::string, double > | a_params | ) |
change the value of a parameter in m_params returns 0 if a parameter in this list in not in m_params
void TALYSUtils::setTALYSPath | ( | std::string | a_talysPath | ) |
map< std::string, int > TALYSUtils::setupTALYSMinimizer | ( | ROOT::Math::Minimizer * | a_minimizer, |
bool | a_useScaler = true |
||
) |
add "advancedSetup" parameters to minimizer as limitied variable sets: parameter name, initial value, and range set a_useScaler to scale entire cross section by a constant returns map of parameter name and ID
void TALYSUtils::setZID | ( | int | a_ZID | ) |
vector<TALYSoutputInfo> TALYSUtils::m_outputInfo |
holds information parsed from TALYS "output" file