diff options
author | 2021-05-03 12:48:21 -0700 | |
---|---|---|
committer | 2021-05-03 12:48:21 -0700 | |
commit | 1f8862084391fbeb4b87f765eea01beaf5f21074 (patch) | |
tree | 75c526dbafbd6fb14b5602970087552b72ae9f26 /Source/FieldSolver/FiniteDifferenceSolver/EvolveG.cpp | |
parent | 7113d7e9ce4fe89c87ba5e2c490a24595f85bc74 (diff) | |
download | WarpX-1f8862084391fbeb4b87f765eea01beaf5f21074.tar.gz WarpX-1f8862084391fbeb4b87f765eea01beaf5f21074.tar.zst WarpX-1f8862084391fbeb4b87f765eea01beaf5f21074.zip |
Implement div(B) Cleaning With FDTD (#1829)
* Implement div(B) Cleaning With FDTD
* Add CI Test
* Clean Up
Diffstat (limited to 'Source/FieldSolver/FiniteDifferenceSolver/EvolveG.cpp')
-rw-r--r-- | Source/FieldSolver/FiniteDifferenceSolver/EvolveG.cpp | 95 |
1 files changed, 95 insertions, 0 deletions
diff --git a/Source/FieldSolver/FiniteDifferenceSolver/EvolveG.cpp b/Source/FieldSolver/FiniteDifferenceSolver/EvolveG.cpp new file mode 100644 index 000000000..f69fb57c4 --- /dev/null +++ b/Source/FieldSolver/FiniteDifferenceSolver/EvolveG.cpp @@ -0,0 +1,95 @@ +/* Copyright 2020 + * + * This file is part of WarpX. + * + * License: BSD-3-Clause-LBNL + */ + +#include "Utils/WarpXAlgorithmSelection.H" +#include "FiniteDifferenceSolver.H" +#ifdef WARPX_DIM_RZ +# include "FiniteDifferenceAlgorithms/CylindricalYeeAlgorithm.H" +#else +# include "FiniteDifferenceAlgorithms/CartesianYeeAlgorithm.H" +# include "FiniteDifferenceAlgorithms/CartesianCKCAlgorithm.H" +# include "FiniteDifferenceAlgorithms/CartesianNodalAlgorithm.H" +#endif +#include "Utils/WarpXConst.H" +#include "WarpX.H" +#include <AMReX_Gpu.H> + +using namespace amrex; + +void FiniteDifferenceSolver::EvolveG ( + std::unique_ptr<amrex::MultiFab>& Gfield, + std::array<std::unique_ptr<amrex::MultiFab>,3> const& Bfield, + amrex::Real const dt) +{ +#ifdef WARPX_DIM_RZ + // TODO Implement G update equation in RZ geometry + amrex::ignore_unused(Gfield, Bfield, dt); +#else + // Select algorithm + if (m_do_nodal) + { + EvolveGCartesian<CartesianNodalAlgorithm>(Gfield, Bfield, dt); + } + else if (m_fdtd_algo == MaxwellSolverAlgo::Yee) + { + EvolveGCartesian<CartesianYeeAlgorithm>(Gfield, Bfield, dt); + } + else if (m_fdtd_algo == MaxwellSolverAlgo::CKC) + { + EvolveGCartesian<CartesianCKCAlgorithm>(Gfield, Bfield, dt); + } + else + { + amrex::Abort("EvolveG: unknown FDTD algorithm"); + } +#endif +} + +#ifndef WARPX_DIM_RZ + +template<typename T_Algo> +void FiniteDifferenceSolver::EvolveGCartesian ( + std::unique_ptr<amrex::MultiFab>& Gfield, + std::array<std::unique_ptr<amrex::MultiFab>,3> const& Bfield, + amrex::Real const dt) +{ +#ifdef AMREX_USE_OMP +#pragma omp parallel if (amrex::Gpu::notInLaunchRegion()) +#endif + + // Loop over grids and over tiles within each grid + for (amrex::MFIter mfi(*Gfield, TilingIfNotGPU()); mfi.isValid(); ++mfi) + { + // Extract field data for this grid/tile + amrex::Array4<amrex::Real> const& G = Gfield->array(mfi); + amrex::Array4<amrex::Real> const& Bx = Bfield[0]->array(mfi); + amrex::Array4<amrex::Real> const& By = Bfield[1]->array(mfi); + amrex::Array4<amrex::Real> const& Bz = Bfield[2]->array(mfi); + + // Extract stencil coefficients + amrex::Real const* const AMREX_RESTRICT coefs_x = m_stencil_coefs_x.dataPtr(); + amrex::Real const* const AMREX_RESTRICT coefs_y = m_stencil_coefs_y.dataPtr(); + amrex::Real const* const AMREX_RESTRICT coefs_z = m_stencil_coefs_z.dataPtr(); + + const int n_coefs_x = m_stencil_coefs_x.size(); + const int n_coefs_y = m_stencil_coefs_y.size(); + const int n_coefs_z = m_stencil_coefs_z.size(); + + // Extract tilebox to loop over + amrex::Box const& tf = mfi.tilebox(Gfield->ixType().toIntVect()); + + // Loop over cells and update G + amrex::ParallelFor(tf, [=] AMREX_GPU_DEVICE (int i, int j, int k) + { + G(i,j,k) += dt * (T_Algo::UpwardDx(Bx, coefs_x, n_coefs_x, i, j, k) + + T_Algo::UpwardDy(By, coefs_y, n_coefs_y, i, j, k) + + T_Algo::UpwardDz(Bz, coefs_z, n_coefs_z, i, j, k)); + }); + } +} + +#endif |