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 : test14.c
21 *
22 * - Description : ecriture des noeuds d'un maillage MED
23 * a l'aide des routines de niveau 2
24 * equivalent a test4.c
25 *
26 *****************************************************************************/
27
28 #include <med.h>
29 #define MESGERR
30 #include <med_utils.h>
31
32 #ifdef DEF_LECT_ECR
33 #define MODE_ACCES MED_LECTURE_ECRITURE
34 #elif DEF_LECT_AJOUT
35 #define MODE_ACCES MED_LECTURE_AJOUT
36 #else
37 #define MODE_ACCES MED_CREATION
38 #endif
39
40 int main (int argc, char **argv)
41
42
43 {
44 med_idt fid;
45 /* la dimension du maillage */
46 med_int mdim = 2;
47 /* nom du maillage de longueur maxi MED_TAILLE_NOM */
48 char maa[MED_TAILLE_NOM+1] = "maa1";
49 /* le nombre de noeuds */
50 med_int nnoe = 4;
51 /* table des coordonnees
52 profil : (dimension * nombre de noeuds) */
53 med_float coo[8] = {0.0, 0.0, 1.0, 0.0, 0.0, 1.0, 1.0, 1.0};
54 /* tables des noms et des unites des coordonnees
55 profil : (dimension*MED_TAILLE_PNOM+1) */
56 /* 12345678901234561234567890123456 */
57 char nomcoo[2*MED_TAILLE_PNOM+1] = "x y ";
58 char unicoo[2*MED_TAILLE_PNOM+1] = "cm cm ";
59 /* tables des noms, numeros, numeros de familles des noeuds
60 autant d'elements que de noeuds - les noms ont pout longueur
61 MED_TAILLE_PNOM */
62 /* 1234567890123456123456789012345612345678901234561234567890123456 */
63 char nomnoe[4*MED_TAILLE_PNOM+1] = "nom1 nom2 nom3 nom4";
64 med_int numnoe[4] = {1,2,3,4};
65 med_int nufano[4] = {0,1,2,2};;
66
67 /* Creation du fichier test14.med */
68 if ((fid = MEDouvrir("test14.med",MODE_ACCES)) < 0) {
69 MESSAGE("Erreur a la creation du fichier test14.med");
70 return -1;
71 }
72
73 /* Creation du maillage */
74 if (MEDmaaCr(fid,maa,mdim,MED_NON_STRUCTURE,"Un maillage pour test14") < 0) {
75 MESSAGE("Erreur a la creation du maillage");
76 SSCRUTE(maa)
77 return -1;
78 }
79
80 /* Ecriture des noeuds d'un maillage MED :
81 - Des cooordonnees en mode MED_FULL_INTERLACE : (X1,Y1,X2,Y2,X3,Y3,...)
82 dans un repere cartesien
83 - Des noms (optionnel dans un fichier MED)
84 - Des numeros (optionnel dans un fichier MED)
85 - Des numeros de familles des noeuds */
86 if (MEDnoeudsEcr(fid,maa,mdim,coo,MED_FULL_INTERLACE,MED_CART,
87 nomcoo,unicoo,nomnoe,MED_VRAI,numnoe,MED_VRAI,
88 nufano,nnoe) < 0) {
89 MESSAGE("Erreur a l'ecriture des noeuds du maillage");
90 return -1;
91 }
92
93 /* Fermeture du fichier */
94 if (MEDfermer(fid) < 0) {
95 MESSAGE("Erreur a la fermeture du fichier");
96 return -1;
97 }
98
99 return 0;
100 }
101
102
103
104