10#ifndef WARPX_WarpXParticleContainer_H_
11#define WARPX_WarpXParticleContainer_H_
66#if defined(WARPX_DIM_1D_Z)
68 static constexpr auto names = {
"z",
"w",
"ux",
"uy",
"uz"};
69#elif defined(WARPX_DIM_XZ)
71 static constexpr auto names = {
"x",
"z",
"w",
"ux",
"uy",
"uz"};
72#elif defined(WARPX_DIM_RZ)
74 static constexpr auto names = {
"r",
"z",
"w",
"ux",
"uy",
"uz",
"theta"};
75#elif defined(WARPX_DIM_RCYLINDER)
77 static constexpr auto names = {
"r",
"w",
"ux",
"uy",
"uz",
"theta"};
78#elif defined(WARPX_DIM_RSPHERE)
80 static constexpr auto names = {
"r",
"w",
"ux",
"uy",
"uz",
"theta",
"phi"};
81#elif defined(WARPX_DIM_3D)
83 static constexpr auto names = {
"x",
"y",
"z",
"w",
"ux",
"uy",
"uz"};
85 #error WarpX dimension is not correctly set!
98 static constexpr std::initializer_list<char const *>
names = {};
120 [[nodiscard]]
const std::array<RealVector, PIdx::nattribs>&
GetAttribs ()
const
125 [[nodiscard]] std::array<RealVector, PIdx::nattribs>&
GetAttribs ()
232 const std::string& current_fp_string,
248 int n_external_attr_real,
249 int n_external_attr_int) = 0;
256 void PushX ( amrex::Real dt);
257 void PushX (
int lev, amrex::Real dt);
262 virtual void PushP (
int lev, amrex::Real dt,
282 amrex::Real dt, amrex::Real relative_time);
296 bool local =
false,
bool reset =
false,
297 bool apply_boundary_and_scale_volume =
false,
298 bool interpolate_across_levels =
true,
301 bool local =
false,
bool reset =
false,
302 bool apply_boundary_and_scale_volume =
false,
305 std::unique_ptr<amrex::MultiFab>
GetChargeDensity(
int lev,
bool local =
false);
333 amrex::Real relative_time,
347 [[maybe_unused]]amrex::Real relative_time)
359 [[maybe_unused]]
long const offset,
360 [[maybe_unused]]
long const np_to_deposit,
361 [[maybe_unused]]
int const thread_num,
362 [[maybe_unused]]
const int lev,
363 [[maybe_unused]]
int const depos_lev,
364 [[maybe_unused]]amrex::Real
const relative_time,
475 int uniqueparticles, amrex::Long
id=-1);
539 int DoQED()
const {
return false; }
547 template<PhysicalSpecies PhysSpec>
571 virtual std::vector<std::
string>
getUserIntAttribs ()
const {
return std::vector<std::string>{}; }
591 auto const pos = std::find(int_names.begin(), int_names.end(), name);
592 return (pos != int_names.end());
Array4< int const > offset
PhysicalSpecies
Definition SpeciesPhysicalProperties.H:16
@ unspecified
Definition SpeciesPhysicalProperties.H:17
PushType
Particle push scheme.
Definition WarpXAlgorithmSelection.H:170
PositionPushType
For advanced collision algorithms that split the particle push in substeps.
Definition WarpXAlgorithmSelection.H:181
@ Full
Definition WarpXAlgorithmSelection.H:181
MomentumPushType
For advanced collision algorithms that split the particle push in substeps.
Definition WarpXAlgorithmSelection.H:189
@ Full
Definition WarpXAlgorithmSelection.H:189
SubcyclingHalf
Subcycling half selector.
Definition WarpXAlgorithmSelection.H:166
@ None
Definition WarpXAlgorithmSelection.H:166
Definition BreitWheelerEngineWrapper.H:294
Definition PlasmaInjector.H:39
Definition QuantumSyncEngineWrapper.H:273
Definition WarpXParticleContainer.H:112
WarpXParIter(ContainerType &pc, int level)
Definition WarpXParticleContainer.cpp:82
RealVector & GetAttribs(const std::string &name)
Definition WarpXParticleContainer.H:155
const RealVector & GetAttribs(const std::string &name) const
Definition WarpXParticleContainer.H:150
std::array< RealVector, PIdx::nattribs > & GetAttribs()
Definition WarpXParticleContainer.H:125
const IntVector & GetiAttribs(int comp) const
Definition WarpXParticleContainer.H:140
const IntVector & GetiAttribs(const std::string &name) const
Definition WarpXParticleContainer.H:160
const RealVector & GetAttribs(int comp) const
Definition WarpXParticleContainer.H:130
const std::array< RealVector, PIdx::nattribs > & GetAttribs() const
Definition WarpXParticleContainer.H:120
IntVector & GetiAttribs(const std::string &name)
Definition WarpXParticleContainer.H:165
RealVector & GetAttribs(int comp)
Definition WarpXParticleContainer.H:135
IntVector & GetiAttribs(int comp)
Definition WarpXParticleContainer.H:145
amrex::Real self_fields_required_precision
Definition WarpXParticleContainer.H:499
amrex::ParticleReal sumParticleCharge(bool local=false) const
Definition WarpXParticleContainer.cpp:2149
void DepositTotalNGPTemperature(amrex::MultiFab *temperature, const int lev)
Definition WarpXParticleContainer.cpp:1821
virtual void Evolve(ablastr::fields::MultiFabRegister &fields, int lev, const std::string ¤t_fp_string, amrex::Real t, amrex::Real dt, SubcyclingHalf subcycling_half=SubcyclingHalf::None, bool skip_deposition=false, PositionPushType position_push_type=PositionPushType::Full, MomentumPushType momentum_push_type=MomentumPushType::Full, ImplicitOptions const *implicit_options=nullptr)=0
Pure virtual function to advance particles (typically by one time step).
int do_continuous_injection
Definition WarpXParticleContainer.H:618
amrex::Vector< amrex::FArrayBox > local_Szy
Definition WarpXParticleContainer.H:668
virtual amrex::Vector< amrex::Parser * > getUserIntAttribParser() const
Definition WarpXParticleContainer.H:575
amrex::Vector< amrex::FArrayBox > local_Sxy
Definition WarpXParticleContainer.H:662
~WarpXParticleContainer() override=default
bool AmIA() const noexcept
Definition WarpXParticleContainer.H:548
virtual void DefaultInitializeRuntimeAttributes(typename ContainerLike< amrex::PinnedArenaAllocator >::ParticleTileType &pinned_tile, int n_external_attr_real, int n_external_attr_int)=0
Virtual method to initialize runtime attributes. Must be overriden by each derived class.
amrex::Vector< amrex::FArrayBox > local_Syx
Definition WarpXParticleContainer.H:664
amrex::Vector< amrex::FArrayBox > local_Szz
Definition WarpXParticleContainer.H:669
amrex::Vector< amrex::ParticleReal > m_B_external_particle
Definition WarpXParticleContainer.H:505
amrex::Vector< amrex::FArrayBox > local_Sxx
Definition WarpXParticleContainer.H:661
bool m_gather_from_main_grid
instead of gathering fields from the finest patch level, gather from the coarsest
Definition WarpXParticleContainer.H:609
virtual void AllocData()
Definition WarpXParticleContainer.cpp:171
void defineAllParticleTiles() noexcept
Definition WarpXParticleContainer.cpp:2344
std::pair< amrex::ParticleReal, amrex::ParticleReal > sumParticleWeightAndEnergy(bool local=false) const
Definition WarpXParticleContainer.cpp:2083
virtual void PostRestart()=0
void particlePostLocate(ParticleType &p, const amrex::ParticleLocData &pld, int lev) override
Definition WarpXParticleContainer.cpp:2359
virtual void ReadHeader(std::istream &is)=0
int self_fields_max_iters
Definition WarpXParticleContainer.H:501
void DepositNumberDensity(amrex::MultiFab *number_density, const int lev)
Definition WarpXParticleContainer.cpp:1954
amrex::Real m_current_injection_position
Current injection position.
Definition WarpXParticleContainer.H:509
int species_id
Definition WarpXParticleContainer.H:596
virtual bool getTemperatureDepositionFlag() const noexcept
Definition WarpXParticleContainer.H:676
std::string m_qed_breit_wheeler_ele_product_name
Definition WarpXParticleContainer.H:648
virtual void WriteHeader(std::ostream &os) const =0
amrex::Gpu::DeviceVector< amrex::Real > adk_exp_prefactor
Definition WarpXParticleContainer.H:629
int do_adk_correction
Definition WarpXParticleContainer.H:621
amrex::Gpu::DeviceVector< amrex::Real > adk_power
Definition WarpXParticleContainer.H:627
PhysicalSpecies physical_species
Definition WarpXParticleContainer.H:600
bool do_not_push
Definition WarpXParticleContainer.H:611
std::unique_ptr< amrex::MultiFab > GetDebyeLength(int lev)
Definition WarpXParticleContainer.cpp:2028
bool HasiAttrib(const std::string &name)
Definition WarpXParticleContainer.H:588
virtual void ContinuousFluxInjection(amrex::Real, amrex::Real)
Definition WarpXParticleContainer.H:424
virtual std::vector< std::string > getUserIntAttribs() const
Definition WarpXParticleContainer.H:571
std::string getSpeciesTypeName() const
This function returns a string containing the name of the species type.
Definition WarpXParticleContainer.H:553
int m_qed_quantum_sync_phot_product
Definition WarpXParticleContainer.H:651
amrex::ParticleReal maxParticleVelocity(bool local=false)
Definition WarpXParticleContainer.cpp:2240
std::unique_ptr< amrex::MultiFab > GetAverageNGPTemperature(int lev)
Definition WarpXParticleContainer.cpp:1930
virtual void InitIonizationModule()
Definition WarpXParticleContainer.H:219
virtual void InitData()=0
amrex::Gpu::DeviceVector< amrex::Real > adk_prefactor
Definition WarpXParticleContainer.H:628
void SetDoBackTransformedParticles(const bool do_back_transformed_particles)
Definition WarpXParticleContainer.H:518
amrex::Vector< amrex::FArrayBox > local_Syy
Definition WarpXParticleContainer.H:665
int ionization_initial_level
Definition WarpXParticleContainer.H:625
virtual QuantumSynchrotronEngine * get_quantum_sync_engine_ptr() const
Definition WarpXParticleContainer.H:581
amrex::Real self_fields_absolute_tolerance
Definition WarpXParticleContainer.H:500
amrex::Vector< amrex::FArrayBox > local_jx
Definition WarpXParticleContainer.H:656
void setDoNotDeposit(int flag)
Definition WarpXParticleContainer.H:586
virtual void set_breit_wheeler_engine_ptr(const std::shared_ptr< BreitWheelerEngine > &)
Definition WarpXParticleContainer.H:643
amrex::Vector< amrex::FArrayBox > local_Syz
Definition WarpXParticleContainer.H:666
void DepositCurrent(ablastr::fields::MultiLevelVectorField const &J, amrex::Real dt, amrex::Real relative_time)
Deposit current density.
Definition WarpXParticleContainer.cpp:1332
virtual void UpdateAntennaPosition(const amrex::Real)
Update antenna position for continuous injection of lasers in a boosted frame. Empty function for con...
Definition WarpXParticleContainer.H:419
virtual std::vector< std::string > getUserRealAttribs() const
Definition WarpXParticleContainer.H:573
bool doContinuousInjection() const
Definition WarpXParticleContainer.H:421
bool GetDoBackTransformedParticles() const
Definition WarpXParticleContainer.H:522
amrex::StructOfArrays< DiagIdx::nattribs, 0 > DiagnosticParticleData
Definition WarpXParticleContainer.H:201
amrex::Vector< amrex::FArrayBox > local_jy
Definition WarpXParticleContainer.H:657
std::unique_ptr< amrex::MultiFab > GetChargeDensity(int lev, bool local=false)
Definition WarpXParticleContainer.cpp:1791
static void ReadParameters()
Definition WarpXParticleContainer.cpp:158
int getIonizationInitialLevel() const noexcept
Definition WarpXParticleContainer.H:673
virtual BreitWheelerEngine * get_breit_wheeler_engine_ptr() const
Definition WarpXParticleContainer.H:580
amrex::Gpu::DeviceVector< amrex::Real > adk_correction_factors
Definition WarpXParticleContainer.H:631
int ion_atomic_number
Definition WarpXParticleContainer.H:624
bool m_do_back_transformed_particles
Definition WarpXParticleContainer.H:637
amrex::Vector< amrex::FArrayBox > local_jz
Definition WarpXParticleContainer.H:658
amrex::Gpu::DeviceVector< amrex::Real > ionization_energies
Definition WarpXParticleContainer.H:626
amrex::ParticleReal getCharge() const
Definition WarpXParticleContainer.H:526
std::unique_ptr< amrex::MultiFab > GetNumberDensity(int lev)
Definition WarpXParticleContainer.cpp:2012
amrex::Vector< amrex::FArrayBox > local_Szx
Definition WarpXParticleContainer.H:667
virtual void DepositTemperature(WarpXParIter &pti, RealVector const &wp, RealVector const &uxp, RealVector const &uyp, RealVector const &uzp, amrex::MultiFab *const Tx, amrex::MultiFab *const Ty, amrex::MultiFab *const Tz, long const offset, long const np_to_deposit, int const thread_num, const int lev, int const depos_lev, amrex::Real const relative_time, PushType push_type, const warpx::particles::deposition::TemperatureDepositionType type, const warpx::particles::deposition::TemperatureDepositionPass pass)
Definition WarpXParticleContainer.H:350
WarpXParticleContainer & operator=(WarpXParticleContainer &&)=default
void ApplyBoundaryConditions()
Apply particle BC.
Definition WarpXParticleContainer.cpp:2381
virtual bool has_breit_wheeler() const
Definition WarpXParticleContainer.H:535
virtual void PushP(int lev, amrex::Real dt, const amrex::MultiFab &Ex, const amrex::MultiFab &Ey, const amrex::MultiFab &Ez, const amrex::MultiFab &Bx, const amrex::MultiFab &By, const amrex::MultiFab &Bz)=0
std::string m_qed_breit_wheeler_pos_product_name
Definition WarpXParticleContainer.H:650
std::string m_qed_quantum_sync_phot_product_name
Definition WarpXParticleContainer.H:652
virtual void ContinuousInjection(const amrex::RealBox &)
Definition WarpXParticleContainer.H:413
WarpXParticleContainer & operator=(const WarpXParticleContainer &)=delete
ParticleBoundaries m_boundary_conditions
Definition WarpXParticleContainer.H:603
virtual void resample(const amrex::Vector< amrex::Geometry > &, const int, bool)
Virtual method to resample the species. Overriden by PhysicalParticleContainer only....
Definition WarpXParticleContainer.H:561
int m_qed_breit_wheeler_pos_product
Definition WarpXParticleContainer.H:649
int ionization_product
Definition WarpXParticleContainer.H:622
void AddNParticles(int lev, long n, amrex::Vector< amrex::ParticleReal > const &x, amrex::Vector< amrex::ParticleReal > const &y, amrex::Vector< amrex::ParticleReal > const &z, amrex::Vector< amrex::ParticleReal > const &ux, amrex::Vector< amrex::ParticleReal > const &uy, amrex::Vector< amrex::ParticleReal > const &uz, int nattr_real, amrex::Vector< amrex::Vector< amrex::ParticleReal > > const &attr_real, int nattr_int, amrex::Vector< amrex::Vector< int > > const &attr_int, int uniqueparticles, amrex::Long id=-1)
Adds n particles to the simulation.
Definition WarpXParticleContainer.cpp:180
int m_qed_breit_wheeler_ele_product
Definition WarpXParticleContainer.H:647
bool do_splitting
Definition WarpXParticleContainer.H:496
virtual void set_quantum_sync_engine_ptr(const std::shared_ptr< QuantumSynchrotronEngine > &)
Definition WarpXParticleContainer.H:645
std::array< amrex::ParticleReal, 3 > meanParticleVelocity(bool local=false)
Definition WarpXParticleContainer.cpp:2154
virtual void AccumulateVelocitiesAndComputeTemperature(ablastr::fields::MultiLevelVectorField const &T_vf, amrex::Real relative_time)
Accumulate velocity moments for matched temperature deposition using particle shapes.
Definition WarpXParticleContainer.H:345
bool initialize_self_fields
Definition WarpXParticleContainer.H:498
int self_fields_verbosity
Definition WarpXParticleContainer.H:502
virtual bool has_quantum_sync() const
Definition WarpXParticleContainer.H:534
WarpXParticleContainer(amrex::AmrCore *amr_core, int ispecies)
Definition WarpXParticleContainer.cpp:94
std::string physical_element
Definition WarpXParticleContainer.H:632
virtual void DepositCurrentAndMassMatrices(WarpXParIter &pti, const RealVector &wp, const RealVector &uxp, const RealVector &uyp, const RealVector &uzp, amrex::MultiFab *jx, amrex::MultiFab *jy, amrex::MultiFab *jz, amrex::MultiFab *Sxx, amrex::MultiFab *Sxy, amrex::MultiFab *Sxz, amrex::MultiFab *Syx, amrex::MultiFab *Syy, amrex::MultiFab *Syz, amrex::MultiFab *Szx, amrex::MultiFab *Szy, amrex::MultiFab *Szz, const amrex::FArrayBox *bxfab, const amrex::FArrayBox *byfab, const amrex::FArrayBox *bzfab, long offset, long np_to_deposit, int thread_num, int lev, int depos_lev, amrex::Real dt)
Definition WarpXParticleContainer.cpp:933
void deleteInvalidParticles()
Definition WarpXParticleContainer.cpp:352
int split_type
Definition WarpXParticleContainer.H:512
virtual amrex::Vector< amrex::Parser * > getUserRealAttribParser() const
Definition WarpXParticleContainer.H:577
amrex::Vector< amrex::FArrayBox > local_Sxz
Definition WarpXParticleContainer.H:663
amrex::ParticleReal sumParticleEnergy(bool local=false) const
Definition WarpXParticleContainer.cpp:2137
void PushX(amrex::Real dt)
Definition WarpXParticleContainer.cpp:2274
WarpXParticleContainer(WarpXParticleContainer &&)=default
virtual PlasmaInjector * GetPlasmaInjector(const int)
Definition WarpXParticleContainer.H:225
friend MultiParticleContainer
Definition WarpXParticleContainer.H:197
amrex::Vector< amrex::ParticleReal > m_E_external_particle
Definition WarpXParticleContainer.H:506
std::string ionization_product_name
Definition WarpXParticleContainer.H:623
amrex::ParticleReal m_mass
Definition WarpXParticleContainer.H:599
int getSpeciesId() const
Definition WarpXParticleContainer.H:426
int DoFieldIonization() const
Definition WarpXParticleContainer.H:530
int do_not_deposit
Definition WarpXParticleContainer.H:497
void setDoNotPush(bool flag)
Definition WarpXParticleContainer.H:584
WarpXParticleContainer(const WarpXParticleContainer &)=delete
amrex::ParticleReal getMass() const
Definition WarpXParticleContainer.H:528
void DepositCharge(const ablastr::fields::MultiLevelScalarField &rho, bool local=false, bool reset=false, bool apply_boundary_and_scale_volume=false, bool interpolate_across_levels=true, int icomp=0)
Deposit charge density.
Definition WarpXParticleContainer.cpp:1682
void setDoNotGather(int flag)
Definition WarpXParticleContainer.H:585
amrex::ParticleReal sumParticleWeight(bool local=false) const
Definition WarpXParticleContainer.cpp:2143
amrex::Vector< std::map< std::pair< int, int >, DiagnosticParticleData > > DiagnosticParticles
Definition WarpXParticleContainer.H:206
int DoQED() const
Definition WarpXParticleContainer.H:537
int do_resampling
Definition WarpXParticleContainer.H:634
int do_not_gather
Definition WarpXParticleContainer.H:612
static void BackwardCompatibility()
bool m_deposit_on_main_grid
instead of depositing (current, charge) on the finest patch level, deposit to the coarsest grid
Definition WarpXParticleContainer.H:606
amrex::Vector< amrex::FArrayBox > local_rho
Definition WarpXParticleContainer.H:655
int do_field_ionization
Definition WarpXParticleContainer.H:620
amrex::ParticleReal charge
Definition WarpXParticleContainer.H:598
SoARef GetStructOfArrays() const
typename SoA::RealVector RealVector
ParticleContainer_impl< ParticleType, NArrayReal, NArrayInt, Allocator, CellAssignor > ContainerType
typename SoA::IntVector IntVector
typename SoA::RealVector RealVector
ParticleTile< ParticleType, NArrayReal, NArrayInt, Allocator > ParticleTileType
std::vector< std::string > GetIntSoANames() const
T_ParticleType ParticleType
Definition EffectivePotentialPoissonSolver.H:63
amrex::Vector< ScalarField > MultiLevelScalarField
Definition MultiFabRegister.H:200
amrex::Vector< VectorField > MultiLevelVectorField
Definition MultiFabRegister.H:208
PODVector< T, ArenaAllocator< T > > DeviceVector
ParIter_impl< SoAParticle< T_NArrayReal, T_NArrayInt >, T_NArrayReal, T_NArrayInt, Allocator, CellAssignor > ParIterSoA
ParticleContainer_impl< SoAParticle< T_NArrayReal, T_NArrayInt >, T_NArrayReal, T_NArrayInt, Allocator, CellAssignor > ParticleContainerPureSoA
std::string get_name(const PhysicalSpecies &ps)
Returns the name associated to a PhysicalSpecies.
Definition SpeciesPhysicalProperties.cpp:295
TemperatureDepositionType
Definition TemperatureDepositionTypes.H:20
TemperatureDepositionPass
Definition TemperatureDepositionTypes.H:25
Definition WarpXParticleContainer.H:102
@ ux
Definition WarpXParticleContainer.H:105
@ x
Definition WarpXParticleContainer.H:105
@ nattribs
Definition WarpXParticleContainer.H:106
@ z
Definition WarpXParticleContainer.H:105
@ w
Definition WarpXParticleContainer.H:104
@ y
Definition WarpXParticleContainer.H:105
@ uy
Definition WarpXParticleContainer.H:105
@ uz
Definition WarpXParticleContainer.H:105
Definition ImplicitOptions.H:7
Definition WarpXParticleContainer.H:92
static constexpr std::initializer_list< char const * > names
Definition WarpXParticleContainer.H:98
@ nattribs
the number of attributes above (always last)
Definition WarpXParticleContainer.H:95
Definition WarpXParticleContainer.H:65
static constexpr auto names
Definition WarpXParticleContainer.H:71
@ nattribs
Definition WarpXParticleContainer.H:70
@ x
Definition WarpXParticleContainer.H:70
@ uz
Definition WarpXParticleContainer.H:70
@ w
Definition WarpXParticleContainer.H:70
@ uy
Definition WarpXParticleContainer.H:70
@ z
Definition WarpXParticleContainer.H:70
@ ux
Definition WarpXParticleContainer.H:70
Definition ParticleBoundaries.H:42
Definition MultiFabRegister.H:262