11#ifndef WARPX_ParticleContainer_H_
12#define WARPX_ParticleContainer_H_
32#include <AMReX_Config.H>
110 std::string
const& current_fp_string,
114 bool skip_deposition=
false,
124 void PushX (amrex::Real dt);
132 void PushP (
int lev, amrex::Real dt,
155 amrex::Real relative_time);
170 amrex::Real dt, amrex::Real relative_time);
189 std::unique_ptr<amrex::MultiFab>
GetChargeDensity(
int lev,
bool local =
false);
197 void doCollisions (
int step, amrex::Real cur_time, amrex::Real dt);
225 void Restart (
const std::string& dir);
235 bool sort_particles_for_deposition,
291 bool const onMainGrid =
true;
293 return static_cast<int>(std::count(
v.begin(),
v.end(), onMainGrid ));
298 bool const fromMainGrid =
true;
300 return static_cast<int>(std::count(
v.begin(),
v.end(), fromMainGrid ));
374 [[nodiscard]]
int getSpeciesID (
const std::string& product_str)
const;
423 template<
typename ...Args>
426 Args
const&... pc_dsts)
const noexcept
462 static_cast<amrex::ParticleReal
>(
544 template<
typename First,
typename ...Args>
546 First
const& pc_dst, Args
const&... others)
const noexcept
550 "For particle creation processes, either all or none of the "
551 "particle species must use tiling.");
@ v
Definition RigidInjectedParticleContainer.H:27
#define WARPX_ALWAYS_ASSERT_WITH_MESSAGE(EX, MSG)
Definition TextMsg.H:13
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
void SortParticlesByBin(const amrex::IntVect &bin_size, bool sort_particles_for_deposition, const amrex::IntVect &sort_idx_type)
Definition MultiParticleContainer.cpp:784
std::vector< std::string > GetLasersNames() const
Definition MultiParticleContainer.H:321
void RedistributeLocal(int num_ghost)
Definition MultiParticleContainer.cpp:824
amrex::Vector< std::unique_ptr< WarpXParticleContainer > >::iterator begin()
Definition MultiParticleContainer.H:376
void deleteInvalidParticles()
Definition MultiParticleContainer.cpp:816
std::unique_ptr< amrex::Parser > m_Bz_particle_parser
Definition MultiParticleContainer.H:337
void InitQED()
Definition MultiParticleContainer.cpp:1163
std::unique_ptr< amrex::Parser > m_Ey_particle_parser
Definition MultiParticleContainer.H:340
std::unique_ptr< amrex::MultiFab > GetChargeDensity(int lev, bool local=false)
Definition MultiParticleContainer.cpp:687
int nLasers() const
Definition MultiParticleContainer.H:267
bool getDoBackTransformedParticles() const
Definition MultiParticleContainer.H:284
amrex::Real m_qed_schwinger_zmax
Definition MultiParticleContainer.H:526
amrex::Real m_qed_schwinger_zmin
Definition MultiParticleContainer.H:525
void InitMultiPhysicsModules()
Definition MultiParticleContainer.cpp:486
std::string m_B_ext_particle_s
Definition MultiParticleContainer.H:332
void QuantumSyncGenerateTable()
Definition MultiParticleContainer.cpp:1326
MultiParticleContainer & operator=(MultiParticleContainer const &)=delete
amrex::Vector< amrex::ParticleReal > h_repeated_plasma_lens_strengths_E
Definition MultiParticleContainer.H:354
void AllocData()
Definition MultiParticleContainer.cpp:458
void SetParticleDistributionMap(int lev, amrex::DistributionMapping &new_dm)
Definition MultiParticleContainer.cpp:888
void InitData()
Definition MultiParticleContainer.cpp:466
amrex::Real m_qed_schwinger_ymin
Definition MultiParticleContainer.H:523
std::vector< bool > m_laser_deposit_on_main_grid
Definition MultiParticleContainer.H:416
void Evolve(ablastr::fields::MultiFabRegister &fields, int lev, std::string const ¤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)
This evolves all the particles by one PIC time step, including current deposition,...
Definition MultiParticleContainer.cpp:504
void Increment(amrex::MultiFab &mf, int lev)
Definition MultiParticleContainer.cpp:872
void mapSpeciesProduct()
Definition MultiParticleContainer.cpp:949
void ContinuousInjection(const amrex::RealBox &injection_box) const
Definition MultiParticleContainer.cpp:901
amrex::Gpu::DeviceVector< amrex::ParticleReal > d_repeated_plasma_lens_lengths
Definition MultiParticleContainer.H:357
MultiParticleContainer(MultiParticleContainer const &)=delete
void doResampling(const amrex::Vector< amrex::Geometry > &geom, int timestep, bool verbose)
This function loops over all species and performs resampling if appropriate.
Definition MultiParticleContainer.cpp:1131
amrex::Vector< std::unique_ptr< WarpXParticleContainer > >::iterator end()
Definition MultiParticleContainer.H:377
int NSpeciesBreitWheeler() const
Definition MultiParticleContainer.H:477
void ReadHeader(std::istream &is)
Definition ParticleIO.cpp:231
static constexpr auto m_default_quantum_sync_photon_creation_energy_threshold
Definition MultiParticleContainer.H:461
void ApplyBoundaryConditions()
Definition MultiParticleContainer.cpp:832
std::vector< std::string > lasers_names
Definition MultiParticleContainer.H:410
amrex::Gpu::DeviceVector< amrex::ParticleReal > d_repeated_plasma_lens_starts
Definition MultiParticleContainer.H:356
bool m_do_qed_schwinger
Definition MultiParticleContainer.H:502
std::unique_ptr< amrex::Parser > m_By_particle_parser
Definition MultiParticleContainer.H:336
void PushX(amrex::Real dt)
This pushes the particle positions by one time step for all the species in the MultiParticleContainer...
Definition MultiParticleContainer.cpp:549
amrex::Vector< amrex::ParticleReal > h_repeated_plasma_lens_lengths
Definition MultiParticleContainer.H:353
std::string m_qed_schwinger_ele_product_name
Definition MultiParticleContainer.H:504
int m_nspecies_quantum_sync
Definition MultiParticleContainer.H:457
int m_qed_schwinger_ele_product
Definition MultiParticleContainer.H:508
int nSpecies() const
Definition MultiParticleContainer.H:266
int m_nspecies_breit_wheeler
Definition MultiParticleContainer.H:458
void MFItInfoCheckTiling(const WarpXParticleContainer &) const noexcept
Definition MultiParticleContainer.H:541
void InitQuantumSync()
Definition MultiParticleContainer.cpp:1194
std::shared_ptr< BreitWheelerEngine > m_shr_p_bw_engine
Definition MultiParticleContainer.H:446
void Redistribute()
Definition MultiParticleContainer.cpp:800
std::vector< PCTypes > species_types
Definition MultiParticleContainer.H:421
void PostRestart()
Definition MultiParticleContainer.cpp:476
int NSpeciesQuantumSync() const
Definition MultiParticleContainer.H:472
amrex::ParticleReal m_quantum_sync_photon_creation_energy_threshold
Definition MultiParticleContainer.H:466
void DepositCurrent(ablastr::fields::MultiLevelVectorField const &J, amrex::Real dt, amrex::Real relative_time)
Deposit current density.
Definition MultiParticleContainer.cpp:592
WarpXParticleContainer & GetParticleContainerFromName(const std::string &name) const
Definition MultiParticleContainer.cpp:438
std::vector< std::string > species_names
Definition MultiParticleContainer.H:408
amrex::Box ComputeSchwingerGlobalBox() const
Definition MultiParticleContainer.cpp:1607
amrex::Gpu::DeviceVector< amrex::ParticleReal > d_repeated_plasma_lens_strengths_B
Definition MultiParticleContainer.H:359
amrex::Real m_qed_schwinger_ymax
Definition MultiParticleContainer.H:524
void doQEDSchwinger()
Definition MultiParticleContainer.cpp:1499
std::string m_E_ext_particle_s
Definition MultiParticleContainer.H:333
amrex::Real m_qed_schwinger_xmin
Definition MultiParticleContainer.H:521
int nSpeciesGatherFromMainGrid() const
Definition MultiParticleContainer.H:296
amrex::ParserExecutor< 1 > m_Bfield_time_partparser
Definition MultiParticleContainer.H:348
WarpXParticleContainer * GetParticleContainerPtr(int index) const
Definition MultiParticleContainer.H:85
void defineAllParticleTiles()
Definition MultiParticleContainer.cpp:808
void BreitWheelerGenerateTable()
Definition MultiParticleContainer.cpp:1415
std::unique_ptr< amrex::MultiFab > GetZeroChargeDensity(int lev)
This returns a MultiFAB filled with zeros. It is used to return the charge density when there is no p...
Definition MultiParticleContainer.cpp:567
void ReadParameters()
Definition MultiParticleContainer.cpp:130
int doContinuousInjection() const
Definition MultiParticleContainer.cpp:921
amrex::Vector< amrex::ParticleReal > h_repeated_plasma_lens_strengths_B
Definition MultiParticleContainer.H:355
int nSpeciesDepositOnMainGrid() const
Definition MultiParticleContainer.H:289
void DepositTemperatures(ablastr::fields::MultiFabRegister &fields, amrex::Real relative_time)
Deposit temperature to species MFs. This is done for each species and can be used in the future for a...
Definition MultiParticleContainer.cpp:657
MultiParticleContainer & operator=(MultiParticleContainer &&)=default
std::unique_ptr< CollisionHandler > collisionhandler
Definition MultiParticleContainer.H:412
amrex::ParticleReal m_repeated_plasma_lens_period
Definition MultiParticleContainer.H:351
amrex::Real m_qed_schwinger_xmax
Definition MultiParticleContainer.H:522
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)
Definition MultiParticleContainer.cpp:557
void doCollisions(int step, amrex::Real cur_time, amrex::Real dt)
Definition MultiParticleContainer.cpp:1125
void MFItInfoCheckTiling(const WarpXParticleContainer &pc_src, First const &pc_dst, Args const &... others) const noexcept
Definition MultiParticleContainer.H:545
int getSpeciesID(const std::string &product_str) const
Definition MultiParticleContainer.cpp:994
amrex::Vector< amrex::Long > NumberOfParticlesInGrid(int lev) const
Definition MultiParticleContainer.cpp:849
void InitBreitWheeler()
Definition MultiParticleContainer.cpp:1266
void doFieldIonization(int lev, const amrex::MultiFab &Ex, const amrex::MultiFab &Ey, const amrex::MultiFab &Ez, const amrex::MultiFab &Bx, const amrex::MultiFab &By, const amrex::MultiFab &Bz)
Definition MultiParticleContainer.cpp:1059
amrex::Vector< amrex::Long > GetZeroParticlesInGrid(int lev) const
This returns a vector filled with zeros whose size is the number of boxes in the simulation boxarray....
Definition MultiParticleContainer.cpp:840
bool m_do_back_transformed_particles
Definition MultiParticleContainer.H:539
void GenerateGlobalDebyeLength()
Definition MultiParticleContainer.cpp:709
std::array< amrex::ParticleReal, 3 > meanParticleVelocity(int index)
Definition MultiParticleContainer.H:90
amrex::Vector< std::unique_ptr< WarpXParticleContainer > > allcontainers
Definition MultiParticleContainer.H:533
void SetParticleBoxArray(int lev, amrex::BoxArray &new_ba)
Definition MultiParticleContainer.cpp:880
void doQedQuantumSync(int lev, const amrex::MultiFab &Ex, const amrex::MultiFab &Ey, const amrex::MultiFab &Ez, const amrex::MultiFab &Bx, const amrex::MultiFab &By, const amrex::MultiFab &Bz)
Performs QED photon emission for the species for which it is enabled.
Definition MultiParticleContainer.cpp:1766
WarpXParticleContainer & GetParticleContainer(int index) const
Definition MultiParticleContainer.H:82
void ScrapeParticlesAtEB(ablastr::fields::MultiLevelScalarField const &distance_to_eb)
Definition MultiParticleContainer.cpp:1154
void UpdateAntennaPosition(amrex::Real dt) const
Update antenna position for continuous injection of lasers in a boosted frame. Empty function for con...
Definition MultiParticleContainer.cpp:911
MultiParticleContainer(MultiParticleContainer &&)=default
void CheckIonizationProductSpecies()
Definition MultiParticleContainer.cpp:1143
std::unique_ptr< amrex::Parser > m_Ex_particle_parser
Definition MultiParticleContainer.H:339
std::vector< std::string > GetSpeciesAndLasersNames() const
Definition MultiParticleContainer.H:323
amrex::Vector< amrex::ParticleReal > h_repeated_plasma_lens_starts
Definition MultiParticleContainer.H:352
int m_qed_schwinger_threshold_poisson_gaussian
Definition MultiParticleContainer.H:517
std::vector< bool > m_gather_from_main_grid
instead of gathering fields from the finest patch level, gather from the coarsest
Definition MultiParticleContainer.H:419
void doQedEvents(int lev, const amrex::MultiFab &Ex, const amrex::MultiFab &Ey, const amrex::MultiFab &Ez, const amrex::MultiFab &Bx, const amrex::MultiFab &By, const amrex::MultiFab &Bz)
Performs QED events (Breit-Wheeler process and photon emission)
Definition MultiParticleContainer.cpp:1669
void DepositCharge(const ablastr::fields::MultiLevelScalarField &rho, amrex::Real relative_time)
Deposit charge density.
Definition MultiParticleContainer.cpp:620
void CheckQEDProductSpecies()
Definition MultiParticleContainer.cpp:1847
amrex::Real m_qed_schwinger_y_size
Definition MultiParticleContainer.H:512
amrex::Gpu::DeviceVector< amrex::ParticleReal > d_repeated_plasma_lens_strengths_E
Definition MultiParticleContainer.H:358
amrex::ParticleReal maxParticleVelocity()
Definition MultiParticleContainer.cpp:449
int nContainers() const
Definition MultiParticleContainer.H:268
std::unique_ptr< amrex::Parser > m_E_particle_from_file_parser
Definition MultiParticleContainer.H:345
void WriteHeader(std::ostream &os) const
Definition ParticleIO.cpp:242
std::string m_qed_schwinger_pos_product_name
Definition MultiParticleContainer.H:506
void Restart(const std::string &dir)
Definition ParticleIO.cpp:129
std::vector< std::string > GetSpeciesNames() const
Definition MultiParticleContainer.H:319
void ContinuousFluxInjection(amrex::Real t, amrex::Real dt) const
Definition MultiParticleContainer.cpp:937
int m_qed_schwinger_pos_product
Definition MultiParticleContainer.H:510
amrex::ParserExecutor< 1 > m_Efield_time_partparser
Definition MultiParticleContainer.H:347
amrex::MFItInfo getMFItInfo(const WarpXParticleContainer &pc_src, Args const &... pc_dsts) const noexcept
Definition MultiParticleContainer.H:425
MultiParticleContainer(amrex::AmrCore *amr_core)
Definition MultiParticleContainer.cpp:96
std::unique_ptr< amrex::Parser > m_B_particle_from_file_parser
Definition MultiParticleContainer.H:343
std::unique_ptr< amrex::Parser > m_Ez_particle_parser
Definition MultiParticleContainer.H:341
std::shared_ptr< QuantumSynchrotronEngine > m_shr_p_qs_engine
Definition MultiParticleContainer.H:447
~MultiParticleContainer()=default
std::vector< bool > m_deposit_on_main_grid
instead of depositing (current, charge) on the finest patch level, deposit to the coarsest grid
Definition MultiParticleContainer.H:415
void SetDoBackTransformedParticles(bool do_back_transformed_particles)
Definition MultiParticleContainer.cpp:1018
PCTypes
Definition MultiParticleContainer.H:406
@ RigidInjected
Definition MultiParticleContainer.H:406
@ Physical
Definition MultiParticleContainer.H:406
@ Photon
Definition MultiParticleContainer.H:406
std::unique_ptr< amrex::Parser > m_Bx_particle_parser
Definition MultiParticleContainer.H:335
void doQedBreitWheeler(int lev, const amrex::MultiFab &Ex, const amrex::MultiFab &Ey, const amrex::MultiFab &Ez, const amrex::MultiFab &Bx, const amrex::MultiFab &By, const amrex::MultiFab &Bz)
Performs Breit-Wheeler process for the species for which it is enabled.
Definition MultiParticleContainer.cpp:1683
Definition WarpXParticleContainer.H:195
constexpr auto c
vacuum speed of light [m/s]
Definition constant.H:149
constexpr auto m_e
electron mass [kg]
Definition constant.H:161
amrex::Vector< ScalarField > MultiLevelScalarField
Definition MultiFabRegister.H:200
amrex::Vector< VectorField > MultiLevelVectorField
Definition MultiFabRegister.H:208
bool notInLaunchRegion() noexcept
PODVector< T, ArenaAllocator< T > > DeviceVector
Definition ImplicitOptions.H:7
Definition MultiFabRegister.H:262
MFItInfo & SetDynamic(bool f) noexcept
MFItInfo & EnableTiling(const IntVect &ts=FabArrayBase::mfiter_tile_size) noexcept