SNESGetIterationNumber#
Gets the number of nonlinear iterations completed in the current or most recent SNESSolve()
Synopsis#
#include "petscsnes.h"
PetscErrorCode SNESGetIterationNumber(SNES snes, PetscInt *iter)
Not Collective
Input Parameter#
snes -
SNES
context
Output Parameter#
iter - iteration number
Notes#
For example, during the computation of iteration 2 this would return 1.
This is useful for using lagged Jacobians (where one does not recompute the
Jacobian at each SNES
iteration). For example, the code
ierr = SNESGetIterationNumber(snes,&it);
if (!(it % 2)) {
[compute Jacobian here]
}
can be used in your function that computes the Jacobian to cause the Jacobian to be
recomputed every second SNES
iteration. See also SNESSetLagJacobian()
After the SNES
solve is complete this will return the number of nonlinear iterations used.
See Also#
SNES: Nonlinear Solvers, SNES
, SNESSolve()
, SNESSetLagJacobian()
, SNESGetLinearSolveIterations()
, SNESSetMonitor()
Level#
intermediate
Location#
Examples#
src/snes/tutorials/ex63.c
src/snes/tutorials/ex3.c
src/snes/tutorials/ex19.c
src/snes/tutorials/ex5.c
src/snes/tutorials/ex1f.F90
src/snes/tutorials/ex5f90.F90
src/snes/tutorials/ex15.c
src/snes/tutorials/ex73f90t.F90
src/snes/tutorials/ex14.c
src/snes/tutorials/ex42.c
Index of all SNES routines
Table of Contents for all manual pages
Index of all manual pages