Version: SMASH-3.2
decayactionsfinder.h
Go to the documentation of this file.
1 /*
2  *
3  * Copyright (c) 2014-2020,2022-2024
4  * SMASH Team
5  *
6  * GNU General Public License (GPLv3 or later)
7  *
8  */
9 
10 #ifndef SRC_INCLUDE_SMASH_DECAYACTIONSFINDER_H_
11 #define SRC_INCLUDE_SMASH_DECAYACTIONSFINDER_H_
12 
13 #include <vector>
14 
15 #include "actionfinderfactory.h"
16 #include "input_keys.h"
17 
18 namespace smash {
19 
27  public:
35  explicit DecayActionsFinder(double res_lifetime_factor,
36  bool do_non_strong_decays)
37  : res_lifetime_factor_(res_lifetime_factor),
38  do_final_non_strong_decays_(do_non_strong_decays) {}
39 
47  ActionList find_actions_in_cell(
48  const ParticleList &search_list, double dt, const double,
49  const std::vector<FourVector> &) const override;
50 
53  const ParticleList &, const ParticleList &, double,
54  const std::vector<FourVector> &) const override {
55  return {};
56  }
57 
60  const ParticleList &, const Particles &, double,
61  const std::vector<FourVector> &) const override {
62  return {};
63  }
64 
74  ActionList find_final_actions(const Particles &search_list,
75  bool only_res = false) const override;
76 
78  const double res_lifetime_factor_ = 1.;
79 
82 
89 };
90 
91 } // namespace smash
92 
93 #endif // SRC_INCLUDE_SMASH_DECAYACTIONSFINDER_H_
ActionFinderInterface is the abstract base class for all action finders, i.e.
A simple decay finder: Just loops through all particles and checks if they can decay during the next ...
const bool decay_initial_particles_
Whether to initial state particles can decay.
DecayActionsFinder(double res_lifetime_factor, bool do_non_strong_decays)
Initialize the finder.
const bool do_final_non_strong_decays_
Do all non-strong decays (including weak and electro-magnetic ones)
ActionList find_actions_with_surrounding_particles(const ParticleList &, const Particles &, double, const std::vector< FourVector > &) const override
Ignore the surrounding searches for decays.
const double res_lifetime_factor_
Multiplicative factor to be applied to resonance lifetimes.
ActionList find_final_actions(const Particles &search_list, bool only_res=false) const override
Force all resonances to decay at the end of the simulation.
ActionList find_actions_in_cell(const ParticleList &search_list, double dt, const double, const std::vector< FourVector > &) const override
Check the whole particle list for decays.
ActionList find_actions_with_neighbors(const ParticleList &, const ParticleList &, double, const std::vector< FourVector > &) const override
Ignore the neighbor searches for decays.
default_type default_value() const
Get the default value of the key.
Definition: key.h:177
The Particles class abstracts the storage and manipulation of particles.
Definition: particles.h:33
Definition: action.h:24
static const Key< bool > collTerm_decayInitial
See user guide description for more information.
Definition: input_keys.h:2158