1#ifndef __CS_CDO_QUANTITIES_H__
2#define __CS_CDO_QUANTITIES_H__
296 const double xab[3] = {xb[0] - qa.
center[0],
299 const double cp[3] = {qa.
unitv[1]*xab[2] - qa.
unitv[2]*xab[1],
602 if (f_id < cdoq->n_i_faces)
623 if (f_id < cdoq->n_i_faces)
644 return (f_id < cdoq->n_i_faces) ?
cs_cdo_quantities_bit_t
Bit values for setting which quantities to compute.
Definition cs_cdo_quantities.h:106
@ CS_CDO_QUANTITIES_CB_SCHEME
Definition cs_cdo_quantities.h:115
@ CS_CDO_QUANTITIES_EB_SCHEME
Definition cs_cdo_quantities.h:110
@ CS_CDO_QUANTITIES_HHO_SCHEME
Definition cs_cdo_quantities.h:112
@ CS_CDO_QUANTITIES_FB_SCHEME
Definition cs_cdo_quantities.h:111
@ CS_CDO_QUANTITIES_VCB_SCHEME
Definition cs_cdo_quantities.h:114
@ CS_CDO_QUANTITIES_MAC_SCHEME
Definition cs_cdo_quantities.h:116
@ CS_CDO_QUANTITIES_VB_SCHEME
Definition cs_cdo_quantities.h:113
static cs_real_t cs_quant_get_face_surf(cs_lnum_t f_id, const cs_cdo_quantities_t *cdoq)
Retrieve the face surface for a primal face (interior or border)
Definition cs_cdo_quantities.h:641
static const cs_real_t * cs_quant_get_face_center(cs_lnum_t f_id, const cs_cdo_quantities_t *cdoq)
Retrieve the face center for a primal face (interior or border)
Definition cs_cdo_quantities.h:620
void cs_cdo_quantities_dump(const cs_cdo_quantities_t *cdoq)
Dump a cs_cdo_quantities_t structure (for debuggingpurpose)
Definition cs_cdo_quantities.cpp:1811
void cs_cdo_quantities_log_summary(const cs_cdo_quantities_t *cdoq)
Summarize generic information about the cdo mesh quantities.
Definition cs_cdo_quantities.cpp:1753
cs_quant_t cs_quant_get_edge_center(cs_lnum_t e_id, const cs_cdo_connect_t *topo, const cs_cdo_quantities_t *cdoq)
Retrieve the edge center for a primal edge (interior or border)
Definition cs_cdo_quantities.cpp:2448
cs_quant_t cs_quant_set_face(cs_lnum_t f_id, const cs_cdo_quantities_t *cdoq)
Define a cs_quant_t structure for a primal face (interior or border)
Definition cs_cdo_quantities.cpp:2360
const cs_real_t * cs_cdo_quantities_get_pvol_ec(const cs_cdo_quantities_t *cdoq, const cs_adjacency_t *c2e)
Retrieve the portion of volume surrounding each edge of a cell. This volume corresponds to an octahed...
Definition cs_cdo_quantities.cpp:1995
static const cs_real_t * cs_quant_get_face_vector_area(cs_lnum_t f_id, const cs_cdo_quantities_t *cdoq)
Retrieve the face vector which the face_area * face_normal for a primal face (interior or border)
Definition cs_cdo_quantities.h:599
void cs_cdo_quantities_set_algo_ccenter(cs_cdo_quantities_cell_center_algo_t algo)
Set the type of algorithm to use for computing the cell center.
Definition cs_cdo_quantities.cpp:1522
const cs_real_t * cs_cdo_quantities_get_dual_volumes(cs_cdo_quantities_t *cdoq, const cs_cdo_connect_t *connect)
Compute or retrieve the dual volume surrounding each vertex. The parallel operation (sum reduction) i...
Definition cs_cdo_quantities.cpp:2093
cs_nvec3_t cs_quant_set_dedge_nvec(cs_lnum_t shift, const cs_cdo_quantities_t *cdoq)
Get the two normalized vector associated to a dual edge.
Definition cs_cdo_quantities.cpp:2500
void cs_cdo_quantities_set(cs_flag_t option_flag)
Set which quantities have to be computed. Additionnal quantities are added to cs_cdo_quantities_flag ...
Definition cs_cdo_quantities.cpp:1508
cs_nvec3_t cs_quant_set_edge_nvec(cs_lnum_t e_id, const cs_cdo_quantities_t *cdoq)
Get the normalized vector associated to a primal edge.
Definition cs_cdo_quantities.cpp:2479
const cs_real_t * cs_cdo_quantities_get_pvol_fc(const cs_cdo_quantities_t *cdoq, const cs_adjacency_t *c2f)
Retrieve the portion of volume surrounding each face of a cell. This volume corresponds to a pyramid ...
Definition cs_cdo_quantities.cpp:1904
void cs_cdo_quantities_compute_b_wvf(const cs_cdo_connect_t *connect, const cs_cdo_quantities_t *cdoq, cs_lnum_t bf_id, cs_real_t wvf[])
Compute the weight related to each vertex of a face. This weight ensures a 2nd order approximation if...
Definition cs_cdo_quantities.cpp:2313
cs_cdo_quantities_t * cs_cdo_quantities_free(cs_cdo_quantities_t *cdoq)
Destroy a cs_cdo_quantities_t structure.
Definition cs_cdo_quantities.cpp:1696
long long cs_cdo_quantities_get_time_perfo(void)
Retrieve the time elapsed to build the cs_cdo_quantities_t structure.
Definition cs_cdo_quantities.cpp:1493
void cs_cdo_quantities_compute_dual_volumes(const cs_cdo_quantities_t *cdoq, const cs_cdo_connect_t *connect, cs_real_t **p_dual_vol)
Compute the dual volume surrounding each vertex. The parallel operation (sum reduction) is performed ...
Definition cs_cdo_quantities.cpp:2122
void cs_cdo_quantities_compute_pvol_fc(const cs_cdo_quantities_t *cdoq, const cs_adjacency_t *c2f, cs_real_t **p_pvol_fc)
Compute the portion of volume surrounding each face of a cell. This volume corresponds to a pyramid w...
Definition cs_cdo_quantities.cpp:1934
cs_nvec3_t cs_quant_set_face_nvec(cs_lnum_t f_id, const cs_cdo_quantities_t *cdoq)
Retrieve the face surface and its unit normal vector for a primal face (interior or border)
Definition cs_cdo_quantities.cpp:2408
cs_cdo_quantities_cell_center_algo_t
Type of algorithm used to compute the cell centers.
Definition cs_cdo_quantities.h:72
@ CS_CDO_QUANTITIES_SUBDIV_CENTER
Definition cs_cdo_quantities.h:77
@ CS_CDO_QUANTITIES_BARYC_CENTER
Definition cs_cdo_quantities.h:75
@ CS_CDO_QUANTITIES_SATURNE_CENTER
Definition cs_cdo_quantities.h:76
@ CS_CDO_QUANTITIES_MEANV_CENTER
Definition cs_cdo_quantities.h:74
void cs_cdo_quantities_compute_i_tef(const cs_cdo_connect_t *connect, const cs_cdo_quantities_t *cdoq, cs_lnum_t f_id, cs_real_t tef[])
Compute the area of the triangles with basis each edge of the face and apex the face center....
Definition cs_cdo_quantities.cpp:2177
void cs_cdo_quantities_compute_pvol_ec(const cs_cdo_quantities_t *cdoq, const cs_adjacency_t *c2e, cs_real_t **p_pvol_ec)
Compute the portion of volume surrounding each edge of a cell. The computed quantity is scanned with ...
Definition cs_cdo_quantities.cpp:2028
void cs_quant_dump(FILE *f, cs_lnum_t num, const cs_quant_t q)
Dump a cs_quant_t structure.
Definition cs_cdo_quantities.cpp:2520
cs_cdo_quantities_t * cs_cdo_quantities_build(const cs_mesh_t *m, const cs_mesh_quantities_t *mq, const cs_cdo_connect_t *topo)
Build a cs_cdo_quantities_t structure. Some quantities are shared with the cs_mesh_quantities_t struc...
Definition cs_cdo_quantities.cpp:1542
void cs_cdo_quantities_compute_b_tef(const cs_cdo_connect_t *connect, const cs_cdo_quantities_t *cdoq, cs_lnum_t bf_id, cs_real_t tef[])
Compute the area of the triangles with basis each edge of the face and apex the face center....
Definition cs_cdo_quantities.cpp:2220
void cs_cdo_quantities_compute_i_wvf(const cs_cdo_connect_t *connect, const cs_cdo_quantities_t *cdoq, cs_lnum_t f_id, cs_real_t wvf[])
Compute the weight related to each vertex of a face. This weight ensures a 2nd order approximation if...
Definition cs_cdo_quantities.cpp:2263
static double cs_compute_area_from_quant(const cs_quant_t qa, const cs_real_t *xb)
Compute the area of the triangle of base given by q (related to a segment) with apex located at xa.
Definition cs_cdo_quantities.h:293
#define BEGIN_C_DECLS
Definition cs_defs.h:542
cs_nreal_t cs_nreal_3_t[3]
Definition cs_defs.h:385
double cs_real_t
Floating-point value.
Definition cs_defs.h:342
unsigned cs_gnum_t
global mesh entity number
Definition cs_defs.h:327
#define END_C_DECLS
Definition cs_defs.h:543
int cs_lnum_t
local mesh entity id
Definition cs_defs.h:335
unsigned short int cs_flag_t
Definition cs_defs.h:344
@ cp
Definition cs_field_pointer.h:102
cs_flag_cartesian_axis_t
Definition cs_flag.h:307
static CS_F_HOST_DEVICE cs_real_t cs_math_3_norm(const cs_real_t v[3])
Compute the euclidean norm of a vector of dimension 3.
Definition cs_math.h:765
char * algo
Definition field_names.h:102
Definition cs_mesh_adjacencies.h:68
Definition cs_cdo_connect.h:61
Definition cs_cdo_quantities.h:145
cs_gnum_t n_g_edges
Definition cs_cdo_quantities.h:227
cs_lnum_t n_i_faces
Definition cs_cdo_quantities.h:170
const cs_real_t * b_dist
Definition cs_cdo_quantities.h:198
cs_real_t * i_face_surf
Definition cs_cdo_quantities.h:190
cs_lnum_t n_faces
Definition cs_cdo_quantities.h:169
cs_lnum_t n_b_faces
Definition cs_cdo_quantities.h:171
cs_quant_info_t edge_info
Definition cs_cdo_quantities.h:247
cs_real_t * b_face_center
Definition cs_cdo_quantities.h:197
cs_real_t * dual_vol
Definition cs_cdo_quantities.h:268
cs_gnum_t n_g_vertices
Definition cs_cdo_quantities.h:253
const cs_real_t * i_dist
Definition cs_cdo_quantities.h:192
cs_real_t * b_face_surf
Definition cs_cdo_quantities.h:196
cs_lnum_t n_cells
Definition cs_cdo_quantities.h:159
cs_real_t * cell_vol
Definition cs_cdo_quantities.h:162
cs_real_t * pvol_ec
Definition cs_cdo_quantities.h:242
cs_quant_info_t face_info
Definition cs_cdo_quantities.h:221
cs_gnum_t n_g_cells
Definition cs_cdo_quantities.h:160
double vol_tot
Definition cs_cdo_quantities.h:154
const cs_real_t * vtx_coord
Definition cs_cdo_quantities.h:260
cs_lnum_t n_vertices
Definition cs_cdo_quantities.h:252
cs_real_t * b_face_normal
Definition cs_cdo_quantities.h:195
cs_gnum_t n_g_faces
Definition cs_cdo_quantities.h:172
cs_nreal_3_t * i_face_u_normal
Definition cs_cdo_quantities.h:188
cs_real_t * cell_centers
Definition cs_cdo_quantities.h:161
cs_lnum_t n_edges
Definition cs_cdo_quantities.h:226
cs_real_t * pvol_fc
Definition cs_cdo_quantities.h:215
cs_real_t * pvol_vc
Definition cs_cdo_quantities.h:255
cs_quant_info_t cell_info
Definition cs_cdo_quantities.h:164
cs_real_t * dface_normal
Definition cs_cdo_quantities.h:240
bool remove_boundary_faces
Definition cs_cdo_quantities.h:150
cs_real_t * edge_vector
Definition cs_cdo_quantities.h:229
cs_nreal_3_t * b_face_u_normal
Definition cs_cdo_quantities.h:194
cs_real_t * i_face_normal
Definition cs_cdo_quantities.h:189
cs_real_t * i_face_center
Definition cs_cdo_quantities.h:191
cs_flag_cartesian_axis_t * face_axis
Definition cs_cdo_quantities.h:200
cs_real_t * dedge_vector
Definition cs_cdo_quantities.h:213
Definition cs_mesh_quantities.h:92
Definition cs_cdo_quantities.h:123
double meas_max
Definition cs_cdo_quantities.h:129
double meas_min
Definition cs_cdo_quantities.h:128
double h_min
Definition cs_cdo_quantities.h:130
double h_max
Definition cs_cdo_quantities.h:131
Definition cs_cdo_quantities.h:137
double meas
Definition cs_cdo_quantities.h:139
double center[3]
Definition cs_cdo_quantities.h:141
double unitv[3]
Definition cs_cdo_quantities.h:140