Sparse linear equation solver driver. More...
#include "cs_defs.h"
#include <stdarg.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <assert.h>
#include <math.h>
#include "bft_mem.h"
#include "bft_error.h"
#include "bft_printf.h"
#include "cs_base.h"
#include "cs_blas.h"
#include "cs_field.h"
#include "cs_log.h"
#include "cs_halo.h"
#include "cs_map.h"
#include "cs_mesh.h"
#include "cs_mesh_location.h"
#include "cs_matrix.h"
#include "cs_matrix_default.h"
#include "cs_matrix_util.h"
#include "cs_parall.h"
#include "cs_post.h"
#include "cs_timer.h"
#include "cs_timer_stats.h"
#include "cs_time_step.h"
#include "cs_sles.h"
Functions | |
void | cs_sles_set_epzero (double new_value) |
Set the threshold value used in the detection of immediate exit. | |
double | cs_sles_get_epzero (void) |
Get the current threshold value used in the detection of immediate exit. | |
void | cs_sles_initialize (void) |
Initialize sparse linear equation solver API. | |
void | cs_sles_finalize (void) |
Finalize sparse linear equation solver API. | |
void | cs_sles_log (cs_log_t log_type) |
Log sparse linear equation solver info. | |
cs_sles_t * | cs_sles_find (int f_id, const char *name) |
Return pointer to linear system object, based on matching field id or system name. | |
cs_sles_t * | cs_sles_find_or_add (int f_id, const char *name) |
Return pointer to linear system object, based on matching field id or system name. | |
void | cs_sles_push (int f_id, const char *name) |
Temporarily replace field id with name for matching calls to cs_sles_setup, cs_sles_solve, cs_sles_free, and other operations involving access through a field id. | |
void | cs_sles_pop (int f_id) |
Restore behavior temporarily modified by cs_sles_push. | |
cs_sles_t * | cs_sles_define (int f_id, const char *name, void *context, const char *type_name, cs_sles_setup_t *setup_func, cs_sles_solve_t *solve_func, cs_sles_free_t *free_func, cs_sles_log_t *log_func, cs_sles_copy_t *copy_func, cs_sles_destroy_t *destroy_func) |
Define sparse linear equation solver for a given field or equation name. | |
void | cs_sles_set_verbosity (cs_sles_t *sles, int verbosity) |
Set the verbosity for a given linear equation solver. | |
int | cs_sles_get_verbosity (cs_sles_t *sles) |
Get the verbosity for a given linear equation solver. | |
void | cs_sles_set_post_output (cs_sles_t *sles, int writer_id) |
Activate postprocessing output for a given linear equation solver. | |
int | cs_sles_get_post_output (cs_sles_t *sles) |
Return the id of the associated writer if postprocessing output is active for a given linear equation solver. | |
const char * | cs_sles_get_type (cs_sles_t *sles) |
Return type name of solver context. | |
void * | cs_sles_get_context (cs_sles_t *sles) |
Return pointer to solver context structure pointer. | |
int | cs_sles_get_f_id (const cs_sles_t *sles) |
Return field id associated with a given sparse linear equation solver. | |
const char * | cs_sles_get_name (const cs_sles_t *sles) |
Return name associated with a given sparse linear equation solver. | |
bool | cs_sles_get_allow_no_op (const cs_sles_t *sles) |
Query if immediate_return ("no-op") is allowed when initial guess is zero (solve by increments) and the RHS is already zero within the normalized tolerance criteria. | |
void | cs_sles_set_allow_no_op (cs_sles_t *sles, bool allow_no_op) |
Indicate if immediate_return ("no-op") is allowed when initial guess is zero (solve by increments) and the RHS is already zero within the normalized tolerance criteria. | |
void | cs_sles_setup (cs_sles_t *sles, const cs_matrix_t *a) |
Setup sparse linear equation solver. | |
cs_sles_convergence_state_t | cs_sles_solve (cs_sles_t *sles, const cs_matrix_t *a, double precision, double r_norm, int *n_iter, double *residual, const cs_real_t *rhs, cs_real_t *vx, size_t aux_size, void *aux_vectors) |
General sparse linear system resolution. | |
void | cs_sles_free (cs_sles_t *sles) |
Free sparse linear equation solver setup. | |
int | cs_sles_copy (cs_sles_t *dest, const cs_sles_t *src) |
Copy the definition of a sparse linear equation solver to another. | |
void | cs_sles_set_error_handler (cs_sles_t *sles, cs_sles_error_handler_t *error_handler_func) |
Associate a convergence error handler to a given sparse linear equation solver. | |
cs_sles_define_t * | cs_sles_get_default_define (void) |
Return pointer to default sparse linear solver definition function. | |
void | cs_sles_set_default_define (cs_sles_define_t *define_func) |
Set default sparse linear solver definition function. | |
void | cs_sles_set_default_verbosity (cs_sles_verbosity_t *verbosity_func) |
Set default verbosity definition function. | |
void | cs_sles_post_error_output_def (const char *name, int mesh_id, const cs_matrix_t *a, const cs_real_t *rhs, cs_real_t *vx) |
Output default post-processing data for failed system convergence. | |
void | cs_sles_post_output_var (const char *name, int mesh_id, int location_id, int writer_id, int diag_block_size, cs_real_t var[]) |
Output post-processing variable related to system convergence. | |
const char * | cs_sles_base_name (int f_id, const char *name) |
Return base name associated to a field id, name couple. | |
const char * | cs_sles_name (int f_id, const char *name) |
Return name associated to a field id, name couple. |
Sparse linear equation solver driver.
The Sparse Linear Equation Solver subsystem is designed to allow both simple usage of built-in solvers, and plugging of solvers from external libraries.
As the options associated with different solvers may be very varied, this subsystem is based on the use of a series of callback functions which may be associated with a given linear system (defined either by field id for quick and recurrent access, or by unique system name). It is possible to provide a default function so calls for the resolution of systems not specified before can be handled.
To summarize, the functions here define a linear system solver driver, with the real work being done by functions bound to this model. The main intent is to help manage passing varied user options to the solvers, and handling consistency of logging.
const char * cs_sles_base_name | ( | int | f_id, |
const char * | name ) |
Return base name associated to a field id, name couple.
This is simply a utility function which will return its name argument if f_id < 0, and the associated field's name or label otherwise.
[in] | f_id | associated field id, or < 0 |
[in] | name | associated name if f_id < 0, or NULL |
Copy the definition of a sparse linear equation solver to another.
The intended use of this function is to allow associating different solvers to related systems, so as to differentiate logging, while using the same settings by default.
If the source solver does not provide a cs_sles_copy_t function, No modification is done to the solver. If the copy function is available, the context is copied, as are the matching function pointers.
If previous settings have been defined and used, they are saved as per cs_sles_define.
[in,out] | dest | pointer to destination solver object |
[in] | src | pointer to source solver object |
cs_sles_t * cs_sles_define | ( | int | f_id, |
const char * | name, | ||
void * | context, | ||
const char * | type_name, | ||
cs_sles_setup_t * | setup_func, | ||
cs_sles_solve_t * | solve_func, | ||
cs_sles_free_t * | free_func, | ||
cs_sles_log_t * | log_func, | ||
cs_sles_copy_t * | copy_func, | ||
cs_sles_destroy_t * | destroy_func ) |
Define sparse linear equation solver for a given field or equation name.
If this system did not previously exist, it is added to the list of "known" systems.
The context pointer is used to point to a structure adapted to the function pointers given here, and combined with those functions, allows using both built-in, external, or user-defined solvers.
It is recommended the context type name provided here directly relate to the associated structure type (for example, "cs_sles_it_t" or "cs_multigrid_t").
[in] | f_id | associated field id, or < 0 |
[in] | name | associated name if f_id < 0, or NULL |
[in,out] | context | pointer to solver context management structure (cs_sles subsystem becomes owner) |
[in] | type_name | context structure or object type name |
[in] | setup_func | pointer to system setup function |
[in] | solve_func | pointer to system solution function (also calls setup_func if not done yet or free_func called since last solve) |
[in] | free_func | pointer function freeing system setup |
[in] | log_func | pointer to system info logging function (optional, but recommended) |
[in] | copy_func | pointer to settings copy function (optional) |
[in] | destroy_func | pointer to function destroying solver context (called with cs_sles_finalize or with a new call to this function for the same system) |
void cs_sles_finalize | ( | void | ) |
Finalize sparse linear equation solver API.
cs_sles_t * cs_sles_find | ( | int | f_id, |
const char * | name ) |
Return pointer to linear system object, based on matching field id or system name.
If this system did not previously exist, NULL is returned.
[in] | f_id | associated field id, or < 0 |
[in] | name | associated name if f_id < 0, or NULL |
cs_sles_t * cs_sles_find_or_add | ( | int | f_id, |
const char * | name ) |
Return pointer to linear system object, based on matching field id or system name.
If this system did not previously exist, it is created and added to to the list of "known" systems. In this case, it will be usable only if cs_sles_define() is called for the same field id and name (in which case calling the present function is redundant), or if cs_sles_set_sefault_define() has been previously used to define the default solver policy.
[in] | f_id | associated field id, or < 0 |
[in] | name | associated name if f_id < 0, or NULL |
void cs_sles_free | ( | cs_sles_t * | sles | ) |
Free sparse linear equation solver setup.
This function frees resolution-related data, such as multigrid hierarchy, preconditioning, and any other temporary arrays or objects required for resolution, but maintains context information such as that used for logging (especially performance data).
[in,out] | sles | pointer to solver object |
Query if immediate_return ("no-op") is allowed when initial guess is zero (solve by increments) and the RHS is already zero within the normalized tolerance criteria.
[in] | sles | pointer to solver object |
void * cs_sles_get_context | ( | cs_sles_t * | sles | ) |
Return pointer to solver context structure pointer.
The context structure depends on the type of solver used, which may in turn be determined by the string returned by cs_sles_get_type(). If may be used by appropriate functions specific to that type.
[in] | sles | pointer to solver object |
cs_sles_define_t * cs_sles_get_default_define | ( | void | ) |
Return pointer to default sparse linear solver definition function.
The associated function will be used to provide a definition when cs_sles_setup or cs_sles_solve is used for a system for which no matching call to cs_sles_define has been done.
double cs_sles_get_epzero | ( | void | ) |
Get the current threshold value used in the detection of immediate exit.
int cs_sles_get_f_id | ( | const cs_sles_t * | sles | ) |
Return field id associated with a given sparse linear equation solver.
[in] | sles | pointer to solver object |
const char * cs_sles_get_name | ( | const cs_sles_t * | sles | ) |
Return name associated with a given sparse linear equation solver.
This is simply a utility function which will return its name argument if f_id < 0, and the associated field's name or label otherwise.
[in] | sles | pointer to solver object |
int cs_sles_get_post_output | ( | cs_sles_t * | sles | ) |
Return the id of the associated writer if postprocessing output is active for a given linear equation solver.
[in] | sles | pointer to solver object |
const char * cs_sles_get_type | ( | cs_sles_t * | sles | ) |
Return type name of solver context.
The returned string is intended to help determine which type is associated with the void * pointer returned by cs_sles_get_context for a given solver definition, so as to be able to call additional specific functions beyond the generic functions assigned to a cs_sles_t object.
If no type_name string was associated to the solver upon its definition by cs_sles_define, or it has not been defined yet, the string returned is "<undefined>". It is recommended the type name provided cs_sles_define directly relate to the associated structure type (for example, "cs_sles_it_t" or "cs_multigrid_t").
[in] | sles | pointer to solver object |
int cs_sles_get_verbosity | ( | cs_sles_t * | sles | ) |
Get the verbosity for a given linear equation solver.
This verbosity will be used by cs_sles_setup and cs_sles_solve.
[in,out] | sles | pointer to solver object |
void cs_sles_initialize | ( | void | ) |
Initialize sparse linear equation solver API.
void cs_sles_log | ( | cs_log_t | log_type | ) |
Log sparse linear equation solver info.
[in] | log_type | log type (CS_LOG_SETUP or CS_LOG_PERFORMANCE) |
const char * cs_sles_name | ( | int | f_id, |
const char * | name ) |
Return name associated to a field id, name couple.
[in] | f_id | associated field id, or < 0 |
[in] | name | associated name if f_id < 0, or NULL |
void cs_sles_pop | ( | int | f_id | ) |
Restore behavior temporarily modified by cs_sles_push.
[in] | f_id | associated field id, or < 0 |
void cs_sles_post_error_output_def | ( | const char * | name, |
int | mesh_id, | ||
const cs_matrix_t * | a, | ||
const cs_real_t * | rhs, | ||
cs_real_t * | vx ) |
Output default post-processing data for failed system convergence.
[in] | name | variable name |
[in] | mesh_id | id of error output mesh, or 0 if none |
[in] | a | linear equation matrix |
[in] | rhs | right hand side |
[in,out] | vx | current system solution |
void cs_sles_post_output_var | ( | const char * | name, |
int | mesh_id, | ||
int | location_id, | ||
int | writer_id, | ||
int | diag_block_size, | ||
cs_real_t | var[] ) |
Output post-processing variable related to system convergence.
[in] | name | variable name |
[in] | mesh_id | id of error output mesh, or 0 if none |
[in] | location_id | mesh location id (cells or vertices) |
[in] | writer_id | id of specified associated writer, or CS_POST_WRITER_ALL_ASSOCIATED for all |
[in] | diag_block_size | block size for diagonal |
[in,out] | var | variable values |
void cs_sles_push | ( | int | f_id, |
const char * | name ) |
Temporarily replace field id with name for matching calls to cs_sles_setup, cs_sles_solve, cs_sles_free, and other operations involving access through a field id.
This function is provided to allow some peculiar calling sequences, in which cs_equation_iterative_solve_scalar is called with a given field id, but specific solver options must still be set. In the future, a cleaner method to handle those exceptional cases would be preferred. As such, only a stack depth of 1 is allowed.
[in] | f_id | associated field id, or < 0 |
[in] | name | associated name if f_id < 0, or NULL |
Indicate if immediate_return ("no-op") is allowed when initial guess is zero (solve by increments) and the RHS is already zero within the normalized tolerance criteria.
[in,out] | sles | pointer to solver object |
[in] | allow_no_op | true if immediate return is allowed, false if at least one iteration is required |
void cs_sles_set_default_define | ( | cs_sles_define_t * | define_func | ) |
Set default sparse linear solver definition function.
The provided function will be used to provide a definition when cs_sles_setup or cs_sles_solve is used for a system for which no matching call to cs_sles_define has been done.
[in] | define_func | pointer to default definition function |
void cs_sles_set_default_verbosity | ( | cs_sles_verbosity_t * | verbosity_func | ) |
Set default verbosity definition function.
The provided function will be used to define the verbosity when cs_sles_find_or_add is called.
[in] | verbosity_func | pointer to default verbosity function |
void cs_sles_set_epzero | ( | double | new_value | ) |
Set the threshold value used in the detection of immediate exit.
void cs_sles_set_error_handler | ( | cs_sles_t * | sles, |
cs_sles_error_handler_t * | error_handler_func ) |
Associate a convergence error handler to a given sparse linear equation solver.
The error will be called whenever convergence fails. To dissassociate the error handler, this function may be called with handler
= NULL.
The association will only be successful if the matching solver has already been defined.
[in,out] | sles | pointer to solver object |
[in] | error_handler_func | pointer to convergence error handler function |
void cs_sles_set_post_output | ( | cs_sles_t * | sles, |
int | writer_id ) |
Activate postprocessing output for a given linear equation solver.
This allows the output of the residual at the end of each solution series, using a single postprocessing writer. By default, no output is activated.
[in,out] | sles | pointer to solver object |
[in] | writer_id | id of the writer |
void cs_sles_set_verbosity | ( | cs_sles_t * | sles, |
int | verbosity ) |
Set the verbosity for a given linear equation solver.
This verbosity will be used by cs_sles_setup and cs_sles_solve.
By default, the verbosity is set to 0, or the value returned by the function set with cs_sles_set_default_define().
[in,out] | sles | pointer to solver object |
[in] | verbosity | verbosity level |
void cs_sles_setup | ( | cs_sles_t * | sles, |
const cs_matrix_t * | a ) |
Setup sparse linear equation solver.
Use of this function is optional: if a cs_sles_solve is called for the same system before this function is called, the latter will be called automatically.
If no options were previously provided for the matching system, default options will be used.
[in,out] | sles | pointer to solver object |
[in] | a | matrix |
cs_sles_convergence_state_t cs_sles_solve | ( | cs_sles_t * | sles, |
const cs_matrix_t * | a, | ||
double | precision, | ||
double | r_norm, | ||
int * | n_iter, | ||
double * | residual, | ||
const cs_real_t * | rhs, | ||
cs_real_t * | vx, | ||
size_t | aux_size, | ||
void * | aux_vectors ) |
General sparse linear system resolution.
If no options were previously provided for the matching system, default options will be used.
Note that if cs_sles_setup was previously called for this system, and cs_sles_free has not been called since, the matrix provided should be the same. The optional separation between the two stages is intended to allow amortizing the cost of setup over multiple solutions.
The system is considered to have converged when residual/r_norm <= precision, residual being the L2 norm of a.vx-rhs.
[in,out] | sles | pointer to solver object |
[in] | a | matrix |
[in] | precision | solver precision |
[in] | r_norm | residual normalization |
[out] | n_iter | number of "equivalent" iterations |
[out] | residual | residual |
[in] | rhs | right hand side |
[in,out] | vx | system solution |
[in] | aux_size | size of aux_vectors (in bytes) |
aux_vectors | optional working area (internal allocation if NULL) |