aboutsummaryrefslogtreecommitdiff
path: root/Source/Particles/WarpXParticleContainer.H
diff options
context:
space:
mode:
authorGravatar Remi Lehe <remi.lehe@normalesup.org> 2021-06-28 16:09:04 -0700
committerGravatar GitHub <noreply@github.com> 2021-06-28 16:09:04 -0700
commit16d1ca457abaa8d057018b69adaa1c3b54d6f995 (patch)
tree29618ee601b824210035e022c1c38a76bed1c0be /Source/Particles/WarpXParticleContainer.H
parenta0ee8d81410833fe6480d3303eaa889708659bf7 (diff)
downloadWarpX-16d1ca457abaa8d057018b69adaa1c3b54d6f995.tar.gz
WarpX-16d1ca457abaa8d057018b69adaa1c3b54d6f995.tar.zst
WarpX-16d1ca457abaa8d057018b69adaa1c3b54d6f995.zip
Multi-J scheme (#1828)
* Introduce new option skip_deposition * Properly implement the option to skip deposition * Skip deposition for electrostatic solver * Correct typo * Add Index Enumerator and Equations for F/G Without Averaging * Define new functions for current deposition and charge deposition * Disable interpolation between levels * Correct compilation error in RZ mode * Add argument for relative time * Add Index Enumerator and Equations for F/G With Averaging * [skip ci] Add new OneStep function * Fix compilation errors * Correct more compilation errors * [skip ci] Fix compilation * Split the PSATD push into separate functions * Add guards for rho field * [skip ci] Use new functions in OneStep * [skip ci] Separate the inverse transform of E_avg, B_avg * Add deposition of rho * [skip ci] Prevent deposition of rho if unallocated * Fix error in deposition function * Add subcycling of current deposition * [skip ci] Add inverse transform of averaged fields * [skip ci] Move component of rho * Add function to copy J * Temporarily deactivate contribution from F * [skip ci] Implement call to linear in J * Add psatd time averaging for multiJ * [skip ci] Fix implementation of averaging * [skip ci] Implement divE cleaning * Fix Bug for RZ Builds * Fix Bug for RZ Builds * Fix Bug in Init of PML Spectral Solvers * Cleaning * Cleaning * Add div(B) Cleaning (G Equation) * Multi-J Not Implemented with Galilean PSATD or PMLs * Add 2D CI Test Using Multi-J Scheme * Add More Inline Comments * Add More Inline Comments & Doxygen * Add Doxygen for Constructor of SpectralSolver * More Doxygen in Class SpectralSolver * Add Doxygen for New Functions in WarpXPushFieldsEM.cpp * Add Doxygen for New Functions in WarpX/MultiParticleContainer * do_dive/b_cleaning Must Be True With linear_in_J Option * Cast multij_n_depose to Real in Divisions * New Input Syntax * Add const where Possible, Fix Warnings * Docs for New Input Syntax, Fix Abort Messages * Consistent Use of Idx, IdxAvg, IdxLin * Improve Documentation of psatd.J_linear_in_time * Use const Type Qualifier whenever Possible * Simplify Initialization of Pointer ion_lev * Improve Doxygen * Update documentation * Add Note on NCI to Docs * Make warpx.do_multi_J_n_depositions Not Optional * Simplify Logic in getRequiredNumberOfFields * Use More const Type Qualifiers Co-authored-by: Edoardo Zoni <ezoni@lbl.gov>
Diffstat (limited to 'Source/Particles/WarpXParticleContainer.H')
-rw-r--r--Source/Particles/WarpXParticleContainer.H36
1 files changed, 33 insertions, 3 deletions
diff --git a/Source/Particles/WarpXParticleContainer.H b/Source/Particles/WarpXParticleContainer.H
index cde77dc74..1f3551c7b 100644
--- a/Source/Particles/WarpXParticleContainer.H
+++ b/Source/Particles/WarpXParticleContainer.H
@@ -206,9 +206,39 @@ public:
const amrex::MultiFab& By,
const amrex::MultiFab& Bz) = 0;
- void DepositCharge(amrex::Vector<std::unique_ptr<amrex::MultiFab> >& rho,
- bool local = false, bool reset = false,
- bool do_rz_volume_scaling = false );
+ /**
+ * \brief Deposit current density.
+ *
+ * \param[in,out] J vector of current densities (one three-dimensional array of pointers
+ * to MultiFabs per mesh refinement level)
+ * \param[in] dt: Time step for particle level (is used when temporarily
+ * modifying the particle positions, either within the
+ * Esirkepov or when `relative_t` is different than 0
+ * \param[in] relative_t: Time at which to deposit J, relative to the time
+ * of the current positions of the particles (expressed as
+ * a fraction of dt). When different than 0, the particle
+ * position will be temporarily modified to match the
+ * time of the deposition.
+ */
+ void DepositCurrent (amrex::Vector<std::array< std::unique_ptr<amrex::MultiFab>, 3 > >& J,
+ const amrex::Real dt, const amrex::Real relative_t);
+
+ /**
+ * \brief Deposit charge density.
+ *
+ * \param[in,out] rho vector of charge densities (one pointer to MultiFab per mesh refinement level)
+ * \param[in] local if false, exchange the data in the guard cells after the deposition
+ * \param[in] reset if true, reset all values of rho to zero
+ * \param[in] do_rz_volume_scaling whether to scale the final density by some volume norm in RZ geometry
+ * \param[in] interpolate_across_levels whether to average down from the fine patch to the coarse patch
+ * \param[in] icomp component of the MultiFab where rho is deposited (old, new)
+ */
+ void DepositCharge (amrex::Vector<std::unique_ptr<amrex::MultiFab> >& rho,
+ const bool local = false, const bool reset = false,
+ const bool do_rz_volume_scaling = false,
+ const bool interpolate_across_levels = true,
+ const int icomp = 0);
+
std::unique_ptr<amrex::MultiFab> GetChargeDensity(int lev, bool local = false);
virtual void DepositCharge (WarpXParIter& pti,