MED fichier
c/test10_mem.c
/* This file is part of MED.
*
* COPYRIGHT (C) 1999 - 2023 EDF R&D, CEA/DEN
* MED is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* MED is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with MED. If not, see <http://www.gnu.org/licenses/>.
*/
#define _a 0.446948490915965
#define _b 0.091576213509771
#define _p1 0.11169079483905
#define _p2 0.0549758718227661
/******************************************************************************
* - Nom du fichier : test10_mem.c
*
* - Description : ecriture de champs de resultats MED en mémoire
*
*****************************************************************************/
#include <med.h>
#define MESGERR 1
#include "med_utils.h"
#include <string.h>
#ifdef DEF_LECT_ECR
#define MODE_ACCES MED_ACC_RDWR
#elif DEF_LECT_AJOUT
#define MODE_ACCES MED_ACC_RDEXT
#else
#define MODE_ACCES MED_ACC_CREAT
#endif
#ifndef USER_INTERLACE
#define USER_INTERLACE MED_FULL_INTERLACE
#endif
#define USER_MODE MED_COMPACT_STMODE
#ifdef DEF_MED_FLOAT32
#define FTYPECHA MED_FLOAT32
#define ftypecha med_float32
#define filename_ "test10_f32"
#else
#define FTYPECHA MED_DOUBLE
#define ftypecha med_double
#define filename_ "test10"
#endif
#ifdef DEF_MED_INT32
#define ITYPECHA MED_INT32
#define itypecha med_int32
#define filename__ filename_ "_i32"
#elif DEF_MED_INT64
#define ITYPECHA MED_INT64
#define itypecha med_int64
#define filename__ filename_ "_i64"
#else
#define ITYPECHA MED_INT
#define itypecha med_int
#define filename__ filename_
#endif
#define filename filename__ ".med"
int main (int argc, char **argv)
{
med_err ret=0;
med_idt fid;
/* Maillage support aux champs*/
/* Ces maillages sont vides*/
char maa1[MED_NAME_SIZE+1]= "maa1";
char maa2[MED_NAME_SIZE+1]= "maa2";
char * lien_maa2 = "./testfoo.med";
char maa3[MED_NAME_SIZE+1]= "maa3";
/* Caractéristiques du champ n° 1 sur TRIA6 */
char nomcha1[MED_NAME_SIZE+1] = "champ reel";
char comp1[2*MED_SNAME_SIZE+1] = "comp1 comp2 ";
/*12345678901234561234567890123456*/
char unit1[2*MED_SNAME_SIZE+1] = "unit1 unit2 ";
med_int ncomp1 = 2;
/* Caractéristiques du model n° 1 de localisation des points de gauss pour le champ n°1*/
med_int ngauss1_1 = 6;
char gauss1_1[MED_NAME_SIZE+1] = "Model n1";
med_float refcoo1[12] = { -1.0,1.0, -1.0,-1.0, 1.0,-1.0, -1.0,0.0, 0.0,-1.0, 0.0,0.0 };
/* Constantes */
med_float gscoo1_1[12] = { 2*_b-1, 1-4*_b, 2*_b-1, 2*_b-1, 1-4*_b,
2*_b-1, 1-4*_a, 2*_a-1, 2*_a-1, 1-4*_a, 2*_a-1, 2*_a-1 };
med_float wg1_1[6] = { 4*_p2, 4*_p2, 4*_p2, 4*_p1, 4*_p1, 4*_p1 };
med_int nval1_1= 1*6; /*1 valeurs et 6 points de gauss par valeur */
med_int _nent1_1= 1; /*1 valeurs et 6 points de gauss par valeur */
ftypecha valr1_1[1*6*2] = {0.0,1.0, 2.0,3.0, 10.0,11.0, 12.0,13.0, 20.0,21.0, 22.0,23.0}; /* 2 composantes*/
/* Caractéristiques du model n° 2 de localisation des points de gauss pour le champ n°1*/
med_int ngauss1_2 = 3;
char gauss1_2[MED_NAME_SIZE+1] = "Model n2";
med_float gscoo1_2[6] = { -2.0/3,1.0/3, -2.0/3,-2.0/3, 1.0/3,-2.0/3 };
med_float wg1_2[3] = { 2.0/3, 2.0/3, 2.0/3 };
med_int nval1_2= 2*3; /*2 valeurs et 3 points de gauss par valeur */
med_int _nent1_2= 2; /*2 valeurs et 3 points de gauss par valeur */
ftypecha valr1_2[2*3*2] = {0.0,1.0, 2.0,3.0, 10.0,11.0, 12.0,13.0, 20.0,21.0, 22.0,23.0}; /* 2 composantes*/
ftypecha valr1_2p[2*3*2] = { 12.0,13.0, 20.0,21.0, 22.0,23.0}; /* 2 composantes*/
/* Caractéristiques du model n° 3 sans points de gauss pour le champ n°1*/
med_int nval1_3= 6; /*6 valeurs et pas de points de gauss */
med_int _nent1_3= 6; /*6 valeurs et pas de points de gauss */
ftypecha valr1_3[2*3*2] = {0.0,1.0, 2.0,3.0, 10.0,11.0, 12.0,13.0, 20.0,21.0, 22.0,23.0}; /* 2 composantes*/
ftypecha valr1_3p[2*2*2] = { 2.0,3.0, 10.0,11.0 }; /* 2 composantes profil1 */
/* Caractéristiques du champ n° 2 */
char nomcha2[MED_NAME_SIZE+1] = "champ entier";
char comp2[3*MED_SNAME_SIZE+1] = "comp1 comp2 comp3 ";
/*123456789012345612345678901234561234567890123456*/
char unit2[3*MED_SNAME_SIZE+1] = "unit1 unit2 unit3 ";
med_int ncomp2 = 3;
med_int nval2 = 5; /*5 valeurs */
itypecha valr2[5*3 ] = {0,1,2, 10,11,12, 20,21,22, 30,31,32, 40,41,42}; /* 3 composantes*/
/* u32b : 4294967296 s32b : 2147483647 -2147483647 */
itypecha valr2_[5*3 ] = {2147483647, -2147483648, 4294967296, 10,11,12, 20,21,22, 30,31,32, 40,41,42};
itypecha valr2p[3*3 ] = {0,1,2, 20,21,22, 40,41,42}; /* 3 composantes*/
/* Profils utilisés */
char nomprofil1[MED_NAME_SIZE+1] = "PROFIL(champ(1))";
char nomprofil1b[MED_NAME_SIZE+1] = "PROFIL(champ(1b))";
char nomprofil2[MED_NAME_SIZE+1] = "PROFIL(champ2)";
med_int profil1[2] = { 2, 3 };
med_int profil2[3] = { 1, 3, 5 };
/* Caractéristiques du champ n° 3 */
char nomcha3[MED_NAME_SIZE+1] = "champ entier 3";
char comp3[3*MED_SNAME_SIZE+1] = "comp1 comp2 ";
/*123456789012345612345678901234561234567890123456*/
char unit3[3*MED_SNAME_SIZE+1] = "unit1 unit2 ";
char dtunit[MED_SNAME_SIZE+1] = "s";
med_int ncomp3 = 2;
med_int nval3 = 5*4; /*5 valeurs et 4 noeuds par element*/
med_int _nent3 = 5; /*5 valeurs et 4 noeuds par element*/
itypecha valr3[5*4*2] = {0,1, 10,11, 20,21, 30,31,
40,41, 50,51, 60,61, 70,71,
80,81, 90,91, 100,101, 110,111,
120,121, 130,131, 140,141, 150,151,
160,161, 170,171, 180,181, 190,191}; /* 2 composantes*/
itypecha valr3p[3*4*2] = {0,1, 10,11, 20,21, 30,31,
80,81, 90,91, 100,101, 110,111,
160,161, 170,171, 180,181, 190,191}; /* 2 composantes*/
char nomcoo[3*MED_SNAME_SIZE+1] = "x y z ";
char unicoo[3*MED_SNAME_SIZE+1] = "cm cm cm ";
char _maa[MED_NAME_SIZE+1]="";
char _desc[MED_COMMENT_SIZE+1]="";
char _dtunit[MED_SNAME_SIZE+1]="";
char _nomcoo[3*MED_SNAME_SIZE+1]="";
char _unicoo[3*MED_SNAME_SIZE+1]="";
med_int _nstep=0;
char __dtunit [MED_SNAME_SIZE+1]="";
med_int _mdim=0,_sdim=0;
med_int ncha=0;
med_access_mode _accessmode;
/* Il n'est pas necessaire de pré-allouer la mémoire.
med-fichier s'occupe d'allouer la mémoire au fil de l'utilisation de l'API.*/
/* Attention la structure doit être initialisée à MED_MEMFILE_INIT avant toute première utilisation.*/
/* On décide de pré-allouer suffisement de mémoire : 10MB */
/* med-fichier utilisera l'espace réservé sans réallocation.*/
/* memfile[0].app_image_size = 10*1024*1024; */
/* memfile[0].app_image_ptr = calloc(memfile[0].app_image_size,sizeof(char)); */
/* On décide de pré-allouer insuffisement de mémoire : 1KB */
/* med-fichier utilisera l'espace réservé puis effectuera une réallocation.*/
/* memfile[0].app_image_size = 1024; */
/* memfile[0].app_image_ptr = calloc(memfile[0].app_image_size,sizeof(char)); */
/* Ouverture du fichier */
/* mode RDWR uniquement si le fichier test10.med a préalablement été généré par test10
ou par le sync de test10_mem (en CREATE).
Si test10.med n'existe pas et demande le mode RDWR
-> erreur car nous n'avons pas initialisé une image mémoire valide !
*/
_accessmode = MED_ACC_CREAT;
if ((fid = MEDmemFileOpen("test10_mem.med",memfile,MED_TRUE,_accessmode) ) < 0){
MESSAGE("Erreur à l'ouverture du fichier : ");
return -1;
}
/* Ouverture du fichier */
/* Si l'on ne veut pas créer de fichier sur disque, sync=MED_FALSE */
/* if ((fid = MEDmemFileOpen("test10.med",memfile,MED_FALSE,MED_ACC_CREAT) ) < 0){ */
/* MESSAGE("Erreur à l'ouverture du fichier : "); */
/* return -1; */
/* } */
/* combien de champs dans le fichier (pour tester le fichier mémoire)*/
if ((ncha = MEDnField(fid)) < 0) {
MESSAGE("Impossible de lire le nombre de champs : ");ISCRUTE(ncha);
}
printf("Nombre de champs : "IFORMAT" \n",ncha);
if (ncha == 3 ) { /*Un quatrième champ est crée seulement si un fichier test10.med existait et mode RDWR + sync */
/* creation du champ réel n° 1 */
if ( MEDfieldCr(fid,"Ajout Complémentaire",MED_FLOAT64,ncomp1,comp1,unit1,dtunit,maa1 ) < 0) {
MESSAGE("Erreur à la création du champ : ");SSCRUTE("Ajout Complémentaire");
ret = -1;
};
}
/* creation de maa1 de dimension 3*/
if (MEDmeshCr( fid, maa1, 3, 3, MED_UNSTRUCTURED_MESH,
"Maillage vide","s", MED_SORT_DTIT,
MED_CARTESIAN, nomcoo, unicoo) < 0) {
MESSAGE("Erreur a la creation du maillage : "); SSCRUTE(maa1);
ret = -1;
}
/* creation de maa3 de dimension 3*/
if (MEDmeshCr( fid, maa3, 3, 3, MED_UNSTRUCTURED_MESH,
"Maillage vide","s", MED_SORT_DTIT,
MED_CARTESIAN, nomcoo, unicoo) < 0) {
MESSAGE("Erreur a la creation du maillage : "); SSCRUTE(maa3);
ret = -1;
}
/* creation du champ réel n°1 */
if ( MEDfieldCr(fid,nomcha1,FTYPECHA,ncomp1,comp1,unit1,dtunit,maa1 ) < 0) {
MESSAGE("Erreur à la création du champ : ");SSCRUTE(nomcha1);
ret = -1;
};
/* creation du champ entier n°2 */
if ( MEDfieldCr(fid,nomcha2,ITYPECHA,ncomp2,comp2,unit2,dtunit,maa2 ) < 0) {
MESSAGE("Erreur à la création du champ : ");SSCRUTE(nomcha2);
ret = -1;
};
/* creation du lien au fichier distant contenant maa2 */
if (MEDlinkWr(fid,maa2,lien_maa2) < 0) {
MESSAGE("Erreur à la création du lien : ");SSCRUTE(lien_maa2);
ret = -1;
};
/* creation de la localisation des points de Gauss modèle n° 1 */
if (MEDlocalizationWr(fid, gauss1_1, MED_TRIA6, MED_TRIA6/100, refcoo1, USER_INTERLACE,
ngauss1_1, gscoo1_1, wg1_1,
MESSAGE("Erreur à la création du modèle n° 1 : ");SSCRUTE(gauss1_1);
ret = -1;
};
/* creation de la localisation des points de Gauss modèle n° 2 */
if (MEDlocalizationWr(fid, gauss1_2, MED_TRIA6, MED_TRIA6/100, refcoo1, USER_INTERLACE,
ngauss1_2, gscoo1_2, wg1_2,
MESSAGE("Erreur à la création du modèle n° 1 : ");SSCRUTE(gauss1_2);
ret = -1;
};
/* ecriture du champ n° 1*/
/* enregistre uniquement les composantes n° 2 de valr1_1, et n'utilise ni pas de temps ni n° d'ordre*/
gauss1_1,USER_INTERLACE, 2, _nent1_1, (unsigned char*)valr1_1 ) < 0) {
MESSAGE("Erreur à l'écriture du champ : ");
SSCRUTE(maa1);
ret = -1;
};
/* enregistre uniquement les composantes n° 1 de valr1_1, et n'utilise ni pas de temps ni n° d'ordre */
gauss1_1,USER_INTERLACE, 1, _nent1_1, (unsigned char*)valr1_1 ) < 0) {
MESSAGE("Erreur à l'écriture du champ : ");
SSCRUTE(maa1);
ret = -1;
};
/* enregistre uniquement les composantes n° 1 de valr1_2, au pas de temps n° 1(5.5), n'utilise pas de n° d'ordre*/
/* ce champ repose sur le maillage maa2 qui est distant */
gauss1_2,USER_INTERLACE, 1, _nent1_2, (unsigned char*)valr1_2 ) < 0) {
MESSAGE("Erreur à l'écriture du champ : ");
SSCRUTE(maa1);
ret = -1;
};
/*Ce test utilise un deuxième maillage pour un même champ, ceci n'existe plus en 3.0*/
/* enregistre uniquement les composantes n°2 de valr1_2, au pas de temps n°1(5.5), n'utilise pas de n°d'ordre*/
/* ce champ repose sur le maillage maa1 qui est local */
/*Ce test utilise un deuxième maillage pour un même champ, ceci n'existe plus en 3.0*/
gauss1_1,USER_INTERLACE, 2, _nent1_1, (unsigned char*)valr1_1 ) < 0) {
MESSAGE("Erreur à l'écriture du champ : ");
SSCRUTE(maa1);
ret = -1;
};
/* enregistre uniquement les composantes n° 1 de valr1_1, au pas de temps n° 1(5.5), et n° d'itération n° 2*/
/* ce champ repose sur le maillage maa3 qui est local */
gauss1_2,USER_INTERLACE, 1, _nent1_2, (unsigned char*)valr1_2 ) < 0) {
MESSAGE("Erreur à l'écriture du champ : ");
SSCRUTE(maa1);
ret = -1;
};
/* Creation d'un profil (selection du deuxieme élément de valr1_1) */
/* On n'utilise que la première valeur (2) du profil */
if ( MEDprofileWr(fid,nomprofil1,1,profil1) < 0) {
MESSAGE("Erreur à l'écriture du profil : ");
SSCRUTE(nomprofil1);
ret = -1;
};
if ( MEDprofileWr(fid,nomprofil1b,1,profil1) < 0) {
MESSAGE("Erreur à l'écriture du profil : ");
SSCRUTE(nomprofil1b);
ret = -1;
};
/* enregistre toutes les composantes du deuxième élément de valr1_1 (premier élément en stockage compact de valr1p),
au pas de temps n° 2(5.6), et n° d'itération n° 2*/
if ( MEDfieldValueWithProfileWr(fid, nomcha1,2,2,5.6,MED_CELL,MED_TRIA6,USER_MODE,nomprofil1,
MED_NO_LOCALIZATION,USER_INTERLACE, MED_ALL_CONSTITUENT, nval1_3, (unsigned char*)valr1_3p ) < 0) {
MESSAGE("Erreur à l'écriture du champ : ");
SSCRUTE(maa1);
ret = -1;
};
/* enregistre toutes les composantes du deuxième élément de valr1_1 (premier élément en stockage compact de valr1p),
au pas de temps n° 2(5.6), et n° d'itération n° 2 */
if ( MEDfieldValueWithProfileWr(fid, nomcha1,2,2,5.6,MED_CELL,MED_TRIA6,USER_MODE,nomprofil1b,
gauss1_2,USER_INTERLACE, MED_ALL_CONSTITUENT, _nent1_2, (unsigned char*)valr1_2p ) < 0) {
MESSAGE("Erreur à l'écriture du champ : ");
SSCRUTE(maa1);
ret = -1;
};
if ( MEDfieldValueWithProfileWr(fid, nomcha1,3,2,5.7,MED_CELL,MED_TRIA6,USER_MODE,nomprofil1,
MED_NO_LOCALIZATION,USER_INTERLACE, 2, _nent1_3, (unsigned char*)valr1_3p ) < 0) {
MESSAGE("Erreur à l'écriture du champ : ");
SSCRUTE(maa1);
ret = -1;
};
/* Ecriture du champ n° 2 */
if ( MEDfieldValueWr(fid, nomcha2,MED_NO_DT,MED_NO_IT,0,
USER_INTERLACE, 1, nval2, (unsigned char*)valr2 ) < 0) {
MESSAGE("Erreur à l'écriture du champ : ");
SSCRUTE(maa1);
ret = -1;
};
USER_INTERLACE, 2, nval2, (unsigned char*)valr2 ) < 0) {
MESSAGE("Erreur à l'écriture du champ : ");
SSCRUTE(maa1);
ret = -1;
};
USER_INTERLACE, 3, nval2, (unsigned char*)valr2 ) < 0) {
MESSAGE("Erreur à l'écriture du champ : ");
SSCRUTE(maa1);
ret = -1;
};
/* Creation d'un profil (selection des éléments 1,3,5 de valr2) */
/* On utilise les trois valeurs du profil */
if ( MEDprofileWr(fid,nomprofil2,3,profil2) < 0) {
MESSAGE("Erreur à l'écriture du profil : ");
SSCRUTE(nomprofil2);
ret = -1;
};
MED_NO_LOCALIZATION,USER_INTERLACE, 3, nval2, (unsigned char*)valr2p ) < 0) {
MESSAGE("Erreur à l'écriture du champ : ");
SSCRUTE(maa1);
ret = -1;
};
/* creation du champ entier n°3 */
if ( MEDfieldCr(fid,nomcha3,ITYPECHA,ncomp3,comp3,unit3,dtunit,maa1) < 0) {
MESSAGE("Erreur à la création du champ : ");SSCRUTE(nomcha3);
ret = -1;
};
/* Ecriture du champ n° 3 */
USER_INTERLACE, 1, nval3, (unsigned char*)valr3 ) < 0) {
MESSAGE("Erreur à l'écriture du champ : ");
SSCRUTE(maa1);
ret = -1;
};
USER_INTERLACE, MED_ALL_CONSTITUENT, _nent3, (unsigned char*)valr3 ) < 0) {
MESSAGE("Erreur à l'écriture du champ : ");
SSCRUTE(maa1);
ret = -1;
};
MED_NO_LOCALIZATION,USER_INTERLACE, MED_ALL_CONSTITUENT, _nent3, (unsigned char*)valr3p ) < 0) {
MESSAGE("Erreur à l'écriture du champ : ");
SSCRUTE(maa1);
ret = -1;
};
/* fermeture du fichier */
if ( MEDfileClose(fid) < 0 ) {
ret=-1;
MESSAGE("Erreur à la fermeture du fichier ");
}
/* H5Fflush(fid, H5F_SCOPE_GLOBAL ); */
_accessmode = MED_ACC_RDWR;
/* Utilisation du fichier mémoire et synchronisation avec un nouveau fichier.*/
/*ATTENTION : Il faut au moins une écriture/création dans le fichier pour que le sync se fasse en mode RW*/
if ((fid = MEDmemFileOpen("test10_mem_ext.med",memfile,MED_TRUE,_accessmode) ) < 0){
MESSAGE("Erreur à l'ouverture du fichier : ");
return -1;
}
/* combien de champs dans le fichier (pour tester le fichier mémoire)*/
if ((ncha = MEDnField(fid)) < 0) {
MESSAGE("Impossible de lire le nombre de champs : ");ISCRUTE(ncha);
}
printf("Nombre de champs : "IFORMAT" \n",ncha);
/*Il faut une écriture pour que le sync se fasse en mode RW*/
if ( (ncha == 3) || (_accessmode == MED_ACC_RDWR) )
/* creation du champ complémentaire n° 2 */
if ( MEDfieldCr(fid,"Ajout Complémentaire 2",FTYPECHA,ncomp1,comp1,unit1,dtunit,maa1 ) < 0) {
MESSAGE("Erreur à la création du champ : Complémentaire 2");
ret = -1;
};
/* Lecture des infos concernant le premier maillage */
if ( MEDmeshInfo( fid, 1, _maa, &_sdim, &_mdim, &_type, _desc, __dtunit, &_sort,
&_nstep, &_rep, _nomcoo,_unicoo) < 0 ) {
MESSAGE("Erreur a la lecture des informations sur le maillage : ");SSCRUTE(_maa);
return -1;
} else {
printf("Maillage de nom : |%s| , de dimension : "IFORMAT" , et de type %d\n",_maa,_mdim,_type);
printf("\t -Dimension de l'espace : "IFORMAT"\n",_sdim);
printf("\t -Description du maillage : %s\n",_desc);
printf("\t -Noms des axes : |%s|\n",_nomcoo);
printf("\t -Unités des axes : |%s|\n",_unicoo);
printf("\t -Type de repère : %d\n",_rep);
printf("\t -Nombre d'étapes de calcul : "IFORMAT"\n",_nstep);
printf("\t -Unité des dates : |%s|\n",__dtunit);
}
/* combien de champs dans le fichier (pour tester le fichier mémoire)*/
if ((ncha = MEDnField(fid)) < 0) {
MESSAGE("Impossible de lire le nombre de champs : ");ISCRUTE(ncha);
}
printf("Nombre de champs : "IFORMAT" \n",ncha);
if ( MEDfileClose(fid) < 0 ) {
ret=-1;
MESSAGE("Erreur à la fermeture du fichier ");
}
free(memfile[0].app_image_ptr);
memfile->app_image_size =0;
return ret;
}
itypecha
#define itypecha
Definition: 4.0.1/test10.c:70
MED_COMMENT_SIZE
#define MED_COMMENT_SIZE
Definition: med.h:81
_p2
#define _p2
Definition: 3.0.8/test10.c:20
MED_UNSTRUCTURED_MESH
Definition: med.h:133
med_memfile
Structure d'acceuil du buffer d'un fichier MED en mémoire.
Definition: med.h:395
MED_SNAME_SIZE
#define MED_SNAME_SIZE
Definition: med.h:84
MED_TRUE
Definition: med.h:262
ISCRUTE_int
#define ISCRUTE_int(entier)
Definition: med_utils.h:314
med_idt
hid_t med_idt
Definition: med.h:333
MED_SEG2
#define MED_SEG2
Definition: med.h:202
USER_INTERLACE
#define USER_INTERLACE
Definition: 3.0.8/test10.c:45
FTYPECHA
#define FTYPECHA
Definition: 4.0.1/test10.c:55
med_err
herr_t med_err
Definition: med.h:334
MED_DESCENDING_EDGE
Definition: med.h:145
med_sorting_type
med_sorting_type
Definition: med.h:311
MEDmeshInfo
MEDC_EXPORT med_err MEDmeshInfo(const med_idt fid, const int meshit, char *const meshname, med_int *const spacedim, med_int *const meshdim, med_mesh_type *const meshtype, char *const description, char *const dtunit, med_sorting_type *const sortingtype, med_int *const nstep, med_axis_type *const axistype, char *const axisname, char *const axisunit)
Cette routine permet de lire les informations relatives à un maillage dans un fichier.
Definition: MEDmeshInfo.c:43
MED_ACC_RDWR
Definition: med.h:123
MEDfieldValueWr
MEDC_EXPORT med_err MEDfieldValueWr(const med_idt fid, const char *const fieldname, const med_int numdt, const med_int numit, const med_float dt, const med_entity_type entitype, const med_geometry_type geotype, const med_switch_mode switchmode, const med_int componentselect, const med_int nentity, const unsigned char *const value)
Cette fonction permet d'écrire les valeurs d'un champ définies sur des entités d'un maillage pour une...
Definition: MEDfieldValueWr.c:44
MED_NO_LOCALIZATION
#define MED_NO_LOCALIZATION
Definition: med.h:277
MED_ALLENTITIES_PROFILE
#define MED_ALLENTITIES_PROFILE
Definition: med.h:293
MESSAGE
#define MESSAGE(chaine)
Definition: med_utils.h:324
med_int
int med_int
Definition: med.h:344
MED_NO_MESH_SUPPORT
#define MED_NO_MESH_SUPPORT
Definition: med.h:275
MED_SORT_DTIT
Definition: med.h:311
ISCRUTE
#define ISCRUTE(entier)
Definition: med_utils.h:313
MEDlocalizationWr
MEDC_EXPORT med_err MEDlocalizationWr(const med_idt fid, const char *const localizationname, const med_geometry_type geotype, const med_int spacedimension, const med_float *const elementcoordinate, const med_switch_mode switchmode, const med_int nipoint, const med_float *const ipointcoordinate, const med_float *const weight, const char *const geointerpname, const char *const ipointstructmeshname)
Cette routine permet l'écriture d'une localisation localizationname de points d'intégration dans/auto...
Definition: MEDlocalizationWr.c:49
MEDfieldValueWithProfileWr
MEDC_EXPORT med_err MEDfieldValueWithProfileWr(const med_idt fid, const char *const fieldname, const med_int numdt, const med_int numit, const med_float dt, const med_entity_type entitype, const med_geometry_type geotype, const med_storage_mode storagemode, const char *const profilename, const char *const localizationname, const med_switch_mode switchmode, const med_int componentselect, const med_int nentity, const unsigned char *const value)
Cette fonction permet d'écrire les valeurs d'un champ définies sur des entités d'un maillage pour une...
Definition: MEDfieldValueWithProfileWr.c:48
ITYPECHA
#define ITYPECHA
Definition: 4.0.1/test10.c:69
_p1
#define _p1
Definition: 3.0.8/test10.c:19
med_float
double med_float
Definition: med.h:338
IFORMAT
#define IFORMAT
Definition: med_utils.h:145
_b
#define _b
Definition: 3.0.8/test10.c:18
MED_NO_DT
#define MED_NO_DT
Definition: med.h:322
med_access_mode
med_access_mode
Definition: med.h:122
MED_NONE
#define MED_NONE
Definition: med.h:233
MEDfileClose
MEDC_EXPORT med_err MEDfileClose(med_idt fid)
Fermeture d'un fichier MED.
Definition: MEDfileClose.c:30
MED_MEMFILE_INIT
#define MED_MEMFILE_INIT
Definition: med.h:409
med_memfile::app_image_size
size_t app_image_size
Definition: med.h:397
SSCRUTE
#define SSCRUTE(chaine)
Definition: med_utils.h:323
med_mesh_type
med_mesh_type
Definition: med.h:133
MED_FLOAT64
Definition: med.h:168
MEDmeshCr
MEDC_EXPORT med_err MEDmeshCr(const med_idt fid, const char *const meshname, const med_int spacedim, const med_int meshdim, const med_mesh_type meshtype, const char *const description, const char *const dtunit, const med_sorting_type sortingtype, const med_axis_type axistype, const char *const axisname, const char *const axisunit)
Cette routine permet de créer un maillage dans un fichier.
Definition: MEDmeshCr.c:45
MED_CELL
Definition: med.h:145
MED_NAME_SIZE
#define MED_NAME_SIZE
Definition: med.h:83
MED_NODE_ELEMENT
Definition: med.h:146
MEDmemFileOpen
MEDC_EXPORT med_idt MEDmemFileOpen(const char *const filename, med_memfile *const memfile, const med_bool filesync, const med_access_mode accessmode)
Ouverture d'un fichier MED pour une utilisation en mémoire.
Definition: MEDmemFileOpen.c:43
MED_ALL_CONSTITUENT
#define MED_ALL_CONSTITUENT
Definition: med.h:301
MED_CARTESIAN
Definition: med.h:260
med_utils.h
MED_NODE
Definition: med.h:145
ftypecha
#define ftypecha
Definition: 4.0.1/test10.c:56
MED_NO_PROFILE
#define MED_NO_PROFILE
Definition: med.h:283
AFF_MEMFILE
#define AFF_MEMFILE
Definition: med.h:412
MEDfieldCr
MEDC_EXPORT med_err MEDfieldCr(const med_idt fid, const char *const fieldname, const med_field_type fieldtype, const med_int ncomponent, const char *const componentname, const char *const componentunit, const char *const dtunit, const char *const meshname)
Cette fonction crée un champ dans un fichier.
Definition: MEDfieldCr.c:44
med_axis_type
med_axis_type
Definition: med.h:260
med.h
MED_NO_IT
#define MED_NO_IT
Definition: med.h:323
MEDprofileWr
MEDC_EXPORT med_err MEDprofileWr(const med_idt fid, const char *const profilename, const med_int profilesize, const med_int *const profilearray)
Cette routine permet d'écrire un profil dans un fichier MED.
Definition: MEDprofileWr.c:40
_a
#define _a
Definition: 3.0.8/test10.c:17
MED_NO_INTERPOLATION
#define MED_NO_INTERPOLATION
Definition: med.h:279
MEDnField
MEDC_EXPORT med_int MEDnField(const med_idt fid)
Cette fonction permet de lire le nombre de champs dans un fichier.
Definition: MEDnField.c:35
MED_ACC_CREAT
Definition: med.h:125
main
int main(int argc, char **argv)
Definition: 3.0.8/test10.c:50
MED_QUAD4
#define MED_QUAD4
Definition: med.h:206
MED_TRIA6
#define MED_TRIA6
Definition: med.h:207
MEDlinkWr
MEDC_EXPORT med_err MEDlinkWr(const med_idt fid, const char *const meshname, const char *const link)
Cette routine permet d'écrire un lien dans un fichier MED.
Definition: MEDlinkWr.c:36
USER_MODE
#define USER_MODE
Definition: 3.0.8/test10.c:48
MED_DESCENDING_FACE
Definition: med.h:145