21 #ifndef GEOS_PHYSICSSOLVERS_CONTACT_SOLIDMECHANICSAUGMENTEDLAGRANGIANCONTACT_HPP_
22 #define GEOS_PHYSICSSOLVERS_CONTACT_SOLIDMECHANICSAUGMENTEDLAGRANGIANCONTACT_HPP_
24 #include "physicsSolvers/solidMechanics/contact/ContactSolverBase.hpp"
33 Group *
const parent );
43 return "SolidMechanicsAugmentedLagrangianContact";
64 bool const setSparsity =
true ) override final;
86 void assembleContact(
real64 const time,
93 void assembleForceResidualPressureContribution(
DomainPartition & domain,
107 real64 const scalingFactor,
114 integer configurationLoopIter ) override final;
124 template< typename LAMBDA >
131 for(
const auto & [finiteElementName, faceElementList] : faceTypesToFaceElements )
137 lambda( finiteElementName, subRegionFE, faceElemList );
149 template<
typename LAMBDA >
153 bool const isStickState =
true;
156 faceTypesToFaceElements = m_faceTypesToFaceElementsStick.at( meshName );
158 for(
const auto & [finiteElementName, faceElementList] : faceTypesToFaceElements )
164 lambda( finiteElementName, subRegionFE, faceElemList, isStickState );
176 template<
typename LAMBDA >
180 bool const isStickState =
false;
183 faceTypesToFaceElements = m_faceTypesToFaceElementsSlip.at( meshName );
185 for(
const auto & [finiteElementName, faceElementList] : faceTypesToFaceElements )
191 lambda( finiteElementName, subRegionFE, faceElemList, isStickState );
224 void validateTetrahedralQuadrature(
Group & meshBodies );
264 void initializeTractionFromAdjacentCellStress(
DomainPartition & domain )
const;
281 constexpr
static char const * normalDisplacementToleranceString() {
return "normalDisplacementTolerance"; }
283 constexpr
static char const * normalTractionToleranceString() {
return "normalTractionTolerance"; }
285 constexpr
static char const * slidingToleranceString() {
return "slidingTolerance"; }
287 constexpr
static char const * dispJumpUpdPenaltyString() {
return "dispJumpUpdPenalty"; }
289 constexpr
static char const * simultaneousString() {
return "simultaneous"; }
291 constexpr
static char const * symmetricString() {
return "symmetric"; }
293 constexpr
static char const * iterativePenaltyNFacString() {
return "iterPenaltyN"; }
295 constexpr
static char const * iterativePenaltyTFacString() {
return "iterPenaltyT"; }
297 constexpr
static char const * tolJumpDispNFacString() {
return "tolJumpN"; }
299 constexpr
static char const * tolJumpDispTFacString() {
return "tolJumpT"; }
301 constexpr
static char const * tolNormalTracFacString() {
return "tolNormalTrac"; }
303 constexpr
static char const * tolTauLimitString() {
return "tolTauLimit"; }
309 real64 m_slidingCheckTolerance = 5.e-02;
312 int m_simultaneous = 1;
319 real64 m_iterPenaltyNFac = 10.0;
322 real64 m_iterPenaltyTFac = 0.1;
325 real64 m_tolJumpDispNFac = 1.e-07;
328 real64 m_tolJumpDispTFac = 1.e-05;
331 real64 m_tolNormalTracFac = 0.5;
The DoFManager is responsible for allocating global dofs, constructing sparsity patterns,...
Partition of the decomposed physical domain. It also manages the connexion information to its neighbo...
Base class for FEM element implementations.
ArrayView< T, 1 > arrayView1d
Alias for 1D array view.
GEOS_GLOBALINDEX_TYPE globalIndex
Global index type (for indexing objects across MPI partitions).
LvArray::CRSMatrix< T, COL_INDEX, INDEX_TYPE, LvArray::ChaiBuffer > CRSMatrix
Alias for CRS Matrix class.
std::string string
String type.
LvArray::SparsityPatternView< COL_INDEX, INDEX_TYPE const, LvArray::ChaiBuffer > SparsityPatternView
Alias for Sparsity pattern View.
LvArray::SparsityPattern< COL_INDEX, INDEX_TYPE, LvArray::ChaiBuffer > SparsityPattern
Alias for Sparsity pattern class.
double real64
64-bit floating point type.
LvArray::CRSMatrixView< T, COL_INDEX, INDEX_TYPE const, LvArray::ChaiBuffer > CRSMatrixView
Alias for CRS Matrix View.
internal::StdMapWrapper< std::map< Key, T, Compare, Allocator >, USE_STD_CONTAINER_BOUNDS_CHECKING > stdMap
int integer
Signed integer type.
Array< T, 1 > array1d
Alias for 1D array.
LAInterface::ParallelVector ParallelVector
Alias for ParallelVector.