#include "cs_cdo_bc.h"#include "cs_cdo_connect.h"#include "cs_cdo_quantities.h"#include "cs_cdo_local.h"#include "cs_equation_param.h"#include "cs_time_step.h"#include "cs_xdef_eval.h" Include dependency graph for cs_equation_bc.h:
 Include dependency graph for cs_equation_bc.h:Go to the source code of this file.
| Typedefs | |
| typedef void() | cs_cdo_apply_boundary_t(short int f, const cs_equation_param_t *eqp, const cs_cell_mesh_t *cm, const cs_property_data_t *pty, cs_cell_builder_t *cb, cs_cell_sys_t *csys) | 
| Apply a boundary condition for a given face (inlet, outlet, wall, sliding wall, symmetry...)  More... | |
| typedef void() | cs_cdo_enforce_bc_t(const cs_equation_param_t *eqp, const cs_cell_mesh_t *cm, cs_face_mesh_t *fm, cs_hodge_t *hodge, cs_cell_builder_t *cb, cs_cell_sys_t *csys) | 
| Enforcement of a boundary condition (Dirichlet, Robin, sliding...)  More... | |
| Functions | |
| void | cs_equation_init_boundary_flux_from_bc (cs_real_t t_eval, const cs_cdo_quantities_t *cdoq, const cs_equation_param_t *eqp, cs_real_t *values) | 
| Set the values for the normal boundary flux stemming from the Neumann boundary conditions (zero is left where a Dirichlet is set. This can be updated later one)  More... | |
| void | cs_equation_bc_set_cw_vb (const cs_cell_mesh_t *cm, const cs_equation_param_t *eqp, const cs_cdo_bc_face_t *face_bc, const cs_flag_t vtx_bc_flag[], const cs_real_t dir_values[], cs_real_t t_eval, cs_cell_sys_t *csys, cs_cell_builder_t *cb) | 
| Set the BC into a cellwise view of the current system. Case of vertex-based schemes.  More... | |
| void | cs_equation_bc_set_cw_eb (const cs_cell_mesh_t *cm, const cs_equation_param_t *eqp, const cs_cdo_bc_face_t *face_bc, const cs_real_t dir_values[], cs_cell_sys_t *csys, cs_cell_builder_t *cb) | 
| Set the BC into a cellwise view of the current system. Case of edge-based schemes.  More... | |
| void | cs_equation_bc_set_cw_fb (const cs_cell_mesh_t *cm, const cs_equation_param_t *eqp, const cs_cdo_bc_face_t *face_bc, const cs_real_t dir_values[], cs_cell_sys_t *csys, cs_cell_builder_t *cb) | 
| Set the BC into a cellwise view of the current system. Case of Face-based schemes.  More... | |
| void | cs_equation_bc_set_vertex_flag (const cs_cdo_connect_t *connect, const cs_cdo_bc_face_t *face_bc, cs_flag_t *vflag) | 
| Define an array of flags for each vertex collecting the flags of associated boundary faces.  More... | |
| void | cs_equation_bc_set_edge_flag (const cs_cdo_connect_t *connect, const cs_cdo_bc_face_t *face_bc, cs_flag_t *edge_flag) | 
| Define an array of flags for each edge collecting the flags of associated boundary faces.  More... | |
| void | cs_equation_compute_dirichlet_vb (cs_real_t t_eval, const cs_mesh_t *mesh, const cs_cdo_quantities_t *quant, const cs_cdo_connect_t *connect, const cs_equation_param_t *eqp, const cs_cdo_bc_face_t *face_bc, cs_cell_builder_t *cb, cs_flag_t *bcflag, cs_real_t *values) | 
| Compute the values of the Dirichlet BCs when DoFs are attached to vertices.  More... | |
| void | cs_equation_compute_dirichlet_fb (const cs_mesh_t *mesh, const cs_cdo_quantities_t *quant, const cs_cdo_connect_t *connect, const cs_equation_param_t *eqp, const cs_cdo_bc_face_t *face_bc, cs_real_t t_eval, cs_cell_builder_t *cb, cs_real_t *values) | 
| Compute the values of the Dirichlet BCs when DoFs are attached to CDO face-based schemes.  More... | |
| void | cs_equation_compute_neumann_svb (cs_real_t t_eval, short int def_id, short int f, const cs_equation_param_t *eqp, const cs_cell_mesh_t *cm, double *neu_values) | 
| Compute the values of the Neumann BCs when DoFs are scalar-valued and attached to a vertex-based schemes (Vb or VCb) Case of the Neumann BCs i.e. Neumann is defined by a scalar.  More... | |
| void | cs_equation_compute_full_neumann_svb (cs_real_t t_eval, short int def_id, short int f, const cs_equation_param_t *eqp, const cs_cell_mesh_t *cm, double *neu_values) | 
| Compute the values of the Neumann BCs when DoFs are scalar-valued and attached to a vertex-based schemes (Vb or VCb) Case of the full Neumann BCs i.e. Neumann is defined by a vector.  More... | |
| void | cs_equation_compute_neumann_sfb (cs_real_t t_eval, short int def_id, short int f, const cs_equation_param_t *eqp, const cs_cell_mesh_t *cm, double *neu_values) | 
| Compute the values of the Neumann BCs when DoFs are attached to the face f. Case of scalar-valued equation (not full Neumann BCs)  More... | |
| void | cs_equation_compute_full_neumann_sfb (cs_real_t t_eval, short int def_id, short int f, const cs_equation_param_t *eqp, const cs_cell_mesh_t *cm, double *neu_values) | 
| Compute the values of the Neumann BCs when DoFs are attached to the face f. Case of scalar-valued equation with a full Neumann BC definition.  More... | |
| void | cs_equation_compute_neumann_vfb (cs_real_t t_eval, short int def_id, short int f, const cs_equation_param_t *eqp, const cs_cell_mesh_t *cm, double *neu_values) | 
| Compute the values of the Neumann BCs at the face f when DoFs are attached to faces. Case of vector-valued equation (not the full Neumann)  More... | |
| void | cs_equation_compute_robin (cs_real_t t_eval, short int def_id, short int f, const cs_equation_param_t *eqp, const cs_cell_mesh_t *cm, double *rob_values) | 
| Compute the values of the Robin BCs.  More... | |
| void | cs_equation_compute_circulation_eb (cs_real_t t_eval, const cs_mesh_t *mesh, const cs_cdo_quantities_t *quant, const cs_cdo_connect_t *connect, const cs_equation_param_t *eqp, cs_real_t *values) | 
| Compute the values of the tangential component lying on the domain boundary. Kind of BCs used when DoFs are attached to CDO (primal) edge-based schemes. One sets the values of the circulation.  More... | |
| void | cs_equation_bc_update_for_increment (cs_cell_sys_t *csys) | 
| Update the boundary conditions to fullfill the constraint when an incremental solve is set.  More... | |
| typedef void() cs_cdo_apply_boundary_t(short int f, const cs_equation_param_t *eqp, const cs_cell_mesh_t *cm, const cs_property_data_t *pty, cs_cell_builder_t *cb, cs_cell_sys_t *csys) | 
Apply a boundary condition for a given face (inlet, outlet, wall, sliding wall, symmetry...)
| [in] | f | face id in the cell mesh numbering | 
| [in] | eqp | pointer to a cs_equation_param_t struct. | 
| [in] | cm | pointer to a cs_cell_mesh_t structure | 
| [in] | pty | pointer to a cs_property_data_t structure | 
| [in,out] | cb | pointer to a cs_cell_builder_t structure | 
| [in,out] | csys | structure storing the cell-wise system | 
| typedef void() cs_cdo_enforce_bc_t(const cs_equation_param_t *eqp, const cs_cell_mesh_t *cm, cs_face_mesh_t *fm, cs_hodge_t *hodge, cs_cell_builder_t *cb, cs_cell_sys_t *csys) | 
Enforcement of a boundary condition (Dirichlet, Robin, sliding...)
| [in] | eqp | pointer to a cs_equation_param_t struct. | 
| [in] | cm | pointer to a cs_cell_mesh_t structure | 
| [in,out] | fm | pointer to a cs_face_mesh_t structure | 
| [in,out] | hodge | pointer to a cs_hodge_t structure | 
| [in,out] | cb | pointer to a cs_cell_builder_t structure | 
| [in,out] | csys | structure storing the cell-wise system | 
| void cs_equation_bc_set_cw_eb | ( | const cs_cell_mesh_t * | cm, | 
| const cs_equation_param_t * | eqp, | ||
| const cs_cdo_bc_face_t * | face_bc, | ||
| const cs_real_t | dir_values[], | ||
| cs_cell_sys_t * | csys, | ||
| cs_cell_builder_t * | cb | ||
| ) | 
Set the BC into a cellwise view of the current system. Case of edge-based schemes.
| [in] | cm | pointer to a cellwise view of the mesh | 
| [in] | eqp | pointer to a cs_equation_param_t structure | 
| [in] | face_bc | pointer to a cs_cdo_bc_face_t structure | 
| [in] | dir_values | Dirichlet values associated to each vertex | 
| [in,out] | csys | pointer to a cellwise view of the system | 
| [in,out] | cb | pointer to a cellwise builder | 
| void cs_equation_bc_set_cw_fb | ( | const cs_cell_mesh_t * | cm, | 
| const cs_equation_param_t * | eqp, | ||
| const cs_cdo_bc_face_t * | face_bc, | ||
| const cs_real_t | dir_values[], | ||
| cs_cell_sys_t * | csys, | ||
| cs_cell_builder_t * | cb | ||
| ) | 
Set the BC into a cellwise view of the current system. Case of Face-based schemes.
| [in] | cm | pointer to a cellwise view of the mesh | 
| [in] | eqp | pointer to a cs_equation_param_t structure | 
| [in] | face_bc | pointer to a cs_cdo_bc_face_t structure | 
| [in] | dir_values | Dirichlet values associated to each face | 
| [in,out] | csys | pointer to a cellwise view of the system | 
| [in,out] | cb | pointer to a cellwise builder | 
| [in] | cm | pointer to a cellwise view of the mesh | 
| [in] | eqp | pointer to a cs_equation_param_t structure | 
| [in] | face_bc | pointer to a cs_cdo_bc_face_t structure | 
| [in] | dir_values | Dirichlet values associated to each vertex | 
| [in,out] | csys | pointer to a cellwise view of the system | 
| [in,out] | cb | pointer to a cellwise builder | 
| void cs_equation_bc_set_cw_vb | ( | const cs_cell_mesh_t * | cm, | 
| const cs_equation_param_t * | eqp, | ||
| const cs_cdo_bc_face_t * | face_bc, | ||
| const cs_flag_t | vtx_bc_flag[], | ||
| const cs_real_t | dir_values[], | ||
| cs_real_t | t_eval, | ||
| cs_cell_sys_t * | csys, | ||
| cs_cell_builder_t * | cb | ||
| ) | 
Set the BC into a cellwise view of the current system. Case of vertex-based schemes.
| [in] | cm | pointer to a cellwise view of the mesh | 
| [in] | eqp | pointer to a cs_equation_param_t structure | 
| [in] | face_bc | pointer to a cs_cdo_bc_face_t structure | 
| [in] | vtx_bc_flag | BC flags associated to vertices | 
| [in] | dir_values | Dirichlet values associated to each vertex | 
| [in] | t_eval | time at which one performs the evaluation | 
| [in,out] | csys | pointer to a cellwise view of the system | 
| [in,out] | cb | pointer to a cellwise builder | 
| void cs_equation_bc_set_edge_flag | ( | const cs_cdo_connect_t * | connect, | 
| const cs_cdo_bc_face_t * | face_bc, | ||
| cs_flag_t * | edge_flag | ||
| ) | 
Define an array of flags for each edge collecting the flags of associated boundary faces.
| [in] | connect | pointer to a cs_cdo_connect_t struct. | 
| [in] | face_bc | pointer to a structure collecting boundary conditions applied to faces | 
| [in,out] | edge_flag | BC flag on edges to define | 
| void cs_equation_bc_set_vertex_flag | ( | const cs_cdo_connect_t * | connect, | 
| const cs_cdo_bc_face_t * | face_bc, | ||
| cs_flag_t * | vflag | ||
| ) | 
Define an array of flags for each vertex collecting the flags of associated boundary faces.
| [in] | connect | pointer to a cs_cdo_connect_t struct. | 
| [in] | face_bc | pointer to a structure collecting boundary conditions applied to faces | 
| [in,out] | vflag | BC flag on vertices to define | 
| void cs_equation_bc_update_for_increment | ( | cs_cell_sys_t * | csys | ) | 
Update the boundary conditions to fullfill the constraint when an incremental solve is set.
| [in,out] | csys | pointer to the cell system structure | 
| void cs_equation_compute_circulation_eb | ( | cs_real_t | t_eval, | 
| const cs_mesh_t * | mesh, | ||
| const cs_cdo_quantities_t * | quant, | ||
| const cs_cdo_connect_t * | connect, | ||
| const cs_equation_param_t * | eqp, | ||
| cs_real_t * | values | ||
| ) | 
Compute the values of the tangential component lying on the domain boundary. Kind of BCs used when DoFs are attached to CDO (primal) edge-based schemes. One sets the values of the circulation.
| [in] | t_eval | time at which one evaluates the boundary cond. | 
| [in] | mesh | pointer to a cs_mesh_t structure | 
| [in] | quant | pointer to a cs_cdo_quantities_t structure | 
| [in] | connect | pointer to a cs_cdo_connect_t struct. | 
| [in] | eqp | pointer to a cs_equation_param_t | 
| [in,out] | values | pointer to the array of values to set | 
| void cs_equation_compute_dirichlet_fb | ( | const cs_mesh_t * | mesh, | 
| const cs_cdo_quantities_t * | quant, | ||
| const cs_cdo_connect_t * | connect, | ||
| const cs_equation_param_t * | eqp, | ||
| const cs_cdo_bc_face_t * | face_bc, | ||
| cs_real_t | t_eval, | ||
| cs_cell_builder_t * | cb, | ||
| cs_real_t * | values | ||
| ) | 
Compute the values of the Dirichlet BCs when DoFs are attached to CDO face-based schemes.
| [in] | mesh | pointer to a cs_mesh_t structure | 
| [in] | quant | pointer to a cs_cdo_quantities_t structure | 
| [in] | connect | pointer to a cs_cdo_connect_t struct. | 
| [in] | eqp | pointer to a cs_equation_param_t | 
| [in] | face_bc | pointer to a cs_cdo_bc_face_t structure | 
| [in] | t_eval | time at which one evaluates the boundary cond. | 
| [in,out] | cb | pointer to a cs_cell_builder_t structure | 
| [in,out] | values | pointer to the array of values to set | 
| void cs_equation_compute_dirichlet_vb | ( | cs_real_t | t_eval, | 
| const cs_mesh_t * | mesh, | ||
| const cs_cdo_quantities_t * | quant, | ||
| const cs_cdo_connect_t * | connect, | ||
| const cs_equation_param_t * | eqp, | ||
| const cs_cdo_bc_face_t * | face_bc, | ||
| cs_cell_builder_t * | cb, | ||
| cs_flag_t * | bcflag, | ||
| cs_real_t * | values | ||
| ) | 
Compute the values of the Dirichlet BCs when DoFs are attached to vertices.
| [in] | t_eval | time at which one performs the evaluation | 
| [in] | mesh | pointer to a cs_mesh_t structure | 
| [in] | quant | pointer to a cs_cdo_quantities_t structure | 
| [in] | connect | pointer to a cs_cdo_connect_t struct. | 
| [in] | eqp | pointer to a cs_equation_param_t | 
| [in] | face_bc | pointer to a cs_cdo_bc_face_t structure | 
| [in,out] | cb | pointer to a cs_cell_builder_t structure | 
| [in,out] | bcflag | pointer to an array storing type of BC | 
| [in,out] | values | pointer to the array of values to set | 
| void cs_equation_compute_full_neumann_sfb | ( | cs_real_t | t_eval, | 
| short int | def_id, | ||
| short int | f, | ||
| const cs_equation_param_t * | eqp, | ||
| const cs_cell_mesh_t * | cm, | ||
| double * | neu_values | ||
| ) | 
Compute the values of the Neumann BCs when DoFs are attached to the face f. Case of scalar-valued equation with a full Neumann BC definition.
| [in] | t_eval | time at which one performs the evaluation | 
| [in] | def_id | id of the definition for setting the Neumann BC | 
| [in] | f | local face number in the cs_cell_mesh_t | 
| [in] | eqp | pointer to a cs_equation_param_t | 
| [in] | cm | pointer to a cs_cell_mesh_t structure | 
| [in,out] | neu_values | array storing Neumann values for all DoFs | 
| void cs_equation_compute_full_neumann_svb | ( | cs_real_t | t_eval, | 
| short int | def_id, | ||
| short int | f, | ||
| const cs_equation_param_t * | eqp, | ||
| const cs_cell_mesh_t * | cm, | ||
| double * | neu_values | ||
| ) | 
Compute the values of the Neumann BCs when DoFs are scalar-valued and attached to a vertex-based schemes (Vb or VCb) Case of the full Neumann BCs i.e. Neumann is defined by a vector.
| [in] | t_eval | time at which one performs the evaluation | 
| [in] | def_id | id of the definition for setting the Neumann BC | 
| [in] | f | local face number in the cs_cell_mesh_t | 
| [in] | eqp | pointer to a cs_equation_param_t | 
| [in] | cm | pointer to a cs_cell_mesh_t structure | 
| [in,out] | neu_values | array storing the Neumann values for all DoFs | 
| void cs_equation_compute_neumann_sfb | ( | cs_real_t | t_eval, | 
| short int | def_id, | ||
| short int | f, | ||
| const cs_equation_param_t * | eqp, | ||
| const cs_cell_mesh_t * | cm, | ||
| double * | neu_values | ||
| ) | 
Compute the values of the Neumann BCs when DoFs are attached to the face f. Case of scalar-valued equation (not full Neumann BCs)
| [in] | t_eval | time at which one performs the evaluation | 
| [in] | def_id | id of the definition for setting the Neumann BC | 
| [in] | f | local face number in the cs_cell_mesh_t | 
| [in] | eqp | pointer to a cs_equation_param_t | 
| [in] | cm | pointer to a cs_cell_mesh_t structure | 
| [in,out] | neu_values | array storing Neumann values for all DoFs | 
| void cs_equation_compute_neumann_svb | ( | cs_real_t | t_eval, | 
| short int | def_id, | ||
| short int | f, | ||
| const cs_equation_param_t * | eqp, | ||
| const cs_cell_mesh_t * | cm, | ||
| double * | neu_values | ||
| ) | 
Compute the values of the Neumann BCs when DoFs are scalar-valued and attached to a vertex-based schemes (Vb or VCb) Case of the Neumann BCs i.e. Neumann is defined by a scalar.
| [in] | t_eval | time at which one performs the evaluation | 
| [in] | def_id | id of the definition for setting the Neumann BC | 
| [in] | f | local face number in the cs_cell_mesh_t | 
| [in] | eqp | pointer to a cs_equation_param_t | 
| [in] | cm | pointer to a cs_cell_mesh_t structure | 
| [in,out] | neu_values | array storing the Neumann values for all DoFs | 
| void cs_equation_compute_neumann_vfb | ( | cs_real_t | t_eval, | 
| short int | def_id, | ||
| short int | f, | ||
| const cs_equation_param_t * | eqp, | ||
| const cs_cell_mesh_t * | cm, | ||
| double * | neu_values | ||
| ) | 
Compute the values of the Neumann BCs at the face f when DoFs are attached to faces. Case of vector-valued equation (not the full Neumann)
| [in] | t_eval | time at which one performs the evaluation | 
| [in] | def_id | id of the definition for setting the Neumann BC | 
| [in] | f | local face number in the cs_cell_mesh_t | 
| [in] | eqp | pointer to a cs_equation_param_t | 
| [in] | cm | pointer to a cs_cell_mesh_t structure | 
| [in,out] | neu_values | array storing Neumann values at DoFs | 
| void cs_equation_compute_robin | ( | cs_real_t | t_eval, | 
| short int | def_id, | ||
| short int | f, | ||
| const cs_equation_param_t * | eqp, | ||
| const cs_cell_mesh_t * | cm, | ||
| double * | rob_values | ||
| ) | 
Compute the values of the Robin BCs.
| [in] | t_eval | time at which one performs the evaluation | 
| [in] | def_id | id of the definition for setting the Neumann BC | 
| [in] | f | local face number in the cs_cell_mesh_t | 
| [in] | eqp | pointer to a cs_equation_param_t | 
| [in] | cm | pointer to a cs_cell_mesh_t structure | 
| [in,out] | rob_values | array storing Robin values to use | 
| void cs_equation_init_boundary_flux_from_bc | ( | cs_real_t | t_eval, | 
| const cs_cdo_quantities_t * | cdoq, | ||
| const cs_equation_param_t * | eqp, | ||
| cs_real_t * | values | ||
| ) | 
Set the values for the normal boundary flux stemming from the Neumann boundary conditions (zero is left where a Dirichlet is set. This can be updated later one)
| [in] | t_eval | time at which one performs the evaluation | 
| [in] | cdoq | pointer to a cs_cdo_quantities_t structure | 
| [in] | eqp | pointer to a cs_equation_param_t structure | 
| [in,out] | values | pointer to the array of values to set | 
Set the values for the normal boundary flux stemming from the Neumann boundary conditions (zero is left where a Dirichlet is set. This can be updated later one)
| [in] | t_eval | time at which one performs the evaluation | 
| [in] | cdoq | pointer to a cs_cdo_quantities_t structure | 
| [in] | eqp | pointer to a cs_equation_param_t structure | 
| [in,out] | values | pointer to the array of values to set |