1 #ifndef __CS_EQUATION_BUILDER_H__ 2 #define __CS_EQUATION_BUILDER_H__ 258 cs_eflag_t _flag = eqb->msh_flag | eqb->st_msh_flag;
261 _flag |= eqb->bd_msh_flag;
Store common elements used when building an algebraic system related to an equation.
cs_cdo_system_helper_t * system_helper
Definition: cs_equation_builder.h:147
void cs_equation_builder_reset(cs_equation_builder_t *eqb)
Free some members of a cs_equation_builder_t structure.
Definition: cs_equation_builder.c:330
cs_timer_counter_t tcs
Definition: cs_equation_builder.h:229
cs_real_t * dir_values
Definition: cs_equation_builder.h:190
Definition: cs_equation_builder.h:91
bool diff_pty_uniform
Definition: cs_equation_builder.h:117
unsigned char cs_mask_t
Definition: cs_flag.h:158
Set of parameters to handle an unsteady convection-diffusion-reaction equation with term sources...
Definition: cs_equation_param.h:186
cs_source_term_cellwise_t * compute_source[CS_N_MAX_SOURCE_TERMS]
Definition: cs_equation_builder.h:139
const cs_range_set_t * cs_equation_builder_get_range_set(const cs_equation_builder_t *builder, int block_id)
Retrieve the range set structure associated to a builder structure for the block defined in block_id ...
Definition: cs_equation_builder.c:256
static cs_eflag_t cs_equation_builder_cell_mesh_flag(cs_flag_t cell_flag, const cs_equation_builder_t *eqb)
Retrieve the flag to give for building a cs_cell_mesh_t structure.
Definition: cs_equation_builder.h:255
#define BEGIN_C_DECLS
Definition: cs_defs.h:510
void() cs_equation_build_hook_t(const cs_equation_param_t *eqp, const cs_equation_builder_t *eqb, const void *eqc, const cs_cell_mesh_t *cm, void *context, cs_hodge_t *mass_hodge, cs_hodge_t *diff_hodge, cs_cell_sys_t *csys, cs_cell_builder_t *cb)
Generic function prototype for a hook during the cellwise building of the linear system Enable an adv...
Definition: cs_equation_builder.h:76
void * hook_context
Definition: cs_equation_builder.h:215
Definition: cs_cdo_system.h:368
Set of local quantities and connectivities related to a mesh cell.
Definition: cs_cdo_local.h:203
bool graddiv_pty_uniform
Definition: cs_equation_builder.h:119
cs_equation_build_hook_t * hook_function
Definition: cs_equation_builder.h:216
cs_mask_t * source_mask
Definition: cs_equation_builder.h:130
Structure associated to a discrete Hodge operator *.
Definition: cs_hodge.h:186
double cs_real_t
Floating-point value.
Definition: cs_defs.h:322
cs_equation_builder_t * cs_equation_builder_create(const cs_equation_param_t *eqp, const cs_mesh_t *mesh)
Allocate a new structure to handle the building of algebraic system related to a cs_equation_t struct...
Definition: cs_equation_builder.c:100
Set of arrays and local (small) dense matrices related to a mesh cell This is a key structure for bui...
Definition: cs_cdo_local.h:147
void cs_equation_builder_free(cs_equation_builder_t **p_builder)
Free a cs_equation_builder_t structure.
Definition: cs_equation_builder.c:285
struct _cs_matrix_t cs_matrix_t
Definition: cs_matrix.h:110
bool reac_pty_uniform[CS_CDO_N_MAX_REACTIONS]
Definition: cs_equation_builder.h:121
Set of common parameters to manage an iterative algorithm.
Definition: cs_iter_algo.h:101
cs_flag_t sys_flag
Definition: cs_equation_builder.h:109
bool time_pty_uniform
Definition: cs_equation_builder.h:120
cs_real_t * enforced_values
Definition: cs_equation_builder.h:156
Definition: cs_cdo_bc.h:109
void cs_equation_builder_log_performance(const cs_equation_param_t *eqp, const cs_equation_builder_t *eqb)
Print a message in the performance output file related to the monitoring of equation.
Definition: cs_equation_builder.c:351
cs_eflag_t st_msh_flag
Definition: cs_equation_builder.h:106
cs_cdo_bc_face_t * face_bc
Definition: cs_equation_builder.h:187
Definition: cs_range_set.h:57
Set of local and temporary buffers.
Definition: cs_cdo_local.h:60
bool curlcurl_pty_uniform
Definition: cs_equation_builder.h:118
cs_real_t * increment
Definition: cs_equation_builder.h:171
cs_eflag_t bd_msh_flag
Definition: cs_equation_builder.h:103
cs_eflag_t msh_flag
Definition: cs_equation_builder.h:100
void cs_equation_builder_enforce_block_dofs(const cs_equation_builder_t *eqb, cs_cell_builder_t *cb, cs_cell_sys_t *csys)
Take into account the enforcement of internal DoFs. Case of matrices defined by blocks. Apply an algebraic manipulation. Update members of the cs_cell_sys_t structure related to the internal enforcement.
Definition: cs_equation_builder.c:576
#define CS_CDO_N_MAX_REACTIONS
Definition: cs_param_cdo.h:74
void cs_equation_builder_init_properties(const cs_equation_param_t *eqp, const cs_equation_builder_t *eqb, cs_hodge_t *diff_hodge, cs_cell_builder_t *cb)
Initialize all properties potentially useful to build the algebraic system. This function is shared a...
Definition: cs_equation_builder.c:440
#define END_C_DECLS
Definition: cs_defs.h:511
unsigned short int cs_flag_t
Definition: cs_defs.h:324
#define CS_N_MAX_SOURCE_TERMS
Definition: cs_source_term.h:49
bool init_step
Definition: cs_equation_builder.h:93
const cs_matrix_t * cs_equation_builder_get_matrix(const cs_equation_builder_t *builder, int block_id)
Retrieve the range set structure associated to a builder structure for the block defined in block_id ...
Definition: cs_equation_builder.c:224
unsigned int cs_eflag_t
Definition: cs_flag.h:187
bool cs_equation_builder_set_reaction_pty_cw(const cs_equation_param_t *eqp, const cs_equation_builder_t *eqb, const cs_cell_mesh_t *cm, cs_cell_builder_t *cb)
Initialize all reaction properties. This function is shared across all CDO schemes. The cs_cell_builder_t structure stores the computed property values. If the property is uniform, a first call to the function cs_equation_builder_init_properties has to be done before the loop on cells.
Definition: cs_equation_builder.c:401
cs_iter_algo_t * incremental_algo
Definition: cs_equation_builder.h:172
cs_timer_counter_t tcb
Definition: cs_equation_builder.h:227
void cs_equation_builder_enforce_dofs(const cs_equation_builder_t *eqb, cs_cell_builder_t *cb, cs_cell_sys_t *csys)
Take into account the enforcement of internal DoFs. Apply an algebraic manipulation. Update members of the cs_cell_sys_t structure related to the internal enforcement.
Definition: cs_equation_builder.c:504
void() cs_source_term_cellwise_t(const cs_xdef_t *source, const cs_cell_mesh_t *cm, cs_real_t time_eval, cs_cell_builder_t *cb, void *input, double *values)
Compute the contribution for a cell related to a source term and add it to the given array of values...
Definition: cs_source_term.h:70
Definition: cs_timer.h:55
cs_timer_counter_t tce
Definition: cs_equation_builder.h:231
#define CS_FLAG_BOUNDARY_CELL_BY_FACE
(= 1) boundary cell with at least one border face
Definition: cs_flag.h:62