Version: SMASH-3.2
smash::HyperSurfaceCrossActionsFinder Class Reference

#include <hypersurfacecrossingfinder.h>

Finder for hypersurface crossing actions.

Loops through all particles and checks if they cross the hypersurface during the next timestep.

Definition at line 26 of file hypersurfacecrossingfinder.h.

Inheritance diagram for smash::HyperSurfaceCrossActionsFinder:
smash::ActionFinderInterface

Public Member Functions

 HyperSurfaceCrossActionsFinder (double tau, double y, double pT)
 Construct hypersurfacecrossing action finder. More...
 
ActionList find_actions_in_cell (const ParticleList &plist, double dt, const double, const std::vector< FourVector > &beam_momentum) const override
 Find the next hypersurface crossings for each particle that occur within the timestepless propagation. More...
 
ActionList find_actions_with_neighbors (const ParticleList &, const ParticleList &, double, const std::vector< FourVector > &) const override
 Ignore the neighbor searches for hypersurface crossing. More...
 
ActionList find_actions_with_surrounding_particles (const ParticleList &, const Particles &, double, const std::vector< FourVector > &) const override
 Ignore the surrounding searches for hypersurface crossing. More...
 
ActionList find_final_actions (const Particles &, bool) const override
 No final actions for hypersurface crossing. More...
 
- Public Member Functions inherited from smash::ActionFinderInterface
virtual ~ActionFinderInterface ()=default
 

Private Member Functions

bool crosses_hypersurface (ParticleData &pdata_before_propagation, ParticleData &pdata_after_propagation, const double tau) const
 Determine whether particle crosses hypersurface within next timestep during propagation. More...
 
FourVector coordinates_on_hypersurface (ParticleData &pdata_before_propagation, ParticleData &pdata_after_propagation, const double tau) const
 Find the coordinates where particle crosses hypersurface. More...
 

Private Attributes

const double prop_time_
 Proper time of the hypersurface in fm. More...
 
const double rap_cut_
 Rapidity (momentum space) cut for the particles contributing to the initial conditions for hydrodynamics. More...
 
const double pT_cut_
 Transverse momentum cut for the particles contributing to the initial conditions for hydrodynamics. More...
 

Constructor & Destructor Documentation

◆ HyperSurfaceCrossActionsFinder()

smash::HyperSurfaceCrossActionsFinder::HyperSurfaceCrossActionsFinder ( double  tau,
double  y,
double  pT 
)
inlineexplicit

Construct hypersurfacecrossing action finder.

Parameters
[in]tauProper time of the hypersurface. [fm]
[in]yValue for rapidity cut: absolute value of momentum space rapidity up to which particles are considered for initial conditions
[in]pTValue for transverse momentum cut: maximum transverse momentum up to which particles are considered for initial conditions

Definition at line 38 of file hypersurfacecrossingfinder.h.

39  : prop_time_{tau}, rap_cut_{y}, pT_cut_{pT} {};
const double prop_time_
Proper time of the hypersurface in fm.
const double rap_cut_
Rapidity (momentum space) cut for the particles contributing to the initial conditions for hydrodynam...
const double pT_cut_
Transverse momentum cut for the particles contributing to the initial conditions for hydrodynamics.

Member Function Documentation

◆ find_actions_in_cell()

ActionList smash::HyperSurfaceCrossActionsFinder::find_actions_in_cell ( const ParticleList &  plist,
double  dt,
const double  ,
const std::vector< FourVector > &  beam_momentum 
) const
overridevirtual

Find the next hypersurface crossings for each particle that occur within the timestepless propagation.

Parameters
[in]plistList of all particles.
[in]dtTime until crossing can appear (until end of timestep). [fm]
[in]beam_momentum[GeV] List of beam momenta for each particle; only necessary for frozen Fermi motion necessary if frozen Fermi Motion is activated
Returns
List of all found wall crossings.

Implements smash::ActionFinderInterface.

Definition at line 19 of file hypersurfacecrossingfinder.cc.

21  {
22  ActionList actions;
23 
24  for (const ParticleData &p : plist) {
25  ParticleData pdata_before_propagation = p;
26  ParticleData pdata_after_propagation = p; // Will receive updated position
27  double t0 = p.position().x0();
28  double t_end = t0 + dt; // Time at the end of timestep
29 
30  // We don't want to remove particles before the nuclei have interacted
31  // because those would not yet be part of the newly-created medium.
32  if (t_end < 0.0) {
33  continue;
34  }
35 
36  // For frozen Fermi motion:
37  // Fermi momenta are only applied if particles interact. The particle
38  // properties p.velocity() and p.momentum() already contain the values
39  // corrected by Fermi motion, but those particles that have not yet
40  // interacted are propagated along the beam-axis with v = (0, 0, beam_v)
41  // (and not with p.velocity()).
42  // To identify the corresponding hypersurface crossings the finding for
43  // those paricles without prior interactions has to be performed with
44  // v = vbeam instead of p.velcocity().
45  // Note: The beam_momentum vector is empty in case frozen Fermi motion is
46  // not applied.
47  const bool no_prior_interactions =
48  (static_cast<uint64_t>(p.id()) < // particle from
49  static_cast<uint64_t>(beam_momentum.size())) && // initial nucleus
50  (p.get_history().collisions_per_particle == 0);
51  ThreeVector v;
52  if (no_prior_interactions) {
53  const FourVector vbeam = beam_momentum[p.id()];
54  v = vbeam.velocity();
55  } else {
56  v = p.velocity();
57  }
58 
59  // propagate particles to position where they would be at the end of the
60  // time step (after dt)
61  const FourVector distance = FourVector(0.0, v * dt);
62  FourVector position = p.position() + distance;
63  position.set_x0(t_end);
64  // update coordinates to the position corresponding to t_end
65  pdata_after_propagation.set_4position(position);
66 
67  bool hypersurface_is_crossed = crosses_hypersurface(
68  pdata_before_propagation, pdata_after_propagation, prop_time_);
69 
70  /*
71  If rapidity or transverse momentum cut is to be employed; check if
72  particles are within the relevant region
73  Implementation explanation: The default for both cuts is 0.0, as a cut at
74  0 implies that not a single particle contributes to the initial
75  conditions. If the user specifies a value of 0.0 in the config, SMASH
76  crashes with a corresponding error message. The same applies to negtive
77  values.
78  */
79  bool is_within_y_cut = true;
80  // Check whether particle is in desired rapidity range
81  if (rap_cut_ > 0.0) {
82  const double rapidity =
83  0.5 * std::log((p.momentum().x0() + p.momentum().x3()) /
84  (p.momentum().x0() - p.momentum().x3()));
85  if (std::fabs(rapidity) > rap_cut_) {
86  is_within_y_cut = false;
87  }
88  }
89 
90  bool is_within_pT_cut = true;
91  // Check whether particle is in desired pT range
92  if (pT_cut_ > 0.0) {
93  const double transverse_momentum =
94  std::sqrt(p.momentum().x1() * p.momentum().x1() +
95  p.momentum().x2() * p.momentum().x2());
96  if (transverse_momentum > pT_cut_) {
97  is_within_pT_cut = false;
98  }
99  }
100 
101  if (hypersurface_is_crossed && is_within_y_cut && is_within_pT_cut) {
102  // Get exact coordinates where hypersurface is crossed
103  FourVector crossing_position = coordinates_on_hypersurface(
104  pdata_before_propagation, pdata_after_propagation, prop_time_);
105 
106  double time_until_crossing = crossing_position[0] - t0;
107 
108  ParticleData outgoing_particle(p);
109  outgoing_particle.set_4position(crossing_position);
110  ActionPtr action = std::make_unique<FluidizationAction>(
111  p, outgoing_particle, time_until_crossing);
112  actions.emplace_back(std::move(action));
113  }
114  }
115  return actions;
116 }
FourVector coordinates_on_hypersurface(ParticleData &pdata_before_propagation, ParticleData &pdata_after_propagation, const double tau) const
Find the coordinates where particle crosses hypersurface.
bool crosses_hypersurface(ParticleData &pdata_before_propagation, ParticleData &pdata_after_propagation, const double tau) const
Determine whether particle crosses hypersurface within next timestep during propagation.
constexpr int p
Proton.

◆ find_actions_with_neighbors()

ActionList smash::HyperSurfaceCrossActionsFinder::find_actions_with_neighbors ( const ParticleList &  ,
const ParticleList &  ,
double  ,
const std::vector< FourVector > &   
) const
inlineoverridevirtual

Ignore the neighbor searches for hypersurface crossing.

Implements smash::ActionFinderInterface.

Definition at line 56 of file hypersurfacecrossingfinder.h.

58  {
59  return {};
60  }

◆ find_actions_with_surrounding_particles()

ActionList smash::HyperSurfaceCrossActionsFinder::find_actions_with_surrounding_particles ( const ParticleList &  ,
const Particles ,
double  ,
const std::vector< FourVector > &   
) const
inlineoverridevirtual

Ignore the surrounding searches for hypersurface crossing.

Implements smash::ActionFinderInterface.

Definition at line 63 of file hypersurfacecrossingfinder.h.

65  {
66  return {};
67  }

◆ find_final_actions()

ActionList smash::HyperSurfaceCrossActionsFinder::find_final_actions ( const Particles ,
bool   
) const
inlineoverridevirtual

No final actions for hypersurface crossing.

Implements smash::ActionFinderInterface.

Definition at line 70 of file hypersurfacecrossingfinder.h.

70  {
71  return {};
72  }

◆ crosses_hypersurface()

bool smash::HyperSurfaceCrossActionsFinder::crosses_hypersurface ( ParticleData pdata_before_propagation,
ParticleData pdata_after_propagation,
const double  tau 
) const
private

Determine whether particle crosses hypersurface within next timestep during propagation.

Parameters
[in]pdata_before_propagationParticle data at the beginning of time step in question
[in]pdata_after_propagationParticle data at the end of time step in question
[in]tauProper time of the hypersurface that is tested
Returns
Does particle cross the hypersurface?

Definition at line 118 of file hypersurfacecrossingfinder.cc.

120  {
121  bool hypersurface_is_crossed = false;
122  const bool t_greater_z_before_prop =
123  (std::fabs(pdata_before_propagation.position().x0()) >
124  std::fabs(pdata_before_propagation.position().x3())
125  ? true
126  : false);
127  const bool t_greater_z_after_prop =
128  (std::fabs(pdata_after_propagation.position().x0()) >
129  std::fabs(pdata_after_propagation.position().x3())
130  ? true
131  : false);
132 
133  if (t_greater_z_before_prop && t_greater_z_after_prop) {
134  // proper time before and after propagation
135  const double tau_before = pdata_before_propagation.position().tau();
136  const double tau_after = pdata_after_propagation.position().tau();
137 
138  if (tau_before <= tau && tau <= tau_after) {
139  hypersurface_is_crossed = true;
140  }
141  } else if (!t_greater_z_before_prop && t_greater_z_after_prop) {
142  // proper time after propagation
143  const double tau_after = pdata_after_propagation.position().tau();
144  if (tau_after >= tau) {
145  hypersurface_is_crossed = true;
146  }
147  }
148 
149  return hypersurface_is_crossed;
150 }

◆ coordinates_on_hypersurface()

FourVector smash::HyperSurfaceCrossActionsFinder::coordinates_on_hypersurface ( ParticleData pdata_before_propagation,
ParticleData pdata_after_propagation,
const double  tau 
) const
private

Find the coordinates where particle crosses hypersurface.

Parameters
[in]pdata_before_propagationParticle data at the beginning of time in question
[in]pdata_after_propagationParticle data at the end of time step in question
[in]tauProper time of the hypersurface that is crossed
Returns
Fourvector of the crossing position

Definition at line 152 of file hypersurfacecrossingfinder.cc.

154  {
155  // find t and z at start of propagation
156  const double t1 = pdata_before_propagation.position().x0();
157  const double z1 = pdata_before_propagation.position().x3();
158 
159  // find t and z after propagation
160  const double t2 = pdata_after_propagation.position().x0();
161  const double z2 = pdata_after_propagation.position().x3();
162 
163  // find slope and intercept of linear function that describes propagation on
164  // straight line
165  const double m = (z2 - z1) / (t2 - t1);
166  const double n = z1 - m * t1;
167 
168  // The equation to solve is a quadratic equation which provides two solutions,
169  // the latter is usually out of the t-interval we are looking at.
170  const double sol1 = n * m / (1 - m * m) +
171  std::sqrt((1 - m * m) * tau * tau + n * n) / (1 - m * m);
172  [[maybe_unused]] const double sol2 = // only used in DEBUG output
173  n * m / (1 - m * m) -
174  std::sqrt((1 - m * m) * tau * tau + n * n) / (1 - m * m);
175 
176  assert((sol1 >= t1 && sol1 <= t2));
177  assert(!(sol2 >= t1 && sol2 <= t2));
178 
179  // Propagate to point where hypersurface is crossed
180  const ThreeVector v = pdata_before_propagation.velocity();
181  const FourVector distance = FourVector(0.0, v * (sol1 - t1));
182  FourVector crossing_position = pdata_before_propagation.position() + distance;
183  crossing_position.set_x0(sol1);
184 
185  return crossing_position;
186 }
constexpr int n
Neutron.

Member Data Documentation

◆ prop_time_

const double smash::HyperSurfaceCrossActionsFinder::prop_time_
private

Proper time of the hypersurface in fm.

Definition at line 76 of file hypersurfacecrossingfinder.h.

◆ rap_cut_

const double smash::HyperSurfaceCrossActionsFinder::rap_cut_
private

Rapidity (momentum space) cut for the particles contributing to the initial conditions for hydrodynamics.

If applied, only particles characterized by a rapidity between [-y_cut, y_cut] are printed to the hypersurface.

Definition at line 84 of file hypersurfacecrossingfinder.h.

◆ pT_cut_

const double smash::HyperSurfaceCrossActionsFinder::pT_cut_
private

Transverse momentum cut for the particles contributing to the initial conditions for hydrodynamics.

If applied, only particles characterized by a transverse momentum between [0, pT_cut] are printed to the hypersurface.

Definition at line 93 of file hypersurfacecrossingfinder.h.


The documentation for this class was generated from the following files: