FNSetParallel#

Selects the mode of operation in parallel runs.

Synopsis#

#include "slepcfn.h" 
PetscErrorCode FNSetParallel(FN fn,FNParallelType pmode)

Logically Collective

Input Parameters#

  • fn - the math function context

  • pmode - the parallel mode

Options Database Key#

  • -fn_parallel - Sets the parallel mode, either ‘redundant’ or ‘synchronized’

Notes#

This is relevant only when the function is evaluated on a matrix, with either FNEvaluateFunctionMat() or FNEvaluateFunctionMatVec().

In the ‘redundant’ parallel mode, all processes will make the computation redundantly, starting from the same data, and producing the same result. This result may be slightly different in the different processes if using a multithreaded BLAS library, which may cause issues in ill-conditioned problems.

In the ‘synchronized’ parallel mode, only the first MPI process performs the computation and then the computed matrix is broadcast to the other processes in the communicator. This communication is done automatically at the end of FNEvaluateFunctionMat() or FNEvaluateFunctionMatVec().

See Also#

FNEvaluateFunctionMat() or FNEvaluateFunctionMatVec(), FNGetParallel()

Level#

advanced

Location#

src/sys/classes/fn/interface/fnbasic.c


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