1 /*************************************************************************
  2 * COPYRIGHT (C) 1999 - 2007  EDF R&D, CEA/DEN
  3 * THIS LIBRARY IS FREE SOFTWARE; YOU CAN REDISTRIBUTE IT AND/OR MODIFY
  4 * IT UNDER THE TERMS OF THE GNU LESSER GENERAL PUBLIC LICENSE 
  5 * AS PUBLISHED BY THE FREE SOFTWARE FOUNDATION; 
  6 * EITHER VERSION 2.1 OF THE LICENSE, OR (AT YOUR OPTION) ANY LATER VERSION.
  7 *  
  8 * THIS LIBRARY IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, BUT
  9 * WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF
 10 * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. SEE THE GNU
 11 * LESSER GENERAL PUBLIC LICENSE FOR MORE DETAILS.
 12 *
 13 * YOU SHOULD HAVE RECEIVED A COPY OF THE GNU LESSER GENERAL PUBLIC LICENSE
 14 * ALONG WITH THIS LIBRARY; IF NOT, WRITE TO THE FREE SOFTWARE FOUNDATION,
 15 * INC., 59 TEMPLE PLACE, SUITE 330, BOSTON, MA 02111-1307 USA
 16 *
 17 *************************************************************************/
 18 
 19 /******************************************************************************
 20  * - Nom du fichier : test13.c
 21  *
 22  * - Description : lecture des equivalences d'un maillage MED.
 23  *
 24  *****************************************************************************/
 25 
 26 #include <med.h>
 27 #define MESGERR
 28 #include <med_utils.h>
 29 
 30 #ifdef DEF_LECT_ECR
 31 #define MODE_ACCES MED_LECTURE_ECRITURE
 32 #elif DEF_LECT_AJOUT
 33 #define MODE_ACCES MED_LECTURE_AJOUT
 34 #else
 35 #define MODE_ACCES MED_CREATION
 36 #endif
 37 
 38 /* On prend en compte tous les types de mailles concernees
 39  *    par les equivalences */
 40 #define MED_NBR_MAILLE_EQU 8
 41 
 42 int main (int argc, char **argv)
 43 
 44 
 45 {
 46   med_err ret = 0;
 47   med_idt fid;
 48   char maa[MED_TAILLE_NOM+1];
 49   med_int mdim;
 50   med_int nequ,ncor;
 51   med_int *cor;
 52   char equ[MED_TAILLE_NOM+1];
 53   char des[MED_TAILLE_DESC+1];
 54   med_geometrie_element typmai[MED_NBR_GEOMETRIE_MAILLE+1] = {MED_POINT1,MED_SEG2,
 55                                                               MED_SEG3,MED_TRIA3,
 56                                                               MED_TRIA6,MED_QUAD4,
 57                                                               MED_QUAD8,MED_POLYGONE};
 58   med_geometrie_element typfac[MED_NBR_GEOMETRIE_FACE+1] = {MED_TRIA3,MED_TRIA6,
 59                                                             MED_QUAD4,MED_QUAD8,
 60                                                             MED_POLYGONE};
 61   med_geometrie_element typare[MED_NBR_GEOMETRIE_ARETE] = {MED_SEG2,MED_SEG3};
 62   int i,j,k;
 63   med_maillage type;
 64 
 65   if (argc != 2) {
 66     MESSAGE("Il faut passer un fichier MED en paramètre");
 67     return -1;
 68   }
 69 
 70   /* Ouverture du fichier passe en argument en lecture seule */
 71   if ((fid = MEDouvrir(argv[1],MED_LECTURE)) < 0) {
 72     MESSAGE("Erreur a l'ouverture du fichier : "); SSCRUTE(argv[1]);
 73     return -1;
 74   }
 75 
 76   /* Lecture des infos sur le premier maillage */
 77   if (MEDmaaInfo(fid,1,maa,&mdim,&type,des) < 0) {
 78     MESSAGE("Erreur a lecture des infos sur le 1er maillage");
 79     return -1;
 80   }
 81   printf("Maillage de nom %s et de dimension %d \n",maa,mdim);
 82 
 83   /* Lecture du nombre d'equivalence */
 84   if ((nequ = MEDnEquiv(fid,maa)) < 0) {
 85     MESSAGE("Erreur a la lecture du nombre d'equivalence");
 86     return -1;
 87   }
 88   printf("Nombre d'equivalences : %d \n",nequ);
 89 
 90   /* Lecture de toutes les equivalences du maillage */
 91   if (nequ > 0)
 92     for (i = 0;i<nequ;i++) {
 93       printf("Equivalence numero : %d \n",i+1);
 94 
 95       /* Lecture des infos sur l'equivalence */
 96       if (MEDequivInfo(fid,maa,i+1,equ,des) < 0) {
 97         MESSAGE("Erreur a la lecture de l'equivalence d'indice");
 98         ISCRUTE(i+1);
 99         return -1;
100       }
101       printf("Nom de l'equivalence: %s \n",equ);
102       printf("Description de l'equivalence : %s \n",des);
103 
104       /* Lecture des correspondances sur les differents types d'entites */
105 
106       /* Les noeuds */
107       if ((ncor = MEDnCorres(fid,maa,equ,MED_NOEUD,0)) < 0) {
108         MESSAGE("Erreur a la lecture du nombre de correspondance sur les noeuds");
109         return -1;
110       }
111       printf("Il y a %d correspondances sur les noeuds \n",ncor);
112       if (ncor > 0) {
113         cor = (med_int*) malloc(sizeof(med_int)*ncor*2);
114         if (MEDequivLire(fid,maa,equ,cor,ncor,MED_NOEUD,0) < 0) {
115           MESSAGE("Erreur a la lecture des correspondances sur les noeuds");
116           ret = -1;
117         }
118         if (ret == 0)
119           for (j=0;j<ncor;j++)
120             printf("Correspondance %d : %d et %d \n",j+1,*(cor+2*j),
121                    *(cor+2*j+1));
122         free(cor);
123       }
124 
125       /* Les mailles : on ne prend pas en compte les mailles 3D */
126       if (ret == 0)
127         for (j=0;j<MED_NBR_MAILLE_EQU;j++) {
128 
129           if ((ncor = MEDnCorres(fid,maa,equ,MED_MAILLE,typmai[j])) < 0) {
130             MESSAGE("Erreur a la lecture du nombre de correspondance sur les mailles : ");
131             ISCRUTE(typmai[j]);
132             return -1;
133           }
134           printf("Il y a %d correspondances sur les mailles %d \n",ncor,
135                  typmai[j]);
136           if (ncor > 0) {
137             cor = (med_int*) malloc(sizeof(med_int)*ncor*2);
138             if (MEDequivLire(fid,maa,equ,cor,ncor,MED_MAILLE,
139                              typmai[j]) < 0) {
140               MESSAGE("Erreur a la lecture des correspondances sur les mailles : ");
141               ISCRUTE(typmai[j]);
142               ret = -1;
143             }
144             if (ret == 0)
145               for (k=0;k<ncor;k++)
146                 printf("Correspondance %d : %d et %d \n",k+1,*(cor+2*k),
147                        *(cor+2*k+1));
148             free(cor);
149           }
150         }
151 
152       /* Les faces */
153       if (ret == 0)
154         for (j=0;j<MED_NBR_GEOMETRIE_FACE+1;j++) {
155           if ((ncor = MEDnCorres(fid,maa,equ,MED_FACE,typfac[j])) < 0) {
156             MESSAGE("Erreur a la lecture du nombre de correspondance sur les faces : ");
157             ISCRUTE(typfac[j]);
158             return -1;
159           }
160           printf("Il y a %d correspondances sur les faces %d \n",ncor,
161                  typfac[j]);
162           if (ncor > 0) {
163             cor = (med_int*) malloc(sizeof(med_int)*ncor*2);
164             if (MEDequivLire(fid,maa,equ,cor,ncor,MED_FACE,
165                              typfac[j]) < 0) {
166               MESSAGE("Erreur a la lecture des correspondances sur les faces : ");
167               ISCRUTE(typfac[j]);
168               ret = -1;
169             }
170             if (ret == 0)
171               for (k=0;k<ncor;k++)
172                 printf("Correspondance %d : %d et %d \n",k+1,*(cor+2*k),
173                        *(cor+2*k+1));
174             free(cor);
175           }
176         }
177 
178       /*  Les aretes */
179       if (ret == 0)
180         for (j=0;j<MED_NBR_GEOMETRIE_ARETE;j++) {
181           if ((ncor = MEDnCorres(fid,maa,equ,MED_ARETE,typare[j])) < 0) {
182             MESSAGE("Erreur a la lecture du nombre de correspondance sur les aretes : ");
183             ISCRUTE(typare[j]);
184             return -1;
185           }
186           printf("Il y a %d correspondances sur les aretes %d \n",ncor,
187                  typare[j]);
188           if (ncor > 0) {
189             cor = (med_int*) malloc(sizeof(med_int)*ncor*2);
190            if (MEDequivLire(fid,maa,equ,cor,ncor,MED_ARETE,
191                                typare[j]) < 0) {
192              MESSAGE("Erreur a la lecture des correspondances sur les faces : ");
193              ISCRUTE(typare[j]);
194              ret = -1;
195            }
196            if (ret == 0)
197              for (k=0;k<ncor;k++)
198                printf("Correspondance %d : %d et %d \n",k+1,*(cor+2*k),
199                       *(cor+2*k+1));
200            free(cor);
201           }
202         }
203 
204     }
205 
206   /* Fermeture du fichier */
207   if (MEDfermer(fid) < 0) {
208     MESSAGE("Erreur a la fermeture du fichier ");
209     return -1;
210   }
211 
212   return ret;
213 }
214 
215 
216 
217