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 : test19.c
 21  *
 22  * - Description : conversion groupes => famille 
 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 int main (int argc, char **argv)
 39 
 40 
 41 {
 42   med_idt fid;
 43   char maa[MED_TAILLE_NOM+1] = "maillage_test19";
 44   char desc[MED_TAILLE_DESC+1]="un maillage pour test19.med";
 45   med_int mdim=2;
 46   /* Donnees de tests pour MEDgro2FamCr() 
 47      Les noeuds/mailles sont numerotes de 1 a 5 et les
 48      groupes de 1 a 3.
 49      Au depart, on a :
 50      - G1 : 1,2
 51      - G2 : 3,4,6
 52      - G3 : 1,4
 53      Au retour, on foit avoir 4 familles de noeuds + 4 familles de mailles 
 54      + la famille 0 dans le fichier :
 55      - F0 : 5       - groupes : aucun groupe par defaut (convention habituelle).
 56      - F1 : 1       - groupes : G1,G3  
 57      - F2 : 2       - groupes : G1
 58      - F3 : 3,6     - groupes : G2
 59      - F4 : 4       - groupes : G2,G3
 60   */
 61   med_int ngroup = 3;
 62   med_int nent = 6;
 63   char nom_groupes[MED_TAILLE_LNOM*3+1];
 64   /*                     0 1  2 3 4  5 6 */
 65   med_int entites[7] = { 1,2, 3,4,6, 1,4};
 66   med_int index[4] =   { 1,   3,     6,   8};
 67   int i;
 68   char nom_famille0[MED_TAILLE_NOM+1] = "FAMILLE0";
 69   /* on fait la meme distribution pour des mailles */
 70   med_int ngeo = 3;
 71   med_geometrie_element geo[3] = {MED_SEG2,MED_TRIA3,MED_TETRA4};
 72   /* MED_SEG2 : M1,M2,M3 - MED_TRI3 : M4,M5 - MED_TETRA4 : M6 */
 73   med_int index_geo[4] = {1,4,6,7};
 74 
 75   /* Creation du fichier test19.med */
 76   if ((fid = MEDouvrir("test19.med",MODE_ACCES)) < 0) {
 77     MESSAGE("Erreur a la creation du fichier test19.med");
 78     return -1;
 79   }
 80   printf("Creation du fichier test19.med \n");
 81 
 82   /* Creation du maillage */
 83   if (MEDmaaCr(fid,maa,mdim,MED_NON_STRUCTURE,desc) < 0) {
 84     MESSAGE("Erreur a la creation du maillage");
 85     return -1;
 86   }
 87   printf("Creation du maillage \n");
 88 
 89   /* on teste la fonction MEDgro2fam() */
 90   /* on definit les noms des groupes */
 91   strcpy(nom_groupes,"GROUPE 1");
 92   for (i=8;i<MED_TAILLE_LNOM;i++)
 93     nom_groupes[i] = ' ';
 94   nom_groupes[MED_TAILLE_LNOM] = '\0';
 95   strcat(nom_groupes,"GROUPE 2");
 96   for (i=8;i<MED_TAILLE_LNOM;i++)
 97     nom_groupes[MED_TAILLE_LNOM+i] = ' ';
 98   nom_groupes[2*MED_TAILLE_LNOM] = '\0';
 99   strcat(nom_groupes,"GROUPE 3");
100   for (i=8;i<MED_TAILLE_LNOM;i++)
101     nom_groupes[2*MED_TAILLE_LNOM+i] = ' ';
102   nom_groupes[3*MED_TAILLE_LNOM] = '\0';
103 
104   /* On cree la famille 0 */
105   if (MEDfamCr(fid,maa,nom_famille0,0,NULL,NULL,NULL,0,NULL,0) < 0) {
106     MESSAGE("Erreur a la creation de la famille 0");
107     return -1;
108   }
109   printf("Creation de la famille 0 \n");
110 
111   /* 
112    * On definit et on archive les familles de noeuds dans test.19.med 
113    */
114   if (MEDgro2famCr(fid,maa,nom_groupes,index,ngroup,entites,nent,
115                    MED_NOEUD,NULL,NULL,0) < 0) {
116     MESSAGE("Erreur a la creation des familles de noeuds ");
117     return -1;
118   }
119   printf("On constuit les familles de noeuds et on les stocke dans test19.med \n");
120 
121   /* 
122    * On fait la meme chose pour des mailles de differents types 
123    */
124   if (MEDgro2famCr(fid,maa,nom_groupes,index,ngroup,entites,nent,
125                    MED_MAILLE,geo,index_geo,ngeo) < 0) {
126     MESSAGE("Erreur a la creation des familles d'elements ");
127     return -1;
128   }
129   printf("On constuit les familles d'elements et on les stocke dans test19.med \n");
130 
131   /* Fermeture du fichier */
132   if (MEDfermer(fid) <0) {
133     MESSAGE("Erreur a la fermeture du fichier");
134     return -1;
135   }
136   printf("Fermeture du fichier \n");
137 
138   return 0;
139 }