#include "petscksp.h" PetscErrorCode KSPMonitorSet(KSP ksp,PetscErrorCode (*monitor)(KSP,PetscInt,PetscReal,void*),void *mctx,PetscErrorCode (*monitordestroy)(void**))Logically Collective on ksp
ksp | - iterative context obtained from KSPCreate() | |
monitor | - pointer to function (if this is NULL, it turns off monitoring | |
mctx | - [optional] 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) |
monitor (KSP ksp, PetscInt it, PetscReal rnorm, void *mctx)
ksp | - iterative context obtained from KSPCreate() | |
it | - iteration number | |
rnorm | - (estimated) 2-norm of (preconditioned) residual | |
mctx | - optional monitoring context, as set by KSPMonitorSet() |
-ksp_monitor | - sets KSPMonitorDefault() | |
-ksp_monitor_true_residual | - sets KSPMonitorTrueResidualNorm() | |
-ksp_monitor_max | - sets KSPMonitorTrueResidualMaxNorm() | |
-ksp_monitor_lg_residualnorm | - sets line graph monitor, uses KSPMonitorLGResidualNormCreate() | |
-ksp_monitor_lg_true_residualnorm | - sets line graph monitor, uses KSPMonitorLGResidualNormCreate() | |
-ksp_monitor_singular_value | - sets KSPMonitorSingularValue() | |
-ksp_monitor_cancel | - cancels all monitors that have been hardwired into a code by calls to KSPMonitorSet(), but does not cancel those set via the options database. |
Several different monitoring routines may be set by calling KSPMonitorSet() multiple times; all will be called in the order in which they were set.