22 static constexpr 
int LCollider = LogArea::Collider::id;
 
   30   const auto& [file_dir_key, filename_key, particles_key] = [&is_projectile]() {
 
   42   const std::string particle_list_file_directory = config.
take(file_dir_key);
 
   44   const std::string particle_list_file_name = config.
take(filename_key);
 
   47     throw std::runtime_error(
 
   48         "Your Particle List is already filled before reading in from the " 
   50         "Something went wrong. Please check your config.");
 
   59   std::map<PdgCode, int> particle_list = config.
take(particles_key);
 
   60   for (
const auto& particle : particle_list) {
 
   61     if (particle.first == 
pdg::p) {
 
   63     } 
else if (particle.first == 
pdg::n) {
 
   66       throw std::runtime_error(
 
   67           "Your nucleus can only contain protons and/or neutrons." 
   68           "Please check what particles you have specified in the config");
 
   76   const std::string path =
 
   77       file_path(particle_list_file_directory, particle_list_file_name);
 
   81   } 
else if (!same_file) {
 
   82     filestream_ = std::make_unique<std::ifstream>(path);
 
   98   for (
const auto& it : vec) {
 
  100     if (it.isospin == 1) {
 
  102     } 
else if (it.isospin == 0) {
 
  105       throw std::runtime_error(
 
  106           "Your particles charges are not 1 = proton or 0 = neutron.\n" 
  107           "Check whether your list is correct or there is an error.");
 
  111     double current_mass = current_type.
mass();
 
  113     particles_.back().set_4momentum(current_mass, 0.0, 0.0, 0.0);
 
  135   return nucleon_position;
 
  145   for (
auto i = 
begin(); i != 
end(); i++) {
 
  147     i->set_4momentum(i->pole_mass(), 0.0, 0.0, 0.0);
 
  160   logg[
LCollider].warn() << 
"Fermi motion activated with a custom nucleus.\n";
 
  161   logg[
LCollider].warn() << 
"Be aware that generating the Fermi momenta\n" 
  162                          << 
"assumes nucleons distributed according to a\n" 
  163                          << 
"Woods-Saxon distribution.";
 
  167                                      const std::string& file_name) {
 
  168   if (file_directory.back() == 
'/') {
 
  169     return file_directory + file_name;
 
  171     return file_directory + 
'/' + file_name;
 
  176     std::ifstream& infile)
 const {
 
  177   int proton_counter = 0;
 
  178   int neutron_counter = 0;
 
  180   std::vector<Nucleoncustom> custom_nucleus;
 
  183     std::getline(infile, line);
 
  187       infile.seekg(0, infile.beg);
 
  188       std::getline(infile, line);
 
  191     std::istringstream iss(line);
 
  192     if (!(iss >> nucleon.
x >> nucleon.
y >> nucleon.
z >>
 
  194       throw std::runtime_error(
 
  195           "SMASH could not read in a line from your initial nuclei input file." 
  196           "\nCheck if your file has the following format: x y z " 
  197           "spinprojection isospin");
 
  201     } 
else if (nucleon.
isospin == 0) {
 
  204     custom_nucleus.push_back(nucleon);
 
  208     throw std::runtime_error(
 
  209         "Number of protons and/or neutrons in the nuclei input file does not " 
  210         "correspond to the number specified in the config.\nCheck the config " 
  211         "and your input file.");
 
  213     return custom_nucleus;
 
Interface to the SMASH configuration files.
T take(const Key< T > &key)
The default interface for SMASH to read configuration values.
size_t index_
Index needed to read out vector in distribute nucleon.
std::string file_path(const std::string &file_directory, const std::string &file_name)
Generates the name of the stream file.
static std::unique_ptr< std::ifstream > filestream_shared_
Filestream variable used if projectile and target are read in from the same file and they use the sam...
int number_of_protons_
Number of protons per nucleus.
ThreeVector distribute_nucleon() override
Returns position of a nucleon as given in the external file.
void arrange_nucleons() override
Sets the positions of the nucleons inside a nucleus.
CustomNucleus(Configuration &config, int testparticles, bool same_file)
Constructor that needs configuration parameters from input file and the number of testparticles.
std::vector< Nucleoncustom > custom_nucleus_
Vector contianing Data for one nucleus given in the particlelist.
int number_of_neutrons_
Number of neutrons per nucleus.
int number_of_nucleons_
Number of nucleons per nucleus Set initally to zero to be modified in the constructor.
std::unique_ptr< std::ifstream > filestream_
Filestream variable used if projectile and target are read in from different files and they therefore...
std::vector< Nucleoncustom > readfile(std::ifstream &infile) const
The returned vector contains Data for one nucleus given in the particlelist.
void generate_fermi_momenta() override
Generates Fermi momenta as it is done in the mother class but in addition prints a warning that the F...
void fill_from_list(const std::vector< Nucleoncustom > &vec)
Fills Particlelist from vector containing data for one nucleus.
std::unique_ptr< std::ifstream > * used_filestream_
Pointer to the used filestream pointer.
The FourVector class holds relevant values in Minkowski spacetime with (+, −, −, −) metric signature.
double euler_theta_
Euler angle theta.
void random_euler_angles()
Randomly generate Euler angles.
virtual void generate_fermi_momenta()
Generates momenta according to Fermi motion for the nucleons.
virtual void set_parameters_automatic()
Sets the deformation parameters of the Woods-Saxon distribution according to the current mass number.
double euler_phi_
The Euler angle phi of the three Euler angles used to apply rotations to the nucleus.
std::vector< ParticleData > particles_
Particles associated with this nucleus.
double euler_psi_
Euler angle psi.
void align_center()
Shifts the nucleus so that its center is at (0,0,0)
std::vector< ParticleData >::iterator begin()
For iterators over the particle list:
std::vector< ParticleData >::iterator end()
For iterators over the particle list:
Particle type contains the static properties of a particle species.
static const ParticleType & find(PdgCode pdgcode)
Returns the ParticleType object for the given pdgcode.
PdgCode stores a Particle Data Group Particle Numbering Scheme particle type number.
The ThreeVector class represents a physical three-vector  with the components .
void rotate(double phi, double theta, double psi)
Rotate vector by the given Euler angles phi, theta, psi.
Collection of useful constants that are known at compile time.
std::array< einhard::Logger<>, std::tuple_size< LogArea::AreaTuple >::value > logg
An array that stores all pre-configured Logger objects.
bool has_projectile_or_target(const Configuration &config)
Find out whether a configuration has a projectile or a target sub-section.
bool is_about_projectile(const Configuration &config)
Find out whether a configuration is about projectile or target.
static constexpr int LCollider
Contains data for one nucleon that is read in from the list.
bool isospin
to differentiate between protons isospin=1 and neutrons isospin=0
bool spinprojection
spinprojection of the nucleon