MED fichier
test11.c
Aller à la documentation de ce fichier.
1 /* This file is part of MED.
2  *
3  * COPYRIGHT (C) 1999 - 2021 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 
46 med_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 
49 int 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;
80  med_sorting_type sort;
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 
304 med_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 :
325  type_geo = MED_GET_NODE_GEOMETRY_TYPE;
326  nb_geo = MED_N_NODE_FIXED_GEO;
328  break;
329  case MED_CELL :
330  case MED_NODE_ELEMENT :
331  type_geo = MED_GET_CELL_GEOMETRY_TYPE;
332  nb_geo = MED_N_CELL_FIXED_GEO;
334  break;
335  case MED_DESCENDING_FACE :
336  type_geo = MED_GET_FACE_GEOMETRY_TYPE;
337  nb_geo = MED_N_FACE_FIXED_GEO;
339  break;
340  case MED_DESCENDING_EDGE :
341  type_geo = MED_GET_EDGE_GEOMETRY_TYPE;
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 
MED_GET_EDGE_GEOMETRY_TYPENAME
const char * MED_GET_EDGE_GEOMETRY_TYPENAME[MED_N_EDGE_FIXED_GEO+2]
Definition: MEDiterators.c:148
MEDlinkInfo
MEDC_EXPORT med_err MEDlinkInfo(const med_idt fid, const int linkit, char *const meshname, med_int *const linksize)
Cette routine permet de lire les informations sur un lien dans un fichier MED.
Definition: MEDlinkInfo.c:38
MED_FULL_INTERLACE
Definition: med.h:96
MED_COMMENT_SIZE
#define MED_COMMENT_SIZE
Definition: med.h:79
MEDnProfile
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
USER_MODE
#define USER_MODE
Definition: test11.c:43
MEDnLink
MEDC_EXPORT med_int MEDnLink(const med_idt fid)
Cette routine permet la lecture du nombre de lien dans un fichier MED.
Definition: MEDnLink.c:34
MEDfileOpen
MEDC_EXPORT med_idt MEDfileOpen(const char *const filename, const med_access_mode accessmode)
Ouverture d'un fichier MED.
Definition: MEDfileOpen.c:42
med_geometry_type
int med_geometry_type
Definition: med.h:194
med_int64
int64_t med_int64
Definition: med.h:344
MED_SNAME_SIZE
#define MED_SNAME_SIZE
Definition: med.h:82
MEDnField
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
med_double
double med_double
Definition: med.h:338
ISCRUTE_int
#define ISCRUTE_int(entier)
Definition: med_utils.h:314
MED_DESCENDING_FACE
Definition: med.h:143
med_size
hsize_t med_size
Definition: med.h:329
med_idt
hid_t med_idt
Definition: med.h:331
MED_FLOAT32
Definition: med.h:167
MED_ACC_RDONLY
Definition: med.h:120
getFieldsOn
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:303
med_err
herr_t med_err
Definition: med.h:332
MED_N_NODE_FIXED_GEO
#define MED_N_NODE_FIXED_GEO
Definition: med.h:251
med_sorting_type
med_sorting_type
Definition: med.h:309
MED_GET_FACE_GEOMETRY_TYPE
med_geometry_type MED_GET_FACE_GEOMETRY_TYPE[MED_N_FACE_FIXED_GEO+2]
Definition: MEDiterators.c:114
med_entity_type
med_entity_type
Definition: med.h:143
MED_INT64
Definition: med.h:169
MED_CELL
Definition: med.h:143
MEDfieldnValueWithProfile
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,...
Definition: MEDfieldnValueWithProfile.c:45
MESSAGE
#define MESSAGE(chaine)
Definition: med_utils.h:324
MED_INT32
Definition: med.h:168
MEDlocalizationRd
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...
Definition: MEDlocalizationRd.c:44
med_int
int med_int
Definition: med.h:342
med_field_type
med_field_type
Definition: med.h:165
MED_INT
Definition: med.h:170
med_float32
float med_float32
Definition: med.h:339
MEDnLocalization
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...
Definition: MEDnLocalization.c:36
MED_GET_CELL_GEOMETRY_TYPE
med_geometry_type MED_GET_CELL_GEOMETRY_TYPE[MED_N_CELL_FIXED_GEO+2]
Definition: MEDiterators.c:55
med.h
ISCRUTE
#define ISCRUTE(entier)
Definition: med_utils.h:313
med_bool
med_bool
Definition: med.h:260
MEDlinkRd
MEDC_EXPORT med_err MEDlinkRd(const med_idt fid, const char *const meshname, char *const link)
Cette routine permet de lire un lien dans un fichier MED.
Definition: MEDlinkRd.c:37
med_float
double med_float
Definition: med.h:336
MED_GET_NODE_GEOMETRY_TYPENAME
const char * MED_GET_NODE_GEOMETRY_TYPENAME[MED_N_NODE_FIXED_GEO+2]
Definition: MEDiterators.c:162
IFORMAT
#define IFORMAT
Definition: med_utils.h:145
main
int main(int argc, char **argv)
Definition: test11.c:48
MED_NODE
Definition: med.h:143
MED_GET_CELL_GEOMETRY_TYPENAME
const char *const MED_GET_CELL_GEOMETRY_TYPENAME[MED_N_CELL_FIXED_GEO+2]
Definition: MEDiterators.c:84
MED_N_FACE_FIXED_GEO
#define MED_N_FACE_FIXED_GEO
Definition: med.h:243
MEDfieldnProfile
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,...
Definition: MEDfieldnProfile.c:40
MEDprofileSizeByName
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.
Definition: MEDprofileSizeByName.c:37
MED_N_CELL_FIXED_GEO
#define MED_N_CELL_FIXED_GEO
Definition: med.h:239
MED_GET_ENTITY_TYPENAME
const char *const MED_GET_ENTITY_TYPENAME[MED_N_ENTITY_TYPES+2]
Definition: MEDiterators.c:36
med_mesh_type
med_mesh_type
Definition: med.h:131
SSCRUTE
#define SSCRUTE(chaine)
Definition: med_utils.h:323
MEDlocalizationInfo
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...
Definition: MEDlocalizationInfo.c:46
MED_GET_NODE_GEOMETRY_TYPE
med_geometry_type MED_GET_NODE_GEOMETRY_TYPE[MED_N_NODE_FIXED_GEO+2]
Definition: MEDiterators.c:156
MEDfieldValueWithProfileRd
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 ...
Definition: MEDfieldValueWithProfileRd.c:42
med_switch_mode
med_switch_mode
Definition: med.h:96
MED_NAME_SIZE
#define MED_NAME_SIZE
Definition: med.h:81
MEDfieldComputingStepInfo
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...
Definition: MEDfieldComputingStepInfo.c:39
MEDfileClose
MEDC_EXPORT med_err MEDfileClose(med_idt fid)
Fermeture d'un fichier MED.
Definition: MEDfileClose.c:30
MED_N_EDGE_FIXED_GEO
#define MED_N_EDGE_FIXED_GEO
Definition: med.h:247
MED_ALL_CONSTITUENT
#define MED_ALL_CONSTITUENT
Definition: med.h:299
EXIT_IF
#define EXIT_IF(expression, message, arg)
Definition: med_utils.h:343
MED_GET_FACE_GEOMETRY_TYPENAME
const char *const MED_GET_FACE_GEOMETRY_TYPENAME[MED_N_FACE_FIXED_GEO+2]
Definition: MEDiterators.c:127
MED_NO_PROFILE
#define MED_NO_PROFILE
Definition: med.h:281
MED_NO_INTERLACE
Definition: med.h:98
MEDfieldInfo
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 .
Definition: MEDfieldInfo.c:42
med_axis_type
med_axis_type
Definition: med.h:258
USER_INTERLACE
#define USER_INTERLACE
Definition: test11.c:40
MED_FLOAT64
Definition: med.h:166
MEDlinkInfoByName
MEDC_EXPORT med_int MEDlinkInfoByName(const med_idt fid, const char *const meshname)
Cette routine permet de lire les informations sur un lien dans un fichier MED.
Definition: MEDlinkInfoByName.c:36
MEDmeshInfo
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
MED_GET_EDGE_GEOMETRY_TYPE
med_geometry_type MED_GET_EDGE_GEOMETRY_TYPE[MED_N_EDGE_FIXED_GEO+2]
Definition: MEDiterators.c:140
med_int32
int32_t med_int32
Definition: med.h:343
MEDprofileRd
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.
Definition: MEDprofileRd.c:39
MEDfieldnComponent
MEDC_EXPORT med_int MEDfieldnComponent(const med_idt fid, const int ind)
Cette fonction lit le nombre de composantes d'un champ.
Definition: MEDfieldnComponent.c:34
med_float64
double med_float64
Definition: med.h:337
MEDprofileInfo
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.
Definition: MEDprofileInfo.c:40
med_utils.h
MED_NODE_ELEMENT
Definition: med.h:144
MED_DESCENDING_EDGE
Definition: med.h:143