Test_MEDmeshNodeCoordinateTrsfWr.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 #include <med.h>
00020 #define MESGERR 1
00021 #include <med_utils.h>
00022 #include <math.h>
00023 
00024 #ifndef M_PI_2
00025 # define M_PI_2         1.57079632679489661923  /* pi/2 */
00026 #endif
00027 
00028 #ifndef M_PI_4
00029 # define M_PI_4         0.78539816339744830962  /* pi/4 */
00030 #endif
00031 
00032 #ifdef DEF_LECT_ECR
00033 #define MODE_ACCES MED_ACC_RDWR
00034 #elif DEF_LECT_AJOUT
00035 #define MODE_ACCES MED_ACC_RDEXT
00036 #else
00037 #define MODE_ACCES MED_ACC_CREAT
00038 #endif
00039 
00040 int main (int argc, char **argv)
00041 
00042 
00043 {
00044   med_err ret = 0;
00045   med_idt fid;
00046   /* la dimension du maillage */
00047   med_int mdim = 2;
00048   /* nom du maillage de longueur maxi MED_NAME_SIZE */
00049   char maa[MED_NAME_SIZE+1] = "maa1";
00050   /* le nombre de noeuds */
00051   med_int nnoe = 4;
00052   /* table des coordonnees
00053       (dimension * nombre de noeuds) */
00054   med_float coo[8] = {0.0, 1.0, 2.0, 3.0, 4.0, 5.0, 6.0, 7.0};
00055   med_float coo_2[8] = {0.0, 10.0, 20.0, 30.0, 40.0, 50.0, 60.0, 70.0};
00056   /* tables des noms et des unites des coordonnees
00057       (dimension*MED_SNAME_SIZE+1) */
00058   /*                                  12345678901234561234567890123456*/
00059   char nomcoo[2*MED_SNAME_SIZE+1] = "x               y               ";
00060   char unicoo[2*MED_SNAME_SIZE+1] = "cm              cm              ";
00061   /* tables des noms, numeros, numeros de familles des noeuds
00062      autant d'elements que de noeuds - les noms ont pout longueur
00063      MED_SNAME_SIZE */
00064   /*                                  1234567890123456123456789012345612345678901234561234567890123456*/
00065   char nomnoe[4*MED_SNAME_SIZE+1] = "nom1            nom2            nom3            nom4            ";
00066   med_int numnoe[4] = {1,2,3,4};
00067   med_int nufano[4] = {0,1,2,2};
00068   const med_float phi1=0;
00069   const med_float phi2=M_PI_4;
00070   const med_float phi3=M_PI_2;
00071   med_float       trsf1[7]= {0,0,0, cos(phi1/2), 0, sin(phi1/2), 0 };
00072   med_float       trsf2[7]= {0,0,0, cos(phi2/2), 0, sin(phi2/2), 0 };
00073   med_float       trsf3[7]= {0,0,0, cos(phi3/2), 0, sin(phi3/2), 0 };
00074 
00075   /* ouverture du fichier */
00076   if ((fid = MEDfileOpen("Test_MEDmeshNodeCoordinateTrsfWr.med",MODE_ACCES)) < 0){
00077     MESSAGE("Erreur à l'ouverture du fichier : ");
00078     return -1;
00079   }
00080 
00081   /* Creation du maillage "maa" de type MED_NON_STRUCURE
00082      et de dimension 2 */
00083   if (MEDmeshCr( fid, maa, mdim, mdim, MED_UNSTRUCTURED_MESH,
00084              "un maillage pour Test_MEDmeshNodeCoordinateTrsfWr","s", MED_SORT_DTIT,
00085                  MED_CARTESIAN, nomcoo, unicoo) < 0) {
00086     MESSAGE("Erreur a la creation du maillage : "); SSCRUTE(maa);
00087     ret = -1;
00088   }
00089 
00090   /* Ecriture des coordonnees des noeuds en mode MED_FULL_INTERLACE :
00091      (X1,Y1, X2,Y2, X3,Y3, ...) dans un repere cartesien */
00092   if (MEDmeshNodeCoordinateWr(fid,maa,MED_NO_DT,MED_NO_IT,MED_UNDEF_DT,
00093                               MED_FULL_INTERLACE,nnoe,  coo) < 0) {
00094     MESSAGE("Erreur a l'ecriture des coordonnees des noeuds");
00095     ret = -1;
00096   }
00097 
00098   /* Ecriture des noms des noeuds (optionnel dans un maillage MED) */
00099   if (MEDmeshEntityNameWr(fid,maa,MED_NO_DT,MED_NO_IT,MED_NODE,MED_NONE,nnoe,nomnoe) < 0) {
00100     MESSAGE("Erreur a l'ecriture des noms des noeuds");
00101     ret = -1;
00102   }
00103 
00104   /* Ecriture des numeros des noeuds (optionnel dans un maillage MED) */
00105   if (MEDmeshEntityNumberWr(fid,maa,MED_NO_DT,MED_NO_IT,MED_NODE,MED_NONE,nnoe,numnoe) < 0) {
00106     MESSAGE("Erreur a l'ecriture des numeros des noeuds");
00107     ret = -1;
00108   }
00109 
00110   /* Ecriture des numeros de famille des noeuds */
00111   if (MEDmeshEntityFamilyNumberWr(fid,maa,MED_NO_DT,MED_NO_IT,MED_NODE,MED_NONE,nnoe,nufano) < 0) {
00112     MESSAGE("Erreur a l'ecriture des numeros de familles des noeuds");
00113     ret = -1;
00114   }
00115 
00116   /* Transformation des coordonnees des noeuds coo_1 :
00117    */
00118   fprintf(stdout,"Un message d'erreur est attendu: \n");
00119   if ( MEDmeshNodeCoordinateTrsfWr(fid,maa,MED_NO_DT,MED_NO_IT,0.4,trsf1) >= 0) {
00120     MESSAGE("Erreur a l'ecriture de la transformation géométrique n°1");
00121     MESSAGE("Aucune transformation géométrique à la séquence de calcul MED_NO_DT,MED_NO_IT n'est possible.");
00122   }
00123   fprintf(stdout,"Fin du message d'erreur attendu\n :");
00124 
00125   /* Transformation des coordonnees des noeuds coo_1 :
00126    */
00127   if ( MEDmeshNodeCoordinateTrsfWr(fid,maa,1,1,0.4,trsf1) < 0) {
00128     MESSAGE("Erreur a l'ecriture de la transformation géométrique n°1");
00129     ret = -1;
00130   }
00131 
00132   /* Ecriture des coordonnees des noeuds en mode MED_FULL_INTERLACE :
00133      (X1,Y1, X2,Y2, X3,Y3, ...) dans un repere cartesien */
00134   fprintf(stdout,"Un message d'erreur est attendu : \n");
00135   if (MEDmeshNodeCoordinateWr(fid,maa,1,1, 0.5,
00136                               MED_FULL_INTERLACE,nnoe, coo_2) >= 0) {
00137     MESSAGE("Erreur a l'ecriture des coordonnees des noeuds");
00138     MESSAGE("Aucune ecriture des coordonnees des noeuds n'est possible sur une séquence de calcul comportant "\
00139             "une transformation géométrique.");
00140   }
00141   fprintf(stdout,"Fin du message d'erreur attendu :\n");
00142 
00143   /* Ecriture des coordonnees des noeuds en mode MED_FULL_INTERLACE :
00144      (X1,Y1, X2,Y2, X3,Y3, ...) dans un repere cartesien */
00145   if (MEDmeshNodeCoordinateWr(fid,maa,2,1, 0.5,
00146                               MED_FULL_INTERLACE,nnoe, coo_2) < 0) {
00147     MESSAGE("Erreur a l'ecriture des coordonnees des noeuds");
00148     ret = -1;
00149   }
00150 
00151   /* Transformation des coordonnees des noeuds coo_2 :
00152    */
00153   fprintf(stdout,"Un message d'erreur est attendu\n :");
00154   if ( MEDmeshNodeCoordinateTrsfWr(fid,maa,2,1,0.5,trsf2) >= 0) {
00155     MESSAGE("Erreur a l'ecriture de la transformation géométrique n°2");
00156     MESSAGE("Aucune transformation géométrique à une séquence de calcul comportant de nouvelles coordonnées n'est possible.");
00157   }
00158   fprintf(stdout,"Fin du message d'erreur attendu\n :");
00159 
00160   /* Transformation des coordonnees des noeuds coo_2 :
00161    */
00162   if ( MEDmeshNodeCoordinateTrsfWr(fid,maa,2,2,0.6,trsf2) < 0) {
00163     MESSAGE("Erreur a l'ecriture de la transformation géométrique n°2");
00164     ret = -1;
00165   }
00166 
00167   /* Transformation des coordonnees des noeuds coo_3 :
00168    */
00169   if ( MEDmeshNodeCoordinateTrsfWr(fid,maa,3,2,0.7,trsf3) < 0) {
00170     MESSAGE("Erreur a l'ecriture de la transformation géométrique n°3");
00171     ret = -1;
00172   }
00173 
00174   if ( MEDmeshComputationStepCr(fid,maa, 3,2, 3,3, 3.3) < 0) {
00175     MESSAGE("Erreur a la creation d'un pas de temps du maillage maa");
00176   }
00177 
00178  /* Modification des numeros des noeuds (optionnel dans un maillage MED) */
00179   numnoe[2]=200;
00180   if (MEDmeshEntityNumberWr(fid,maa,3,3,MED_NODE,MED_NONE,nnoe,numnoe) < 0) {
00181     MESSAGE("Erreur a l'ecriture des numeros des noeuds");
00182     ret = -1;
00183   }
00184 
00185   if ( MEDmeshComputationStepCr(fid,maa, 3,3, 3,4, 3.4) < 0) {
00186     MESSAGE("Erreur a la creation d'un pas de temps du maillage maa");
00187   }
00188 
00189   /*TODO : Ecrire un test de comparaison interne next prev et ordre de découverte itératif */
00190 
00191   /* Fermeture du fichier */
00192   if (MEDfileClose(fid) < 0) {
00193     MESSAGE("Erreur a la fermeture du fichier test4.med");
00194     return -1;
00195   }
00196   return ret;
00197 }
00198 
00199 
00200 
00201 

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