31 #define MODE_ACCES MED_ACC_RDWR
33 #define MODE_ACCES MED_ACC_RDEXT
35 #define MODE_ACCES MED_ACC_CREAT
38 #ifndef USER_INTERLACE
39 #define USER_INTERLACE MED_FULL_INTERLACE
42 #define USER_MODE MED_COMPACT_STMODE
47 int main (
int argc,
char **argv)
53 char * fichier = NULL;
61 char *comp= NULL, *unit= NULL;
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;
85 MESSAGE(
"Aucun nom de fichier precise, fichier test10.med utilise ");
86 fichier =
"test10.med";
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);
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);
120 MESSAGE(
"Impossible de lire le nombre de champs : ");
ISCRUTE(ncha);
124 printf(
"Nombre de champs : "IFORMAT" \n",ncha);
127 for (i =0;i<ncha;i++) {
129 printf(
"\nChamp numero : %d \n",i+1);
133 MESSAGE(
"Erreur a la lecture du nombre de composantes : ");
ISCRUTE(ncomp);
139 EXIT_IF(comp == NULL,NULL,NULL);
141 EXIT_IF(unit == NULL,NULL,NULL);
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 : ");
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);
162 MESSAGE(
"Erreur a la lecture de la taille du lien : ");
167 lien = malloc((lnsize+1)*
sizeof(
char));
168 EXIT_IF(lien == NULL,NULL,NULL);
170 if (
MEDlinkRd(fid,_meshname, lien) < 0 ) {
171 MESSAGE(
"Erreur a la lecture du lien : ");
175 printf(
"\tLe maillage |%s| est porte par un fichier distant |%s|\n",_meshname,lien);
188 else {
MESSAGE(
"Erreur a la lecture des champs aux noeuds "); ret = -1;
continue;}
191 else {
MESSAGE(
"Erreur a la lecture des champs aux mailles "); ret = -1;
continue;}
194 else {
MESSAGE(
"Erreur a la lecture des champs aux faces "); ret = -1;
continue;}
197 else {
MESSAGE(
"Erreur a la lecture des champs aux aretes"); ret = -1;
continue;}
203 if (lret != 0) {
MESSAGE(
"Erreur a la lecture des champs aux noeuds des mailles "); ret = -1;};
210 printf(
"\nNombre de profils stockes : "IFORMAT"\n\n",npro);
211 for (i=1 ; i <= npro ; i++ ) {
216 printf(
"\t- Profil n°%i de nom |%s| et de taille "IFORMAT"\n",i,pflname,nval);
219 MESSAGE(
"Erreur a la lecture des valeurs du profil : ");
224 for (j=0;j<nval;j++) printf(
" "IFORMAT" ",*(pflval+j));
233 printf(
"\nNombre de liens stockes : "IFORMAT"\n\n",nln);
234 for (i=1 ; i <= nln ; i++ ) {
239 printf(
"\t- Lien n°%i de nom |%s| et de taille "IFORMAT"\n",i,nomlien,nval);
241 lien = (
char * ) malloc((nval+1)*
sizeof(char));
242 EXIT_IF(lien == NULL,NULL,NULL);
244 if (
MEDlinkRd(fid, nomlien, lien ) < 0 ) {
245 MESSAGE(
"Erreur a la lecture du lien : ");
250 printf(
"\t\t|%s|\n\n",lien);
258 printf(
"\nNombre de localisations stockees : "IFORMAT"\n\n",nloc);
259 for (i=1 ; i <= nloc ; i++ ) {
261 geointerpname, ipointstructmeshname,&nsectionmeshcell,
262 §iongeotype) < 0) {
263 MESSAGE(
"Erreur a la demande d'information sur la localisation n° : ");
ISCRUTE_int(i);
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);
275 MESSAGE(
"Erreur a la lecture des valeurs de la localisation : ");
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));
282 printf(
"\t Localisation des points de GAUSS : \n\t\t");
283 for (j=0;j<t2;j++) printf(
" %f ",*(gscoo+j));
285 printf(
"\t Poids associes aux points de GAUSS :\n\t\t");
286 for (j=0;j<t3;j++) printf(
" %f ",*(wg+j));
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;
320 const char *
const * AFF;
346 for (k=1;k<=nb_geo;k++) {
350 if (nbpdtnor < 1 )
continue;
352 for (j=0;j<nbpdtnor;j++) {
355 &nmesh, meshname,&localmesh, &meshnumdt, &meshnumit ) <0) {
356 MESSAGE(
"Erreur a la demande d'information sur (pdt,nor) : ");
362 for (i=0;i< nmesh;++i) {
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 : ");
373 for (l=0;l<_nprofile;l++) {
378 locname, &ngauss) ) < 0 ) {
379 MESSAGE(
"Erreur a la lecture du nombre de valeurs du champ : ");
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);
396 EXIT_IF(valr == NULL,NULL,NULL);
400 (
unsigned char*) valr) < 0 ) {
401 MESSAGE(
"Erreur a la lecture des valeurs du champ : ");
409 EXIT_IF(vale == NULL,NULL,NULL);
413 (
unsigned char*) vale) < 0 ) {
414 MESSAGE(
"Erreur a la lecture des valeurs du champ : ");
421 if ( strlen(locname) )
422 printf(
"\t- Modèle de localisation des points de Gauss de nom |%s|\n",locname);
425 ngroup = (type_geo[k] % 100);
432 printf(
"\t- Valeurs :\n\t");
433 for (m=0;m<(nval*ngauss)/ngroup;m++) {
435 for (n=0;n<ngroup*ncomp;n++)
437 printf(
" %f ",*(valr+(m*ngroup*ncomp)+n));
439 printf(
" "IFORMAT" ",*(vale+(m*ngroup*ncomp)+n));
446 printf(
"\t- Valeurs :\n\t");
447 for (m=0;m<ncomp;m++) {
449 for (n=0;n<(nval*ngauss);n++)
451 printf(
" %f ",*(valr+(m*nval)+n));
453 printf(
" "IFORMAT" ",*(vale+(m*nval)+n));
460 if ( valr ) {free(valr);valr = NULL;}}
462 if (vale) { free(vale);vale = NULL; }
466 printf(
"\t- Profil : MED_NO_PROFILE\n");
469 MESSAGE(
"Erreur a la lecture du nombre de valeurs du profil : ");
474 printf(
"\t- Profil : |%s| de taille "IFORMAT"\n",pflname,pflsize);
477 EXIT_IF(pflval == NULL,NULL,NULL);
479 MESSAGE(
"Erreur a la lecture des valeurs du profil : ");
484 for (m=0;m<pflsize;m++) printf(
" "IFORMAT" ",*(pflval+m));