4 #ifdef ERF_USE_PARTICLES
7 #include <AMReX_Particles.H>
9 struct ERFParticlesIntIdxAoS
17 struct ERFParticlesRealIdxAoS
24 struct ERFParticlesIntIdxSoA
31 struct ERFParticlesRealIdxSoA
43 namespace ERFParticleInitializations
46 const std::string init_box_uniform =
"box";
49 namespace ERFParticleNames
51 const std::string tracers =
"tracer_particles";
54 struct ERFParticlesAssignor
58 amrex::IntVect operator() ( P
const& p,
59 amrex::GpuArray<amrex::Real,AMREX_SPACEDIM>
const& plo,
60 amrex::GpuArray<amrex::Real,AMREX_SPACEDIM>
const& dxi,
61 const amrex::Box& domain )
const noexcept
64 AMREX_D_DECL(
int(amrex::Math::floor((p.pos(0)-plo[0])*dxi[0])),
65 int(amrex::Math::floor((p.pos(1)-plo[1])*dxi[1])),
66 p.idata(ERFParticlesIntIdxAoS::k) ) );
67 iv[0] += domain.smallEnd()[0];
68 iv[1] += domain.smallEnd()[1];
74 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
75 void update_location_idata ( P& a_p,
76 amrex::GpuArray<amrex::Real,AMREX_SPACEDIM>
const& a_plo,
77 amrex::GpuArray<amrex::Real,AMREX_SPACEDIM>
const& a_dxi,
78 const amrex::Array4<amrex::Real const>& a_height_arr )
82 amrex::IntVect iv(
int(amrex::Math::floor((a_p.pos(0)-a_plo[0])*a_dxi[0])),
83 int(amrex::Math::floor((a_p.pos(1)-a_plo[1])*a_dxi[1])),
84 a_p.idata(ERFParticlesIntIdxAoS::k) );
87 auto zlo = a_height_arr(iv[0] ,iv[1] ,iv[2] ) * (1.0-lx) * (1.0-ly) +
88 a_height_arr(iv[0]+1,iv[1] ,iv[2] ) * lx * (1.0-ly) +
89 a_height_arr(iv[0] ,iv[1]+1,iv[2] ) * (1.0-lx) * ly +
90 a_height_arr(iv[0]+1,iv[1]+1,iv[2] ) * lx * ly;
91 auto zhi = a_height_arr(iv[0] ,iv[1] ,iv[2]+1) * (1.0-lx) * (1.0-ly) +
92 a_height_arr(iv[0]+1,iv[1] ,iv[2]+1) * lx * (1.0-ly) +
93 a_height_arr(iv[0] ,iv[1]+1,iv[2]+1) * (1.0-lx) * ly +
94 a_height_arr(iv[0]+1,iv[1]+1,iv[2]+1) * lx * ly;
96 if (a_p.pos(2) > zhi) {
97 a_p.idata(ERFParticlesIntIdxAoS::k) += 1;
98 }
else if (a_p.pos(2) <= zlo) {
99 a_p.idata(ERFParticlesIntIdxAoS::k) -= 1;
107 class ERFPC :
public amrex::ParticleContainer< ERFParticlesRealIdxAoS::ncomps,
108 ERFParticlesIntIdxAoS::ncomps,
109 ERFParticlesRealIdxSoA::ncomps,
110 ERFParticlesIntIdxSoA::ncomps,
111 amrex::DefaultAllocator,
112 ERFParticlesAssignor >
117 ERFPC ( amrex::ParGDBBase* a_gdb,
118 const std::string& a_name =
"particles" )
119 :
amrex::ParticleContainer< ERFParticlesRealIdxAoS::ncomps,
120 ERFParticlesIntIdxAoS::ncomps,
121 ERFParticlesRealIdxSoA::ncomps,
122 ERFParticlesIntIdxSoA::ncomps,
123 amrex::DefaultAllocator,
124 ERFParticlesAssignor> (a_gdb)
126 BL_PROFILE(
"ERFPCPC::ERFPC()");
132 ERFPC (
const amrex::Geometry& a_geom,
133 const amrex::DistributionMapping& a_dmap,
134 const amrex::BoxArray& a_ba,
135 const std::string& a_name =
"particles" )
136 :
amrex::ParticleContainer< ERFParticlesRealIdxAoS::ncomps,
137 ERFParticlesIntIdxAoS::ncomps,
138 ERFParticlesRealIdxSoA::ncomps,
139 ERFParticlesIntIdxSoA::ncomps,
140 amrex::DefaultAllocator,
141 ERFParticlesAssignor> ( a_geom, a_dmap, a_ba )
143 BL_PROFILE(
"ERFPCPC::ERFPC()");
149 virtual void InitializeParticles (
const amrex::Real time,
const std::unique_ptr<amrex::MultiFab>& a_ptr =
nullptr);
152 virtual void EvolveParticles (
int,
154 amrex::Vector<amrex::Vector<amrex::MultiFab>>&,
155 const amrex::Vector<std::unique_ptr<amrex::MultiFab>>& );
158 virtual amrex::Vector<std::string> varNames ()
const
160 BL_PROFILE(
"ERFPCPC::varNames()");
161 return {AMREX_D_DECL(
"xvel",
"yvel",
"zvel"),
"mass",
"temperature"};
165 virtual amrex::Vector<std::string> meshPlotVarNames ()
const
167 BL_PROFILE(
"ERFPCPC::varNames()");
168 return {
"mass_density"};
172 virtual void AdvectWithFlow ( amrex::MultiFab*,
175 const std::unique_ptr<amrex::MultiFab>& );
178 virtual void AdvectWithGravity (
int,
180 const std::unique_ptr<amrex::MultiFab>& );
183 virtual void ComputeTemperature (
const amrex::MultiFab&,
186 const std::unique_ptr<amrex::MultiFab>& );
189 virtual void massDensity ( amrex::MultiFab&,
const int&,
const int& a_comp = 0)
const;
192 virtual void computeMeshVar(
const std::string& a_var_name,
193 amrex::MultiFab& a_mf,
194 const int a_lev)
const
196 if (a_var_name ==
"mass_density") {
197 massDensity( a_mf, a_lev );
204 inline void setAdvectWithFlow (
bool a_flag)
206 BL_PROFILE(
"ERFPCPC::setAdvectWithFlow()");
207 m_advect_w_flow = a_flag;
210 inline void setAdvectWithGravity (
bool a_flag)
212 BL_PROFILE(
"ERFPCPC::setAdvectWithGravity()");
213 m_advect_w_gravity = a_flag;
220 void initializeParticlesUniformDistributionInBox (
const std::unique_ptr<amrex::MultiFab>& a_ptr,
221 const amrex::RealBox& particle_box);
225 bool m_advect_w_flow;
226 bool m_advect_w_gravity;
228 amrex::RealBox m_particle_box;
232 std::string m_initialization_type;
237 bool m_initialized =
false;
239 bool m_stable_redistribute;
242 virtual void readInputs ();
246 bool place_randomly_in_cells;
amrex::Real Real
Definition: ERF_ShocInterface.H:19
Definition: ERF_ConsoleIO.cpp:12