51 PetscBool changed_y = PETSC_FALSE;
53 SNESLineSearch line_search;
54 PetscReal fnorm, xnorm, ynorm;
55 PetscBool domainerror;
58 LibmeshPetscCall(SNESGetLineSearch(snes, &line_search));
59 LibmeshPetscCall(SNESLineSearchGetVecs(line_search, &X, &
F, &Y, &W, &
G));
60 LibmeshPetscCall(SNESLineSearchGetNorms(line_search, &xnorm, &fnorm, &ynorm));
61 LibmeshPetscCall(SNESLineSearchSetReason(line_search, SNES_LINESEARCH_SUCCEEDED));
63 LibmeshPetscCall(SNESLineSearchPreCheck(line_search, X, Y, &changed_y));
66 LibmeshPetscCall(VecWAXPY(W, -1., Y, X));
69 PetscVector<Number> solution(W, this->
comm());
86 std::set<dof_id_type> nodes_displaced;
88 std::vector<unsigned int> disp_nums;
94 for (
const auto & pen_loc : pen_locs)
95 for (
const auto & pinfo_pair : pen_loc.second->_penetration_info)
97 auto node_id = pinfo_pair.first;
98 auto pen_info = pinfo_pair.second;
101 if (pen_info->_distance > 0)
106 auto pair = nodes_displaced.insert(node_id);
107 mooseAssert(pair.second,
"Node id " << node_id <<
" has already been displaced");
110 const auto & node =
mesh.node_ref(node_id);
117 auto required_solution_change = pen_info->_distance * pen_info->_normal;
120 std::vector<PetscInt> indices;
121 std::vector<PetscScalar> values;
122 for (
auto disp_num : disp_nums)
124 auto dof_number = node.dof_number(0, disp_num, 0);
125 indices.push_back(static_cast<PetscInt>(dof_number));
126 values.push_back(static_cast<PetscScalar>(required_solution_change(
component++)));
128 LibmeshPetscCall(VecSetValues(
129 W, static_cast<PetscInt>(indices.size()), indices.data(), values.data(), ADD_VALUES));
133 LibmeshPetscCall(VecAssemblyBegin(W));
134 LibmeshPetscCall(VecAssemblyEnd(W));
136 LibmeshPetscCall(SNESComputeFunction(snes, W,
F));
137 LibmeshPetscCall(SNESGetFunctionDomainError(snes, &domainerror));
139 LibmeshPetscCall(SNESLineSearchSetReason(line_search, SNES_LINESEARCH_FAILED_DOMAIN));
141 LibmeshPetscCall(VecNorm(
F, NORM_2, &fnorm));
143 LibmeshPetscCall(VecCopy(W, X));
145 LibmeshPetscCall(SNESLineSearchComputeNorms(line_search));
virtual MooseMesh & mesh() override
SNES snes(const char *name=nullptr)
virtual GeometricSearchData & geomSearchData() override
NonlinearSystemBase & _nl
static const std::string component
const Parallel::Communicator & comm() const
void setSolution(const NumericVector< Number > &soln)
static const std::string F
unsigned int variable_number(std::string_view var) const
static const std::string G
PetscNonlinearSolver< Real > * _solver
const std::vector< std::string > & getDisplacementVarNames() const
const std::map< std::pair< BoundaryID, BoundaryID >, PenetrationLocator *> & getPenetrationLocators() const
virtual void updateMesh(bool mesh_changing=false)
processor_id_type processor_id() const
DisplacedProblem * _displaced_problem
virtual libMesh::System & system() override