SNESLineSearchSetPostCheck#
Sets a user function that is called after the line search has been applied to determine the step direction and length. Allows the user a chance to change or override the decision of the line search routine
Synopsis#
#include "petscsnes.h"
PetscErrorCode SNESLineSearchSetPostCheck(SNESLineSearch linesearch, PetscErrorCode (*func)(SNESLineSearch ls, Vec x, Vec d, Vec w, PetscBool *changed_d, PetscBool *changed_w, void *ctx), void *ctx)
Logically Collective
Input Parameters#
linesearch - the
SNESLineSearch
contextfunc - [optional] function evaluation routine
ctx - [optional] user-defined context for private data for the function evaluation routine (may be
NULL
)
Calling sequence of func
#
ls - the
SNESLineSearch
contextx - the current solution
d - the current search direction
w - \( w = x + lambda*d \) for some lambda
changed_d - indicates if the search direction
d
has been changedchanged_w - indicates
w
has been changedctx - the context passed to
SNESLineSearchSetPreCheck()
Notes#
Use SNESLineSearchSetPreCheck()
to change the step before the line search is completed.
The calling sequence of the callback does not contain the current scaling factor. To access the value, use SNESLineSearchGetLambda()
.
Use SNESVISetVariableBounds()
and SNESVISetComputeVariableBounds()
to cause SNES
to automatically control the ranges of variables allowed.
See Also#
SNES: Nonlinear Solvers, SNES
, SNESLineSearch
, SNESGetLineSearch()
, SNESLineSearchPostCheck()
, SNESLineSearchSetPreCheck()
, SNESLineSearchGetPreCheck()
, SNESLineSearchGetPostCheck()
,
SNESVISetVariableBounds()
, SNESVISetComputeVariableBounds()
, SNESSetFunctionDomainError()
, SNESSetJacobianDomainError()
Level#
intermediate
Location#
Examples#
src/snes/tutorials/ex3.c
src/ts/tutorials/ex27.c
Index of all SNES routines
Table of Contents for all manual pages
Index of all manual pages