:orphan:
# SNESMonitorSet
Sets an ADDITIONAL function that is to be used at every iteration of the nonlinear solver to display the iteration's progress.
## Synopsis
```
#include "petscsnes.h"
PetscErrorCode SNESMonitorSet(SNES snes, PetscErrorCode (*f)(SNES, PetscInt, PetscReal, void *), void *mctx, PetscErrorCode (*monitordestroy)(void **))
```
Logically Collective
## Input Parameters
- ***snes -*** the `SNES` context
- ***f -*** the monitor function, for the calling sequence see `SNESMonitorFunction`
- ***mctx -*** [optional] user-defined context for private data for the
monitor routine (use `NULL` if no context is desired)
- ***monitordestroy -*** [optional] routine that frees monitor context (may be `NULL`)
## Options Database Keys
- ***-snes_monitor -*** sets `SNESMonitorDefault()`
- ***-snes_monitor draw::draw_lg -*** sets line graph monitor,
- ***-snes_monitor_cancel -*** cancels all monitors that have been hardwired into a code by calls to `SNESMonitorSet()`, but does not cancel those set via
the options database.
## Note
Several different monitoring routines may be set by calling
`SNESMonitorSet()` multiple times; all will be called in the
order in which they were set.
## Fortran Note
Only a single monitor function can be set for each `SNES` object
## See Also
[](ch_snes), `SNES`, `SNESSolve()`, `SNESMonitorDefault()`, `SNESMonitorCancel()`, `SNESMonitorFunction`
## Level
intermediate
## Location
src/snes/interface/snes.c
## Examples
src/snes/tutorials/ex2.c
src/snes/tutorials/ex21.c
src/snes/tutorials/ex22.c
src/snes/tutorials/ex3.c
src/ts/tutorials/ex12.c
src/ts/tutorials/ex52.c
src/ts/tutorials/ex7.c
---
[Edit on GitLab](https://gitlab.com/petsc/petsc/-/edit/release/src/snes/interface/snes.c)
[Index of all SNES routines](index.md)
[Table of Contents for all manual pages](/manualpages/index.md)
[Index of all manual pages](/manualpages/singleindex.md)