programmer's documentation
cs_field_pointer.h
Go to the documentation of this file.
1 #ifndef __CS_FIELD_POINTER_H__
2 #define __CS_FIELD_POINTER_H__
3 
4 /*============================================================================
5  * Field pointers and ids for standard and model fields
6  *============================================================================*/
7 
8 /*
9  This file is part of Code_Saturne, a general-purpose CFD tool.
10 
11  Copyright (C) 1998-2016 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_defs.h"
35 
36 /*----------------------------------------------------------------------------*/
37 
39 
40 /*=============================================================================
41  * Macro definitions
42  *============================================================================*/
43 
44 /* Macro used for scoping of field pointer enums */
45 
46 #define CS_ENUMF_(e) CS_FIELD_POINTER_ ## e
47 
48 /* Macro used to return a field pointer by its enumerated value */
49 
50 #define CS_F_(e) cs_glob_field_pointers[CS_FIELD_POINTER_ ## e].f
51 
52 #define CS_FI_(e, i) cs_glob_field_pointers[CS_FIELD_POINTER_ ## e].a->p[i]
53 
54 /*============================================================================
55  * Type definitions
56  *============================================================================*/
57 
60 typedef enum {
61 
62  /* Base variables and properties */
63 
109  /* Specific physics variables and properties */
110 
181  /* End of attributes */
182 
184 
186 
190  int n;
192 };
193 
199 };
200 
201 /*============================================================================
202  * Global variables
203  *============================================================================*/
204 
205 /* Pointers */
206 
208 
209 /*=============================================================================
210  * Public function prototypes
211  *============================================================================*/
212 
213 /*----------------------------------------------------------------------------
214  * Free all field pointer data.
215  *----------------------------------------------------------------------------*/
216 
217 void
219 
220 /*----------------------------------------------------------------------------
221  * Map a simple field to an enumerated pointer.
222  *
223  * The associated field pointer may then be retreived using \ref CS_F_(e).
224  *
225  * parameters:
226  * e <-- field enumerator value
227  * f <-- pointer to field structure
228  *----------------------------------------------------------------------------*/
229 
230 void
232  cs_field_t *f);
233 
234 /*----------------------------------------------------------------------------
235  * Map a field to an (enumerated pointer, index) couple.
236  *
237  * This sort of mapping may be used for sets of fields whose size
238  * is not known in advance.
239  *
240  * The associated field pointer may then be retreived using \ref CS_F_(e, i).
241  *
242  * parameters:
243  * e <-- field enumerator value
244  * index <-- field enumerator index
245  * f <-- pointer to field structure
246  *----------------------------------------------------------------------------*/
247 
248 void
250  int index,
251  cs_field_t *f);
252 
253 /*----------------------------------------------------------------------------
254  * Map base fields to enumerated pointers.
255  *----------------------------------------------------------------------------*/
256 
257 void
259 
260 /*----------------------------------------------------------------------------
261  * Map some boundary fields to enumerated pointers.
262  *----------------------------------------------------------------------------*/
263 
264 void
266 
267 /*----------------------------------------------------------------------------
268  * Map base fields to enumerated pointers for atmospheric models
269  *
270  * parameters:
271  * n_chem_species <-- number of chemical species
272  * species_f_if <-- field id for each chemical species
273  *----------------------------------------------------------------------------*/
274 
275 void
276 cs_field_pointer_map_atmospheric(int n_chem_species,
277  const int species_f_id[]);
278 
279 /*----------------------------------------------------------------------------
280  * Map base fields to enumerated pointers for atmospheric models
281  *
282  * parameters:
283  * n_coals <-- number of coals
284  * n_classes <-- number of coal classes
285  *----------------------------------------------------------------------------*/
286 
287 void
289  int n_classes);
290 
291 /*----------------------------------------------------------------------------*
292  * Map base fields to enumerated pointers for compressible model
293  *----------------------------------------------------------------------------*/
294 
295 void
297 
298 /*----------------------------------------------------------------------------*
299  * Map base fields to enumerated pointers for gas mix model
300  *----------------------------------------------------------------------------*/
301 
302 void
304 
305 /*----------------------------------------------------------------------------
306  * Map base fields to enumerated pointers for gas combustion.
307  *----------------------------------------------------------------------------*/
308 
309 void
311 
312 /*----------------------------------------------------------------------------*/
313 
315 
316 #endif /* __CS_FIELD_POINTER_H__ */
Definition: cs_field_pointer.h:69
Definition: cs_field_pointer.h:154
Definition: cs_field_pointer.h:155
Definition: cs_field_pointer.h:150
Definition: cs_field_pointer.h:164
Definition: cs_field_pointer.h:196
void cs_field_pointer_map_base(void)
Map base fields to enumerated pointers.
Definition: cs_field_pointer.c:289
Definition: cs_field_pointer.h:104
Definition: cs_field_pointer.h:140
Definition: cs_field_pointer.h:159
Definition: cs_field_pointer.h:129
Definition: cs_field_pointer.h:156
Field descriptor.
Definition: cs_field.h:121
Definition: cs_field_pointer.h:161
Definition: cs_field_pointer.h:133
void cs_field_pointer_destroy_all(void)
Free all field pointer data.
Definition: cs_field_pointer.c:172
Definition: cs_field_pointer.h:141
Definition: cs_field_pointer.h:151
#define BEGIN_C_DECLS
Definition: cs_defs.h:448
Definition: cs_field_pointer.h:114
cs_field_t * f
Definition: cs_field_pointer.h:197
Definition: cs_field_pointer.h:82
Definition: cs_field_pointer.h:78
#define CS_ENUMF_(e)
Macro used for scoping of field pointer enums.
Definition: cs_field_pointer.h:46
Definition: cs_field_pointer.h:168
Definition: cs_field_pointer.h:123
Definition: cs_field_pointer.h:152
void cs_field_pointer_map_boundary(void)
Map some boundary fields to enumerated pointers.
Definition: cs_field_pointer.c:354
Definition: cs_field_pointer.h:116
Definition: cs_field_pointer.h:135
void cs_field_pointer_map_gas_mix(void)
Map base fields to enumerated pointers for gas mix model.
Definition: cs_field_pointer.c:491
Definition: cs_field_pointer.h:66
Definition: cs_field_pointer.h:167
Definition: cs_field_pointer.h:100
void cs_field_pointer_map_compressible(void)
Map base fields to enumerated pointers for compressible model.
Definition: cs_field_pointer.c:467
Definition: cs_field_pointer.h:126
int n
Definition: cs_field_pointer.h:190
Definition: cs_field_pointer.h:95
Definition: cs_field_pointer.h:77
Definition: cs_field_pointer.h:132
Definition: cs_field_pointer.h:144
Definition: cs_field_pointer.h:143
Definition: cs_field_pointer.h:67
void cs_field_pointer_map_coal_combustion(int n_coals, int n_classes)
Map base fields to enumerated pointers for coal combustion.
Definition: cs_field_pointer.c:400
Definition: cs_field_pointer.h:106
Definition: cs_field_pointer.h:166
Definition: cs_field_pointer.h:149
Definition: cs_field_pointer.h:177
Definition: cs_field_pointer.h:183
Definition: cs_field_pointer.h:118
Definition: cs_field_pointer.h:111
Definition: cs_field_pointer.h:98
Definition: cs_field_pointer.h:165
Definition: cs_field_pointer.h:113
Definition: cs_field_pointer.h:157
void cs_field_pointer_map_indexed(cs_field_pointer_id_t e, int index, cs_field_t *f)
Map a field to an (enumerated pointer, index) couple.
Definition: cs_field_pointer.c:225
Definition: cs_field_pointer.h:142
void cs_field_pointer_map(cs_field_pointer_id_t e, cs_field_t *f)
Map a simple field to an enumerated pointer.
Definition: cs_field_pointer.c:196
Definition: cs_field_pointer.h:92
Definition: cs_field_pointer.h:174
Definition: cs_field_pointer.h:64
Definition: cs_field_pointer.h:131
Definition: cs_field_pointer.h:94
Definition: cs_field_pointer.h:86
Definition: cs_field_pointer.h:179
Definition: cs_field_pointer.h:107
Definition: cs_field_pointer.h:101
Definition: cs_field_pointer.h:171
Definition: cs_field_pointer.h:170
Definition: cs_field_pointer.h:134
Definition: cs_field_pointer.h:172
Definition: cs_field_pointer.h:74
Definition: cs_field_pointer.h:146
struct cs_field_pointer_array_t * a
Definition: cs_field_pointer.h:198
Definition: cs_field_pointer.h:127
Definition: cs_field_pointer.h:85
Definition: cs_field_pointer.h:76
Definition: cs_field_pointer.h:175
Definition: cs_field_pointer.h:189
#define END_C_DECLS
Definition: cs_defs.h:449
Definition: cs_field_pointer.h:136
Definition: cs_field_pointer.h:72
Definition: cs_field_pointer.h:80
Definition: cs_field_pointer.h:121
Definition: cs_field_pointer.h:153
Definition: cs_field_pointer.h:147
Definition: cs_field_pointer.h:137
Definition: cs_field_pointer.h:138
Definition: cs_field_pointer.h:125
Definition: cs_field_pointer.h:139
Definition: cs_field_pointer.h:97
Definition: cs_field_pointer.h:93
Definition: cs_field_pointer.h:73
Definition: cs_field_pointer.h:103
Definition: cs_field_pointer.h:119
cs_field_pointer_id_t
Definition: cs_field_pointer.h:60
Definition: cs_field_pointer.h:115
Definition: cs_field_pointer.h:90
Definition: cs_field_pointer.h:145
Definition: cs_field_pointer.h:176
Definition: cs_field_pointer.h:70
Definition: cs_field_pointer.h:158
Definition: cs_field_pointer.h:162
void cs_field_pointer_map_atmospheric(int n_chem_species, const int species_f_id[])
Map base fields to enumerated pointers for atmospheric models.
Definition: cs_field_pointer.c:373
cs_field_t * p[]
Definition: cs_field_pointer.h:191
Definition: cs_field_pointer.h:88
Definition: cs_field_pointer.h:122
Definition: cs_field_pointer.h:130
Definition: cs_field_pointer.h:81
Definition: cs_field_pointer.h:173
Definition: cs_field_pointer.h:75
void cs_field_pointer_map_gas_combustion(void)
Map base fields to enumerated pointers for gas combustion.
Definition: cs_field_pointer.c:504
union cs_field_pointer_val_t * cs_glob_field_pointers
Definition: cs_field_pointer.c:130