WarpX
Loading...
Searching...
No Matches
WarpXParticleContainer.H
Go to the documentation of this file.
1/* Copyright 2019-2020 Andrew Myers, Axel Huebl, David Grote
2 * Jean-Luc Vay, Junmin Gu, Luca Fedeli
3 * Maxence Thevenet, Remi Lehe, Revathi Jambunathan
4 * Weiqun Zhang, Yinjian Zhao
5 *
6 * This file is part of WarpX.
7 *
8 * License: BSD-3-Clause-LBNL
9 */
10#ifndef WARPX_WarpXParticleContainer_H_
11#define WARPX_WarpXParticleContainer_H_
12
15
20
21#ifdef WARPX_QED
24#endif
26
29
31
32#include <AMReX_Array.H>
33#include <AMReX_FArrayBox.H>
34#include <AMReX_Geometry.H>
35#include <AMReX_GpuAllocators.H>
36#include <AMReX_GpuContainers.H>
37#include <AMReX_INT.H>
38#include <AMReX_ParIter.H>
39#include <AMReX_Particles.H>
40#include <AMReX_Random.H>
41#include <AMReX_REAL.H>
43#include <AMReX_Vector.H>
44
45#include <AMReX_BaseFwd.H>
46#include <AMReX_AmrCoreFwd.H>
47
48#include <array>
49#include <iosfwd>
50#include <map>
51#include <memory>
52#include <string>
53#include <utility>
54
64struct PIdx
65{
66#if defined(WARPX_DIM_1D_Z)
67 enum { z , w , ux , uy , uz, nattribs};
68 static constexpr auto names = {"z", "w", "ux", "uy", "uz"};
69#elif defined(WARPX_DIM_XZ)
70 enum { x , z , w , ux , uy , uz, nattribs};
71 static constexpr auto names = {"x", "z", "w", "ux", "uy", "uz"};
72#elif defined(WARPX_DIM_RZ)
73 enum { r , z , w , ux , uy , uz , theta, nattribs};
74 static constexpr auto names = {"r", "z", "w", "ux", "uy", "uz", "theta"};
75#elif defined(WARPX_DIM_RCYLINDER)
76 enum { r , w , ux , uy , uz , theta, nattribs};
77 static constexpr auto names = {"r", "w", "ux", "uy", "uz", "theta"};
78#elif defined(WARPX_DIM_RSPHERE)
79 enum { r , w , ux , uy , uz , theta , phi, nattribs};
80 static constexpr auto names = {"r", "w", "ux", "uy", "uz", "theta", "phi"};
81#elif defined(WARPX_DIM_3D)
82 enum { x , y, z, w, ux, uy, uz, nattribs};
83 static constexpr auto names = {"x", "y", "z", "w", "ux", "uy", "uz"};
84#else
85 #error WarpX dimension is not correctly set!
86#endif
87
88 static_assert(names.size() == nattribs);
89};
90
91
92struct IntIdx {
93 enum
94 {
96 };
97
98 static constexpr std::initializer_list<char const *> names = {};
99};
100
102{
103 enum {
104 w = 0,
105 x, y, z, ux, uy, uz,
107 };
108};
109
111 : public amrex::ParIterSoA<PIdx::nattribs, 0, amrex::PolymorphicArenaAllocator>
112{
113public:
115
116 WarpXParIter (ContainerType& pc, int level);
117
118 WarpXParIter (ContainerType& pc, int level, amrex::MFItInfo& info);
119
120 [[nodiscard]] const std::array<RealVector, PIdx::nattribs>& GetAttribs () const
121 {
122 return GetStructOfArrays().GetRealData();
123 }
124
125 [[nodiscard]] std::array<RealVector, PIdx::nattribs>& GetAttribs ()
126 {
127 return GetStructOfArrays().GetRealData();
128 }
129
130 [[nodiscard]] const RealVector& GetAttribs (int comp) const
131 {
132 return GetStructOfArrays().GetRealData(comp);
133 }
134
135 [[nodiscard]] RealVector& GetAttribs (int comp)
136 {
137 return GetStructOfArrays().GetRealData(comp);
138 }
139
140 [[nodiscard]] const IntVector& GetiAttribs (int comp) const
141 {
142 return GetStructOfArrays().GetIntData(comp);
143 }
144
145 [[nodiscard]] IntVector& GetiAttribs (int comp)
146 {
147 return GetStructOfArrays().GetIntData(comp);
148 }
149
150 [[nodiscard]] const RealVector& GetAttribs (const std::string& name) const
151 {
152 return GetStructOfArrays().GetRealData(name);
153 }
154
155 [[nodiscard]] RealVector& GetAttribs (const std::string& name)
156 {
157 return GetStructOfArrays().GetRealData(name);
158 }
159
160 [[nodiscard]] const IntVector& GetiAttribs (const std::string& name) const
161 {
162 return GetStructOfArrays().GetIntData(name);
163 }
164
165 [[nodiscard]] IntVector& GetiAttribs (const std::string& name)
166 {
167 return GetStructOfArrays().GetIntData(name);
168 }
169};
170
194 : public amrex::ParticleContainerPureSoA<PIdx::nattribs, 0, amrex::PolymorphicArenaAllocator>
195{
196public:
198
200
201 // amrex::StructOfArrays with DiagIdx::nattribs amrex::ParticleReal components
202 // and 0 int components for the particle data.
204 // DiagnosticParticles is a vector, with one element per MR level.
205 // DiagnosticParticles[lev] is typically a key-value pair where the key is
206 // a pair [grid_index, tile_index], and the value is the corresponding
207 // DiagnosticParticleData (see above) on this tile.
209
210 WarpXParticleContainer (amrex::AmrCore* amr_core, int ispecies, const std::string& name);
211 ~WarpXParticleContainer() override = default;
212
213 // Move and copy operations
218
219 virtual void InitData () = 0;
220
221 virtual void InitIonizationModule () {}
222
223 /*
224 * \brief Virtual function that returns a pointer to the plasma injector,
225 * for derived classes that define one (PhysicalParticleContainer).
226 */
227 virtual PlasmaInjector* GetPlasmaInjector (const int /*i*/) { return nullptr; }
228
233 int lev,
234 const std::string& current_fp_string,
235 amrex::Real t, amrex::Real dt, SubcyclingHalf subcycling_half=SubcyclingHalf::None, bool skip_deposition=false,
236 PositionPushType position_push_type=PositionPushType::Full,
237 MomentumPushType momentum_push_type=MomentumPushType::Full,
238 ImplicitOptions const * implicit_options = nullptr) = 0;
239
254 virtual void FinishImplicitParticleUpdate (
256 int lev, amrex::Real t, amrex::Real dt);
257
262 int lev,
263 amrex::Real dt)
264 {
266 }
267
268 virtual void PostRestart () = 0;
269
270 virtual void AllocData ();
271
278 int n_external_attr_real,
279 int n_external_attr_int) = 0;
280
286 void PushX ( amrex::Real dt);
287 void PushX (int lev, amrex::Real dt);
288
292 virtual void PushP (int lev, amrex::Real dt,
293 const amrex::MultiFab& Ex,
294 const amrex::MultiFab& Ey,
295 const amrex::MultiFab& Ez,
296 const amrex::MultiFab& Bx,
297 const amrex::MultiFab& By,
298 const amrex::MultiFab& Bz,
299 MomentumPushType momentum_push_type = MomentumPushType::Full) = 0;
300
313 amrex::Real dt, amrex::Real relative_time);
314
326 void DepositCurrent (const std::string& mf_name, int lev,
327 amrex::Real dt, amrex::Real relative_time);
328
341 bool local = false, bool reset = false,
342 bool apply_boundary_and_scale_volume = false,
343 bool interpolate_across_levels = true,
344 int icomp = 0);
345 void DepositCharge (amrex::MultiFab* rho, int lev,
346 bool local = false, bool reset = false,
347 bool apply_boundary_and_scale_volume = false,
348 int icomp = 0);
349
350 std::unique_ptr<amrex::MultiFab> GetChargeDensity(int lev, bool local = false);
351
352 virtual void DepositCharge (WarpXParIter& pti,
353 RealVector const & wp,
354 const int* ion_lev,
355 amrex::MultiFab* rho,
356 int icomp,
357 long offset,
358 long np_to_deposit,
359 int thread_num,
360 int lev,
361 int depos_lev);
362
363 virtual void DepositCurrent (WarpXParIter& pti,
364 RealVector const & wp,
365 RealVector const & uxp,
366 RealVector const & uyp,
367 RealVector const & uzp,
368 int const* ion_lev,
369 amrex::MultiFab* jx,
370 amrex::MultiFab* jy,
371 amrex::MultiFab* jz,
372 long offset,
373 long np_to_deposit,
374 int thread_num,
375 int lev,
376 int depos_lev,
377 amrex::Real dt,
378 amrex::Real relative_time,
379 PushType push_type);
391 [[maybe_unused]]ablastr::fields::MultiLevelVectorField const & T_vf,
392 [[maybe_unused]]amrex::Real relative_time)
393 {}
394
395 virtual void DepositTemperature (
396 [[maybe_unused]]WarpXParIter& pti,
397 [[maybe_unused]]RealVector const & wp,
398 [[maybe_unused]]RealVector const & uxp,
399 [[maybe_unused]]RealVector const & uyp,
400 [[maybe_unused]]RealVector const & uzp,
401 [[maybe_unused]]amrex::MultiFab * const Tx,
402 [[maybe_unused]]amrex::MultiFab * const Ty,
403 [[maybe_unused]]amrex::MultiFab * const Tz,
404 [[maybe_unused]]long const offset,
405 [[maybe_unused]]long const np_to_deposit,
406 [[maybe_unused]]int const thread_num,
407 [[maybe_unused]]const int lev,
408 [[maybe_unused]]int const depos_lev,
409 [[maybe_unused]]amrex::Real const relative_time,
410 [[maybe_unused]]PushType push_type,
413 {}
414
415 void DepositTotalNGPTemperature (int lev);
416 void CalculateNuei(amrex::MultiFab & species_nuei,
417 WarpXParticleContainer const & electron_species, int lev);
418 std::unique_ptr<amrex::MultiFab> GetDebyeLength (int lev);
419
420 void DepositNumberDensity (amrex::MultiFab* number_density, int lev);
421 std::unique_ptr<amrex::MultiFab> GetNumberDensity (int lev);
422
423 std::unique_ptr<amrex::MultiFab> GetPlasmaFrequency (int lev);
424
426 const RealVector& wp,
427 const RealVector& uxp,
428 const RealVector& uyp,
429 const RealVector& uzp,
430 amrex::MultiFab* Sxx,
431 amrex::MultiFab* Sxy,
432 amrex::MultiFab* Sxz,
433 amrex::MultiFab* Syx,
434 amrex::MultiFab* Syy,
435 amrex::MultiFab* Syz,
436 amrex::MultiFab* Szx,
437 amrex::MultiFab* Szy,
438 amrex::MultiFab* Szz,
439 const amrex::FArrayBox* bxfab,
440 const amrex::FArrayBox* byfab,
441 const amrex::FArrayBox* bzfab,
442 long offset,
443 long np_to_deposit,
444 int thread_num,
445 int lev,
446 int depos_lev,
447 amrex::Real dt);
448
449 // If particles start outside of the domain, ContinuousInjection
450 // makes sure that they are initialized when they enter the domain, and
451 // NOT before. Virtual function, overriden by derived classes.
452 // Current status:
453 // PhysicalParticleContainer: implemented.
454 // LaserParticleContainer: implemented.
455 // RigidInjectedParticleContainer: not implemented.
456 virtual void ContinuousInjection(const amrex::RealBox& /*injection_box*/) {}
457
462 virtual void UpdateAntennaPosition(const amrex::Real /*dt*/) {}
463
465
466 // Inject a continuous flux of particles from a defined plane
467 virtual void ContinuousFluxInjection(amrex::Real /*t*/, amrex::Real /*dt*/) {}
468
469 int getSpeciesId() const {return species_id;}
470
475 std::pair<amrex::ParticleReal, amrex::ParticleReal> sumParticleWeightAndEnergy (bool local = false) const;
476 amrex::ParticleReal sumParticleCharge (bool local = false) const;
477 amrex::ParticleReal sumParticleWeight (bool local = false) const;
478 amrex::ParticleReal sumParticleEnergy (bool local = false) const;
479
480 std::array<amrex::ParticleReal, 3> meanParticleVelocity(bool local = false);
481
482 amrex::ParticleReal maxParticleVelocity(bool local = false);
483
494 void TransformMomentumToCurvilinear (bool forward);
495
520 void AddNParticles (int lev, long n,
527 int nattr_real,
529 int nattr_int, amrex::Vector<amrex::Vector<int>> const & attr_int,
530 int uniqueparticles, amrex::Long id=-1);
531
538
539 virtual void ReadHeader (std::istream& is) = 0;
540
541 virtual void WriteHeader (std::ostream& os) const = 0;
542
543 static void ReadParameters ();
544
545 static void BackwardCompatibility ();
546
550
551 bool do_splitting = false;
558
559 // External fields added to particle fields.
562
565
566 // split along diagonals (0) or axes (1)
567 int split_type = 0;
568
573 void SetDoBackTransformedParticles (const bool do_back_transformed_particles) {
574 m_do_back_transformed_particles = do_back_transformed_particles;
575 }
576
580
582
584
586
587#ifdef WARPX_QED
588 //Species for which QED effects are relevant should override these methods
589 virtual bool has_quantum_sync() const {return false;}
590 virtual bool has_breit_wheeler() const {return false;}
591 virtual bool has_virtual_photons() const {return false;}
592 virtual bool has_virtual_photons_beam_size_effect() const {return false;}
593 virtual int getVirtualPhotonSpeciesIndex() const { return -1; }
594 int DoQED() const { return has_quantum_sync() || has_breit_wheeler(); }
595#else
596 int DoQED() const { return false; }
597#endif
598
599 /* \brief This function tests if the current species
600 * is of a given PhysicalSpecies (specified as a template parameter).
601 * @tparam PhysSpec the PhysicalSpecies to test against
602 * @return the result of the test
603 */
604 template<PhysicalSpecies PhysSpec>
605 bool AmIA () const noexcept {return (physical_species == PhysSpec);}
606
611
618 virtual void resample (const amrex::Vector<amrex::Geometry>& /*geom*/, const int /*timestep*/, bool /*verbose*/) {}
619
626 void defineAllParticleTiles () noexcept;
627
628 virtual std::vector<std::string> getUserIntAttribs () const { return std::vector<std::string>{}; }
629
630 virtual std::vector<std::string> getUserRealAttribs () const { return std::vector<std::string>{}; }
631
633
635
636#ifdef WARPX_QED
637 virtual BreitWheelerEngine* get_breit_wheeler_engine_ptr () const {return nullptr;}
638 virtual QuantumSynchrotronEngine* get_quantum_sync_engine_ptr () const {return nullptr;}
639#endif
640
641 void setDoNotPush (bool flag) { do_not_push = flag; }
642 void setDoNotGather (int flag) { do_not_gather = flag; }
643 void setDoNotDeposit (int flag) { do_not_deposit = flag; }
644
645 bool HasiAttrib (const std::string& name)
646 {
647 std::vector<std::string> const & int_names = GetIntSoANames();
648 auto const pos = std::find(int_names.begin(), int_names.end(), name);
649 return (pos != int_names.end());
650 }
651
652 std::string const & getName() { return species_name; }
653
654protected:
656 std::string species_name;
657
661
662 // Controls boundaries for particles exiting the domain
664
665 // Controls whether particle trajectoris are cropped when particles
666 // cross a PEC boundary
668
671
674
675 bool do_not_push = false;
677
678 // Whether to allow particles outside of the simulation domain to be
679 // initialized when they enter the domain.
680 // This is currently required because continuous injection does not
681 // support all features allowed by direct injection.
683
696 std::string physical_element;
697
699
702
703#ifdef WARPX_QED
704 //Species can receive a shared pointer to a QED engine (species for
705 //which this is relevant should override these functions)
706 virtual void
707 set_breit_wheeler_engine_ptr(const std::shared_ptr<BreitWheelerEngine>&){}
708 virtual void
709 set_quantum_sync_engine_ptr(const std::shared_ptr<QuantumSynchrotronEngine>&){}
710
720#endif
725
726 // local containers for mass matrix deposit used by implicit solvers
736
737public:
738
740
741 // By default this returns false, can be overridden in PysicalParticleContainer
742 virtual bool getTemperatureDepositionFlag () const noexcept {return false;}
743
744private:
745 void particlePostLocate(ParticleType& p, const amrex::ParticleLocData& pld, int lev) override;
746
747};
748
749#endif
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:180
@ Full
Definition WarpXAlgorithmSelection.H:180
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:274
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
Definition WarpXParticleContainer.H:195
amrex::Real self_fields_required_precision
Definition WarpXParticleContainer.H:554
amrex::ParticleReal sumParticleCharge(bool local=false) const
Definition WarpXParticleContainer.cpp:2519
virtual void Evolve(ablastr::fields::MultiFabRegister &fields, int lev, const std::string &current_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:682
amrex::Vector< amrex::FArrayBox > local_Szy
Definition WarpXParticleContainer.H:734
virtual amrex::Vector< amrex::Parser * > getUserIntAttribParser() const
Definition WarpXParticleContainer.H:632
amrex::Vector< amrex::FArrayBox > local_Sxy
Definition WarpXParticleContainer.H:728
void DepositTotalNGPTemperature(int lev)
Definition WarpXParticleContainer.cpp:1932
~WarpXParticleContainer() override=default
WarpXParticleContainer(amrex::AmrCore *amr_core, int ispecies, const std::string &name)
Definition WarpXParticleContainer.cpp:94
bool AmIA() const noexcept
Definition WarpXParticleContainer.H:605
amrex::Vector< amrex::FArrayBox > local_Syx
Definition WarpXParticleContainer.H:730
amrex::Vector< amrex::FArrayBox > local_Szz
Definition WarpXParticleContainer.H:735
amrex::Vector< amrex::ParticleReal > m_B_external_particle
Definition WarpXParticleContainer.H:560
amrex::ParticleContainerPureSoA< PIdx::nattribs, 0, amrex::PolymorphicArenaAllocator > Base
Definition WarpXParticleContainer.H:199
void CalculateNuei(amrex::MultiFab &species_nuei, WarpXParticleContainer const &electron_species, int lev)
Definition WarpXParticleContainer.cpp:2202
amrex::Vector< amrex::FArrayBox > local_Sxx
Definition WarpXParticleContainer.H:727
bool m_gather_from_main_grid
instead of gathering fields from the finest patch level, gather from the coarsest
Definition WarpXParticleContainer.H:673
virtual void AllocData()
Definition WarpXParticleContainer.cpp:174
void defineAllParticleTiles() noexcept
Definition WarpXParticleContainer.cpp:2802
std::pair< amrex::ParticleReal, amrex::ParticleReal > sumParticleWeightAndEnergy(bool local=false) const
Definition WarpXParticleContainer.cpp:2453
virtual void PostRestart()=0
void particlePostLocate(ParticleType &p, const amrex::ParticleLocData &pld, int lev) override
Definition WarpXParticleContainer.cpp:2817
virtual void ReadHeader(std::istream &is)=0
int self_fields_max_iters
Definition WarpXParticleContainer.H:556
amrex::Real m_current_injection_position
Current injection position.
Definition WarpXParticleContainer.H:564
int species_id
Definition WarpXParticleContainer.H:655
virtual bool getTemperatureDepositionFlag() const noexcept
Definition WarpXParticleContainer.H:742
std::string m_qed_breit_wheeler_ele_product_name
Definition WarpXParticleContainer.H:712
virtual void WriteHeader(std::ostream &os) const =0
amrex::Gpu::DeviceVector< amrex::Real > adk_exp_prefactor
Definition WarpXParticleContainer.H:693
int do_adk_correction
Definition WarpXParticleContainer.H:685
amrex::Gpu::DeviceVector< amrex::Real > adk_power
Definition WarpXParticleContainer.H:691
PhysicalSpecies physical_species
Definition WarpXParticleContainer.H:660
amrex::ParticleReal m_charge
Definition WarpXParticleContainer.H:658
bool do_not_push
Definition WarpXParticleContainer.H:675
std::unique_ptr< amrex::MultiFab > GetPlasmaFrequency(int lev)
Definition WarpXParticleContainer.cpp:2409
std::unique_ptr< amrex::MultiFab > GetDebyeLength(int lev)
Definition WarpXParticleContainer.cpp:2103
bool HasiAttrib(const std::string &name)
Definition WarpXParticleContainer.H:645
virtual void ContinuousFluxInjection(amrex::Real, amrex::Real)
Definition WarpXParticleContainer.H:467
virtual std::vector< std::string > getUserIntAttribs() const
Definition WarpXParticleContainer.H:628
std::string getSpeciesTypeName() const
This function returns a string containing the name of the species type.
Definition WarpXParticleContainer.H:610
int m_qed_quantum_sync_phot_product
Definition WarpXParticleContainer.H:715
amrex::ParticleReal maxParticleVelocity(bool local=false)
Definition WarpXParticleContainer.cpp:2610
virtual void InitIonizationModule()
Definition WarpXParticleContainer.H:221
virtual void InitData()=0
amrex::Gpu::DeviceVector< amrex::Real > adk_prefactor
Definition WarpXParticleContainer.H:692
void SetDoBackTransformedParticles(const bool do_back_transformed_particles)
Definition WarpXParticleContainer.H:573
virtual void DefaultInitializeRuntimeAttributes(typename ContainerLike< amrex::PolymorphicArenaAllocator >::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_Syy
Definition WarpXParticleContainer.H:731
int ionization_initial_level
Definition WarpXParticleContainer.H:689
virtual QuantumSynchrotronEngine * get_quantum_sync_engine_ptr() const
Definition WarpXParticleContainer.H:638
amrex::Real self_fields_absolute_tolerance
Definition WarpXParticleContainer.H:555
amrex::Vector< amrex::FArrayBox > local_jx
Definition WarpXParticleContainer.H:722
std::string m_qed_virtual_photon_species_name
Definition WarpXParticleContainer.H:718
void setDoNotDeposit(int flag)
Definition WarpXParticleContainer.H:643
virtual void set_breit_wheeler_engine_ptr(const std::shared_ptr< BreitWheelerEngine > &)
Definition WarpXParticleContainer.H:707
amrex::Vector< amrex::FArrayBox > local_Syz
Definition WarpXParticleContainer.H:732
void DepositCurrent(ablastr::fields::MultiLevelVectorField const &J, amrex::Real dt, amrex::Real relative_time)
Deposit current density.
Definition WarpXParticleContainer.cpp:1417
virtual bool has_virtual_photons() const
Definition WarpXParticleContainer.H:591
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:462
virtual std::vector< std::string > getUserRealAttribs() const
Definition WarpXParticleContainer.H:630
bool doContinuousInjection() const
Definition WarpXParticleContainer.H:464
bool GetDoBackTransformedParticles() const
Definition WarpXParticleContainer.H:577
amrex::StructOfArrays< DiagIdx::nattribs, 0 > DiagnosticParticleData
Definition WarpXParticleContainer.H:203
amrex::Vector< amrex::FArrayBox > local_jy
Definition WarpXParticleContainer.H:723
std::unique_ptr< amrex::MultiFab > GetChargeDensity(int lev, bool local=false)
Definition WarpXParticleContainer.cpp:1902
static void ReadParameters()
Definition WarpXParticleContainer.cpp:161
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, MomentumPushType momentum_push_type=MomentumPushType::Full)=0
int getIonizationInitialLevel() const noexcept
Definition WarpXParticleContainer.H:739
virtual BreitWheelerEngine * get_breit_wheeler_engine_ptr() const
Definition WarpXParticleContainer.H:637
amrex::Gpu::DeviceVector< amrex::Real > adk_correction_factors
Definition WarpXParticleContainer.H:695
int ion_atomic_number
Definition WarpXParticleContainer.H:688
bool m_do_back_transformed_particles
Definition WarpXParticleContainer.H:701
amrex::Vector< amrex::FArrayBox > local_jz
Definition WarpXParticleContainer.H:724
amrex::Gpu::DeviceVector< amrex::Real > ionization_energies
Definition WarpXParticleContainer.H:690
amrex::ParticleReal getCharge() const
Definition WarpXParticleContainer.H:581
std::unique_ptr< amrex::MultiFab > GetNumberDensity(int lev)
Definition WarpXParticleContainer.cpp:2393
amrex::Vector< amrex::FArrayBox > local_Szx
Definition WarpXParticleContainer.H:733
bool m_crop_on_PEC_boundary
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:395
void TransformMomentumToCurvilinear(bool forward)
Map the momentum of the particles to and from the curvilinear frame. This is equivalent to mapping to...
Definition WarpXParticleContainer.cpp:2651
virtual void DepositMassMatrices(ablastr::fields::MultiFabRegister &fields, int lev, amrex::Real dt)
virtual function to deposit mass matrices for charged particles
Definition WarpXParticleContainer.H:261
WarpXParticleContainer & operator=(WarpXParticleContainer &&)=default
void ApplyBoundaryConditions()
Apply particle BC.
Definition WarpXParticleContainer.cpp:2839
virtual bool has_breit_wheeler() const
Definition WarpXParticleContainer.H:590
std::string m_qed_breit_wheeler_pos_product_name
Definition WarpXParticleContainer.H:714
virtual void FinishImplicitParticleUpdate(ablastr::fields::MultiFabRegister &fields, int lev, amrex::Real t, amrex::Real dt)
Finish the implicit particle update at the end of a time step.
Definition WarpXParticleContainer.cpp:2909
std::string m_qed_quantum_sync_phot_product_name
Definition WarpXParticleContainer.H:716
virtual void ContinuousInjection(const amrex::RealBox &)
Definition WarpXParticleContainer.H:456
WarpXParticleContainer & operator=(const WarpXParticleContainer &)=delete
ParticleBoundaries m_boundary_conditions
Definition WarpXParticleContainer.H:663
virtual void resample(const amrex::Vector< amrex::Geometry > &, const int, bool)
Virtual method to resample the species. Overriden by PhysicalParticleContainer only....
Definition WarpXParticleContainer.H:618
int m_qed_breit_wheeler_pos_product
Definition WarpXParticleContainer.H:713
std::string species_name
Definition WarpXParticleContainer.H:656
int ionization_product
Definition WarpXParticleContainer.H:686
int m_qed_virtual_photon_species
Definition WarpXParticleContainer.H:717
amrex::Real m_qed_virtual_photon_min_energy
Definition WarpXParticleContainer.H:719
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:183
int m_qed_breit_wheeler_ele_product
Definition WarpXParticleContainer.H:711
bool do_splitting
Definition WarpXParticleContainer.H:551
virtual void set_quantum_sync_engine_ptr(const std::shared_ptr< QuantumSynchrotronEngine > &)
Definition WarpXParticleContainer.H:709
std::array< amrex::ParticleReal, 3 > meanParticleVelocity(bool local=false)
Definition WarpXParticleContainer.cpp:2524
std::string const & getName()
Definition WarpXParticleContainer.H:652
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:390
bool initialize_self_fields
Definition WarpXParticleContainer.H:553
int self_fields_verbosity
Definition WarpXParticleContainer.H:557
virtual bool has_quantum_sync() const
Definition WarpXParticleContainer.H:589
std::string physical_element
Definition WarpXParticleContainer.H:696
void deleteInvalidParticles()
Definition WarpXParticleContainer.cpp:357
int split_type
Definition WarpXParticleContainer.H:567
virtual amrex::Vector< amrex::Parser * > getUserRealAttribParser() const
Definition WarpXParticleContainer.H:634
amrex::Vector< amrex::FArrayBox > local_Sxz
Definition WarpXParticleContainer.H:729
amrex::ParticleReal sumParticleEnergy(bool local=false) const
Definition WarpXParticleContainer.cpp:2507
void PushX(amrex::Real dt)
Definition WarpXParticleContainer.cpp:2732
WarpXParticleContainer(WarpXParticleContainer &&)=default
virtual PlasmaInjector * GetPlasmaInjector(const int)
Definition WarpXParticleContainer.H:227
friend MultiParticleContainer
Definition WarpXParticleContainer.H:197
amrex::Vector< amrex::ParticleReal > m_E_external_particle
Definition WarpXParticleContainer.H:561
std::string ionization_product_name
Definition WarpXParticleContainer.H:687
amrex::ParticleReal m_mass
Definition WarpXParticleContainer.H:659
int getSpeciesId() const
Definition WarpXParticleContainer.H:469
int DoFieldIonization() const
Definition WarpXParticleContainer.H:585
virtual bool has_virtual_photons_beam_size_effect() const
Definition WarpXParticleContainer.H:592
int do_not_deposit
Definition WarpXParticleContainer.H:552
void setDoNotPush(bool flag)
Definition WarpXParticleContainer.H:641
WarpXParticleContainer(const WarpXParticleContainer &)=delete
amrex::ParticleReal getMass() const
Definition WarpXParticleContainer.H:583
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:1793
void setDoNotGather(int flag)
Definition WarpXParticleContainer.H:642
amrex::ParticleReal sumParticleWeight(bool local=false) const
Definition WarpXParticleContainer.cpp:2513
virtual int getVirtualPhotonSpeciesIndex() const
Definition WarpXParticleContainer.H:593
amrex::Vector< std::map< std::pair< int, int >, DiagnosticParticleData > > DiagnosticParticles
Definition WarpXParticleContainer.H:208
int DoQED() const
Definition WarpXParticleContainer.H:594
int do_resampling
Definition WarpXParticleContainer.H:698
int do_not_gather
Definition WarpXParticleContainer.H:676
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:670
amrex::Vector< amrex::FArrayBox > local_rho
Definition WarpXParticleContainer.H:721
int do_field_ionization
Definition WarpXParticleContainer.H:684
void DepositNumberDensity(amrex::MultiFab *number_density, int lev)
Definition WarpXParticleContainer.cpp:2335
SoARef GetStructOfArrays() const
ParticleContainer_impl< ParticleType, NArrayReal, NArrayInt, Allocator, CellAssignor > ContainerType
std::conditional_t< is_rtsoa_pc, ParticleTileRT< typename ParticleType::RealType, typename ParticleType::IntType >, ParticleTile< ParticleType, NArrayReal, NArrayInt, Allocator > > ParticleTileType
amrex_real Real
amrex_particle_real ParticleReal
amrex_long Long
PODVector< T, ArenaAllocator< T > > DeviceVector
Definition EffectivePotentialPoissonSolver.H:63
amrex::Vector< ScalarField > MultiLevelScalarField
Definition MultiFabRegister.H:210
amrex::Vector< VectorField > MultiLevelVectorField
Definition MultiFabRegister.H:218
__host__ __device__ void ignore_unused(const Ts &...)
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:291
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
@ nattribs
the number of attributes above (always last)
Definition WarpXParticleContainer.H:95
static constexpr std::initializer_list< char const * > names
Definition WarpXParticleContainer.H:98
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:272