WarpX
Loading...
Searching...
No Matches
ScatteringProcess.H
Go to the documentation of this file.
1/* Copyright 2021-2023 The WarpX Community
2 *
3 * This file is part of WarpX.
4 *
5 * Authors: Modern Electron, Roelof Groenewald (TAE Technologies)
6 *
7 * License: BSD-3-Clause-LBNL
8 */
9#ifndef WARPX_PARTICLES_COLLISION_SCATTERING_PROCESS_H_
10#define WARPX_PARTICLES_COLLISION_SCATTERING_PROCESS_H_
11
12#include <AMReX_GpuContainers.H>
13#include <AMReX_Math.H>
14#include <AMReX_REAL.H>
15#include <AMReX_RandomEngine.H>
16#include <AMReX_Vector.H>
17
18#include <string>
19
30
32{
33public:
35 const std::string& scattering_process,
36 const std::string& cross_section_file,
38 );
39
40 template <typename InputVector>
42 const std::string& scattering_process,
43 const InputVector&& energies,
44 const InputVector&& sigmas,
46 );
47
48 ~ScatteringProcess() = default;
49
54
63 static
65 const std::string& cross_section_file,
68 );
69
70 static
74 );
75
76 struct Executor {
84 [[nodiscard]]
87 {
88 if (E_coll < m_energy_lo) {
89 return m_sigma_lo;
90 } else if (E_coll > m_energy_hi) {
91 return m_sigma_hi;
92 } else {
93 using amrex::Math::floor;
94 using amrex::Math::ceil;
95 // calculate index of bounding energy pairs
96 amrex::ParticleReal temp = (E_coll - m_energy_lo) / m_dE;
97 const int idx_1 = static_cast<int>(floor(temp));
98 const int idx_2 = static_cast<int>(ceil(temp));
99
100 // linearly interpolate to the given energy value
101 temp -= idx_1;
102 return m_sigmas_data[idx_1] + (m_sigmas_data[idx_2] - m_sigmas_data[idx_1]) * temp;
103 }
104 }
105
110 };
111
112 [[nodiscard]]
113 Executor const& executor () const {
114#ifdef AMREX_USE_GPU
115 return m_exe_d;
116#else
117 return m_exe_h;
118#endif
119 }
120
122 {
123 return m_exe_h.getCrossSection(E_coll);
124 }
125
126 [[nodiscard]] amrex::ParticleReal getEnergyPenalty () const { return m_exe_h.m_energy_penalty; }
127 [[nodiscard]] amrex::ParticleReal getMinEnergyInput () const { return m_exe_h.m_energy_lo; }
128 [[nodiscard]] amrex::ParticleReal getMaxEnergyInput () const { return m_exe_h.m_energy_hi; }
129 [[nodiscard]] amrex::ParticleReal getEnergyInputStep () const { return m_exe_h.m_dE; }
130
131 [[nodiscard]] ScatteringProcessType type () const { return m_exe_h.m_type; }
132
133private:
134
135 static
136 ScatteringProcessType parseProcessType(const std::string& process);
137
138 void init (const std::string& scattering_process, amrex::ParticleReal energy);
139
141
142#ifdef AMREX_USE_GPU
144 Executor m_exe_d;
145#endif
148
150};
151
152#endif // WARPX_PARTICLES_COLLISION_SCATTERING_PROCESS_H_
#define AMREX_FORCE_INLINE
#define AMREX_GPU_HOST_DEVICE
@ INVALID
Definition BackgroundStopping.H:18
ScatteringProcessType
Definition ScatteringProcess.H:20
@ BACK
Definition ScatteringProcess.H:23
@ CHARGE_EXCHANGE
Definition ScatteringProcess.H:25
@ ELASTIC
Definition ScatteringProcess.H:22
@ EXCITATION
Definition ScatteringProcess.H:26
@ TWOPRODUCT_REACTION
Definition ScatteringProcess.H:24
@ IONIZATION
Definition ScatteringProcess.H:27
@ FORWARD
Definition ScatteringProcess.H:28
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:129
~ScatteringProcess()=default
ScatteringProcess(ScatteringProcess &&)=default
Executor const & executor() const
Definition ScatteringProcess.H:113
int m_grid_size
Definition ScatteringProcess.H:149
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:131
amrex::ParticleReal getMinEnergyInput() const
Definition ScatteringProcess.H:127
amrex::Gpu::HostVector< amrex::ParticleReal > m_sigmas_h
Definition ScatteringProcess.H:146
ScatteringProcess(ScatteringProcess const &)=delete
amrex::ParticleReal getEnergyPenalty() const
Definition ScatteringProcess.H:126
amrex::ParticleReal getMaxEnergyInput() const
Definition ScatteringProcess.H:128
amrex::ParticleReal getCrossSection(amrex::ParticleReal E_coll) const
Definition ScatteringProcess.H:121
void init(const std::string &scattering_process, amrex::ParticleReal energy)
Definition ScatteringProcess.cpp:38
Executor m_exe_h
Definition ScatteringProcess.H:147
amrex::Vector< amrex::ParticleReal > m_energies
Definition ScatteringProcess.H:140
amrex_particle_real ParticleReal
PinnedVector< T > HostVector
PODVector< T, ArenaAllocator< T > > DeviceVector
Definition ScatteringProcess.H:76
ScatteringProcessType m_type
Definition ScatteringProcess.H:109
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::ParticleReal getCrossSection(amrex::ParticleReal E_coll) const
Definition ScatteringProcess.H:86
amrex::ParticleReal m_energy_penalty
Definition ScatteringProcess.H:108
amrex::ParticleReal m_sigma_lo
Definition ScatteringProcess.H:107
amrex::ParticleReal m_energy_lo
Definition ScatteringProcess.H:107
amrex::ParticleReal m_energy_hi
Definition ScatteringProcess.H:107
amrex::ParticleReal * m_sigmas_data
Definition ScatteringProcess.H:106
amrex::ParticleReal m_dE
Definition ScatteringProcess.H:107
amrex::ParticleReal m_sigma_hi
Definition ScatteringProcess.H:107