19 #ifndef GEOS_LINEARALGEBRA_INTERFACES_HYPREMGRREACTIVECOMPOSITIONALMULTIPHASEOBL_HPP_
20 #define GEOS_LINEARALGEBRA_INTERFACES_HYPREMGRREACTIVECOMPOSITIONALMULTIPHASEOBL_HPP_
61 :
MGRStrategyBase( LvArray::integerConversion< HYPRE_Int >( numComponentsPerField[0] ) )
Helper struct for strategies that provides some basic parameter arrays needed by MGR.
MGRCoarseGridMethod m_levelCoarseGridMethod[numLevels]
Coarse grid method for each level.
MGRInterpolationType m_levelInterpType[numLevels]
Interpolation type for each level.
std::vector< HYPRE_Int > m_labels[numLevels]
Dof labels kept at each level.
void setupLabels()
Call this after populating lv_cindexes.
void setPressureAMG(HyprePrecWrapper &solver)
Set up BoomerAMG to perform the solve for the pressure system.
void setReduction(HyprePrecWrapper &precond, HypreMGRData &mgrData)
Helper function that sets the reduction features common to all mgr strategies.
MGRFRelaxationType m_levelFRelaxType[numLevels]
F-relaxation type for each level.
HYPRE_Int m_levelGlobalSmootherIters[numLevels]
Number of global smoother iterations for each level.
MGRGlobalSmootherType m_levelGlobalSmootherType[numLevels]
Global smoother type for each level.
MGRRestrictionType m_levelRestrictType[numLevels]
Restriction type for each level.
ReactiveCompositionalMultiphaseOBL strategy.
void setup(LinearSolverParameters::MGR const &, HyprePrecWrapper &precond, HypreMGRData &mgrData)
Setup the MGR strategy.
ReactiveCompositionalMultiphaseOBL(arrayView1d< int const > const &numComponentsPerField)
Constructor.
@ none
no F-relaxation if performed
@ ilu0
incomplete LU factorization
ArrayView< T, 1 > arrayView1d
Alias for 1D array view.
Container for hypre preconditioner auxiliary data for MGR.
HyprePrecWrapper coarseSolver
MGR coarse solver pointer and functions.
Container for hypre preconditioner function pointers.
Multigrid reduction parameters.