2.3.6/test27.c

Aller à la documentation de ce fichier.
00001 /*  This file is part of MED.
00002  *
00003  *  COPYRIGHT (C) 1999 - 2015  EDF R&D, CEA/DEN
00004  *  MED is free software: you can redistribute it and/or modify
00005  *  it under the terms of the GNU Lesser General Public License as published by
00006  *  the Free Software Foundation, either version 3 of the License, or
00007  *  (at your option) any later version.
00008  *
00009  *  MED is distributed in the hope that it will be useful,
00010  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
00011  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00012  *  GNU Lesser General Public License for more details.
00013  *
00014  *  You should have received a copy of the GNU Lesser General Public License
00015  *  along with MED.  If not, see <http://www.gnu.org/licenses/>.
00016  */
00017 
00018 
00019 /******************************************************************************
00020  * - Nom du fichier : test27.c
00021  *
00022  * - Description : creation de maillages structures (grille cartesienne |
00023  *                 grille standard ) dans le fichier test27.med
00024  *
00025  *****************************************************************************/
00026 
00027 #include <med.h>
00028 #define MESGERR 1
00029 #include "med_utils.h"
00030 #include <string.h>
00031 
00032 #ifdef DEF_LECT_ECR
00033 #define MODE_ACCES MED_LECTURE_ECRITURE
00034 #elif DEF_LECT_AJOUT
00035 #define MODE_ACCES MED_LECTURE_AJOUT
00036 #else
00037 #define MODE_ACCES MED_CREATION
00038 #endif
00039 
00040 int main (int argc, char **argv)
00041 
00042 
00043 {
00044   med_idt fid;
00045   /* la dimension du maillage */
00046   med_int mdim,axe;
00047   med_float indice[4];
00048   med_float coo[8] = {0.0,0.0,1.0,0.0,0.0,1.0,1.0,1.0};
00049   med_int nnoeuds = 4;
00050   med_int structure_grille[2] = {2,2};
00051   med_int nind;
00052   /* nom du maillage de longueur maxi MED_TAILLE_NOM */
00053   char maa[MED_TAILLE_NOM+1];
00054   /* composantes et unites */
00055   char comp[MED_TAILLE_PNOM+1];
00056   char unit[MED_TAILLE_PNOM+1];
00057   /*                               12345678901234561234567890123456 */
00058   char comp2[2*MED_TAILLE_PNOM+1] = "X               Y               ";
00059   char unit2[2*MED_TAILLE_PNOM+1] = "cm              cm              ";
00060 
00061   /* Creation du fichier test27.med */
00062   fid = MEDouvrir("test27.med",MODE_ACCES);
00063   if (fid < 0) {
00064     MESSAGE("Erreur a la creation du fichier test27.med");
00065     return -1;
00066   }
00067   printf("Creation du fichier test27.med \n");
00068 
00069   /* Creation d'un maillage MED_NON_STRUCTURE */
00070   if (MEDmaaCr(fid,"maillage vide",3,MED_NON_STRUCTURE,"un maillage vide") < 0) {
00071     MESSAGE("Erreur a la creation du maillage MED_NON_STRUCTURE");
00072     return -1;
00073   }
00074 
00075   /* creation d'une grille cartesienne de dimension 2 */
00076   strcpy(maa,"grille_cartesienne");
00077   mdim = 2;
00078   /* on commence par definir un maillage MED_STRUCTURE 
00079      de dimension 2 */
00080   if (MEDmaaCr(fid,maa,mdim,MED_STRUCTURE,
00081                    "un exemple de grille cartesienne") < 0) {
00082     MESSAGE("Erreur a la creation de la grille");
00083     return -1;
00084   }
00085   printf("Creation d'un maillage structure MED_STRUCTURE \n");
00086 
00087   /* On specifie la nature du maillage structure : MED_GRILLE_CARTESIENNE */
00088   if (MEDnatureGrilleEcr(fid,maa,MED_GRILLE_CARTESIENNE) < 0) {
00089     MESSAGE("Erreur a l'ecriture de la nature de la grille");
00090     return -1;
00091   }
00092   printf("On definit la nature du maillage structure : MED_GRILLE_CARTESIENNE \n");
00093 
00094   /* on definit les indices des coordonnees de la grille selon chaque dimension  */
00095   /* axe des "X" */
00096   indice[0] = 1.1;
00097   indice[1] = 1.2;
00098   indice[2] = 1.3;
00099   indice[3] = 1.4;
00100   nind = 4;
00101   axe = 1;
00102   /* Les deux chaines suivantes ont une longueur incorrecte*/
00103   strcpy(comp,"X");
00104   strcpy(unit,"cm");
00105   if (MEDindicesCoordEcr(fid,maa,mdim,indice,nind,axe,comp,unit) < 0) {
00106     MESSAGE("Erreur a l'ecriture de l'axe X");
00107     return -1;
00108   }
00109   printf("Ecriture des indices des coordonnees selon l'axe des X \n");
00110 
00111   /* axe des "Y" */
00112   indice[0] = 2.1;
00113   indice[1] = 2.2;
00114   indice[2] = 2.3;
00115   indice[3] = 2.4;
00116   nind = 4;
00117   /* Les deux chaines suivantes ont une longueur incorrecte*/
00118   strcpy(comp,"Y");
00119   strcpy(unit,"cm");
00120   axe = 2;
00121   if (MEDindicesCoordEcr(fid,maa,mdim,indice,nind,axe,comp,unit) < 0) {
00122     MESSAGE("Erreur a l'ecriture de l'axe Y");
00123     return -1;
00124   }
00125   printf("Ecriture des indices des coordonnees selon l'axe des Y \n");
00126 
00127   /* Creation d'une grille MED_STANDARD de dimension 2 */
00128   strcpy(maa,"grille_standard");
00129   mdim = 2;
00130   /* on commence par definir un maillage MED_STRUCTURE 
00131      de dimension 2 */
00132   if (MEDmaaCr(fid,maa,mdim,MED_STRUCTURE,
00133                    "un exemple de grille standard") < 0) {
00134     MESSAGE("Erreur a la creation de la 2e grille");
00135     return -1;
00136   }
00137   printf("Creation d'un maillage structure MED_STRUCTURE \n");
00138 
00139   /* On specifie la nature du maillage structure : MED_GRILLE_STANDARD */
00140   if (MEDnatureGrilleEcr(fid,maa,MED_GRILLE_STANDARD) < 0) {
00141     MESSAGE("Erreur a l'ecriture du type de la grille");
00142     return -1;
00143   }
00144   printf("On definit la nature du maillage structure : MED_GRILLE_STANDARD \n");
00145 
00146   /* On ecrit les coordonnees de la grille */
00147   if (MEDcoordEcr(fid,maa,mdim,coo,MED_FULL_INTERLACE,nnoeuds,MED_CART,comp2,unit2) < 0) {
00148     MESSAGE("Erreur a l'ecriture des noeuds de la grille MED_GRILLE_STANDARD");
00149     return -1;
00150   }
00151   printf("Ecriture des coordonnees des noeuds \n");
00152 
00153   /* On definit la structure de la grille */
00154   if (MEDstructureCoordEcr(fid,maa,mdim,structure_grille) < 0) {
00155     MESSAGE("Erreur a l'ecriture de la structure de la grille");
00156     return -1;
00157   }
00158   printf("Ecriture de la structure de la grille : / 2,2 / \n");
00159   
00160   /* On ferme le fichier */
00161   if (MEDfermer(fid) < 0) {
00162     MESSAGE("Erreur a la fermeture du fichier");
00163     return -1;
00164   }
00165   printf("Fermeture du fichier \n");
00166   
00167   return 0;
00168 }

Généré le Thu Oct 8 14:26:17 2015 pour MED fichier par  doxygen 1.6.1