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