slepc-3.21.0 2024-03-30
Report Typos and Errors

NEPMonitorSet

Sets an ADDITIONAL function to be called at every iteration to monitor the error estimates for each requested eigenpair.

Synopsis

#include "slepcnep.h" 
PetscErrorCode NEPMonitorSet(NEP nep,PetscErrorCode (*monitor)(NEP nep,PetscInt its,PetscInt nconv,PetscScalar *eigr,PetscScalar *eigi,PetscReal *errest,PetscInt nest,void *mctx),void *mctx,PetscErrorCode (*monitordestroy)(void**))
Logically Collective

Input Parameters

nep  - eigensolver context obtained from NEPCreate()
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)

Calling sequence of monitor

 PetscErrorCode monitor(NEP nep,PetscInt its,PetscInt nconv,PetscScalar *eigr,PetscScalar *eigi,PetscReal *errest,PetscInt nest,void *mctx)
nep  - nonlinear eigensolver context obtained from NEPCreate()
its  - iteration number
nconv  - number of converged eigenpairs
eigr  - real part of the eigenvalues
eigi  - imaginary part of the eigenvalues
errest  - error estimates for each eigenpair
nest  - number of error estimates
mctx  - optional monitoring context, as set by NEPMonitorSet()

Options Database Keys

-nep_monitor  - print only the first error estimate
-nep_monitor_all  - print error estimates at each iteration
-nep_monitor_conv  - print the eigenvalue approximations only when convergence has been reached
-nep_monitor draw::draw_lg  - sets line graph monitor for the first unconverged approximate eigenvalue
-nep_monitor_all draw::draw_lg  - sets line graph monitor for all unconverged approximate eigenvalues
-nep_monitor_conv draw::draw_lg  - sets line graph monitor for convergence history
-nep_monitor_cancel  - cancels all monitors that have been hardwired into a code by calls to NEPMonitorSet(), but does not cancel those set via the options database.

Notes

Several different monitoring routines may be set by calling NEPMonitorSet() multiple times; all will be called in the order in which they were set.

See Also

NEPMonitorFirst(), NEPMonitorAll(), NEPMonitorCancel()

Level

intermediate

Location

src/nep/interface/nepmon.c

Index of all NEP routines
Table of Contents for all manual pages
Index of all manual pages