1 #ifndef __CS_CDO_SYSTEM_H__
2 #define __CS_CDO_SYSTEM_H__
void() cs_cdo_assembly_func_t(const cs_sdm_t *m, const cs_lnum_t *dof_ids, const cs_range_set_t *rset, cs_cdo_assembly_t *eqa, cs_matrix_assembler_values_t *mav)
Assemble a cellwise matrix into the global matrix Block or no block versions are handled.
Definition: cs_cdo_assembly.h:72
cs_cdo_system_block_t * cs_cdo_system_add_xblock(cs_cdo_system_helper_t *sh, int block_id, cs_lnum_t n_dofs)
Add an external block definition at position "block_id" in the helper structure. Only metadata are se...
Definition: cs_cdo_system.c:1496
void cs_cdo_system_helper_free(cs_cdo_system_helper_t **p_helper)
Free a cs_cdo_system_helper_t structure.
Definition: cs_cdo_system.c:1133
void cs_cdo_system_helper_finalize_assembly(cs_cdo_system_helper_t *sh)
Finalize the assembly after the cellwise building and assembly.
Definition: cs_cdo_system.c:1982
void cs_cdo_system_init_sharing(cs_mesh_t *mesh, cs_cdo_connect_t *connect)
Allocate and initialize matrix-related structures according to the type of discretization used for th...
Definition: cs_cdo_system.c:1056
cs_cdo_system_block_type_t
type of block composing a (block) matrix
Definition: cs_cdo_system.h:82
@ CS_CDO_SYSTEM_BLOCK_EXT
Definition: cs_cdo_system.h:87
@ CS_CDO_SYSTEM_N_BLOCK_TYPES
Definition: cs_cdo_system.h:89
@ CS_CDO_SYSTEM_BLOCK_DEFAULT
Definition: cs_cdo_system.h:84
@ CS_CDO_SYSTEM_BLOCK_UNASS
Definition: cs_cdo_system.h:86
@ CS_CDO_SYSTEM_BLOCK_SPLIT
Definition: cs_cdo_system.h:85
void cs_cdo_system_helper_reset(cs_cdo_system_helper_t *sh)
Free matrix and rhs after the solve step.
Definition: cs_cdo_system.c:2043
void cs_cdo_system_allocate_assembly(void)
Initialize shared assembly structures from the existing helper structures.
Definition: cs_cdo_system.c:2108
cs_cdo_system_matrix_class_t
Class of matrices to consider.
Definition: cs_cdo_system.h:110
@ CS_CDO_SYSTEM_MATRIX_HYPRE
Definition: cs_cdo_system.h:115
@ CS_CDO_SYSTEM_N_MATRIX_CLASSES
Definition: cs_cdo_system.h:117
@ CS_CDO_SYSTEM_MATRIX_NONE
Definition: cs_cdo_system.h:112
@ CS_CDO_SYSTEM_MATRIX_CS
Definition: cs_cdo_system.h:113
@ CS_CDO_SYSTEM_MATRIX_PETSC
Definition: cs_cdo_system.h:114
void cs_cdo_system_destroy_all(void)
Free all members associated to system helpers.
Definition: cs_cdo_system.c:2165
cs_cdo_system_type_t
Definition: cs_cdo_system.h:53
@ CS_CDO_SYSTEM_COUPLED
Definition: cs_cdo_system.h:56
@ CS_CDO_SYSTEM_SADDLE_POINT
Definition: cs_cdo_system.h:57
@ CS_CDO_SYSTEM_DEFAULT
Definition: cs_cdo_system.h:55
cs_cdo_system_block_t * cs_cdo_system_add_sblock(cs_cdo_system_helper_t *sh, int block_id, cs_cdo_system_matrix_class_t matclass, cs_flag_t location, cs_lnum_t n_elements, int stride)
Add a split block definition at position "block_id" in the helper structure. Only metadata are set at...
Definition: cs_cdo_system.c:1277
void cs_cdo_system_helper_init_system(cs_cdo_system_helper_t *sh, cs_real_t **p_rhs)
Allocate and initialize the matrix, rhs and the matrix assembler values.
Definition: cs_cdo_system.c:1804
cs_matrix_t * cs_cdo_system_get_matrix(const cs_cdo_system_helper_t *sh, int block_id)
Retrieve the matrix associated to the given block_id. If the type of block is either CS_CDO_SYSTEM_BL...
Definition: cs_cdo_system.c:1632
cs_cdo_system_block_t * cs_cdo_system_add_ublock(cs_cdo_system_helper_t *sh, int block_id, const cs_adjacency_t *adjacency, cs_flag_t location, cs_lnum_t n_elements, int stride, bool interlaced)
Add an unassembled block definition at position "block_id" in the helper structure Only metadata are ...
Definition: cs_cdo_system.c:1408
cs_matrix_t * cs_cdo_system_get_sub_matrix(cs_cdo_system_helper_t *sh, int block_id, int sub_id)
Retrieve the (sub-)matrix associated to a split block with id equal to block_id. sub_id is the id in ...
Definition: cs_cdo_system.c:1684
cs_range_set_t * cs_cdo_system_get_range_set(const cs_cdo_system_helper_t *sh, int block_id)
Retrieve the range set structure associated to the given block_id.
Definition: cs_cdo_system.c:1566
void cs_cdo_system_build_block(cs_cdo_system_helper_t *sh, int block_id)
Build the associated structures for the given system_helper structure If a member is already allocate...
Definition: cs_cdo_system.c:1725
cs_cdo_system_block_t * cs_cdo_system_add_dblock(cs_cdo_system_helper_t *sh, int block_id, cs_cdo_system_matrix_class_t matclass, cs_flag_t location, cs_lnum_t n_elements, int stride, bool interlaced, bool unrolled)
Add an unassembled block definition at position "block_id" in the helper structure Only metadata are ...
Definition: cs_cdo_system.c:1176
cs_cdo_system_helper_t * cs_cdo_system_helper_create(cs_cdo_system_type_t type, int n_col_blocks, const cs_lnum_t *col_block_sizes, int n_blocks)
Create a system_helper structure from its set of metadata. n_col_blocks and n_blocks may differ accor...
Definition: cs_cdo_system.c:1081
#define BEGIN_C_DECLS
Definition: cs_defs.h:509
double cs_real_t
Floating-point value.
Definition: cs_defs.h:319
#define END_C_DECLS
Definition: cs_defs.h:510
int cs_lnum_t
local mesh entity id
Definition: cs_defs.h:313
unsigned short int cs_flag_t
Definition: cs_defs.h:321
struct _cs_interface_set_t cs_interface_set_t
Definition: cs_interface.h:61
struct _cs_matrix_structure_t cs_matrix_structure_t
Definition: cs_matrix.h:106
struct _cs_matrix_t cs_matrix_t
Definition: cs_matrix.h:110
struct _cs_matrix_assembler_t cs_matrix_assembler_t
Definition: cs_matrix_assembler.h:61
struct _cs_matrix_assembler_values_t cs_matrix_assembler_values_t
Definition: cs_matrix_assembler.h:65
Definition: cs_mesh_adjacencies.h:68
Definition: cs_cdo_connect.h:61
Definition: cs_cdo_system.h:122
int stride
Definition: cs_cdo_system.h:134
cs_cdo_system_matrix_class_t matrix_class
Definition: cs_cdo_system.h:128
cs_flag_t location
Definition: cs_cdo_system.h:132
bool interlaced
Definition: cs_cdo_system.h:151
cs_lnum_t n_elements
Definition: cs_cdo_system.h:133
bool unrolled
Definition: cs_cdo_system.h:150
Definition: cs_cdo_system.h:326
void * block_pointer
Definition: cs_cdo_system.h:356
cs_cdo_system_block_info_t info
Definition: cs_cdo_system.h:332
cs_cdo_system_block_type_t type
Definition: cs_cdo_system.h:344
int id
Definition: cs_cdo_system.h:348
bool owner
Definition: cs_cdo_system.h:346
Structure associated to the default type of block.
Definition: cs_cdo_system.h:165
cs_matrix_t * matrix
Definition: cs_cdo_system.h:186
cs_cdo_assembly_func_t * slave_assembly_func
Definition: cs_cdo_system.h:189
cs_interface_set_t * interface_set
Definition: cs_cdo_system.h:195
cs_matrix_assembler_values_t * mav
Definition: cs_cdo_system.h:187
cs_range_set_t * range_set
Definition: cs_cdo_system.h:194
cs_matrix_assembler_t * matrix_assembler
Definition: cs_cdo_system.h:196
cs_cdo_assembly_func_t * assembly_func
Definition: cs_cdo_system.h:188
cs_matrix_structure_t * matrix_structure
Definition: cs_cdo_system.h:197
Definition: cs_cdo_system.h:368
cs_real_t ** rhs_array
Definition: cs_cdo_system.h:414
cs_lnum_t * col_block_sizes
Definition: cs_cdo_system.h:408
cs_cdo_system_type_t type
Definition: cs_cdo_system.h:405
cs_cdo_system_block_t ** blocks
Definition: cs_cdo_system.h:417
cs_lnum_t full_rhs_size
Definition: cs_cdo_system.h:411
cs_lnum_t * max_col_block_sizes
Definition: cs_cdo_system.h:409
cs_real_t * _rhs
Definition: cs_cdo_system.h:413
int n_col_blocks
Definition: cs_cdo_system.h:407
cs_real_t * rhs
Definition: cs_cdo_system.h:412
int n_blocks
Definition: cs_cdo_system.h:416
Structure associated to the split type of block.
Definition: cs_cdo_system.h:209
bool matrix_struct_ownership
Definition: cs_cdo_system.h:243
cs_cdo_assembly_func_t * slave_assembly_func
Definition: cs_cdo_system.h:235
cs_interface_set_t * interface_set
Definition: cs_cdo_system.h:241
int n_matrices
Definition: cs_cdo_system.h:231
cs_matrix_assembler_values_t ** mav_array
Definition: cs_cdo_system.h:233
cs_matrix_t ** matrices
Definition: cs_cdo_system.h:232
cs_range_set_t * range_set
Definition: cs_cdo_system.h:240
cs_matrix_assembler_t * matrix_assembler
Definition: cs_cdo_system.h:244
cs_cdo_assembly_func_t * assembly_func
Definition: cs_cdo_system.h:234
cs_matrix_structure_t * matrix_structure
Definition: cs_cdo_system.h:245
Structure associated to the unassembled type of block.
Definition: cs_cdo_system.h:257
bool shared_structures
Definition: cs_cdo_system.h:284
const cs_adjacency_t * adjacency
Definition: cs_cdo_system.h:278
cs_real_t * values
Definition: cs_cdo_system.h:275
cs_real_t * _values
Definition: cs_cdo_system.h:276
cs_interface_set_t * interface_set
Definition: cs_cdo_system.h:286
cs_range_set_t * range_set
Definition: cs_cdo_system.h:285
Structure associated to the extended type of block.
Definition: cs_cdo_system.h:298
cs_matrix_t * matrix
Definition: cs_cdo_system.h:308
cs_interface_set_t * interface_set
Definition: cs_cdo_system.h:314
cs_matrix_assembler_values_t * mav
Definition: cs_cdo_system.h:309
cs_range_set_t * range_set
Definition: cs_cdo_system.h:313
cs_matrix_assembler_t * matrix_assembler
Definition: cs_cdo_system.h:315
cs_matrix_structure_t * matrix_structure
Definition: cs_cdo_system.h:316
Definition: cs_range_set.h:57