forked from ECP-WarpX/WarpX
-
Notifications
You must be signed in to change notification settings - Fork 3
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Macroscopic pml with mur in H PML #62
Open
jackieyao0114
wants to merge
37
commits into
RevathiJambunathan:evolveM_dev
Choose a base branch
from
jackieyao0114:macroscopicPML_mu
base: evolveM_dev
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Open
Changes from 21 commits
Commits
Show all changes
37 commits
Select commit
Hold shift + click to select a range
2e46b50
initialize and allocate macro pml mfs
RevathiJambunathan 97abb25
add level when initializing PML constructor
RevathiJambunathan 63bbf84
change to public so we can call from PML constructor
RevathiJambunathan 955e67d
Add new file for macroscopic evolveE pml account for material
RevathiJambunathan 3f5e7b0
initialize macro PML and call macro PML
RevathiJambunathan 86c452f
fix typo
RevathiJambunathan c786179
add relevant header
RevathiJambunathan 0946ea0
fix eol whitespace
RevathiJambunathan 397f387
Apply suggestions from code review
RevathiJambunathan 01510f5
Update Source/FieldSolver/FiniteDifferenceSolver/MacroscopicEvolveEPM…
RevathiJambunathan c852c39
added macroscopic mu in MacroscopicEvolveHPML
jackieyao0114 c3af5e0
removed printing residual in Source/FieldSolver/FiniteDifferenceSolve…
jackieyao0114 167cb6b
Merge branch 'evolveM_dev' into macroscopicPML_mu
ajnonaka 27f2198
Merge branch 'evolveM_dev' of https://github.com/RevathiJambunathan/W…
jackieyao0114 7689f47
updated ncomp in Source/FieldSolver/FiniteDifferenceSolver/Macroscopi…
jackieyao0114 ead2324
Merge branch 'macroscopicPML_mu' of https://github.com/jackieyao0114/…
jackieyao0114 d479e63
EOL fix
jackieyao0114 7cab0d7
fixed pml setup in Examples/Tests/Macroscopic_Maxwell/inputs_3d_noMs
jackieyao0114 cd52411
Apply suggestions from code review (annotations in code)
jackieyao0114 edac43e
clarified mur and Ms requirement in Docs/source/running_cpp/parameter…
jackieyao0114 643f04d
Update Examples/Tests/Macroscopic_Maxwell/inputs_3d_noMs
jackieyao0114 3034b3f
Update Docs/source/running_cpp/parameters.rst
jackieyao0114 a9aba04
removed part of EvolveHPML residual
jackieyao0114 993e834
removed more EvolveHPML residual
jackieyao0114 61fe0dc
removed Source/FieldSolver/FiniteDifferenceSolver/EvolveHPML.cpp
jackieyao0114 117a3a0
initialize H_indexType
ajnonaka 8f9716f
Update Source/FieldSolver/FiniteDifferenceSolver/MacroscopicEvolveHPM…
ajnonaka 537495b
cleanup only
ajnonaka 13ad49e
clean up inputs files (no functional changes)
ajnonaka 94e089f
add Ms at boundary test. sync up inputs files
ajnonaka f1ce428
set alpha and gamma
ajnonaka fa0ea39
Merge branch 'evolveM_dev' into macroscopicPML_mu
ajnonaka fa24235
added Examples/Tests/Macroscopic_Maxwell/inputs_3d_LLG_MsBoundary
jackieyao0114 b5d3d03
Merge branch 'macroscopicPML_mu' of https://github.com/jackieyao0114/…
jackieyao0114 461796e
added Examples/Tests/Macroscopic_Maxwell/inputs_3d_LLG_MsBoundary
jackieyao0114 acf07ae
Merge branch 'macroscopicPML_mu' of https://github.com/jackieyao0114/…
jackieyao0114 c2146c9
Merge branch 'evolveM_dev' into macroscopicPML_mu
ajnonaka File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -148,6 +148,12 @@ class FiniteDifferenceSolver | |
void EvolveHPML ( std::array< amrex::MultiFab*, 3 > Hfield, | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. delete this function too |
||
std::array< amrex::MultiFab*, 3 > const Efield, | ||
amrex::Real const dt ); | ||
|
||
void MacroscopicEvolveHPML ( std::array< amrex::MultiFab*, 3 > Hfield, | ||
std::array< amrex::MultiFab*, 3 > const Efield, | ||
amrex::Real const dt, | ||
std::unique_ptr<MacroscopicProperties> const& macroscopic_properties, | ||
amrex::MultiFab* const mu_mf ); | ||
#endif | ||
|
||
private: | ||
|
@@ -301,9 +307,17 @@ class FiniteDifferenceSolver | |
#ifdef WARPX_MAG_LLG | ||
template< typename T_Algo > | ||
void EvolveHPMLCartesian ( | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. coud you remove this unused function |
||
std::array< amrex::MultiFab*, 3 > Bfield, | ||
std::array< amrex::MultiFab*, 3 > Hfield, | ||
std::array< amrex::MultiFab*, 3 > const Efield, | ||
amrex::Real const dt ); | ||
|
||
template< typename T_Algo > | ||
void MacroscopicEvolveHPMLCartesian ( | ||
std::array< amrex::MultiFab*, 3 > Hfield, | ||
std::array< amrex::MultiFab*, 3 > const Efield, | ||
amrex::Real const dt, | ||
std::unique_ptr<MacroscopicProperties> const& macroscopic_properties, | ||
amrex::MultiFab* const mu_mf ); | ||
#endif | ||
|
||
#endif | ||
|
156 changes: 156 additions & 0 deletions
156
Source/FieldSolver/FiniteDifferenceSolver/MacroscopicEvolveHPML.cpp
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,156 @@ | ||
|
||
#include "Utils/WarpXAlgorithmSelection.H" | ||
#include "FieldSolver/FiniteDifferenceSolver/FiniteDifferenceSolver.H" | ||
#ifdef WARPX_DIM_RZ | ||
# include "FieldSolver/FiniteDifferenceSolver/FiniteDifferenceAlgorithms/CylindricalYeeAlgorithm.H" | ||
#else | ||
# include "FieldSolver/FiniteDifferenceSolver/FiniteDifferenceAlgorithms/CartesianYeeAlgorithm.H" | ||
# include "FieldSolver/FiniteDifferenceSolver/FiniteDifferenceAlgorithms/CartesianCKCAlgorithm.H" | ||
# include "FieldSolver/FiniteDifferenceSolver/FiniteDifferenceAlgorithms/CartesianNodalAlgorithm.H" | ||
#endif | ||
#include "BoundaryConditions/PMLComponent.H" | ||
#include <AMReX_Gpu.H> | ||
#include <AMReX.H> | ||
#include "Utils/CoarsenIO.H" | ||
|
||
using namespace amrex; | ||
|
||
#ifdef WARPX_MAG_LLG | ||
|
||
/** | ||
* \brief Update Hfield in PML region | ||
*/ | ||
void FiniteDifferenceSolver::MacroscopicEvolveHPML ( | ||
std::array< amrex::MultiFab*, 3 > Hfield, | ||
std::array< amrex::MultiFab*, 3 > const Efield, | ||
amrex::Real const dt, | ||
std::unique_ptr<MacroscopicProperties> const& macroscopic_properties, | ||
amrex::MultiFab* const mu_mf ) { | ||
|
||
// Select algorithm (The choice of algorithm is a runtime option, | ||
// but we compile code for each algorithm, using templates) | ||
#ifdef WARPX_DIM_RZ | ||
amrex::ignore_unused(Hfield, Efield, dt, macroscopic_properties, mu_mf); | ||
amrex::Abort("PML are not implemented in cylindrical geometry."); | ||
#else | ||
if (m_do_nodal) { | ||
|
||
MacroscopicEvolveHPMLCartesian <CartesianNodalAlgorithm> ( Hfield, Efield, dt, macroscopic_properties, mu_mf ); | ||
|
||
} else if (m_fdtd_algo == MaxwellSolverAlgo::Yee) { | ||
|
||
MacroscopicEvolveHPMLCartesian <CartesianYeeAlgorithm> ( Hfield, Efield, dt, macroscopic_properties, mu_mf ); | ||
|
||
} else if (m_fdtd_algo == MaxwellSolverAlgo::CKC) { | ||
|
||
MacroscopicEvolveHPMLCartesian <CartesianCKCAlgorithm> ( Hfield, Efield, dt, macroscopic_properties, mu_mf ); | ||
|
||
} else { | ||
amrex::Abort("Unknown algorithm"); | ||
} | ||
#endif | ||
} | ||
|
||
|
||
#ifndef WARPX_DIM_RZ | ||
|
||
template<typename T_Algo> | ||
void FiniteDifferenceSolver::MacroscopicEvolveHPMLCartesian ( | ||
std::array< amrex::MultiFab*, 3 > Hfield, | ||
std::array< amrex::MultiFab*, 3 > const Efield, | ||
amrex::Real const dt, | ||
std::unique_ptr<MacroscopicProperties> const& macroscopic_properties, | ||
amrex::MultiFab* const mu_mf ) { | ||
|
||
amrex::GpuArray<int, 3> const& mu_stag = macroscopic_properties->mu_IndexType; | ||
amrex::GpuArray<int, 3> const& Hx_stag = macroscopic_properties->Hx_IndexType; | ||
amrex::GpuArray<int, 3> const& Hy_stag = macroscopic_properties->Hy_IndexType; | ||
amrex::GpuArray<int, 3> const& Hz_stag = macroscopic_properties->Hz_IndexType; | ||
amrex::GpuArray<int, 3> const& macro_cr = macroscopic_properties->macro_cr_ratio; | ||
jackieyao0114 marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
// Loop through the grids, and over the tiles within each grid | ||
#ifdef _OPENMP | ||
#pragma omp parallel if (amrex::Gpu::notInLaunchRegion()) | ||
#endif | ||
|
||
ajnonaka marked this conversation as resolved.
Show resolved
Hide resolved
|
||
for ( MFIter mfi(*Hfield[0], TilingIfNotGPU()); mfi.isValid(); ++mfi ) { | ||
|
||
// Extract field data for this grid/tile | ||
Array4<Real> const& Hx = Hfield[0]->array(mfi); | ||
Array4<Real> const& Hy = Hfield[1]->array(mfi); | ||
Array4<Real> const& Hz = Hfield[2]->array(mfi); | ||
Array4<Real> const& Ex = Efield[0]->array(mfi); | ||
Array4<Real> const& Ey = Efield[1]->array(mfi); | ||
Array4<Real> const& Ez = Efield[2]->array(mfi); | ||
|
||
// Extract stencil coefficients | ||
Real const * const AMREX_RESTRICT coefs_x = m_stencil_coefs_x.dataPtr(); | ||
int const n_coefs_x = m_stencil_coefs_x.size(); | ||
Real const * const AMREX_RESTRICT coefs_y = m_stencil_coefs_y.dataPtr(); | ||
int const n_coefs_y = m_stencil_coefs_y.size(); | ||
Real const * const AMREX_RESTRICT coefs_z = m_stencil_coefs_z.dataPtr(); | ||
int const n_coefs_z = m_stencil_coefs_z.size(); | ||
|
||
// Extract tileboxes for which to loop | ||
Box const& tbx = mfi.tilebox(Hfield[0]->ixType().ixType()); | ||
Box const& tby = mfi.tilebox(Hfield[1]->ixType().ixType()); | ||
Box const& tbz = mfi.tilebox(Hfield[2]->ixType().ixType()); | ||
// starting component to interpolate macro properties to Hx, Hy, Hz locations | ||
const int scomp = 0; | ||
// mu_mf will be imported but will only be called at grids where Ms == 0 | ||
Array4<Real> const& mu_arr = mu_mf->array(mfi); | ||
|
||
// Loop over the cells and update the fields | ||
amrex::ParallelFor(tbx, tby, tbz, | ||
|
||
[=] AMREX_GPU_DEVICE (int i, int j, int k){ | ||
|
||
Real mu_arrx = CoarsenIO::Interp( mu_arr, mu_stag, Hx_stag, macro_cr, i, j, k, scomp); | ||
|
||
Hx(i, j, k, PMLComp::xz) += 1._rt / mu_arrx * dt * ( | ||
T_Algo::UpwardDz(Ey, coefs_z, n_coefs_z, i, j, k, PMLComp::yx) | ||
+ T_Algo::UpwardDz(Ey, coefs_z, n_coefs_z, i, j, k, PMLComp::yy) | ||
+ T_Algo::UpwardDz(Ey, coefs_z, n_coefs_z, i, j, k, PMLComp::yz) ); | ||
Hx(i, j, k, PMLComp::xy) -= 1._rt / mu_arrx * dt * ( | ||
T_Algo::UpwardDy(Ez, coefs_y, n_coefs_y, i, j, k, PMLComp::zx) | ||
+ T_Algo::UpwardDy(Ez, coefs_y, n_coefs_y, i, j, k, PMLComp::zy) | ||
+ T_Algo::UpwardDy(Ez, coefs_y, n_coefs_y, i, j, k, PMLComp::zz) ); | ||
}, | ||
|
||
[=] AMREX_GPU_DEVICE (int i, int j, int k){ | ||
|
||
Real mu_arry = CoarsenIO::Interp( mu_arr, mu_stag, Hy_stag, macro_cr, i, j, k, scomp); | ||
|
||
Hy(i, j, k, PMLComp::yx) += 1._rt / mu_arry * dt * ( | ||
T_Algo::UpwardDx(Ez, coefs_x, n_coefs_x, i, j, k, PMLComp::zx) | ||
+ T_Algo::UpwardDx(Ez, coefs_x, n_coefs_x, i, j, k, PMLComp::zy) | ||
+ T_Algo::UpwardDx(Ez, coefs_x, n_coefs_x, i, j, k, PMLComp::zz) ); | ||
Hy(i, j, k, PMLComp::yz) -= 1._rt / mu_arry * dt * ( | ||
T_Algo::UpwardDz(Ex, coefs_z, n_coefs_z, i, j, k, PMLComp::xx) | ||
+ T_Algo::UpwardDz(Ex, coefs_z, n_coefs_z, i, j, k, PMLComp::xy) | ||
+ T_Algo::UpwardDz(Ex, coefs_z, n_coefs_z, i, j, k, PMLComp::xz) ); | ||
}, | ||
|
||
[=] AMREX_GPU_DEVICE (int i, int j, int k){ | ||
|
||
Real mu_arrz = CoarsenIO::Interp( mu_arr, mu_stag, Hz_stag, macro_cr, i, j, k, scomp); | ||
|
||
Hz(i, j, k, PMLComp::zy) += 1._rt / mu_arrz * dt * ( | ||
T_Algo::UpwardDy(Ex, coefs_y, n_coefs_y, i, j, k, PMLComp::xx) | ||
+ T_Algo::UpwardDy(Ex, coefs_y, n_coefs_y, i, j, k, PMLComp::xy) | ||
+ T_Algo::UpwardDy(Ex, coefs_y, n_coefs_y, i, j, k, PMLComp::xz) ); | ||
Hz(i, j, k, PMLComp::zx) -= 1._rt / mu_arrz * dt * ( | ||
T_Algo::UpwardDx(Ey, coefs_x, n_coefs_x, i, j, k, PMLComp::yx) | ||
+ T_Algo::UpwardDx(Ey, coefs_x, n_coefs_x, i, j, k, PMLComp::yy) | ||
+ T_Algo::UpwardDx(Ey, coefs_x, n_coefs_x, i, j, k, PMLComp::yz) ); | ||
} | ||
|
||
); | ||
|
||
} | ||
|
||
} | ||
|
||
#endif // corresponds to ifndef WARPX_DIM_RZ | ||
|
||
#endif // #ifdef WARPX_MAG_LLG |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Are we actually enforcing this in the code with an Abort(), or warning with a Warn(), or neither? Is it more accurate to say that the value of mu_r in regions where Ms != 0 simply doesn't matter?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Operationally, it is true that the value of mu_r in regions where Ms != 0 simply doesn't matter. But I'm concerned this might be misleading. Maybe a warning should be added in the next PR (together with this document)?