MED fichier
test11.c
Aller à la documentation de ce fichier.
1/* This file is part of MED.
2 *
3 * COPYRIGHT (C) 1999 - 2020 EDF R&D, CEA/DEN
4 * MED is free software: you can redistribute it and/or modify
5 * it under the terms of the GNU Lesser General Public License as published by
6 * the Free Software Foundation, either version 3 of the License, or
7 * (at your option) any later version.
8 *
9 * MED is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU Lesser General Public License for more details.
13 *
14 * You should have received a copy of the GNU Lesser General Public License
15 * along with MED. If not, see <http://www.gnu.org/licenses/>.
16 */
17
18/******************************************************************************
19 * - Nom du fichier : test11.c
20 *
21 * - Description : lecture de champs de resultats MED
22 *
23 *****************************************************************************/
24
25#include <med.h>
26#define MESGERR 1
27#include "med_utils.h"
28#include <string.h>
29
30#include <assert.h>
31
32#ifdef DEF_LECT_ECR
33#define MODE_ACCES MED_ACC_RDWR
34#elif DEF_LECT_AJOUT
35#define MODE_ACCES MED_ACC_RDEXT
36#else
37#define MODE_ACCES MED_ACC_CREAT
38#endif
39
40#ifndef USER_INTERLACE
41#define USER_INTERLACE MED_FULL_INTERLACE
42#endif
43
44#define USER_MODE MED_COMPACT_STMODE
45
46med_err getFieldsOn(med_idt fid, char * nomcha, med_field_type typcha, med_int ncomp,
47 med_entity_type entite, med_switch_mode stockage, med_int ncstp);
48
49int main (int argc, char **argv)
50
51
52{
53 med_err ret,lret;
54 med_idt fid;
55 char * fichier = NULL;
56 char maa[MED_NAME_SIZE+1]="";
57 char desc[MED_COMMENT_SIZE+1]="";
58 char pflname[MED_NAME_SIZE+1]="",nomlien[MED_NAME_SIZE+1]="";
59 char _meshname [MED_NAME_SIZE+1]="";
60 char _dtunit [MED_SNAME_SIZE+1]="";
61 char locname[MED_NAME_SIZE+1]="";
62 char * lien = NULL;
63 char *comp= NULL, *unit= NULL;
64 char nomcha [MED_NAME_SIZE+1]="";
65 med_int mdim=0,sdim=0,ncomp,ncha,npro,nln,pflsize,*pflval,nval;
66 med_int _ncstp=0,ngauss=0,nloc=0,locsdim=0,lnsize=0;
67 int t1,t2,t3;
68 med_field_type typcha;
69 med_geometry_type type_geo;
70 med_float *refcoo, *gscoo, *wg;
71 int i,j;
72 med_bool _local;
73
74 char dtunit[MED_SNAME_SIZE+1]="";
75 char nomcoo[3*MED_SNAME_SIZE+1]="";
76 char unicoo[3*MED_SNAME_SIZE+1]="";
77 char geointerpname[MED_NAME_SIZE+1]="";
78 char ipointstructmeshname[MED_NAME_SIZE+1]="";
79 med_mesh_type type;
81 med_int nstep=0;
82 med_axis_type rep;
83 med_int nsectionmeshcell;
84 med_geometry_type sectiongeotype;
85
86 if (argc != 2) {
87 MESSAGE("Aucun nom de fichier precise, fichier test10.med utilise ");
88 fichier = "test10.med";
89 } else {
90 fichier = argv[1];
91 };
92
93
94 /* Ouverture du fichier med */
95 if ((fid = MEDfileOpen(fichier,MED_ACC_RDONLY)) < 0){
96 MESSAGE("Erreur a l'ouverture du fichier : ");SSCRUTE(fichier);
97 return -1;
98 }
99
100 ret = 0;
101
102
103 /* Lecture des infos concernant le premier maillage */
104 if ( MEDmeshInfo( fid, 1, maa, &sdim, &mdim, &type, desc, dtunit, &sort,
105 &nstep, &rep, nomcoo,unicoo) < 0 ) {
106 MESSAGE("Erreur a la lecture des informations sur le maillage : ");SSCRUTE(maa);
107 return -1;
108 } else {
109 printf("Maillage de nom : |%s| , de dimension : "IFORMAT" , et de type %d\n",maa,mdim,type);
110 printf("\t -Dimension de l'espace : "IFORMAT"\n",sdim);
111 printf("\t -Description du maillage : %s\n",desc);
112 printf("\t -Noms des axes : |%s|\n",nomcoo);
113 printf("\t -Unités des axes : |%s|\n",unicoo);
114 printf("\t -Type de repère : %d\n",rep);
115 printf("\t -Nombre d'étapes de calcul : "IFORMAT"\n",nstep);
116 printf("\t -Unité des dates : |%s|\n",dtunit);
117 }
118
119
120 /* combien de champs dans le fichier */
121 if ((ncha = MEDnField(fid)) < 0) {
122 MESSAGE("Impossible de lire le nombre de champs : ");ISCRUTE(ncha);
123 return ncha;
124 }
125
126 printf("Nombre de champs : "IFORMAT" \n",ncha);
127
128 /* lecture de tous les champs */
129 for (i =0;i<ncha;i++) {
130 lret = 0;
131 printf("\nChamp numero : %d \n",i+1);
132
133 /* Lecture du nombre de composantes */
134 if ((ncomp = MEDfieldnComponent(fid,i+1)) < 0) {
135 MESSAGE("Erreur a la lecture du nombre de composantes : "); ISCRUTE(ncomp);
136 ret = -1; continue;
137 }
138
139 /* Lecture du type du champ, des noms des composantes et du nom de l'unite*/
140 comp = (char*) malloc(ncomp*MED_SNAME_SIZE+1);
141 EXIT_IF(comp == NULL,NULL,NULL);
142 unit = (char*) malloc(ncomp*MED_SNAME_SIZE+1);
143 EXIT_IF(unit == NULL,NULL,NULL);
144
145 if ( MEDfieldInfo(fid,i+1,nomcha,_meshname,&_local,&typcha,comp,unit,_dtunit,&_ncstp) < 0 ) {
146 MESSAGE("Erreur a la demande d'information sur les champs : ");
147 ISCRUTE_int(i+1);SSCRUTE(nomcha);ISCRUTE_int(typcha);SSCRUTE(comp);SSCRUTE(unit);
148 ISCRUTE(ncomp);
149 ret = -1; continue;
150 }
151
152
153 printf("Nom du champ : |%s| de type %d\n",nomcha,typcha);
154 printf("Nombre de composantes : |"IFORMAT"|\n",ncomp);
155 printf("Nom des composantes : |%s|\n",comp);
156 printf("Unites des composantes : |%s| \n",unit);
157 printf("Unites des dates : |%s| \n",_dtunit);
158 printf("Le maillage associé est |%s|\n",_meshname);
159 printf("Nombre d'étapes de calcul |"IFORMAT"|\n",_ncstp);
160
161 /* Le maillage reference est-il porte par un autre fichier */
162 if ( !_local ) {
163
164 if ( (lnsize=MEDlinkInfoByName(fid,_meshname) ) < 0 ) {
165 MESSAGE("Erreur a la lecture de la taille du lien : ");
166 SSCRUTE(_meshname);
167 ret = -1;
168 } else {
169
170 lien = malloc((lnsize+1)*sizeof(char));
171 EXIT_IF(lien == NULL,NULL,NULL);
172
173 if ( MEDlinkRd(fid,_meshname, lien) < 0 ) {
174 MESSAGE("Erreur a la lecture du lien : ");
175 SSCRUTE(_meshname);SSCRUTE(lien);
176 ret = -1;
177 } else {
178 printf("\tLe maillage |%s| est porte par un fichier distant |%s|\n",_meshname,lien);
179 }
180 free(lien);
181 }
182 }
183
184 free(comp);
185 free(unit);
186
187
188 lret = getFieldsOn(fid, nomcha, typcha, ncomp, MED_NODE, USER_INTERLACE,_ncstp );
189
190 if (lret == 0) lret = getFieldsOn(fid, nomcha, typcha, ncomp, MED_CELL, USER_INTERLACE,_ncstp );
191 else { MESSAGE("Erreur a la lecture des champs aux noeuds "); ret = -1; continue;}
192
193 if (lret == 0) lret = getFieldsOn(fid, nomcha, typcha, ncomp, MED_DESCENDING_FACE,USER_INTERLACE,_ncstp);
194 else { MESSAGE("Erreur a la lecture des champs aux mailles "); ret = -1; continue;}
195
196 if (lret == 0) lret = getFieldsOn(fid, nomcha, typcha, ncomp, MED_DESCENDING_EDGE,USER_INTERLACE,_ncstp);
197 else {MESSAGE("Erreur a la lecture des champs aux faces "); ret = -1; continue;}
198
199 if (lret == 0) lret = getFieldsOn(fid, nomcha, typcha, ncomp, MED_NODE_ELEMENT,USER_INTERLACE,_ncstp);
200 else {MESSAGE("Erreur a la lecture des champs aux aretes"); ret = -1; continue;}
201
202 /*TODO */
203/* if (lret == 0) lret = getFieldsOn(fid, nomcha, typcha, ncomp, MED_STRUCT_ELEMENT,USER_INTERLACE,_ncstp); */
204/* else {MESSAGE("Erreur a la lecture des champs aux éléments de structure"); ret = -1; continue;} */
205
206 if (lret != 0) {MESSAGE("Erreur a la lecture des champs aux noeuds des mailles "); ret = -1;};
207 }
208
209
210 /* Interrogation des profils */
211 npro = MEDnProfile(fid);
212
213 printf("\nNombre de profils stockes : "IFORMAT"\n\n",npro);
214 for (i=1 ; i <= npro ; i++ ) {
215 if ( MEDprofileInfo(fid, i, pflname, &nval) < 0) {
216 MESSAGE("Erreur a la demande d'information sur le profil n° : "); ISCRUTE_int(i);
217 ret = -1;continue;
218 }
219 printf("\t- Profil n°%i de nom |%s| et de taille "IFORMAT"\n",i,pflname,nval);
220 pflval = (med_int*) malloc(sizeof(med_int)*nval);
221 if ( MEDprofileRd(fid, pflname, pflval) < 0) {
222 MESSAGE("Erreur a la lecture des valeurs du profil : ");
223 SSCRUTE(pflname);
224 ret = -1;
225 } else {
226 printf("\t");
227 for (j=0;j<nval;j++) printf(" "IFORMAT" ",*(pflval+j));
228 printf("\n\n");
229 }
230 free(pflval);
231 }
232
233 /* Interrogation des liens */
234 nln = MEDnLink(fid);
235
236 printf("\nNombre de liens stockes : "IFORMAT"\n\n",nln);
237 for (i=1 ; i <= nln ; i++ ) {
238 if ( MEDlinkInfo(fid, i, nomlien, &nval) < 0) {
239 MESSAGE("Erreur a la demande d'information sur le lien n° : "); ISCRUTE_int(i);
240 ret = -1;continue;
241 }
242 printf("\t- Lien n°%i de nom |%s| et de taille "IFORMAT"\n",i,nomlien,nval);
243
244 lien = malloc((nval+1)*sizeof(char));
245 EXIT_IF(lien == NULL,NULL,NULL);
246
247 if ( MEDlinkRd(fid, nomlien, lien ) < 0 ) {
248 MESSAGE("Erreur a la lecture du lien : ");
249 SSCRUTE(nomlien);SSCRUTE(lien);
250 ret = -1;
251 } else {
252 lien[nval] = '\0';
253 printf("\t\t|%s|\n\n",lien);
254 }
255 free(lien);
256 }
257
258 /* Interrogation des localisations des points de GAUSS */
259 nloc = MEDnLocalization(fid);
260
261 printf("\nNombre de localisations stockees : "IFORMAT"\n\n",nloc);
262 for (i=1 ; i <= nloc ; i++ ) {
263 if ( MEDlocalizationInfo(fid, i, locname, &type_geo, &locsdim,&ngauss,
264 geointerpname, ipointstructmeshname,&nsectionmeshcell,
265 &sectiongeotype) < 0) {
266 MESSAGE("Erreur a la demande d'information sur la localisation n° : "); ISCRUTE_int(i);
267 ret = -1;continue;
268 }
269 printf("\t- Loc. n°%i de nom |%s| de dimension |"IFORMAT"| avec "IFORMAT" pts de GAUSS \n",i,locname,locsdim,ngauss);
270 t1 = (type_geo%100)*(type_geo/100);
271 t2 = ngauss*(type_geo/100);
272 t3 = ngauss;
273 refcoo = (med_float *) malloc(sizeof(med_float)*t1 );
274 gscoo = (med_float *) malloc(sizeof(med_float)*t2 );
275 wg = (med_float *) malloc(sizeof(med_float)*t3 );
276
277 if ( MEDlocalizationRd(fid, locname, USER_INTERLACE, refcoo, gscoo, wg ) < 0) {
278 MESSAGE("Erreur a la lecture des valeurs de la localisation : ");
279 SSCRUTE(locname);
280 ret = -1;
281 } else {
282 printf("\t Coordonnees de l'element de reference de type %i :\n\t\t",type_geo);
283 for (j=0;j<t1;j++) printf(" %f ",*(refcoo+j));
284 printf("\n");
285 printf("\t Localisation des points de GAUSS : \n\t\t");
286 for (j=0;j<t2;j++) printf(" %f ",*(gscoo+j));
287 printf("\n");
288 printf("\t Poids associes aux points de GAUSS :\n\t\t");
289 for (j=0;j<t3;j++) printf(" %f ",*(wg+j));
290 printf("\n\n");
291 }
292 free(refcoo);
293 free(gscoo);
294 free(wg);
295 }
296
297
298 /* fermeture du fichier */
299 if ( MEDfileClose(fid) < 0) return -1;
300
301 return ret;
302}
303
304med_err getFieldsOn(med_idt fid, char * nomcha, med_field_type typcha, med_int ncomp,
305 med_entity_type entite, med_switch_mode stockage, med_int ncstp) {
306
307 int j,k,l,m,n,nb_geo=0;
308 med_int nbpdtnor=0,pflsize,*pflval,ngauss=0,ngroup,nval;
309 med_int numdt=0,numo=0,_nprofile;
310 med_size medtype_size=0;
311 med_float dt=0.0;
312 unsigned char *val = NULL;
313 med_err ret=0;
314 char pflname [MED_NAME_SIZE+1]="";
315 char locname [MED_NAME_SIZE+1]="";
316 char * lien = NULL;
317 char dt_unit [MED_SNAME_SIZE+1]="unknown";
318
319 med_geometry_type * type_geo;
320
321 const char * const * AFF;
322 const char * const * AFF_ENT=MED_GET_ENTITY_TYPENAME+1;
323 switch (entite) {
324 case MED_NODE :
326 nb_geo = MED_N_NODE_FIXED_GEO;
328 break;
329 case MED_CELL :
330 case MED_NODE_ELEMENT :
332 nb_geo = MED_N_CELL_FIXED_GEO;
334 break;
337 nb_geo = MED_N_FACE_FIXED_GEO;
339 break;
342 nb_geo = MED_N_EDGE_FIXED_GEO;
344 break;
345 }
346
347 for (k=1;k<=nb_geo;k++) {
348
349 /* Combien de (PDT,NOR) a lire */
350 nbpdtnor = ncstp;
351 if (nbpdtnor < 1 ) continue;
352
353 for (j=0;j<nbpdtnor;j++) {
354
355 if ( MEDfieldComputingStepInfo(fid,nomcha,j+1, &numdt, &numo, &dt ) <0) {
356 MESSAGE("Erreur a la demande d'information sur (pdt,nor) : ");
357 ISCRUTE(numdt); ISCRUTE(numo);
358 ret = -1; continue;
359 }
360
361 if ( (_nprofile = MEDfieldnProfile(fid,nomcha,numdt,numo,entite,type_geo[k],
362 pflname,locname ) ) < 0 ) {
363 MESSAGE("Erreur a la demande du nombre de profils referencés par le champ : ");
364 SSCRUTE(nomcha);
365 ISCRUTE(numdt); ISCRUTE(numo);
366 ISCRUTE_int(entite);ISCRUTE_int(type_geo[k]);
367 SSCRUTE(AFF_ENT[(int)entite]);SSCRUTE(AFF[k]);
368 ret = -1; continue;
369 };
370
371 for (l=0;l<_nprofile;l++) {
372
373
374 if ( (nval = MEDfieldnValueWithProfile(fid, nomcha, numdt, numo, entite, type_geo[k],
375 l+1, USER_MODE, pflname,&pflsize,
376 locname, &ngauss) ) < 0 ) {
377 MESSAGE("Erreur a la lecture du nombre de valeurs du champ : ");
378 SSCRUTE(nomcha);ISCRUTE(numdt);ISCRUTE(numo);
379 ISCRUTE_int(entite);ISCRUTE_int(type_geo[k]);
381 ret = -1; continue;
382 };
383
384 printf("\n +Pas de Temps n."IFORMAT" (%f) [%s], n. d'ordre "IFORMAT", avec "IFORMAT" valeur(s) par entité.\n",numdt,dt,dt_unit,numo,ngauss);
385 printf("\t- Il y a "IFORMAT" entités qui portent des valeurs en mode %i. Chaque entite %s\
386 de type geometrique %s associes au profile |%s| a "IFORMAT" valeurs associées \n",
387 nval,USER_MODE,AFF_ENT[(int)entite],AFF[k],pflname,ngauss);
388
389 /*Lecture des valeurs du champ */
390 switch(typcha) {
391 case MED_FLOAT64: medtype_size=sizeof(med_float64); break;
392 case MED_FLOAT32: medtype_size=sizeof(med_float32); break;
393 case MED_INT32 : medtype_size=sizeof(med_int32 ); break;
394 case MED_INT64 : medtype_size=sizeof(med_int64 );
395 break;
396 case MED_INT : medtype_size=sizeof(med_int) ; break;
397 default:
398 MESSAGE("Erreur a la lecture du type de champ : ");
399 ISCRUTE_int(typcha);
400 EXIT_IF(NULL == NULL,NULL,NULL);
401 }
402
403 val = (unsigned char*) calloc(ncomp*nval*ngauss,medtype_size);
404 EXIT_IF(val == NULL,NULL,NULL);
405
406 if (MEDfieldValueWithProfileRd(fid, nomcha, numdt,numo, entite,type_geo[k],
407 USER_MODE, pflname, stockage,MED_ALL_CONSTITUENT, val) < 0 ) {
408 MESSAGE("Erreur a la lecture des valeurs du champ : ");
409 SSCRUTE(nomcha);ISCRUTE_int(entite);ISCRUTE_int(type_geo[k]);
410 ISCRUTE(numdt);ISCRUTE(numo);
411 ret = -1;
412 }
413
414 if ( strlen(locname) )
415 printf("\t- Modèle de localisation des points de Gauss de nom |%s|\n",locname);
416
417 if (entite == MED_NODE_ELEMENT)
418 ngroup = (type_geo[k] % 100);
419 else
420 ngroup = ngauss;
421
422 switch (stockage) {
423
424 case MED_FULL_INTERLACE :
425 printf("\t- Valeurs :\n\t");
426 for (m=0;m<(nval*ngauss)/ngroup;m++) {
427 printf("|");
428 for (n=0;n<ngroup*ncomp;n++)
429 switch(typcha) {
430 case MED_FLOAT64:
431 printf(" %f ",*(((med_double*)val)+(m*ngroup*ncomp)+n ) );
432 /* printf(" %f ", ((med_double*)val)[(m*ngroup*ncomp)+n] ); */
433 /* printf(" %f ", *( val+medtype_size*((m*ngroup*ncomp)+n)) ); */
434 break;
435 case MED_FLOAT32:
436 printf(" %f ",*(((med_float32*)val)+((m*ngroup*ncomp)+n)));
437 break;
438 case MED_INT32 :
439 printf(" %d ",*(((med_int32*)val)+(m*ngroup*ncomp)+n));
440 break;
441 case MED_INT64 :
442 printf(" %lld ",*(((med_int64*)val)+(m*ngroup*ncomp)+n));
443 break;
444 case MED_INT :
445 printf(" "IFORMAT" ",*(((med_int*)val)+(m*ngroup*ncomp)+n));
446 break;
447 default:
448 break;
449 }
450 }
451 break;
452 /*Affichage en fonction du profil à traiter*/
453 case MED_NO_INTERLACE :
454 printf("\t- Valeurs :\n\t");
455 for (m=0;m<ncomp;m++) {
456 printf("|");
457 for (n=0;n<(nval*ngauss);n++)
458 switch(typcha) {
459 case MED_FLOAT64:
460 printf(" %f ",*(((med_double*)val)+(m*nval*ngauss)+n ) );
461 /* printf(" %f ", ((med_double*)val)[(m*nval)+n] ); */
462 /* printf(" %f ", *( val+medtype_size*((m*nval)+n)) ); */
463 break;
464 case MED_FLOAT32:
465 printf(" %f ",*(((med_float32*)val)+((m*nval*ngauss)+n)));
466 break;
467 case MED_INT32 :
468 printf(" %d ",*(((med_int32*)val)+(m*nval*ngauss)+n));
469 break;
470 case MED_INT64 :
471 printf(" %lld ",*(((med_int64*)val)+(m*nval*ngauss)+n));
472 break;
473 case MED_INT :
474 printf(" "IFORMAT" ",*(((med_int*)val)+(m*nval*ngauss)+n));
475 break;
476 default:
477 break;
478 }
479 }
480 break;
481 }
482
483 printf("|\n");
484 if ( val ) {free(val);val = NULL;}
485
486 /*Lecture du profil associe */
487 if (strcmp(pflname,MED_NO_PROFILE) == 0 )
488 printf("\t- Profil : MED_NO_PROFILE\n");
489 else {
490
491 if ( (pflsize = MEDprofileSizeByName(fid,pflname)) <0 ) {
492 MESSAGE("Erreur a la lecture du nombre de valeurs du profil : ");
493 SSCRUTE(pflname);
494 ret = -1; continue;
495 }
496
497 printf("\t- Profil : |%s| de taille "IFORMAT"\n",pflname,pflsize);
498
499 pflval = (med_int*) malloc(sizeof(med_int)*pflsize);
500 EXIT_IF(pflval == NULL,NULL,NULL);
501 if ( MEDprofileRd(fid,pflname,pflval) <0) {
502 MESSAGE("Erreur a la lecture des valeurs du profil : ");
503 SSCRUTE(pflname);
504 ret = -1;
505 }
506 printf("\t");
507 for (m=0;m<pflsize;m++) printf(" "IFORMAT" ",*(pflval+m));
508 printf("\n");
509 free(pflval);
510
511 }
512
513 }
514 }
515 } /* fin for sur les mailles*/
516
517 return ret;
518}
519
#define MED_NAME_SIZE
#define MED_SNAME_SIZE
MEDC_EXPORT med_geometry_type MED_GET_EDGE_GEOMETRY_TYPE[MED_N_EDGE_FIXED_GEO+2]
MEDC_EXPORT const char *const MED_GET_ENTITY_TYPENAME[MED_N_ENTITY_TYPES+2]
MEDC_EXPORT const char *const MED_GET_CELL_GEOMETRY_TYPENAME[MED_N_CELL_FIXED_GEO+2]
#define MED_ALL_CONSTITUENT
MEDC_EXPORT const char *const MED_GET_FACE_GEOMETRY_TYPENAME[MED_N_FACE_FIXED_GEO+2]
MEDC_EXPORT const char * MED_GET_NODE_GEOMETRY_TYPENAME[MED_N_NODE_FIXED_GEO+2]
#define MED_N_NODE_FIXED_GEO
#define MED_NO_PROFILE
MEDC_EXPORT med_geometry_type MED_GET_NODE_GEOMETRY_TYPE[MED_N_NODE_FIXED_GEO+2]
MEDC_EXPORT med_geometry_type MED_GET_FACE_GEOMETRY_TYPE[MED_N_FACE_FIXED_GEO+2]
#define MED_N_FACE_FIXED_GEO
#define MED_COMMENT_SIZE
#define MED_N_EDGE_FIXED_GEO
#define MED_N_CELL_FIXED_GEO
MEDC_EXPORT const char * MED_GET_EDGE_GEOMETRY_TYPENAME[MED_N_EDGE_FIXED_GEO+2]
MEDC_EXPORT med_geometry_type MED_GET_CELL_GEOMETRY_TYPE[MED_N_CELL_FIXED_GEO+2]
#define EXIT_IF(expression, message, arg)
#define SSCRUTE(chaine)
#define MESSAGE(chaine)
#define ISCRUTE(entier)
#define ISCRUTE_int(entier)
MEDC_EXPORT med_int MEDnField(const med_idt fid)
Cette fonction permet de lire le nombre de champs dans un fichier.
Definition MEDnField.c:35
MEDC_EXPORT med_err MEDfieldComputingStepInfo(const med_idt fid, const char *const fieldname, const int csit, med_int *const numdt, med_int *const numit, med_float *const dt)
Cette fonction permet de lire les informations caractérisant une étape de calcul : numéro de pas de t...
MEDC_EXPORT med_err MEDfieldValueWithProfileRd(const med_idt fid, const char *const fieldname, const med_int numdt, const med_int numit, const med_entity_type entitype, const med_geometry_type geotype, const med_storage_mode storagemode, const char *const profilename, const med_switch_mode switchmode, const med_int componentselect, unsigned char *const value)
Cette fonction permet de lire les valeurs d'un champ définies sur des entités d'un maillage pour une ...
MEDC_EXPORT med_int MEDfieldnValueWithProfile(const med_idt fid, const char *const fieldname, const med_int numdt, const med_int numit, const med_entity_type entitype, const med_geometry_type geotype, const int profileit, const med_storage_mode storagemode, char *const profilename, med_int *const profilesize, char *const localizationname, med_int *const nintegrationpoint)
Cette fonction permet de lire le nombre de valeurs à lire dans un champ pour une étape de calcul,...
MEDC_EXPORT med_int MEDfieldnProfile(const med_idt fid, const char *const fieldname, const med_int numdt, const med_int numit, const med_entity_type enttype, const med_geometry_type geotype, char *const defaultprofilename, char *const defaultlocalizationname)
Cette fonction permet de lire le nombre de profils référencés dans un champ pour une étape de calcul,...
MEDC_EXPORT med_int MEDfieldnComponent(const med_idt fid, const int ind)
Cette fonction lit le nombre de composantes d'un champ.
MEDC_EXPORT med_err MEDfieldInfo(const med_idt fid, const int ind, char *const fieldname, char *const meshname, med_bool *const localmesh, med_field_type *const fieldtype, char *const componentname, char *const componentunit, char *const dtunit, med_int *const ncstp)
Cette fonction permet de lire les informations concernant le champ d'indice ind .
MEDC_EXPORT med_err MEDfileClose(med_idt fid)
Fermeture d'un fichier MED.
MEDC_EXPORT med_idt MEDfileOpen(const char *const filename, const med_access_mode accessmode)
Ouverture d'un fichier MED.
Definition MEDfileOpen.c:42
MEDC_EXPORT med_int MEDnLocalization(const med_idt fid)
Cette routine permet de lire le nombre de localisations de points d'intégration contenues dans un fic...
MEDC_EXPORT med_err MEDlocalizationRd(const med_idt fid, const char *const localizationname, const med_switch_mode switchmode, med_float *const elementcoordinate, med_float *const ipointcoordinate, med_float *const weight)
Cette routine permet la lecture d'une localisation localizationname de points d'intégration dans/auto...
MEDC_EXPORT med_err MEDlocalizationInfo(const med_idt fid, const int localizationit, char *const localizationname, med_geometry_type *const geotype, med_int *const spacedimension, med_int *const nipoint, char *const geointerpname, char *const sectionmeshname, med_int *const nsectionmeshcell, med_geometry_type *const sectiongeotype)
Cette routine permet d'obtenir la description de la localisation de points d'intégration n° localizat...
MEDC_EXPORT med_err MEDmeshInfo(const med_idt fid, const int meshit, char *const meshname, med_int *const spacedim, med_int *const meshdim, med_mesh_type *const meshtype, char *const description, char *const dtunit, med_sorting_type *const sortingtype, med_int *const nstep, med_axis_type *const axistype, char *const axisname, char *const axisunit)
Cette routine permet de lire les informations relatives à un maillage dans un fichier.
Definition MEDmeshInfo.c:43
MEDC_EXPORT med_int MEDprofileSizeByName(const med_idt fid, const char *const profilename)
Cette routine permet de lire la taille d'un profil dont on connait le nom.
MEDC_EXPORT med_err MEDprofileInfo(const med_idt fid, const int profileit, char *const profilename, med_int *const profilesize)
Cette routine permet de lire les informations sur un profil dans un fichier MED.
MEDC_EXPORT med_err MEDprofileRd(const med_idt fid, const char *const profilename, med_int *const profilearray)
Cette routine permet de lire un profil dans un fichier MED.
MEDC_EXPORT med_int MEDnProfile(const med_idt fid)
Cette routine permet de lire le nombre de profils dans un fichier MED.
Definition MEDnProfile.c:37
med_err getFieldsOn(med_idt fid, char *nomcha, med_field_type typcha, med_int ncomp, med_entity_type entite, med_switch_mode stockage, med_int ncstp)
Definition test11.c:304
int main(int argc, char **argv)
Definition test11.c:49
#define USER_MODE
Definition test11.c:44
#define USER_INTERLACE
Definition test11.c:41