8.2
general documentation
Loading...
Searching...
No Matches
cs_cdofb_monolithic_sles.h File Reference
#include "cs_defs.h"
#include "cs_cdofb_monolithic_priv.h"
Include dependency graph for cs_cdofb_monolithic_sles.h:

Go to the source code of this file.

Functions

void cs_cdofb_monolithic_sles_init_sharing (const cs_mesh_t *mesh, const cs_cdo_connect_t *connect, const cs_cdo_quantities_t *quant)
 Set pointers to shared structures.
void cs_cdofb_monolithic_sles_init_system_helper (const cs_navsto_param_t *nsp, const cs_param_saddle_t *saddlep, cs_cdofb_monolithic_t *sc)
 Define the system helper for a CDO-Fb scheme solving the Navier-Stokes equation using a monolithic approach for the velocity-pressure coupling.
void cs_cdofb_monolithic_sles_init_solver (const cs_navsto_param_t *nsp, const cs_param_saddle_t *saddlep, cs_cdofb_monolithic_t *sc)
 Define the saddle solver and its context for a CDO-Fb scheme solving the Navier-Stokes equation using a monolithic approach for the velocity-pressure coupling.
void cs_cdofb_monolithic_set_sles (cs_navsto_param_t *nsp, void *context)
 Start setting-up the Navier-Stokes equations when a monolithic algorithm is used to couple the system. No mesh information is available at this stage. nsp is not declared as const to avoid compilation warnings but it should be modified at this stage.
int cs_cdofb_monolithic_sles_alu (const cs_navsto_param_t *nsp, cs_saddle_solver_t *solver, cs_real_t *u_f, cs_real_t *p_c)
 Solve a linear system arising from the discretization of the Navier-Stokes equation using a monolithic velocity-pressure coupling with a CDO face-based approach. Solve this system using the Augmented Lagrangian-Uzawa algorithm.
int cs_cdofb_monolithic_sles_block_krylov (const cs_navsto_param_t *nsp, cs_saddle_solver_t *solver, cs_real_t *u_f, cs_real_t *p_c)
 Solve a linear system arising from the discretization of the Navier-Stokes equation with a CDO face-based approach. The system is split into a velocity block and the (unassembled) divergence operator Block preconditioning using a Schur approximation on a Krylov solver such as the GCR or MINRES is available.
int cs_cdofb_monolithic_sles_gkb_inhouse (const cs_navsto_param_t *nsp, cs_saddle_solver_t *solver, cs_real_t *u_f, cs_real_t *p_c)
 Solve a linear system arising from the discretization of the Navier-Stokes equation using a monolithic velocity-pressure coupling with a CDO face-based approach. Solve this system using the Golub-Kahan Bidiagonalization algorithm. In-house implementation. The PETSc implementation is also available but appears less efficient in our tests.
int cs_cdofb_monolithic_sles_full_system (const cs_navsto_param_t *nsp, cs_saddle_solver_t *solver, cs_real_t *u_f, cs_real_t *p_c)
 Solve a linear system arising from the discretization of the Navier-Stokes equation with a CDO face-based approach. The full system is treated as one block and solved as it is. In this situation, PETSc or MUMPS are usually considered.
int cs_cdofb_monolithic_sles_notay (const cs_navsto_param_t *nsp, cs_saddle_solver_t *solver, cs_real_t *u_f, cs_real_t *p_c)
 Solve a linear system arising from the discretization of the Navier-Stokes equation using a monolithic velocity-pressure coupling with a CDO face-based approach. Solve this system using the Notay's algebraic transformation. The full system is treated as one block and solved as it is. In this situation, PETSc or MUMPS are usually considered.
int cs_cdofb_monolithic_sles_uzawa_cg (const cs_navsto_param_t *nsp, cs_saddle_solver_t *solver, cs_real_t *u_f, cs_real_t *p_c)
 Solve a linear system arising from the discretization of the Navier-Stokes equation using a monolithic velocity-pressure coupling with a CDO face-based approach. Solve this system using the Uzawa-CG algorithm.

Function Documentation

◆ cs_cdofb_monolithic_set_sles()

void cs_cdofb_monolithic_set_sles ( cs_navsto_param_t * nsp,
void * context )

Start setting-up the Navier-Stokes equations when a monolithic algorithm is used to couple the system. No mesh information is available at this stage. nsp is not declared as const to avoid compilation warnings but it should be modified at this stage.

Parameters
[in]nsppointer to a cs_navsto_param_t structure
[in,out]contextpointer to a context structure cast on-the-fly

◆ cs_cdofb_monolithic_sles_alu()

int cs_cdofb_monolithic_sles_alu ( const cs_navsto_param_t * nsp,
cs_saddle_solver_t * solver,
cs_real_t * u_f,
cs_real_t * p_c )

Solve a linear system arising from the discretization of the Navier-Stokes equation using a monolithic velocity-pressure coupling with a CDO face-based approach. Solve this system using the Augmented Lagrangian-Uzawa algorithm.

Parameters
[in]nspset of parameters related to the Navier-Stokes eqs.
[in,out]solverpointer to a cs_saddle_solver_t structure
[in,out]u_fvalues of the velocity at faces (3 components)
[in,out]p_cvalues of the pressure in cells
Returns
the (cumulated) number of iterations of the solver

◆ cs_cdofb_monolithic_sles_block_krylov()

int cs_cdofb_monolithic_sles_block_krylov ( const cs_navsto_param_t * nsp,
cs_saddle_solver_t * solver,
cs_real_t * u_f,
cs_real_t * p_c )

Solve a linear system arising from the discretization of the Navier-Stokes equation with a CDO face-based approach. The system is split into a velocity block and the (unassembled) divergence operator Block preconditioning using a Schur approximation on a Krylov solver such as the GCR or MINRES is available.

Parameters
[in]nspset of parameters related to the Navier-Stokes eqs.
[in,out]solverpointer to a saddle-point solver
[in,out]u_fvalues of the velocity at faces (3 components)
[in,out]p_cvalues of the pressure in cells
Returns
the (cumulated) number of iterations of the solver

◆ cs_cdofb_monolithic_sles_full_system()

int cs_cdofb_monolithic_sles_full_system ( const cs_navsto_param_t * nsp,
cs_saddle_solver_t * solver,
cs_real_t * u_f,
cs_real_t * p_c )

Solve a linear system arising from the discretization of the Navier-Stokes equation with a CDO face-based approach. The full system is treated as one block and solved as it is. In this situation, PETSc or MUMPS are usually considered.

Parameters
[in]nspset of parameters related to the Navier-Stokes eqs.
[in,out]solverpointer to a saddle-point solver
[in,out]u_fvalues of the velocity at faces (3 components)
[in,out]p_cvalues of the pressure in cells
Returns
the (cumulated) number of iterations of the solver

◆ cs_cdofb_monolithic_sles_gkb_inhouse()

int cs_cdofb_monolithic_sles_gkb_inhouse ( const cs_navsto_param_t * nsp,
cs_saddle_solver_t * solver,
cs_real_t * u_f,
cs_real_t * p_c )

Solve a linear system arising from the discretization of the Navier-Stokes equation using a monolithic velocity-pressure coupling with a CDO face-based approach. Solve this system using the Golub-Kahan Bidiagonalization algorithm. In-house implementation. The PETSc implementation is also available but appears less efficient in our tests.

Parameters
[in]nspset of parameters related to the Navier-Stokes eqs.
[in,out]solverpointer to a cs_saddle_solver_t structure
[in,out]u_fvalues of the velocity at faces (3 components)
[in,out]p_cvalues of the pressure in cells
Returns
the (cumulated) number of iterations of the solver

◆ cs_cdofb_monolithic_sles_init_sharing()

void cs_cdofb_monolithic_sles_init_sharing ( const cs_mesh_t * mesh,
const cs_cdo_connect_t * connect,
const cs_cdo_quantities_t * quant )

Set pointers to shared structures.

Parameters
[in]meshpointer to the mesh structure
[in]connectpointer to additional CDO connectivities
[in]quantpointer to additional CDO mesh quantities

◆ cs_cdofb_monolithic_sles_init_solver()

void cs_cdofb_monolithic_sles_init_solver ( const cs_navsto_param_t * nsp,
const cs_param_saddle_t * saddlep,
cs_cdofb_monolithic_t * sc )

Define the saddle solver and its context for a CDO-Fb scheme solving the Navier-Stokes equation using a monolithic approach for the velocity-pressure coupling.

Parameters
[in]nspset of parameters for the Navier-Stokes system
[in]saddlepparameters for solving a saddle-point problem
[in,out]scpointer to a context structure cast on-the-fly

◆ cs_cdofb_monolithic_sles_init_system_helper()

void cs_cdofb_monolithic_sles_init_system_helper ( const cs_navsto_param_t * nsp,
const cs_param_saddle_t * saddlep,
cs_cdofb_monolithic_t * sc )

Define the system helper for a CDO-Fb scheme solving the Navier-Stokes equation using a monolithic approach for the velocity-pressure coupling.

Parameters
[in]nspNavier-Stokes paremeters
[in]saddlepparameters for solving a saddle-point problem
[in,out]scpointer to a context structure cast on-the-fly

◆ cs_cdofb_monolithic_sles_notay()

int cs_cdofb_monolithic_sles_notay ( const cs_navsto_param_t * nsp,
cs_saddle_solver_t * solver,
cs_real_t * u_f,
cs_real_t * p_c )

Solve a linear system arising from the discretization of the Navier-Stokes equation using a monolithic velocity-pressure coupling with a CDO face-based approach. Solve this system using the Notay's algebraic transformation. The full system is treated as one block and solved as it is. In this situation, PETSc or MUMPS are usually considered.

Parameters
[in]nspset of parameters related to the Navier-Stokes eqs.
[in,out]solverpointer to a cs_saddle_solver_t structure
[in,out]u_fvalues of the velocity at faces (3 components)
[in,out]p_cvalues of the pressure in cells
Returns
the (cumulated) number of iterations of the solver

◆ cs_cdofb_monolithic_sles_uzawa_cg()

int cs_cdofb_monolithic_sles_uzawa_cg ( const cs_navsto_param_t * nsp,
cs_saddle_solver_t * solver,
cs_real_t * u_f,
cs_real_t * p_c )

Solve a linear system arising from the discretization of the Navier-Stokes equation using a monolithic velocity-pressure coupling with a CDO face-based approach. Solve this system using the Uzawa-CG algorithm.

Parameters
[in]nspset of parameters related to the Navier-Stokes eqs.
[in,out]solverpointer to a cs_saddle_solver_t structure
[in,out]u_fvalues of the velocity at faces (3 components)
[in,out]p_cvalues of the pressure in cells
Returns
the (cumulated) number of iterations of the solver