Add nodes for all decays possible from the given node and all of its children.
1023 uint32_t n_unstable = 0;
1024 double sqrts_minus_masses = sqrts;
1025 for (
const ParticleTypePtr ptype : node.state_) {
1026 if (!ptype->is_stable()) {
1029 sqrts_minus_masses -= ptype->mass();
1032 n_unstable != 0 ? 1. /
static_cast<double>(n_unstable) : 1.;
1034 for (
const ParticleTypePtr ptype : node.state_) {
1035 if (!ptype->is_stable()) {
1036 const double sqrts_decay = sqrts_minus_masses + ptype->mass();
1037 bool can_decay =
false;
1038 for (
const auto& decay : ptype->decay_modes().decay_mode_list()) {
1042 double final_state_mass = 0.;
1043 for (
const auto&
p : decay->particle_types()) {
1044 final_state_mass +=
p->mass();
1046 if (final_state_mass > sqrts_decay) {
1051 ParticleTypePtrList parts;
1053 auto& new_node = node.add_action(name, norm * decay->weight(), {ptype},
static std::string make_decay_name(const std::string &res_name, const DecayBranchPtr &decay, ParticleTypePtrList &final_state)
Generate name for decay and update final state.
static void add_decays(Node &node, double sqrts)
Add nodes for all decays possible from the given node and all of its children.