9#ifndef WARPX_PARTICLES_COLLISION_SCATTERING_PROCESS_H_
10#define WARPX_PARTICLES_COLLISION_SCATTERING_PROCESS_H_
34 const std::string& scattering_process,
35 const std::string& cross_section_file,
36 amrex::ParticleReal energy
39 template <
typename InputVector>
41 const std::string& scattering_process,
42 const InputVector&& energies,
43 const InputVector&& sigmas,
44 amrex::ParticleReal energy
64 const std::string& cross_section_file,
72 amrex::ParticleReal dE
92 using amrex::Math::floor;
93 using amrex::Math::ceil;
96 const int idx_1 =
static_cast<int>(floor(temp));
97 const int idx_2 =
static_cast<int>(ceil(temp));
122 return m_exe_h.getCrossSection(E_coll);
137 void init (
const std::string& scattering_process, amrex::ParticleReal energy);
#define AMREX_FORCE_INLINE
#define AMREX_GPU_HOST_DEVICE
@ INVALID
Definition BackgroundStopping.H:18
ScatteringProcessType
Definition ScatteringProcess.H:20
@ BACK
Definition ScatteringProcess.H:23
@ ELASTIC
Definition ScatteringProcess.H:22
@ EXCITATION
Definition ScatteringProcess.H:25
@ TWOPRODUCT_REACTION
Definition ScatteringProcess.H:24
@ IONIZATION
Definition ScatteringProcess.H:26
@ FORWARD
Definition ScatteringProcess.H:27
static void readCrossSectionFile(const std::string &cross_section_file, amrex::Vector< amrex::ParticleReal > &energies, amrex::Gpu::HostVector< amrex::ParticleReal > &sigmas)
Definition ScatteringProcess.cpp:99
amrex::ParticleReal getEnergyInputStep() const
Definition ScatteringProcess.H:128
~ScatteringProcess()=default
ScatteringProcess(ScatteringProcess &&)=default
Executor const & executor() const
Definition ScatteringProcess.H:112
int m_grid_size
Definition ScatteringProcess.H:148
static ScatteringProcessType parseProcessType(const std::string &process)
Definition ScatteringProcess.cpp:77
static void sanityCheckEnergyGrid(const amrex::Vector< amrex::ParticleReal > &energies, amrex::ParticleReal dE)
Definition ScatteringProcess.cpp:117
ScatteringProcess & operator=(ScatteringProcess const &)=delete
ScatteringProcess(const std::string &scattering_process, const std::string &cross_section_file, amrex::ParticleReal energy)
Definition ScatteringProcess.cpp:13
ScatteringProcessType type() const
Definition ScatteringProcess.H:130
amrex::ParticleReal getMinEnergyInput() const
Definition ScatteringProcess.H:126
amrex::Gpu::HostVector< amrex::ParticleReal > m_sigmas_h
Definition ScatteringProcess.H:145
ScatteringProcess(ScatteringProcess const &)=delete
amrex::ParticleReal getEnergyPenalty() const
Definition ScatteringProcess.H:125
amrex::ParticleReal getMaxEnergyInput() const
Definition ScatteringProcess.H:127
amrex::ParticleReal getCrossSection(amrex::ParticleReal E_coll) const
Definition ScatteringProcess.H:120
void init(const std::string &scattering_process, amrex::ParticleReal energy)
Definition ScatteringProcess.cpp:38
Executor m_exe_h
Definition ScatteringProcess.H:146
amrex::Vector< amrex::ParticleReal > m_energies
Definition ScatteringProcess.H:139
PinnedVector< T > HostVector
PODVector< T, ArenaAllocator< T > > DeviceVector
Definition ScatteringProcess.H:75
ScatteringProcessType m_type
Definition ScatteringProcess.H:108
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::ParticleReal getCrossSection(amrex::ParticleReal E_coll) const
Definition ScatteringProcess.H:85
amrex::ParticleReal m_energy_penalty
Definition ScatteringProcess.H:107
amrex::ParticleReal m_sigma_lo
Definition ScatteringProcess.H:106
amrex::ParticleReal m_energy_lo
Definition ScatteringProcess.H:106
amrex::ParticleReal m_energy_hi
Definition ScatteringProcess.H:106
amrex::ParticleReal * m_sigmas_data
Definition ScatteringProcess.H:105
amrex::ParticleReal m_dE
Definition ScatteringProcess.H:106
amrex::ParticleReal m_sigma_hi
Definition ScatteringProcess.H:106