MED fichier
test11b.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 : test11b.c
20  *
21  * - Description : lecture de champs de resultats MED (API23)
22  *
23  *****************************************************************************/
24 
25 #include <med.h>
26 #define MESGERR 1
27 #include "med_utils.h"
28 #include <string.h>
29 
30 #ifdef DEF_LECT_ECR
31 #define MODE_ACCES MED_ACC_RDWR
32 #elif DEF_LECT_AJOUT
33 #define MODE_ACCES MED_ACC_RDEXT
34 #else
35 #define MODE_ACCES MED_ACC_CREAT
36 #endif
37 
38 #ifndef USER_INTERLACE
39 #define USER_INTERLACE MED_FULL_INTERLACE
40 #endif
41 
42 #define USER_MODE MED_COMPACT_STMODE
43 
44 med_err getFieldsOn(med_idt fid, char * nomcha, med_field_type typcha, med_int ncomp,
45  med_entity_type entite, med_switch_mode stockage, med_int ncstp);
46 
47 int main (int argc, char **argv)
48 
49 
50 {
51  med_err ret,lret;
52  med_idt fid;
53  char * fichier = NULL;
54  char maa[MED_NAME_SIZE+1]="";
55  char desc[MED_COMMENT_SIZE+1]="";
56  char pflname[MED_NAME_SIZE+1]="",nomlien[MED_NAME_SIZE+1]="";
57  char _meshname [MED_NAME_SIZE+1]="";
58  char _dtunit [MED_SNAME_SIZE+1]="";
59  char locname[MED_NAME_SIZE+1]="";
60  char * lien = NULL;
61  char *comp= NULL, *unit= NULL;
62  char nomcha [MED_NAME_SIZE+1]="";
63  med_int mdim=0,sdim=0,ncomp,ncha,npro,nln,pflsize,*pflval,nval;
64  med_int _ncstp=0,ngauss=0,nloc=0,locsdim=0,lnsize=0;
65  int t1,t2,t3;
66  med_field_type typcha;
67  med_geometry_type type_geo;
68  med_float *refcoo, *gscoo, *wg;
69  int i,j;
70  med_bool _local;
71 
72  char dtunit[MED_SNAME_SIZE+1]="";
73  char nomcoo[3*MED_SNAME_SIZE+1]="";
74  char unicoo[3*MED_SNAME_SIZE+1]="";
75  char geointerpname[MED_NAME_SIZE+1]="";
76  char ipointstructmeshname[MED_NAME_SIZE+1]="";
77  med_mesh_type type;
78  med_sorting_type sort;
79  med_int nstep=0;
80  med_axis_type rep;
81  med_int nsectionmeshcell;
82  med_geometry_type sectiongeotype;
83 
84  if (argc != 2) {
85  MESSAGE("Aucun nom de fichier precise, fichier test10.med utilise ");
86  fichier = "test10.med";
87  } else {
88  fichier = argv[1];
89  };
90 
91 
92  /* Ouverture du fichier med */
93  if ((fid = MEDfileOpen(fichier,MED_ACC_RDONLY)) < 0){
94  MESSAGE("Erreur a l'ouverture du fichier : ");SSCRUTE(fichier);
95  return -1;
96  }
97 
98  ret = 0;
99 
100 
101  /* Lecture des infos concernant le premier maillage */
102  if ( MEDmeshInfo( fid, 1, maa, &sdim, &mdim, &type, desc, dtunit, &sort,
103  &nstep, &rep, nomcoo,unicoo) < 0 ) {
104  MESSAGE("Erreur a la lecture des informations sur le maillage : ");SSCRUTE(maa);
105  return -1;
106  } else {
107  printf("Maillage de nom : |%s| , de dimension : "IFORMAT" , et de type %d\n",maa,mdim,type);
108  printf("\t -Dimension de l'espace : "IFORMAT"\n",sdim);
109  printf("\t -Description du maillage : %s\n",desc);
110  printf("\t -Noms des axes : |%s|\n",nomcoo);
111  printf("\t -Unités des axes : |%s|\n",unicoo);
112  printf("\t -Type de repère : %d\n",rep);
113  printf("\t -Nombre d'étapes de calcul : "IFORMAT"\n",nstep);
114  printf("\t -Unité des dates : |%s|\n",dtunit);
115  }
116 
117 
118  /* combien de champs dans le fichier */
119  if ((ncha = MEDnField(fid)) < 0) {
120  MESSAGE("Impossible de lire le nombre de champs : ");ISCRUTE(ncha);
121  return ncha;
122  }
123 
124  printf("Nombre de champs : "IFORMAT" \n",ncha);
125 
126  /* lecture de tous les champs */
127  for (i =0;i<ncha;i++) {
128  lret = 0;
129  printf("\nChamp numero : %d \n",i+1);
130 
131  /* Lecture du nombre de composantes */
132  if ((ncomp = MEDfieldnComponent(fid,i+1)) < 0) {
133  MESSAGE("Erreur a la lecture du nombre de composantes : "); ISCRUTE(ncomp);
134  ret = -1; continue;
135  }
136 
137  /* Lecture du type du champ, des noms des composantes et du nom de l'unite*/
138  comp = (char*) malloc(ncomp*MED_SNAME_SIZE+1);
139  EXIT_IF(comp == NULL,NULL,NULL);
140  unit = (char*) malloc(ncomp*MED_SNAME_SIZE+1);
141  EXIT_IF(unit == NULL,NULL,NULL);
142 
143  if ( MEDfieldInfo(fid,i+1,nomcha,_meshname,&_local,&typcha,comp,unit,_dtunit,&_ncstp) < 0 ) {
144  MESSAGE("Erreur a la demande d'information sur les champs : ");
145  ISCRUTE_int(i+1);SSCRUTE(nomcha);ISCRUTE_int(typcha);SSCRUTE(comp);SSCRUTE(unit);
146  ISCRUTE(ncomp);
147  ret = -1; continue;
148  }
149 
150 
151  printf("Nom du champ : |%s| de type %d\n",nomcha,typcha);
152  printf("Nom des composantes : |%s|\n",comp);
153  printf("Unites des composantes : |%s| \n",unit);
154  printf("Unites des dates : |%s| \n",_dtunit);
155  printf("Le maillage associé est |%s|\n",_meshname);
156  printf("Nombre d'étapes de calcul |"IFORMAT"|\n",_ncstp);
157 
158  /* Le maillage reference est-il porte par un autre fichier */
159  if ( !_local ) {
160 
161  if ( (lnsize=MEDlinkInfoByName(fid,_meshname) ) < 0 ) {
162  MESSAGE("Erreur a la lecture de la taille du lien : ");
163  SSCRUTE(_meshname);
164  ret = -1;
165  } else {
166 
167  lien = malloc((lnsize+1)*sizeof(char));
168  EXIT_IF(lien == NULL,NULL,NULL);
169 
170  if ( MEDlinkRd(fid,_meshname, lien) < 0 ) {
171  MESSAGE("Erreur a la lecture du lien : ");
172  SSCRUTE(_meshname);SSCRUTE(lien);
173  ret = -1;
174  } else {
175  printf("\tLe maillage |%s| est porte par un fichier distant |%s|\n",_meshname,lien);
176  }
177  free(lien);
178  }
179  }
180 
181  free(comp);
182  free(unit);
183 
184 
185  lret = getFieldsOn(fid, nomcha, typcha, ncomp, MED_NODE, USER_INTERLACE,_ncstp );
186 
187  if (lret == 0) lret = getFieldsOn(fid, nomcha, typcha, ncomp, MED_CELL, USER_INTERLACE,_ncstp );
188  else { MESSAGE("Erreur a la lecture des champs aux noeuds "); ret = -1; continue;}
189 
190  if (lret == 0) lret = getFieldsOn(fid, nomcha, typcha, ncomp, MED_DESCENDING_FACE,USER_INTERLACE,_ncstp);
191  else { MESSAGE("Erreur a la lecture des champs aux mailles "); ret = -1; continue;}
192 
193  if (lret == 0) lret = getFieldsOn(fid, nomcha, typcha, ncomp, MED_DESCENDING_EDGE,USER_INTERLACE,_ncstp);
194  else {MESSAGE("Erreur a la lecture des champs aux faces "); ret = -1; continue;}
195 
196  if (lret == 0) lret = getFieldsOn(fid, nomcha, typcha, ncomp, MED_NODE_ELEMENT,USER_INTERLACE,_ncstp);
197  else {MESSAGE("Erreur a la lecture des champs aux aretes"); ret = -1; continue;}
198 
199  /*TODO */
200 /* if (lret == 0) lret = getFieldsOn(fid, nomcha, typcha, ncomp, MED_STRUCT_ELEMENT,USER_INTERLACE,_ncstp); */
201 /* else {MESSAGE("Erreur a la lecture des champs aux éléments de structure"); ret = -1; continue;} */
202 
203  if (lret != 0) {MESSAGE("Erreur a la lecture des champs aux noeuds des mailles "); ret = -1;};
204  }
205 
206 
207  /* Interrogation des profils */
208  npro = MEDnProfile(fid);
209 
210  printf("\nNombre de profils stockes : "IFORMAT"\n\n",npro);
211  for (i=1 ; i <= npro ; i++ ) {
212  if ( MEDprofileInfo(fid, i, pflname, &nval) < 0) {
213  MESSAGE("Erreur a la demande d'information sur le profil n° : "); ISCRUTE_int(i);
214  ret = -1;continue;
215  }
216  printf("\t- Profil n°%i de nom |%s| et de taille "IFORMAT"\n",i,pflname,nval);
217  pflval = (med_int*) malloc(sizeof(med_int)*nval);
218  if ( MEDprofileRd(fid, pflname, pflval) < 0) {
219  MESSAGE("Erreur a la lecture des valeurs du profil : ");
220  SSCRUTE(pflname);
221  ret = -1;
222  } else {
223  printf("\t");
224  for (j=0;j<nval;j++) printf(" "IFORMAT" ",*(pflval+j));
225  printf("\n\n");
226  }
227  free(pflval);
228  }
229 
230  /* Interrogation des liens */
231  nln = MEDnLink(fid);
232 
233  printf("\nNombre de liens stockes : "IFORMAT"\n\n",nln);
234  for (i=1 ; i <= nln ; i++ ) {
235  if ( MEDlinkInfo(fid, i, nomlien, &nval) < 0) {
236  MESSAGE("Erreur a la demande d'information sur le lien n° : "); ISCRUTE_int(i);
237  ret = -1;continue;
238  }
239  printf("\t- Lien n°%i de nom |%s| et de taille "IFORMAT"\n",i,nomlien,nval);
240 
241  lien = (char * ) malloc((nval+1)*sizeof(char));
242  EXIT_IF(lien == NULL,NULL,NULL);
243 
244  if ( MEDlinkRd(fid, nomlien, lien ) < 0 ) {
245  MESSAGE("Erreur a la lecture du lien : ");
246  SSCRUTE(nomlien);SSCRUTE(lien);
247  ret = -1;
248  } else {
249  lien[nval] = '\0';
250  printf("\t\t|%s|\n\n",lien);
251  }
252  free(lien);
253  }
254 
255  /* Interrogation des localisations des points de GAUSS */
256  nloc = MEDnLocalization(fid);
257 
258  printf("\nNombre de localisations stockees : "IFORMAT"\n\n",nloc);
259  for (i=1 ; i <= nloc ; i++ ) {
260  if ( MEDlocalizationInfo(fid, i, locname, &type_geo, &locsdim,&ngauss,
261  geointerpname, ipointstructmeshname,&nsectionmeshcell,
262  &sectiongeotype) < 0) {
263  MESSAGE("Erreur a la demande d'information sur la localisation n° : "); ISCRUTE_int(i);
264  ret = -1;continue;
265  }
266  printf("\t- Loc. n°%i de nom |%s| de dimension "IFORMAT" avec "IFORMAT" pts de GAUSS \n",i,locname,locsdim,ngauss);
267  t1 = (type_geo%100)*(type_geo/100);
268  t2 = ngauss*(type_geo/100);
269  t3 = ngauss;
270  refcoo = (med_float *) malloc(sizeof(med_float)*t1 );
271  gscoo = (med_float *) malloc(sizeof(med_float)*t2 );
272  wg = (med_float *) malloc(sizeof(med_float)*t3 );
273 
274  if ( MEDlocalizationRd(fid, locname, USER_INTERLACE, refcoo, gscoo, wg ) < 0) {
275  MESSAGE("Erreur a la lecture des valeurs de la localisation : ");
276  SSCRUTE(locname);
277  ret = -1;
278  } else {
279  printf("\t Coordonnees de l'element de reference de type %i :\n\t\t",type_geo);
280  for (j=0;j<t1;j++) printf(" %f ",*(refcoo+j));
281  printf("\n");
282  printf("\t Localisation des points de GAUSS : \n\t\t");
283  for (j=0;j<t2;j++) printf(" %f ",*(gscoo+j));
284  printf("\n");
285  printf("\t Poids associes aux points de GAUSS :\n\t\t");
286  for (j=0;j<t3;j++) printf(" %f ",*(wg+j));
287  printf("\n\n");
288  }
289  free(refcoo);
290  free(gscoo);
291  free(wg);
292  }
293 
294 
295  /* fermeture du fichier */
296  if ( MEDfileClose(fid) < 0) return -1;
297 
298  return ret;
299 }
300 
301 med_err getFieldsOn(med_idt fid, char * nomcha, med_field_type typcha, med_int ncomp,
302  med_entity_type entite, med_switch_mode stockage, med_int ncstp) {
303 
304  int i,j,k,l,m,n,nb_geo=0;
305  med_int nbpdtnor=0,pflsize,*pflval,ngauss=0,ngroup,*vale=NULL,nval;
306  med_int numdt=0,numo=0,_nprofile;
307  med_int meshnumdt=0,meshnumit=0;
308  med_float *valr=NULL,dt=0.0;
309  med_err ret=0;
310  char pflname [MED_NAME_SIZE+1]="";
311  char locname [MED_NAME_SIZE+1]="";
312  char meshname [MED_NAME_SIZE+1]="";
313  char * lien = NULL;
314  char dt_unit [MED_SNAME_SIZE+1]="unknown";
315  med_bool localmesh;
316  med_int nmesh=0;
317 
318  med_geometry_type * type_geo;
319 
320  const char * const * AFF;
321  const char * const * AFF_ENT=MED_GET_ENTITY_TYPENAME+1;
322  switch (entite) {
323  case MED_NODE :
324  type_geo = MED_GET_NODE_GEOMETRY_TYPE;
325  nb_geo = MED_N_NODE_FIXED_GEO;
327  break;
328  case MED_CELL :
329  case MED_NODE_ELEMENT :
330  type_geo = MED_GET_CELL_GEOMETRY_TYPE;
331  nb_geo = MED_N_CELL_FIXED_GEO;
333  break;
334  case MED_DESCENDING_FACE :
335  type_geo = MED_GET_FACE_GEOMETRY_TYPE;
336  nb_geo = MED_N_FACE_FIXED_GEO;
338  break;
339  case MED_DESCENDING_EDGE :
340  type_geo = MED_GET_EDGE_GEOMETRY_TYPE;
341  nb_geo = MED_N_EDGE_FIXED_GEO;
343  break;
344  }
345 
346  for (k=1;k<=nb_geo;k++) {
347 
348  /* Combien de (PDT,NOR) a lire */
349  nbpdtnor = ncstp;
350  if (nbpdtnor < 1 ) continue;
351 
352  for (j=0;j<nbpdtnor;j++) {
353 
354  if ( MEDfield23ComputingStepMeshInfo(fid,nomcha,j+1, &numdt, &numo, &dt,
355  &nmesh, meshname,&localmesh, &meshnumdt, &meshnumit ) <0) {
356  MESSAGE("Erreur a la demande d'information sur (pdt,nor) : ");
357  ISCRUTE(numdt); ISCRUTE(numo);ISCRUTE(nmesh);SSCRUTE(meshname);ISCRUTE_int(localmesh);
358  ISCRUTE(meshnumdt);ISCRUTE(meshnumit);
359  ret = -1; continue;
360  }
361 
362  for (i=0;i< nmesh;++i) {
363 
364  if ( (_nprofile = MEDfield23nProfile(fid,nomcha,numdt,numo,entite,type_geo[k],i+1,meshname,
365  pflname,locname ) ) < 0 ) {
366  MESSAGE("Erreur a la demande du nombre de profils referencés par le champ : ");
367  SSCRUTE(nomcha); ISCRUTE(numdt); ISCRUTE(numo);SSCRUTE(meshname);
368  ISCRUTE_int(entite);ISCRUTE_int(type_geo[k]);SSCRUTE(pflname);SSCRUTE(locname);
369  SSCRUTE(AFF_ENT[(int)entite]);SSCRUTE(AFF[k]);
370  ret = -1; continue;
371  };
372 
373  for (l=0;l<_nprofile;l++) {
374 
375 
376  if ( (nval = MEDfield23nValueWithProfile(fid, nomcha, numdt, numo, entite, type_geo[k],meshname,
377  l+1, USER_MODE, pflname,&pflsize,
378  locname, &ngauss) ) < 0 ) {
379  MESSAGE("Erreur a la lecture du nombre de valeurs du champ : ");
380  SSCRUTE(nomcha);ISCRUTE(numdt);ISCRUTE(numo);SSCRUTE(meshname);
381  ISCRUTE_int(entite);ISCRUTE_int(type_geo[k]);
383  ret = -1; continue;
384  };
385 
386  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);
387  printf("\t- Il y a "IFORMAT" entités qui portent des valeurs en mode %i. Chaque entite %s\
388  de type geometrique %s associes au profile |%s| a "IFORMAT" valeurs associées \n",
389  nval,USER_MODE,AFF_ENT[(int)entite],AFF[k],pflname,ngauss);
390  printf("\t- Le maillage associé est |%s|\n",meshname);
391 
392  /*Lecture des valeurs du champ */
393  if (typcha == MED_FLOAT64) {
394 
395  valr = (med_float*) calloc(ncomp*nval*ngauss,sizeof(med_float));
396  EXIT_IF(valr == NULL,NULL,NULL);
397 
398  if (MEDfield23ValueWithProfileRd(fid, nomcha, numdt,numo, entite,type_geo[k],meshname,
399  USER_MODE, pflname, stockage,MED_ALL_CONSTITUENT,
400  (unsigned char*) valr) < 0 ) {
401  MESSAGE("Erreur a la lecture des valeurs du champ : ");
402  SSCRUTE(nomcha);ISCRUTE_int(entite);ISCRUTE_int(type_geo[k]);
403  ISCRUTE(numdt);ISCRUTE(numo);
404  ret = -1;
405  }
406  } else {
407 
408  vale = (med_int*) calloc(ncomp*nval*ngauss,sizeof(med_int));
409  EXIT_IF(vale == NULL,NULL,NULL);
410 
411  if (MEDfield23ValueWithProfileRd(fid, nomcha, numdt,numo, entite,type_geo[k],meshname,
412  USER_MODE, pflname, stockage,MED_ALL_CONSTITUENT,
413  (unsigned char*) vale) < 0 ) {
414  MESSAGE("Erreur a la lecture des valeurs du champ : ");
415  SSCRUTE(nomcha);ISCRUTE_int(entite);ISCRUTE_int(type_geo[k]);
416  ISCRUTE(numdt);ISCRUTE(numo);
417  ret = -1;
418  };
419  }
420 
421  if ( strlen(locname) )
422  printf("\t- Modèle de localisation des points de Gauss de nom |%s|\n",locname);
423 
424  if (entite == MED_NODE_ELEMENT)
425  ngroup = (type_geo[k] % 100);
426  else
427  ngroup = ngauss;
428 
429  switch (stockage) {
430 
431  case MED_FULL_INTERLACE :
432  printf("\t- Valeurs :\n\t");
433  for (m=0;m<(nval*ngauss)/ngroup;m++) {
434  printf("|");
435  for (n=0;n<ngroup*ncomp;n++)
436  if (typcha == MED_FLOAT64)
437  printf(" %f ",*(valr+(m*ngroup*ncomp)+n));
438  else
439  printf(" "IFORMAT" ",*(vale+(m*ngroup*ncomp)+n));
440 
441  }
442  break;
443 
444  /*Affichage en fonction du profil à traiter*/
445  case MED_NO_INTERLACE :
446  printf("\t- Valeurs :\n\t");
447  for (m=0;m<ncomp;m++) {
448  printf("|");
449  for (n=0;n<(nval*ngauss);n++)
450  if (typcha == MED_FLOAT64)
451  printf(" %f ",*(valr+(m*nval)+n));
452  else
453  printf(" "IFORMAT" ",*(vale+(m*nval)+n));
454  }
455  break;
456  }
457 
458  printf("|\n");
459  if (typcha == MED_FLOAT64) {
460  if ( valr ) {free(valr);valr = NULL;}}
461  else
462  if (vale) { free(vale);vale = NULL; }
463 
464  /*Lecture du profil associe */
465  if (strcmp(pflname,MED_NO_PROFILE) == 0 )
466  printf("\t- Profil : MED_NO_PROFILE\n");
467  else {
468  if ( (pflsize = MEDprofileSizeByName(fid,pflname)) <0 ) {
469  MESSAGE("Erreur a la lecture du nombre de valeurs du profil : ");
470  SSCRUTE(pflname);
471  ret = -1; continue;
472  }
473 
474  printf("\t- Profil : |%s| de taille "IFORMAT"\n",pflname,pflsize);
475 
476  pflval = (med_int*) malloc(sizeof(med_int)*pflsize);
477  EXIT_IF(pflval == NULL,NULL,NULL);
478  if ( MEDprofileRd(fid,pflname,pflval) <0) {
479  MESSAGE("Erreur a la lecture des valeurs du profil : ");
480  SSCRUTE(pflname);
481  ret = -1;
482  }
483  printf("\t");
484  for (m=0;m<pflsize;m++) printf(" "IFORMAT" ",*(pflval+m));
485  printf("\n");
486  free(pflval);
487  }
488  }
489  }
490  }
491  } /* fin for sur les mailles*/
492 
493  return ret;
494 }
495 
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
MEDfield23ValueWithProfileRd
MEDC_EXPORT med_err MEDfield23ValueWithProfileRd(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 char *const meshname, 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: MEDfield23ValueWithProfileRd.c:43
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: test11b.c:300
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_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
ISCRUTE_int
#define ISCRUTE_int(entier)
Definition: med_utils.h:314
MED_DESCENDING_FACE
Definition: med.h:143
med_idt
hid_t med_idt
Definition: med.h:331
MED_ACC_RDONLY
Definition: med.h:120
USER_MODE
#define USER_MODE
Definition: test11b.c:41
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_CELL
Definition: med.h:143
MESSAGE
#define MESSAGE(chaine)
Definition: med_utils.h:324
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
MEDfield23ComputingStepMeshInfo
MEDC_EXPORT med_err MEDfield23ComputingStepMeshInfo(const med_idt fid, const char *const fieldname, const int csit, med_int *const numdt, med_int *const numit, med_float *const dt, med_int *const nmesh, char *const meshname, med_bool *const localmesh, med_int *const meshnumdt, med_int *const meshnumit)
Cette fonction permet de lire les informations caractérisant une étape de calcul : numéro de pas de t...
Definition: MEDfield23ComputingStepMeshInfo.c:43
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
MEDfield23nProfile
MEDC_EXPORT med_int MEDfield23nProfile(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 meshit, char *const meshname, 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: MEDfield23nProfile.c:41
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
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
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
MEDfield23nValueWithProfile
MEDC_EXPORT med_int MEDfield23nValueWithProfile(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 char *const meshname, 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: MEDfield23nValueWithProfile.c:46
med_switch_mode
med_switch_mode
Definition: med.h:96
MED_NAME_SIZE
#define MED_NAME_SIZE
Definition: med.h:81
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: test11b.c:38
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
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
main
int main(int argc, char **argv)
Definition: test11b.c:46
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
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