Skip to content

Commit

Permalink
Merge branch 'development' of https://github.com/AMReX-Codes/amrex in…
Browse files Browse the repository at this point in the history
…to solve_bicgstab-use-fewer-MFs
  • Loading branch information
eebasso committed Nov 17, 2023
2 parents 1d67f04 + d93f344 commit ab6b211
Show file tree
Hide file tree
Showing 4 changed files with 7 additions and 2 deletions.
2 changes: 1 addition & 1 deletion Src/Base/AMReX_FabArrayUtility.H
Original file line number Diff line number Diff line change
Expand Up @@ -1103,7 +1103,7 @@ template <class FAB,
void
Subtract (FabArray<FAB>& dst, FabArray<FAB> const& src, int srccomp, int dstcomp, int numcomp, int nghost)
{
Subtract(dst,src,srccomp,dstcomp,numcomp,nghost);
Subtract(dst,src,srccomp,dstcomp,numcomp,IntVect(nghost));
}

template <class FAB,
Expand Down
2 changes: 1 addition & 1 deletion Src/LinearSolvers/MLMG/AMReX_MLMG.H
Original file line number Diff line number Diff line change
Expand Up @@ -545,7 +545,7 @@ MLMGT<MF>::getGradSolution (const Vector<Array<AMF*,AMREX_SPACEDIM> >& a_grad_so
}
linop.compGrad(alev, GetArrOfPtrs(grad_sol), sol[alev], a_loc);
for (int idim = 0; idim < AMREX_SPACEDIM; ++idim) {
a_grad_sol[alev][idim]->LocalCopy(grad_sol, 0, 0, ncomp, IntVect(0));
a_grad_sol[alev][idim]->LocalCopy(grad_sol[idim], 0, 0, ncomp, IntVect(0));
}
}
}
Expand Down
1 change: 1 addition & 0 deletions Tests/LinearSolvers/EBflux_grad/MyTest.H
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,7 @@ private:
amrex::Vector<amrex::MultiFab> phi;
amrex::Vector<amrex::Array<amrex::MultiFab, AMREX_SPACEDIM>> flux;
amrex::Vector<amrex::Array<amrex::MultiFab, AMREX_SPACEDIM>> grad;
amrex::Vector<amrex::Array<amrex::fMultiFab, AMREX_SPACEDIM>> fgrad; // Used to test getGradSolution when MF is different from AMF
amrex::Vector<amrex::MultiFab> rhs;
amrex::Vector<amrex::MultiFab> acoef;
amrex::Vector<amrex::Array<amrex::MultiFab,AMREX_SPACEDIM> > bcoef;
Expand Down
4 changes: 4 additions & 0 deletions Tests/LinearSolvers/EBflux_grad/MyTest.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -73,6 +73,7 @@ MyTest::solve ()
mlmg.solve(amrex::GetVecOfPtrs(phi), amrex::GetVecOfConstPtrs(rhs), tol_rel, tol_abs);
mlmg.getFluxes(amrex::GetVecOfArrOfPtrs(flux));
mlmg.getGradSolution(amrex::GetVecOfArrOfPtrs(grad));
mlmg.getGradSolution(amrex::GetVecOfArrOfPtrs(fgrad)); // Test when MF is different from AMF
for (int ilev = 0; ilev <= max_level; ++ilev) {
amrex::VisMF::Write(phi[0], "phi-"+std::to_string(ilev));
}
Expand Down Expand Up @@ -146,6 +147,7 @@ MyTest::initData ()
bcoef.resize(nlevels);
flux.resize(1);
grad.resize(1);
fgrad.resize(1);
for (int ilev = 0; ilev < nlevels; ++ilev)
{
dmap[ilev].define(grids[ilev]);
Expand Down Expand Up @@ -193,5 +195,7 @@ MyTest::initData ()
dmap[0], 1, 0, MFInfo(), *factory[0]);
grad[0][idim].define(amrex::convert(grids[0],IntVect::TheDimensionVector(idim)),
dmap[0], 1, 0, MFInfo(), *factory[0]);
fgrad[0][idim].define(amrex::convert(grids[0],IntVect::TheDimensionVector(idim)),
dmap[0], 1, 0, MFInfo(), DefaultFabFactory<BaseFab<float>>());
}
}

0 comments on commit ab6b211

Please sign in to comment.