Code_Saturne
CFD tool
cs_mesh_bad_cells.h
Go to the documentation of this file.
1 #ifndef __CS_MESH_BAD_CELLS_H__
2 #define __CS_MESH_BAD_CELLS_H__
3 
4 /*============================================================================
5  * Detect bad cells within meshes.
6  *============================================================================*/
7 
8 /*
9  This file is part of Code_Saturne, a general-purpose CFD tool.
10 
11  Copyright (C) 1998-2012 EDF S.A.
12 
13  This program is free software; you can redistribute it and/or modify it under
14  the terms of the GNU General Public License as published by the Free Software
15  Foundation; either version 2 of the License, or (at your option) any later
16  version.
17 
18  This program is distributed in the hope that it will be useful, but WITHOUT
19  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
20  FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
21  details.
22 
23  You should have received a copy of the GNU General Public License along with
24  this program; if not, write to the Free Software Foundation, Inc., 51 Franklin
25  Street, Fifth Floor, Boston, MA 02110-1301, USA.
26 */
27 
28 /*----------------------------------------------------------------------------*/
29 
30 /*----------------------------------------------------------------------------
31  * Local headers
32  *----------------------------------------------------------------------------*/
33 
34 #include "cs_base.h"
35 #include "cs_mesh.h"
36 #include "cs_mesh_quantities.h"
37 
38 /*----------------------------------------------------------------------------*/
39 
41 
42 /*============================================================================
43  * Macro definitions
44  *============================================================================*/
45 
46 /*
47  * Detection criteria type
48  */
49 
50 #define CS_BAD_CELL_ORTHO_NORM (1 << 0)
51 #define CS_BAD_CELL_OFFSET (1 << 1)
52 #define CS_BAD_CELL_LSQ_GRAD (1 << 2)
53 #define CS_BAD_CELL_RATIO (1 << 3)
54 #define CS_BAD_CELL_GUILT (1 << 4)
55 #define CS_BAD_CELL_USER (1 << 5)
56 
57 /*=============================================================================
58  * Public function prototypes
59  *============================================================================*/
60 
61 /*----------------------------------------------------------------------------
62  * Compute bad cell quality indicators.
63  *
64  * parameters:
65  * mesh <-- pointer to a mesh structure.
66  * mesh_quantities <-> pointer to a mesh quantities structures.
67  *----------------------------------------------------------------------------*/
68 
69 void
71  cs_mesh_quantities_t *mesh_quantities);
72 
73 /*----------------------------------------------------------------------------
74  * Post-process bad cell quality indicators.
75  *
76  * parameters:
77  * mesh <-- pointer to a mesh structure.
78  * mesh_quantities <-- pointer to a mesh quantities structures.
79  *----------------------------------------------------------------------------*/
80 
81 void
83  const cs_mesh_quantities_t *mesh_quantities);
84 
85 /*----------------------------------------------------------------------------*/
86 
88 
89 #endif /* __CS_MESH_BAD_CELLS_H__ */
#define BEGIN_C_DECLS
Definition: cs_defs.h:365
Definition: cs_mesh.h:62
Definition: cs_mesh_quantities.h:51
void cs_mesh_bad_cells_detect(const cs_mesh_t *mesh, cs_mesh_quantities_t *mesh_quantities)
Compute bad cell quality indicators.
Definition: cs_mesh_bad_cells.c:469
#define END_C_DECLS
Definition: cs_defs.h:366
void cs_mesh_bad_cells_postprocess(const cs_mesh_t *mesh, const cs_mesh_quantities_t *mesh_quantities)
Post-process bad cell quality indicators.
Definition: cs_mesh_bad_cells.c:737
Definition: mesh.f90:25