aboutsummaryrefslogtreecommitdiff
path: root/Source/FieldSolver/FiniteDifferenceSolver
diff options
context:
space:
mode:
authorGravatar Axel Huebl <axel.huebl@plasma.ninja> 2021-06-16 17:48:06 -0700
committerGravatar GitHub <noreply@github.com> 2021-06-16 17:48:06 -0700
commit495d0520b4020a3c59df9b372f02d989a7180b31 (patch)
treecf18944a2f27ed2b4be0407ef1b9eba9c77d8e1d /Source/FieldSolver/FiniteDifferenceSolver
parentf1a0d49cc0ff8ac15cb128a09d8c3256eb259eb3 (diff)
downloadWarpX-495d0520b4020a3c59df9b372f02d989a7180b31.tar.gz
WarpX-495d0520b4020a3c59df9b372f02d989a7180b31.tar.zst
WarpX-495d0520b4020a3c59df9b372f02d989a7180b31.zip
Silver-Mueller: Avoid Managed Memory (#2019)
Avoid relying on managed memory usage in Silver-Mueller boundary conditions. Previously, we initialized the coefficients on the host, copied them to device and then accidentially used the device memory on the host again, as we calculated some constants. This now keeps the initial host-memory around so we can use it for host-only operations.
Diffstat (limited to 'Source/FieldSolver/FiniteDifferenceSolver')
-rw-r--r--Source/FieldSolver/FiniteDifferenceSolver/ApplySilverMuellerBoundary.cpp12
-rw-r--r--Source/FieldSolver/FiniteDifferenceSolver/FiniteDifferenceSolver.H6
-rw-r--r--Source/FieldSolver/FiniteDifferenceSolver/FiniteDifferenceSolver.cpp32
3 files changed, 26 insertions, 24 deletions
diff --git a/Source/FieldSolver/FiniteDifferenceSolver/ApplySilverMuellerBoundary.cpp b/Source/FieldSolver/FiniteDifferenceSolver/ApplySilverMuellerBoundary.cpp
index 1a4aa10b2..a7258da09 100644
--- a/Source/FieldSolver/FiniteDifferenceSolver/ApplySilverMuellerBoundary.cpp
+++ b/Source/FieldSolver/FiniteDifferenceSolver/ApplySilverMuellerBoundary.cpp
@@ -35,17 +35,17 @@ void FiniteDifferenceSolver::ApplySilverMuellerBoundary (
#ifdef WARPX_DIM_RZ
// Calculate relevant coefficients
amrex::Real const cdt = PhysConst::c*dt;
- amrex::Real const cdt_over_dr = cdt*m_stencil_coefs_r[0];
+ amrex::Real const cdt_over_dr = cdt*m_h_stencil_coefs_r[0];
amrex::Real const coef1_r = (1._rt - cdt_over_dr)/(1._rt + cdt_over_dr);
amrex::Real const coef2_r = 2._rt*cdt_over_dr/(1._rt + cdt_over_dr) / PhysConst::c;
amrex::Real const coef3_r = cdt/(1._rt + cdt_over_dr) / PhysConst::c;
- amrex::Real const cdt_over_dz = cdt*m_stencil_coefs_z[0];
+ amrex::Real const cdt_over_dz = cdt*m_h_stencil_coefs_z[0];
amrex::Real const coef1_z = (1._rt - cdt_over_dz)/(1._rt + cdt_over_dz);
amrex::Real const coef2_z = 2._rt*cdt_over_dz/(1._rt + cdt_over_dz) / PhysConst::c;
// Extract stencil coefficients
Real const * const AMREX_RESTRICT coefs_z = m_stencil_coefs_z.dataPtr();
- int const n_coefs_z = m_stencil_coefs_z.size();
+ int const n_coefs_z = m_h_stencil_coefs_z.size();
// Extract cylindrical specific parameters
Real const dr = m_dr;
@@ -143,15 +143,15 @@ void FiniteDifferenceSolver::ApplySilverMuellerBoundary (
#else
// Calculate relevant coefficients
- amrex::Real const cdt_over_dx = PhysConst::c*dt*m_stencil_coefs_x[0];
+ amrex::Real const cdt_over_dx = PhysConst::c*dt*m_h_stencil_coefs_x[0];
amrex::Real const coef1_x = (1._rt - cdt_over_dx)/(1._rt + cdt_over_dx);
amrex::Real const coef2_x = 2._rt*cdt_over_dx/(1._rt + cdt_over_dx) / PhysConst::c;
#ifdef WARPX_DIM_3D
- amrex::Real const cdt_over_dy = PhysConst::c*dt*m_stencil_coefs_y[0];
+ amrex::Real const cdt_over_dy = PhysConst::c*dt*m_h_stencil_coefs_y[0];
amrex::Real const coef1_y = (1._rt - cdt_over_dy)/(1._rt + cdt_over_dy);
amrex::Real const coef2_y = 2._rt*cdt_over_dy/(1._rt + cdt_over_dy) / PhysConst::c;
#endif
- amrex::Real const cdt_over_dz = PhysConst::c*dt*m_stencil_coefs_z[0];
+ amrex::Real const cdt_over_dz = PhysConst::c*dt*m_h_stencil_coefs_z[0];
amrex::Real const coef1_z = (1._rt - cdt_over_dz)/(1._rt + cdt_over_dz);
amrex::Real const coef2_z = 2._rt*cdt_over_dz/(1._rt + cdt_over_dz) / PhysConst::c;
diff --git a/Source/FieldSolver/FiniteDifferenceSolver/FiniteDifferenceSolver.H b/Source/FieldSolver/FiniteDifferenceSolver/FiniteDifferenceSolver.H
index 92812d4e0..5346604d4 100644
--- a/Source/FieldSolver/FiniteDifferenceSolver/FiniteDifferenceSolver.H
+++ b/Source/FieldSolver/FiniteDifferenceSolver/FiniteDifferenceSolver.H
@@ -110,9 +110,15 @@ class FiniteDifferenceSolver
#ifdef WARPX_DIM_RZ
amrex::Real m_dr, m_rmin;
int m_nmodes;
+ // host-only
+ amrex::Vector<amrex::Real> m_h_stencil_coefs_r, m_h_stencil_coefs_z;
+ // device copy after init
amrex::Gpu::DeviceVector<amrex::Real> m_stencil_coefs_r;
amrex::Gpu::DeviceVector<amrex::Real> m_stencil_coefs_z;
#else
+ // host-only
+ amrex::Vector<amrex::Real> m_h_stencil_coefs_x, m_h_stencil_coefs_y, m_h_stencil_coefs_z;
+ // device copy after init
amrex::Gpu::DeviceVector<amrex::Real> m_stencil_coefs_x;
amrex::Gpu::DeviceVector<amrex::Real> m_stencil_coefs_y;
amrex::Gpu::DeviceVector<amrex::Real> m_stencil_coefs_z;
diff --git a/Source/FieldSolver/FiniteDifferenceSolver/FiniteDifferenceSolver.cpp b/Source/FieldSolver/FiniteDifferenceSolver/FiniteDifferenceSolver.cpp
index 3a752ca4b..14decf5c1 100644
--- a/Source/FieldSolver/FiniteDifferenceSolver/FiniteDifferenceSolver.cpp
+++ b/Source/FieldSolver/FiniteDifferenceSolver/FiniteDifferenceSolver.cpp
@@ -36,56 +36,52 @@ FiniteDifferenceSolver::FiniteDifferenceSolver (
m_nmodes = WarpX::GetInstance().n_rz_azimuthal_modes;
m_rmin = WarpX::GetInstance().Geom(0).ProbLo(0);
if (fdtd_algo == MaxwellSolverAlgo::Yee) {
-
- amrex::Vector<amrex::Real> stencil_coefs_r, stencil_coefs_z;
CylindricalYeeAlgorithm::InitializeStencilCoefficients( cell_size,
- stencil_coefs_r, stencil_coefs_z );
- m_stencil_coefs_r.resize(stencil_coefs_r.size());
- m_stencil_coefs_z.resize(stencil_coefs_z.size());
+ m_h_stencil_coefs_r, m_h_stencil_coefs_z );
+ m_stencil_coefs_r.resize(m_h_stencil_coefs_r.size());
+ m_stencil_coefs_z.resize(m_h_stencil_coefs_z.size());
amrex::Gpu::copyAsync(amrex::Gpu::hostToDevice,
- stencil_coefs_r.begin(), stencil_coefs_r.end(),
+ m_h_stencil_coefs_r.begin(), m_h_stencil_coefs_r.end(),
m_stencil_coefs_r.begin());
amrex::Gpu::copyAsync(amrex::Gpu::hostToDevice,
- stencil_coefs_z.begin(), stencil_coefs_z.end(),
+ m_h_stencil_coefs_z.begin(), m_h_stencil_coefs_z.end(),
m_stencil_coefs_z.begin());
amrex::Gpu::synchronize();
} else {
amrex::Abort("FiniteDifferenceSolver: Unknown algorithm");
}
#else
- amrex::Vector<amrex::Real> stencil_coefs_x, stencil_coefs_y, stencil_coefs_z;
-
if (do_nodal) {
CartesianNodalAlgorithm::InitializeStencilCoefficients( cell_size,
- stencil_coefs_x, stencil_coefs_y, stencil_coefs_z );
+ m_h_stencil_coefs_x, m_h_stencil_coefs_y, m_h_stencil_coefs_z );
} else if (fdtd_algo == MaxwellSolverAlgo::Yee) {
CartesianYeeAlgorithm::InitializeStencilCoefficients( cell_size,
- stencil_coefs_x, stencil_coefs_y, stencil_coefs_z );
+ m_h_stencil_coefs_x, m_h_stencil_coefs_y, m_h_stencil_coefs_z );
} else if (fdtd_algo == MaxwellSolverAlgo::CKC) {
CartesianCKCAlgorithm::InitializeStencilCoefficients( cell_size,
- stencil_coefs_x, stencil_coefs_y, stencil_coefs_z );
+ m_h_stencil_coefs_x, m_h_stencil_coefs_y, m_h_stencil_coefs_z );
} else {
amrex::Abort("FiniteDifferenceSolver: Unknown algorithm");
}
- m_stencil_coefs_x.resize(stencil_coefs_x.size());
- m_stencil_coefs_y.resize(stencil_coefs_y.size());
- m_stencil_coefs_z.resize(stencil_coefs_z.size());
+ m_stencil_coefs_x.resize(m_h_stencil_coefs_x.size());
+ m_stencil_coefs_y.resize(m_h_stencil_coefs_y.size());
+ m_stencil_coefs_z.resize(m_h_stencil_coefs_z.size());
amrex::Gpu::copyAsync(amrex::Gpu::hostToDevice,
- stencil_coefs_x.begin(), stencil_coefs_x.end(),
+ m_h_stencil_coefs_x.begin(), m_h_stencil_coefs_x.end(),
m_stencil_coefs_x.begin());
amrex::Gpu::copyAsync(amrex::Gpu::hostToDevice,
- stencil_coefs_y.begin(), stencil_coefs_y.end(),
+ m_h_stencil_coefs_y.begin(), m_h_stencil_coefs_y.end(),
m_stencil_coefs_y.begin());
amrex::Gpu::copyAsync(amrex::Gpu::hostToDevice,
- stencil_coefs_z.begin(), stencil_coefs_z.end(),
+ m_h_stencil_coefs_z.begin(), m_h_stencil_coefs_z.end(),
m_stencil_coefs_z.begin());
amrex::Gpu::synchronize();
#endif