G+Smo  25.01.0
Geometry + Simulation Modules
 
Loading...
Searching...
No Matches
gsDynamicXBraid< T > Class Template Reference

Detailed Description

template<class T>
class gismo::gsDynamicXBraid< T >

Performs the arc length method to solve a nonlinear system of equations.

Template Parameters
Tcoefficient type
+ Inheritance diagram for gsDynamicXBraid< T >:
+ Collaboration diagram for gsDynamicXBraid< T >:

Public Member Functions

braid_Int Access (braid_Vector u, BraidAccessStatus &status) override
 Handles access for input/output.
 
virtual braid_Int BufPack (braid_Vector u, void *buffer, BraidBufferStatus &status)
 Packs the given vector into the MPI communication buffer.
 
braid_Int BufSize (braid_Int *size_ptr, BraidBufferStatus &status) override
 Sets the size of the MPI communication buffer.
 
virtual braid_Int BufUnpack (void *buffer, braid_Vector *u_ptr, BraidBufferStatus &status)
 Unpacks a vector from the MPI communication buffer.
 
virtual braid_Int Clone (braid_Vector u, braid_Vector *v_ptr)
 Clones the given vector.
 
braid_Int Coarsen (braid_Vector fu, braid_Vector *cu_ptr, BraidCoarsenRefStatus &status) override
 Performs spatial coarsening.
 
virtual braid_Int Free (braid_Vector u)
 Frees the given vector.
 
void GetMyID (braid_Int *myid_ptr)
 Gets the MPI process ID.
 
void GetNLevels (braid_Int *nlevels_ptr)
 Gets the total number of levels (XBraid style)
 
void GetNumIter (braid_Int *niter_ptr)
 Gets the number of iterations (XBraid style)
 
void GetRNorms (braid_Int *nrequest_ptr, braid_Real *rnorms)
 Gets the residual norm (XBraid style)
 
 gsDynamicXBraid (const gsDynamicBase< T > *solver, const gsMpiComm &comm, const T &tstart, const T &tend, const index_t numDofs, index_t numSteps=10)
 Constructor.
 
braid_Int id ()
 Returns the MPI process ID.
 
braid_Int Init (braid_Real t, braid_Vector *u_ptr) override
 Initializes a vector.
 
braid_Int iterations ()
 Returns the number of iterations.
 
braid_Int levels ()
 Returns the total number of levels.
 
braid_Real norm (braid_Int nrequest)
 Returns the residual norm.
 
virtual braid_Int Residual (braid_Vector, braid_Vector, BraidStepStatus &)
 Computes the residual (dummy method)
 
void SetAbsTol (braid_Real tol)
 Sets absolute stopping tolerance.
 
void SetAccessLevel (braid_Int access_level)
 
void SetCFactor (braid_Int cfactor)
 Sets the coarsening factor cfactor on all grid levels.
 
void SetCFactor (braid_Int level, braid_Int cfactor)
 Sets the coarsening factor cfactor on grid level (default is 2)
 
void SetCRelaxWt (braid_Int level, braid_Real Cwt)
 Sets the C-relaxation weight.
 
void SetDefaultPrintFile ()
 Sets the default print file.
 
void SetFileIOLevel (braid_Int io_level)
 Sets the file input/output level.
 
void SetFMG ()
 Sets FMG (F-cycle)
 
void SetFullRNormRes (braid_PtFcnResidual residual)
 Sets callback function for residual numer calculation.
 
void SetIncrMaxLevels ()
 Increases the max number of multigrid levels after performing a refinement.
 
void SetMaxIter (braid_Int max_iter)
 Sets max number of multigrid iterations.
 
void SetMaxLevels (braid_Int max_levels)
 Sets the maximum number of multigrid levels.
 
void SetMaxRefinements (braid_Int max_refinements)
 Sets the max number of time grid refinement levels allowed.
 
void SetMinCoarse (braid_Int min_coarse)
 
void SetNFMG (braid_Int k)
 Sets the number of initial F-cycles to do before switching to V-cycles.
 
void SetNFMGVcyc (braid_Int nfmg_Vcyc)
 Sets the number of V-cycles to do at each FMG level (default is 1)
 
void SetNRelax (braid_Int level, braid_Int nrelax)
 
void SetNRelax (braid_Int nrelax)
 
void SetPeriodic (braid_Int periodic)
 Sets periodic time grid (default is 0)
 
void SetPrintFile (const char *printfile_name)
 Sets the output file for runtime print message.
 
void SetPrintLevel (braid_Int print_level)
 
void SetRefine (braid_Int refine)
 Turns time refinement on (refine = 1) or off (refine = 0).
 
void SetRelTol (braid_Real tol)
 Sets relative stopping tolerance.
 
void SetResidual ()
 Sets user-defined residual routine.
 
void SetRichardsonEstimation (braid_Int est_error, braid_Int richardson, braid_Int local_order)
 
void SetSeqSoln (braid_Int use_seq_soln)
 
void SetSkip (braid_Int skip)
 Sets whether to skip all work on the first down cycle (skip = 1). On by default.
 
void SetSpatialCoarsenAndRefine ()
 Sets user-defined coarsening and refinement routine.
 
void SetStorage (braid_Int storage)
 
void SetSync ()
 Sets user-defined sync routine.
 
void SetTemporalNorm (braid_Int tnorm)
 Sets the temporal norm: 1-norm (1), 2-norm (2:default), inf-norm (3)
 
void SetTimeGrid (braid_PtFcnTimeGrid tgrid)
 Sets callback function for time grid.
 
void SetTPointsCutoff (braid_Int tpoints_cutoff)
 Sets the time cutoff.
 
void solve ()
 Runs the parallel-in-time multigrid solver.
 
braid_Int SpatialNorm (braid_Vector u, braid_Real *norm_ptr) override
 Computes the spatial norm of the given vector.
 
braid_Int Step (braid_Vector u, braid_Vector ustop, braid_Vector fstop, BraidStepStatus &status) override
 Performs a single step of the parallel-in-time multigrid.
 
virtual braid_Int Sum (braid_Real alpha, braid_Vector x, braid_Real beta, braid_Vector y)
 Computes the sum of two given vectors.
 

Protected Attributes

BraidCore core
 Braid Core object.
 

Member Function Documentation

◆ SetAccessLevel()

template<typename T >
void SetAccessLevel ( braid_Int  access_level)
inlineinherited

Sets the acces level for gsXBraid. This controls how often the user's access routine is called.

  • Level 0: Never call the user's access routine
  • Level 1: Only call the user's access routine after gsXBraid is finished (default)
  • Level 2: Call the user's access routine every iteration and on every level. This is during _braid_FRestrict, during the down-cycle part of a gsXBraid iteration.

◆ SetMinCoarse()

template<typename T >
void SetMinCoarse ( braid_Int  min_coarse)
inlineinherited

Sets the minimum allowed coarse grid size. gsXBraid stops coarsening whenever creating the next coarser grid will result in a grid smaller than min_coarse. The maximum possible coarse grid size will be min_coarse*coarsening_factor.

◆ SetNRelax() [1/2]

template<typename T >
void SetNRelax ( braid_Int  level,
braid_Int  nrelax 
)
inlineinherited

Sets the number of relaxation sweeps nrelax on grid level. Level 0 is the finest grid. One sweep is a CF relaxation sweep.

◆ SetNRelax() [2/2]

template<typename T >
void SetNRelax ( braid_Int  nrelax)
inlineinherited

Sets the number of relaxation sweeps nrelax on all grid levels. One sweep is a CF relaxation sweep.

◆ SetPrintLevel()

template<typename T >
void SetPrintLevel ( braid_Int  print_level)
inlineinherited

Sets the print level for runtime print message.

  • Level 0: no output
  • Level 1: print runtime information like the residual history
  • Level 2: level 1 output, plus post-Braid run statistics (default)
  • Level 3: level 2 output, plus debug level output.

◆ SetRichardsonEstimation()

template<typename T >
void SetRichardsonEstimation ( braid_Int  est_error,
braid_Int  richardson,
braid_Int  local_order 
)
inlineinherited

Turns on built-in Richardson-based error estimation and/or extrapolation with gsXBraid. When enabled, the Richardson extrapolation (RE) option (richardson == 1) is used to improve the accuracy of the solution at the C-points on the finest level. When the built-in error estimate option is turned on (est_error == 1), RE is used to estimate the local truncation error at each point. These estimates can be accessed through StepStatus and AccessStatus functions. The last parameter is local_order, which represents the LOCAL order of the* time integration scheme. e.g. local_order = 2 for Backward Euler. Also, the Richardson error estimate is only available after roughly 1 Braid iteration. The estimate is given a dummy value of -1.0, until an actual estimate is available. Thus after an adaptive refinement, and a new hierarchy is formed, another iteration must pass before the error estimates are available again.

◆ SetSeqSoln()

template<typename T >
void SetSeqSoln ( braid_Int  use_seq_soln)
inlineinherited

Sets the initial guess to gsXBraid as the sequential time stepping solution.

  • 0: The user's Init() function initializes the state vector (default)
  • 1: Sequential time stepping, with the user's initial condition from Init(t=0) initializes the state vector

◆ SetStorage()

template<typename T >
void SetStorage ( braid_Int  storage)
inlineinherited

Sets the storage properties of the code. -1 : Default, store only C-points 0 : Full storage of C- and F-Points on all levels x > 0 : Full storage on all levels >= x