Skip to content

Commit

Permalink
feat: mgr strategy for lagrangeContactBubbleStabilization (#3492)
Browse files Browse the repository at this point in the history
* feat: mgr strategy for lagrangeContactBubbleStabilization

* Update src/coreComponents/linearAlgebra/interfaces/hypre/mgrStrategies/LagrangianContactMechanicsBubbleStabilization.hpp

* new MGR strategy.

* clean up strategy.
  • Loading branch information
CusiniM authored Jan 22, 2025
1 parent 0ad432d commit 17053bb
Show file tree
Hide file tree
Showing 6 changed files with 159 additions and 0 deletions.
1 change: 1 addition & 0 deletions src/coreComponents/linearAlgebra/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -128,6 +128,7 @@ if( ENABLE_HYPRE )
interfaces/hypre/mgrStrategies/HybridSinglePhasePoromechanics.hpp
interfaces/hypre/mgrStrategies/Hydrofracture.hpp
interfaces/hypre/mgrStrategies/LagrangianContactMechanics.hpp
interfaces/hypre/mgrStrategies/LagrangianContactMechanicsBubbleStabilization.hpp
interfaces/hypre/mgrStrategies/MultiphasePoromechanics.hpp
interfaces/hypre/mgrStrategies/SinglePhasePoromechanicsEmbeddedFractures.hpp
interfaces/hypre/mgrStrategies/SinglePhasePoromechanicsConformingFractures.hpp
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@
#include "linearAlgebra/interfaces/hypre/mgrStrategies/HybridSinglePhasePoromechanics.hpp"
#include "linearAlgebra/interfaces/hypre/mgrStrategies/Hydrofracture.hpp"
#include "linearAlgebra/interfaces/hypre/mgrStrategies/LagrangianContactMechanics.hpp"
#include "linearAlgebra/interfaces/hypre/mgrStrategies/LagrangianContactMechanicsBubbleStabilization.hpp"
#include "linearAlgebra/interfaces/hypre/mgrStrategies/MultiphasePoromechanics.hpp"
#include "linearAlgebra/interfaces/hypre/mgrStrategies/MultiphasePoromechanicsReservoirFVM.hpp"
#include "linearAlgebra/interfaces/hypre/mgrStrategies/ReactiveCompositionalMultiphaseOBL.hpp"
Expand Down Expand Up @@ -138,6 +139,11 @@ void hypre::mgr::createMGR( LinearSolverParameters const & params,
setStrategy< LagrangianContactMechanics >( params.mgr, numComponentsPerField, precond, mgrData );
break;
}
case LinearSolverParameters::MGR::StrategyType::lagrangianContactMechanicsBubbleStab:
{
setStrategy< LagrangianContactMechanicsBubbleStabilization >( params.mgr, numComponentsPerField, precond, mgrData );
break;
}
case LinearSolverParameters::MGR::StrategyType::multiphasePoromechanics:
{
setStrategy< MultiphasePoromechanics >( params.mgr, numComponentsPerField, precond, mgrData );
Expand Down
26 changes: 26 additions & 0 deletions src/coreComponents/linearAlgebra/interfaces/hypre/HypreMGR.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -269,6 +269,32 @@ class MGRStrategyBase
setDisplacementAMG( mgrData.mechSolver, separateComponents );
HYPRE_MGRSetFSolver( precond.ptr, mgrData.mechSolver.solve, mgrData.mechSolver.setup, mgrData.mechSolver.ptr );
}
/**
* @brief
*
* @param solver
*/
void setILUCoarseSolver( HyprePrecWrapper & solver )
{
/* (Required) Create ILU solver */
HYPRE_ILUCreate( &solver.ptr );

/* (Recommended) General solver options */
int const ilu_type = 0; /* 0, 1, 10, 11, 20, 21, 30, 31, 40, 41, 50 */
int const max_iter = 1;
double const tol = 0.0;
int const reordering = 0; /* 0: none, 1: RCM */
int const print_level = 0;
HYPRE_ILUSetType( solver.ptr, ilu_type );
HYPRE_ILUSetMaxIter( solver.ptr, max_iter );
HYPRE_ILUSetTol( solver.ptr, tol );
HYPRE_ILUSetLocalReordering( solver.ptr, reordering );
HYPRE_ILUSetPrintLevel( solver.ptr, print_level );

solver.setup = HYPRE_ILUSetup;
solver.solve = HYPRE_ILUSolve;
solver.destroy = HYPRE_ILUDestroy;
}

};

Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,119 @@
/*
* ------------------------------------------------------------------------------------------------------------
* SPDX-License-Identifier: LGPL-2.1-only
*
* Copyright (c) 2016-2024 Lawrence Livermore National Security LLC
* Copyright (c) 2018-2024 TotalEnergies
* Copyright (c) 2018-2024 The Board of Trustees of the Leland Stanford Junior University
* Copyright (c) 2023-2024 Chevron
* Copyright (c) 2019- GEOS/GEOSX Contributors
* All rights reserved
*
* See top level LICENSE, COPYRIGHT, CONTRIBUTORS, NOTICE, and ACKNOWLEDGEMENTS files for details.
* ------------------------------------------------------------------------------------------------------------
*/

/**
* @file LagrangianContactMechanicsBubbleStabilization.hpp
*/

#ifndef GEOS_LINEARALGEBRA_INTERFACES_HYPREMGRLAGRANGIACONTACTMECHANICSBUBBLESTAB_HPP_
#define GEOS_LINEARALGEBRA_INTERFACES_HYPREMGRLAGRANGIACONTACTMECHANICSBUBBLESTAB_HPP_

#include "linearAlgebra/interfaces/hypre/HypreMGR.hpp"

namespace geos
{

namespace hypre
{

namespace mgr
{

/**
* @brief LagrangianContactMechanicsBubbleStabilization strategy
*
* Contact mechanics with face-centered lagrangian multipliers
*
* dofLabel: 0 = displacement, x-component
* dofLabel: 1 = displacement, y-component
* dofLabel: 2 = displacement, z-component
* dofLabel: 3 = displacement bubble function, x-component
* dofLabel: 4 = displacement bubble function, y-component
* dofLabel: 5 = displacement bubble function, z-component
* dofLabel: 6 = face-centered lagrange multiplier (tn)
* dofLabel: 7 = face-centered lagrange multiplier (tt1)
* dofLabel: 8 = face-centered lagrange multiplier (tt2)
*
* 2-level MGR strategy:
* Level 0:
* 1. F-points: bubbles (3,4,5), C-points: displacements + multipliers (0,1,2,6,7,8)
* 2. F-points smoother: l1jacobi
* 3. Global smoother: none
* Level 1:
* 1. F-points: multipliers (6,7,8), C-points: displacements (0,1,2)
* 2. F-points smoother: l1jacobi
* 3. Global smoother: none
*
* C-points coarse-grid/Schur complement solver: boomer AMG
*/
class LagrangianContactMechanicsBubbleStabilization : public MGRStrategyBase< 2 >
{
public:

/**
* @brief Constructor.
*/
explicit LagrangianContactMechanicsBubbleStabilization( arrayView1d< int const > const & )
: MGRStrategyBase( 9 )
{
// Level 0: we keep all three displacements and the Lagrange Multipliers
m_labels[0] = { 0, 1, 2, 6, 7, 8 };
// Level 1: we keep all three displacements
m_labels[1] = { 0, 1, 2 };

setupLabels();

// Level 0
m_levelFRelaxType[0] = MGRFRelaxationType::l1jacobi;
m_levelFRelaxIters[0] = 1;
m_levelInterpType[0] = MGRInterpolationType::blockJacobi;
m_levelRestrictType[0] = MGRRestrictionType::injection;
m_levelCoarseGridMethod[0] = MGRCoarseGridMethod::galerkin;
m_levelGlobalSmootherType[0] = MGRGlobalSmootherType::none;

// Level 1
m_levelFRelaxType[1] = MGRFRelaxationType::l1jacobi;
m_levelFRelaxIters[1] = 1;
m_levelInterpType[1] = MGRInterpolationType::blockJacobi;
m_levelRestrictType[1] = MGRRestrictionType::injection;
m_levelCoarseGridMethod[1] = MGRCoarseGridMethod::galerkin;
m_levelGlobalSmootherType[1] = MGRGlobalSmootherType::none;
}

/**
* @brief Setup the MGR strategy.
* @param mgrParams MGR configuration parameters
* @param precond preconditioner wrapper
* @param mgrData auxiliary MGR data
*/
void setup( LinearSolverParameters::MGR const & mgrParams,
HyprePrecWrapper & precond,
HypreMGRData & mgrData )
{
setReduction( precond, mgrData );

// Configure the BoomerAMG solver used as mgr coarse solver for the displacement reduced system
setDisplacementAMG( mgrData.coarseSolver, mgrParams.separateComponents );
}
};

} // namespace mgr

} // namespace hypre

} // namespace geos

#endif /*GEOS_LINEARALGEBRA_INTERFACES_HYPREMGRLAGRANGIACONTACTMECHANICSBUBBLESTAB_HPP_*/
Original file line number Diff line number Diff line change
Expand Up @@ -295,6 +295,7 @@ struct LinearSolverParameters
thermalMultiphasePoromechanics, ///< thermal multiphase poromechanics with finite volume compositional multiphase flow
hydrofracture, ///< hydrofracture
lagrangianContactMechanics, ///< Lagrangian contact mechanics
lagrangianContactMechanicsBubbleStab, ///< Lagrangian contact mechanics with bubble stabilization
solidMechanicsEmbeddedFractures ///< Embedded fractures mechanics
};

Expand Down Expand Up @@ -387,6 +388,7 @@ ENUM_STRINGS( LinearSolverParameters::MGR::StrategyType,
"thermalMultiphasePoromechanics",
"hydrofracture",
"lagrangianContactMechanics",
"lagrangianContactMechanicsBubbleStab",
"solidMechanicsEmbeddedFractures" );

/// Declare strings associated with enumeration values.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,10 @@ SolidMechanicsLagrangeContactBubbleStab::SolidMechanicsLagrangeContactBubbleStab
m_faceTypeToFiniteElements["Quadrilateral"] = std::make_unique< finiteElement::H1_QuadrilateralFace_Lagrange1_GaussLegendre2 >();
m_faceTypeToFiniteElements["Triangle"] = std::make_unique< finiteElement::H1_TriangleFace_Lagrange1_Gauss1 >();

LinearSolverParameters & linSolParams = m_linearSolverParameters.get();
linSolParams.mgr.strategy = LinearSolverParameters::MGR::StrategyType::lagrangianContactMechanicsBubbleStab;
linSolParams.mgr.separateComponents = true;
linSolParams.dofsPerNode = 3;
}

SolidMechanicsLagrangeContactBubbleStab::~SolidMechanicsLagrangeContactBubbleStab()
Expand Down Expand Up @@ -249,6 +253,7 @@ void SolidMechanicsLagrangeContactBubbleStab::setupSystem( DomainPartition & dom
solution.create( dofManager.numLocalDofs(), MPI_COMM_GEOS );

computeRotationMatrices( domain );

}

void SolidMechanicsLagrangeContactBubbleStab::computeRotationMatrices( DomainPartition & domain ) const
Expand Down

0 comments on commit 17053bb

Please sign in to comment.