int main (int argc, char **argv) { med_err ret = 0; med_idt fid; /* la dimension du maillage */ med_int mdim = 2; /* nom du maillage de longueur maxi MED_NAME_SIZE */ char maa[MED_NAME_SIZE+1] = "maa1"; /* le nombre de noeuds */ med_int nnoe = 4; /* table des coordonnees (dimension * nombre de noeuds) */ med_float coo[8] = {0.0, 1.0, 2.0, 3.0, 4.0, 5.0, 6.0, 7.0}; med_float coo_2[8] = {0.0, 10.0, 20.0, 30.0, 40.0, 50.0, 60.0, 70.0}; /* tables des noms et des unites des coordonnees (dimension*MED_SNAME_SIZE+1) */ /* 12345678901234561234567890123456*/ char nomcoo[2*MED_SNAME_SIZE+1] = "x y "; char unicoo[2*MED_SNAME_SIZE+1] = "cm cm "; /* tables des noms, numeros, numeros de familles des noeuds autant d'elements que de noeuds - les noms ont pout longueur MED_SNAME_SIZE */ /* 1234567890123456123456789012345612345678901234561234567890123456*/ char nomnoe[4*MED_SNAME_SIZE+1] = "nom1 nom2 nom3 nom4 "; med_int numnoe[4] = {1,2,3,4}; med_int nufano[4] = {0,1,2,2}; const med_float phi1=0; const med_float phi2=M_PI_4; const med_float phi3=M_PI_2; med_float trsf1[7]= {0,0,0, cos(phi1/2), 0, sin(phi1/2), 0 }; med_float trsf2[7]= {0,0,0, cos(phi2/2), 0, sin(phi2/2), 0 }; med_float trsf3[7]= {0,0,0, cos(phi3/2), 0, sin(phi3/2), 0 }; /* ouverture du fichier */ if ((fid = MEDfileOpen("Test_MEDmeshNodeCoordinateTrsfWr.med",MODE_ACCES)) < 0){ MESSAGE("Erreur à l'ouverture du fichier : "); return -1; } /* Creation du maillage "maa" de type MED_NON_STRUCURE et de dimension 2 */ if (MEDmeshCr( fid, maa, mdim, mdim, MED_UNSTRUCTURED_MESH, "un maillage pour Test_MEDmeshNodeCoordinateTrsfWr","s", MED_SORT_DTIT, MED_CARTESIAN, nomcoo, unicoo) < 0) { MESSAGE("Erreur a la creation du maillage : "); SSCRUTE(maa); ret = -1; } /* Ecriture des coordonnees des noeuds en mode MED_FULL_INTERLACE : (X1,Y1, X2,Y2, X3,Y3, ...) dans un repere cartesien */ if (MEDmeshNodeCoordinateWr(fid,maa,MED_NO_DT,MED_NO_IT,MED_UNDEF_DT, MED_FULL_INTERLACE,nnoe, coo) < 0) { MESSAGE("Erreur a l'ecriture des coordonnees des noeuds"); ret = -1; } /* Ecriture des noms des noeuds (optionnel dans un maillage MED) */ if (MEDmeshEntityNameWr(fid,maa,MED_NO_DT,MED_NO_IT,MED_NODE,MED_NONE,nnoe,nomnoe) < 0) { MESSAGE("Erreur a l'ecriture des noms des noeuds"); ret = -1; } /* Ecriture des numeros des noeuds (optionnel dans un maillage MED) */ if (MEDmeshEntityNumberWr(fid,maa,MED_NO_DT,MED_NO_IT,MED_NODE,MED_NONE,nnoe,numnoe) < 0) { MESSAGE("Erreur a l'ecriture des numeros des noeuds"); ret = -1; } /* Ecriture des numeros de famille des noeuds */ if (MEDmeshEntityFamilyNumberWr(fid,maa,MED_NO_DT,MED_NO_IT,MED_NODE,MED_NONE,nnoe,nufano) < 0) { MESSAGE("Erreur a l'ecriture des numeros de familles des noeuds"); ret = -1; } /* Transformation des coordonnees des noeuds coo_1 : */ fprintf(stdout,"Un message d'erreur est attendu: \n"); if ( MEDmeshNodeCoordinateTrsfWr(fid,maa,MED_NO_DT,MED_NO_IT,0.4,trsf1) >= 0) { MESSAGE("Erreur a l'ecriture de la transformation géométrique n°1"); MESSAGE("Aucune transformation géométrique à la séquence de calcul MED_NO_DT,MED_NO_IT n'est possible."); } fprintf(stdout,"Fin du message d'erreur attendu\n :"); /* Transformation des coordonnees des noeuds coo_1 : */ if ( MEDmeshNodeCoordinateTrsfWr(fid,maa,1,1,0.4,trsf1) < 0) { MESSAGE("Erreur a l'ecriture de la transformation géométrique n°1"); ret = -1; } /* Ecriture des coordonnees des noeuds en mode MED_FULL_INTERLACE : (X1,Y1, X2,Y2, X3,Y3, ...) dans un repere cartesien */ fprintf(stdout,"Un message d'erreur est attendu : \n"); if (MEDmeshNodeCoordinateWr(fid,maa,1,1, 0.5, MED_FULL_INTERLACE,nnoe, coo_2) >= 0) { MESSAGE("Erreur a l'ecriture des coordonnees des noeuds"); MESSAGE("Aucune ecriture des coordonnees des noeuds n'est possible sur une séquence de calcul comportant "\ "une transformation géométrique."); } fprintf(stdout,"Fin du message d'erreur attendu :\n"); /* Ecriture des coordonnees des noeuds en mode MED_FULL_INTERLACE : (X1,Y1, X2,Y2, X3,Y3, ...) dans un repere cartesien */ if (MEDmeshNodeCoordinateWr(fid,maa,2,1, 0.5, MED_FULL_INTERLACE,nnoe, coo_2) < 0) { MESSAGE("Erreur a l'ecriture des coordonnees des noeuds"); ret = -1; } /* Transformation des coordonnees des noeuds coo_2 : */ fprintf(stdout,"Un message d'erreur est attendu\n :"); if ( MEDmeshNodeCoordinateTrsfWr(fid,maa,2,1,0.5,trsf2) >= 0) { MESSAGE("Erreur a l'ecriture de la transformation géométrique n°2"); MESSAGE("Aucune transformation géométrique à une séquence de calcul comportant de nouvelles coordonnées n'est possible."); } fprintf(stdout,"Fin du message d'erreur attendu\n :"); /* Transformation des coordonnees des noeuds coo_2 : */ if ( MEDmeshNodeCoordinateTrsfWr(fid,maa,2,2,0.6,trsf2) < 0) { MESSAGE("Erreur a l'ecriture de la transformation géométrique n°2"); ret = -1; } /* Transformation des coordonnees des noeuds coo_3 : */ if ( MEDmeshNodeCoordinateTrsfWr(fid,maa,3,2,0.7,trsf3) < 0) { MESSAGE("Erreur a l'ecriture de la transformation géométrique n°3"); ret = -1; } if ( MEDmeshComputationStepCr(fid,maa, 3,2, 3,3, 3.3) < 0) { MESSAGE("Erreur a la creation d'un pas de temps du maillage maa"); } /* Modification des numeros des noeuds (optionnel dans un maillage MED) */ numnoe[2]=200; if (MEDmeshEntityNumberWr(fid,maa,3,3,MED_NODE,MED_NONE,nnoe,numnoe) < 0) { MESSAGE("Erreur a l'ecriture des numeros des noeuds"); ret = -1; } if ( MEDmeshComputationStepCr(fid,maa, 3,3, 3,4, 3.4) < 0) { MESSAGE("Erreur a la creation d'un pas de temps du maillage maa"); } /*TODO : Ecrire un test de comparaison interne next prev et ordre de découverte itératif */ /* Fermeture du fichier */ if (MEDfileClose(fid) < 0) { MESSAGE("Erreur a la fermeture du fichier test4.med"); return -1; } return ret; }
int main (int argc, char **argv) { med_err _ret=0; med_idt _fid=0; med_geometry_type _geotype=MED_NONE; const char _elementname1[]="MED_BILLE"; /* med_int _elementdim1=3; */ /* const char _supportmeshname1[]="MED_BILLE_SUPPORT"; */ /* med_entity_type _entitytype1=MED_NODE; */ /* med_int _nnode1=1; */ /* med_int _ncell1=0; */ /* med_int _geocelltype1=MED_NONE; */ const char _varattname1_1[MED_NAME_SIZE+1]="MED_VFOO_ATR1_1"; /* const med_attribute_type _varatttype1_1=MED_ATT_INT; */ /* const med_int _ncomponent1_1=1; */ const med_int _varatrvalue1_1[3]={ 22 , 24, 25 }; /* const char _varattname1_2[MED_NAME_SIZE+1]="MED_VFOO_ATR1_2"; */ /* const med_attribute_type _varatttype1_2=MED_ATT_FLOAT64; */ /* const med_int _ncomponent1_2=2; */ const char _varattname1_3[MED_NAME_SIZE+1]="MED_VFOO_ATR1_3"; const med_attribute_type _varatttype1_3=MED_ATT_NAME; const med_int _ncomponent1_3=1; /*Ce qui suit est une seule chaine */ const char _varatrvalue1_3[3*MED_NAME_SIZE+1]= { "*--------------------------------1-----------------------------*" "*--------------------------------2-----------------------------*" "*--------------------------------3-----------------------------*" }; const char _meshname[]="maa1"; char _axisname[3*MED_SNAME_SIZE+1]=""; char _axisunit[3*MED_SNAME_SIZE+1]=""; strcat(_axisname,"x "); strcat(_axisname,"y "); strcat(_axisname,"z "); strcat(_axisunit,"cm "); strcat(_axisunit,"cm "); strcat(_axisunit,"cm "); const med_int _nentity = 3; const med_int _con[3]={ 2, 4 ,5}; /* (3 billes dont les centres sont les noeuds 2, 4 et 5 du maillage maa1 )*/ /* Ouverture en mode lecture du fichier Test_MEDstructuElement.med */ _fid = MEDfileOpen("current.med",MODE_ACCES); if (_fid < 0) { MESSAGE("Erreur à l'ouverture du fichier current.med"); return -1; } /* Creation du maillage "maa1" de type MED_UNSTRUCTURED_MESH et de dimension 3 */ if (MEDmeshCr(_fid,_meshname,3,3,MED_UNSTRUCTURED_MESH, "un premier maillage","s",MED_SORT_DTIT, MED_CARTESIAN,_axisname,_axisunit) < 0) { MESSAGE("Erreur a la creation du maillage maa1"); return -1; } _geotype = MEDstructElementGeotype(_fid,_elementname1); /* ecriture des connectivites des segments */ if ( MEDmeshElementConnectivityWr(_fid,_meshname, MED_NO_DT, MED_NO_IT, MED_UNDEF_DT, MED_STRUCT_ELEMENT, _geotype, MED_NODAL, MED_FULL_INTERLACE, _nentity, _con) < 0 ) { MESSAGE("Impossible d'ecrire la connectivité des billes: "); return -1; } if (MEDmeshStructElementVarAttWr(_fid, _meshname, MED_NO_DT, MED_NO_IT, _geotype, _varattname1_1, _nentity, _varatrvalue1_1 ) < 0 ) { return -1; } if (MEDmeshStructElementVarAttWr(_fid, _meshname, MED_NO_DT, MED_NO_IT, _geotype, _varattname1_3, _nentity, _varatrvalue1_3 ) < 0 ) { return -1; } if ( MEDmeshComputationStepCr(_fid,_meshname,MED_NO_DT,MED_NO_IT, 1,MED_NO_IT,0.5) < 0) { fprintf(stderr,"Erreur a la creation du pas de temps du maillage %s\n",_meshname); return -1; } return _ret; }
int main (int argc, char **argv) { med_err ret = 0; med_idt fid; /* la dimension du maillage */ med_int mdim = 2; /* nom du maillage de longueur maxi MED_NAME_SIZE */ char maa[MED_NAME_SIZE+1] = "maa1"; /* le nombre de noeuds */ med_int nnoe = 4; /* table des coordonnees (dimension * nombre de noeuds) */ med_float coo[8] = {0.0, 1.0, 2.0, 3.0, 4.0, 5.0, 6.0, 7.0}; med_float coo_2[8] = {0.0, 10.0, 20.0, 30.0, 40.0, 50.0, 60.0, 70.0}; /* tables des noms et des unites des coordonnees (dimension*MED_SNAME_SIZE+1) */ /* 12345678901234561234567890123456*/ char nomcoo[2*MED_SNAME_SIZE+1] = "x y "; char unicoo[2*MED_SNAME_SIZE+1] = "cm cm "; /* tables des noms, numeros, numeros de familles des noeuds autant d'elements que de noeuds - les noms ont pout longueur MED_SNAME_SIZE */ /* 1234567890123456123456789012345612345678901234561234567890123456*/ char nomnoe[4*MED_SNAME_SIZE+1] = "nom1 nom2 nom3 nom4 "; med_int numnoe[4] = {1,2,3,4}; med_int nufano[4] = {0,1,2,2}; /* Creation du fichier "test4.med" */ /* ouverture du fichier */ if ((fid = MEDfileOpen("test4.med",MODE_ACCES)) < 0){ MESSAGE("Erreur à l'ouverture du fichier : "); return -1; } /* Creation du maillage "maa" de type MED_NON_STRUCURE et de dimension 2 */ if (MEDmeshCr( fid, maa, mdim, mdim, MED_UNSTRUCTURED_MESH, "un maillage pour test4","s", MED_SORT_DTIT, MED_CARTESIAN, nomcoo, unicoo) < 0) { MESSAGE("Erreur a la creation du maillage : "); SSCRUTE(maa); ret = -1; } /* Ecriture des coordonnees des noeuds en mode MED_FULL_INTERLACE : (X1,Y1, X2,Y2, X3,Y3, ...) dans un repere cartesien */ if (MEDmeshNodeCoordinateWr(fid,maa,MED_NO_DT,MED_NO_IT,MED_UNDEF_DT, MED_FULL_INTERLACE,nnoe, coo) < 0) { MESSAGE("Erreur a l'ecriture des coordonnees des noeuds"); ret = -1; } /* Ecriture des attributs des noeuds du maillage */ if (MEDmeshAttributeWr(fid,maa, 0, nnoe, 0) < 0 ) { MESSAGE("Erreur a l'ecriture des attributs des noeuds du maillage"); ret = -1; } /* Ecriture des noms des noeuds (optionnel dans un maillage MED) */ if (MEDmeshEntityNameWr(fid,maa,MED_NO_DT,MED_NO_IT,MED_NODE,MED_NONE,nnoe,nomnoe) < 0) { MESSAGE("Erreur a l'ecriture des noms des noeuds"); ret = -1; } /* Ecriture des numeros des noeuds (optionnel dans un maillage MED) */ if (MEDmeshEntityNumberWr(fid,maa,MED_NO_DT,MED_NO_IT,MED_NODE,MED_NONE,nnoe,numnoe) < 0) { MESSAGE("Erreur a l'ecriture des numeros des noeuds"); ret = -1; } /* Ecriture des numeros de famille des noeuds */ if (MEDmeshEntityFamilyNumberWr(fid,maa,MED_NO_DT,MED_NO_IT,MED_NODE,MED_NONE,nnoe,nufano) < 0) { MESSAGE("Erreur a l'ecriture des numeros de familles des noeuds"); ret = -1; } /* Ecriture des coordonnees des noeuds en mode MED_FULL_INTERLACE : (X1,Y1, X2,Y2, X3,Y3, ...) dans un repere cartesien */ if (MEDmeshNodeCoordinateWr(fid,maa,0,5,0.5, MED_FULL_INTERLACE,nnoe, coo_2) < 0) { MESSAGE("Erreur a l'ecriture des coordonnees des noeuds"); ret = -1; } /* Ecriture des coordonnees des noeuds en mode MED_FULL_INTERLACE : (X1,Y1, X2,Y2, X3,Y3, ...) dans un repere cartesien */ if (MEDmeshNodeCoordinateWr(fid,maa,2,0,2.0, MED_FULL_INTERLACE,nnoe, coo) < 0) { MESSAGE("Erreur a l'ecriture des coordonnees des noeuds"); ret = -1; } /*TODO : Ecrire un test de comparaison next prev et ordre de découverte itératif */ MEDmeshComputationStepCr(fid,maa,-1,-1,0,2,0.25); MEDmeshComputationStepCr(fid,maa,0,2,0,3,0.35); /* Fermeture du fichier */ if (MEDfileClose(fid) < 0) { MESSAGE("Erreur a la fermeture du fichier test4.med"); return -1; } return ret; }