11#ifndef WARPX_HYBRIDPICMODEL_H_
12#define WARPX_HYBRIDPICMODEL_H_
91 amrex::Vector<std::array< std::unique_ptr<amrex::iMultiFab>,3 > >& eb_update_E
95 std::array< std::unique_ptr<amrex::iMultiFab>,3 >& eb_update_E,
108 amrex::Vector<std::array< std::unique_ptr<amrex::iMultiFab>,3 > >& eb_update_E,
109 bool solve_for_Faraday)
const;
116 std::array< std::unique_ptr<amrex::iMultiFab>,3 >& eb_update_E,
117 int lev,
bool solve_for_Faraday)
const;
124 std::array< std::unique_ptr<amrex::iMultiFab>,3 >& eb_update_E,
125 int lev,
PatchType patch_type,
bool solve_for_Faraday)
const;
132 amrex::Vector<std::array< std::unique_ptr<amrex::iMultiFab>,3 > >& eb_update_E,
141 amrex::Vector<std::array< std::unique_ptr<amrex::iMultiFab>,3 > >& eb_update_E,
150 amrex::Vector<std::array< std::unique_ptr<amrex::iMultiFab>,3 > >& eb_update_E,
245 amrex::Real
const T0,
246 amrex::Real
const gamma,
247 amrex::Real
const rho) {
#define AMREX_FORCE_INLINE
#define AMREX_GPU_HOST_DEVICE
SubcyclingHalf
Subcycling half selector.
Definition WarpXAlgorithmSelection.H:166
amrex::ParserExecutor< 2 > m_eta_h
Definition HybridPICModel.H:199
void ReadParameters()
Definition HybridPICModel.cpp:30
amrex::GpuArray< int, 3 > Bz_IndexType
Definition HybridPICModel.H:226
amrex::GpuArray< int, 3 > Bx_IndexType
Definition HybridPICModel.H:222
amrex::Real m_n0_ref
Definition HybridPICModel.H:183
std::string m_Jz_ext_grid_function
Definition HybridPICModel.H:206
amrex::GpuArray< int, 3 > Ez_IndexType
Definition HybridPICModel.H:232
bool m_external_current_has_time_dependence
Definition HybridPICModel.H:209
void GetCurrentExternal()
Function to evaluate the external current expressions and populate the external current multifab....
Definition HybridPICModel.cpp:259
std::array< amrex::ParserExecutor< 4 >, 3 > m_J_external
Definition HybridPICModel.H:208
amrex::Real m_elec_temp
Definition HybridPICModel.H:181
HybridPICModel()
Definition HybridPICModel.cpp:25
std::unique_ptr< ExternalVectorPotential > m_external_vector_potential
Definition HybridPICModel.H:213
void InitData(const ablastr::fields::MultiFabRegister &fields)
Definition HybridPICModel.cpp:157
amrex::GpuArray< int, 3 > Jx_IndexType
Definition HybridPICModel.H:216
bool m_add_external_fields
Definition HybridPICModel.H:212
amrex::GpuArray< int, 3 > Jz_IndexType
Definition HybridPICModel.H:220
std::string m_Jy_ext_grid_function
Definition HybridPICModel.H:205
std::unique_ptr< amrex::Parser > m_hyper_resistivity_parser
Definition HybridPICModel.H:198
bool m_hyper_resistivity_has_B_dependence
Definition HybridPICModel.H:201
std::unique_ptr< amrex::Parser > m_resistivity_parser
Definition HybridPICModel.H:192
std::string m_eta_expression
Definition HybridPICModel.H:191
void AllocateLevelMFs(ablastr::fields::MultiFabRegister &fields, int lev, const amrex::BoxArray &ba, const amrex::DistributionMapping &dm, int ncomps, const amrex::IntVect &ngJ, const amrex::IntVect &ngRho, const amrex::IntVect &ngEB, const amrex::IntVect &jx_nodal_flag, const amrex::IntVect &jy_nodal_flag, const amrex::IntVect &jz_nodal_flag, const amrex::IntVect &rho_nodal_flag, const amrex::IntVect &Ex_nodal_flag, const amrex::IntVect &Ey_nodal_flag, const amrex::IntVect &Ez_nodal_flag, const amrex::IntVect &Bx_nodal_flag, const amrex::IntVect &By_nodal_flag, const amrex::IntVect &Bz_nodal_flag) const
Definition HybridPICModel.cpp:73
bool m_holmstrom_vacuum_region
Definition HybridPICModel.H:178
void FillElectronPressureMF(amrex::MultiFab &Pe_field, amrex::MultiFab const &rho_field) const
Fill the electron pressure multifab given the kinetic particle charge density (and assumption of quas...
Definition HybridPICModel.cpp:410
amrex::Real m_gamma
Definition HybridPICModel.H:185
std::array< std::unique_ptr< amrex::Parser >, 3 > m_J_external_parser
Definition HybridPICModel.H:207
std::string m_Jx_ext_grid_function
Definition HybridPICModel.H:204
void BfieldEvolveRK(ablastr::fields::MultiLevelVectorField const &Bfield, ablastr::fields::MultiLevelVectorField const &Efield, ablastr::fields::MultiLevelVectorField const &Jfield, ablastr::fields::MultiLevelScalarField const &rhofield, amrex::Vector< std::array< std::unique_ptr< amrex::iMultiFab >, 3 > > &eb_update_E, amrex::Real dt, SubcyclingHalf subcycling_half, amrex::IntVect ng, std::optional< bool > nodal_sync)
Definition HybridPICModel.cpp:440
std::string m_eta_h_expression
Definition HybridPICModel.H:197
bool m_include_hyper_resistivity_term
Definition HybridPICModel.H:200
int m_substeps
Definition HybridPICModel.H:176
bool m_resistivity_has_J_dependence
Definition HybridPICModel.H:194
amrex::GpuArray< int, 3 > Ex_IndexType
Definition HybridPICModel.H:228
void CalculatePlasmaCurrent(ablastr::fields::MultiLevelVectorField const &Bfield, amrex::Vector< std::array< std::unique_ptr< amrex::iMultiFab >, 3 > > &eb_update_E)
Function to calculate the total plasma current based on Ampere's law while neglecting displacement cu...
Definition HybridPICModel.cpp:276
amrex::Real m_n_floor
Definition HybridPICModel.H:188
void HybridPICSolveE(ablastr::fields::MultiLevelVectorField const &Efield, ablastr::fields::MultiLevelVectorField const &Jfield, ablastr::fields::MultiLevelVectorField const &Bfield, ablastr::fields::MultiLevelScalarField const &rhofield, amrex::Vector< std::array< std::unique_ptr< amrex::iMultiFab >, 3 > > &eb_update_E, bool solve_for_Faraday) const
Function to update the E-field using Ohm's law (hybrid-PIC model).
Definition HybridPICModel.cpp:316
void FieldPush(ablastr::fields::MultiLevelVectorField const &Bfield, ablastr::fields::MultiLevelVectorField const &Efield, ablastr::fields::MultiLevelVectorField const &Jfield, ablastr::fields::MultiLevelScalarField const &rhofield, amrex::Vector< std::array< std::unique_ptr< amrex::iMultiFab >, 3 > > &eb_update_E, amrex::Real dt, SubcyclingHalf subcycling_half, amrex::IntVect ng, std::optional< bool > nodal_sync)
Definition HybridPICModel.cpp:573
amrex::ParserExecutor< 2 > m_eta
Definition HybridPICModel.H:193
void CalculateElectronPressure() const
Function to calculate the electron pressure using the simulation charge density. Used in the Ohm's la...
Definition HybridPICModel.cpp:380
amrex::GpuArray< int, 3 > Jy_IndexType
Definition HybridPICModel.H:218
amrex::GpuArray< int, 3 > By_IndexType
Definition HybridPICModel.H:224
amrex::GpuArray< int, 3 > Ey_IndexType
Definition HybridPICModel.H:230
constexpr auto q_e
elementary charge [C]
Definition constant.H:158
Definition EffectivePotentialPoissonSolver.H:63
std::array< amrex::MultiFab *, 3 > VectorField
Definition MultiFabRegister.H:191
amrex::Vector< ScalarField > MultiLevelScalarField
Definition MultiFabRegister.H:200
amrex::Vector< VectorField > MultiLevelVectorField
Definition MultiFabRegister.H:208
PatchType
Definition Enums.H:30
This struct contains only static functions to compute the electron pressure using the particle densit...
Definition HybridPICModel.H:241
AMREX_GPU_HOST_DEVICE static AMREX_FORCE_INLINE amrex::Real get_pressure(amrex::Real const n0, amrex::Real const T0, amrex::Real const gamma, amrex::Real const rho)
Definition HybridPICModel.H:244
Definition MultiFabRegister.H:262