MED fichier
test22.c
Aller à la documentation de ce fichier.
1/* This file is part of MED.
2 *
3 * COPYRIGHT (C) 1999 - 2020 EDF R&D, CEA/DEN
4 * MED is free software: you can redistribute it and/or modify
5 * it under the terms of the GNU Lesser General Public License as published by
6 * the Free Software Foundation, either version 3 of the License, or
7 * (at your option) any later version.
8 *
9 * MED is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU Lesser General Public License for more details.
13 *
14 * You should have received a copy of the GNU Lesser General Public License
15 * along with MED. If not, see <http://www.gnu.org/licenses/>.
16 */
17
18
19/******************************************************************************
20 * - Nom du fichier : test22.c
21 *
22 * - Description : lecture de valeurs scalaires numeriques crees dans test21.
23 *
24 *****************************************************************************/
25
26#include <med.h>
27#define MESGERR 1
28#include <med_utils.h>
29
30#ifdef DEF_LECT_ECR
31#define MODE_ACCES MED_ACC_RDWR
32#elif DEF_LECT_AJOUT
33#define MODE_ACCES MED_ACC_RDEXT
34#else
35#define MODE_ACCES MED_ACC_CREAT
36#endif
37
38int main (int argc, char **argv)
39
40
41{
42 med_idt fid;
43 char nom_scalaire[MED_NAME_SIZE+1];
44 char description[MED_COMMENT_SIZE+1];
45 med_int vali;
46 med_float valr;
47 med_int i,n,npdt,j;
48 med_field_type type;
49 med_int numdt,numo;
50 med_float dt;
51 char dt_unit[MED_SNAME_SIZE+1];
52
53 /* Ouverture du fichier test21.med en lecture seule */
54 if ((fid = MEDfileOpen("test21.med",MED_ACC_RDONLY)) < 0) {
55 MESSAGE("Erreur a l'ouverture du fichier test21.med");
56 return -1;
57 }
58
59 /* Lecture du nombre de variable scalaire */
60 n = MEDnParameter(fid);
61 if (n < 0) {
62 MESSAGE("Erreur a la lecture du nombre de variable scalaire");
63 return -1;
64 }
65 printf("Nombre de variables scalaires dans test21.med = "IFORMAT"\n",n);
66
67 /* Lecture des infos sur les variables (type,description) */
68 for (i=1;i<=n;i++) {
69
70 if (MEDparameterInfo(fid, i, nom_scalaire, &type, description, dt_unit, &npdt) < 0) {
71 MESSAGE("Erreur a la lecture des infos sur la variable d'indice : ");
72 ISCRUTE(i);
73 return -1;
74 }
75 printf("- Scalaire n°"IFORMAT" de nom %s \n",i,nom_scalaire);
76 if (type == MED_FLOAT64)
77 printf(" Type flottant. \n");
78 else
79 printf(" Type entier. \n");
80 printf(" Description associee : [%s] \n",description);
81 printf(" Nombre de pas de temps : "IFORMAT" \n",npdt);
82
83 for (j=1;j<=npdt;j++) {
84
85 if (MEDparameterComputationStepInfo(fid,nom_scalaire,j,&numdt,&numo,&dt) < 0) {
86 MESSAGE("Erreur a la lecture des informations sur le pas de temps d'indice :");
87 ISCRUTE(j);
88 return -1;
89 }
90
91 printf(" Valeur n°"IFORMAT" : \n",j);
92 if (numdt == MED_NO_DT)
93 printf(" - Aucun de pas de temps \n");
94 else
95 printf(" - Pas de de temps de numero "IFORMAT" de valeur %f [%s] \n",numdt,dt,dt_unit);
96 if (numo == MED_NO_IT)
97 printf(" - Aucun numero d'ordre \n");
98 else
99 printf(" - Numero d'ordre : "IFORMAT" \n",numo);
100
101 /* Lecture de la valeur flottante associee au pas de temps */
102 if (type == MED_FLOAT64) {
103 if (MEDparameterValueRd(fid,nom_scalaire,numdt,numo,(unsigned char *) &valr) < 0) {
104 MESSAGE("Erreur a la lecture de la valeur flottante : ");
105 SSCRUTE(nom_scalaire); ISCRUTE(numdt);ISCRUTE(numo);
106 return -1;
107 }
108 printf(" - Valeur : %f \n",valr);
109 } else {
110 /* Lecture de la valeur scalaire associee au pas de temps */
111 if (MEDparameterValueRd(fid,nom_scalaire,numdt,numo,(unsigned char *) &vali) < 0) {
112 MESSAGE("Erreur a la lecture de la valeur entiere : ");
113 SSCRUTE(nom_scalaire); ISCRUTE(numdt);ISCRUTE(numo);
114 return -1;
115 }
116 printf(" - Valeur : "IFORMAT" \n",vali);
117 }
118 }
119
120 }
121
122 /* Fermeture du fichier */
123 if (MEDfileClose(fid) < 0) {
124 MESSAGE("Erreur a la fermeture du fichier ");
125 return -1;
126 }
127
128 return 0;
129}
#define MED_NAME_SIZE
#define MED_SNAME_SIZE
#define MED_COMMENT_SIZE
#define SSCRUTE(chaine)
#define MESSAGE(chaine)
#define ISCRUTE(entier)
MEDC_EXPORT med_err MEDfileClose(med_idt fid)
Fermeture d'un fichier MED.
MEDC_EXPORT med_idt MEDfileOpen(const char *const filename, const med_access_mode accessmode)
Ouverture d'un fichier MED.
Definition MEDfileOpen.c:42
MEDC_EXPORT med_err MEDparameterComputationStepInfo(const med_idt fid, const char *const paramname, const int csit, med_int *const numdt, med_int *const numit, med_float *const dt)
Cette routine permet la lecture des informations relatives à une étape de calcul du paramètre numériq...
MEDC_EXPORT med_int MEDnParameter(const med_idt fid)
Cette routine permet la lecture du nombre de paramètre numérique scalaire dans un fichier.
MEDC_EXPORT med_err MEDparameterInfo(const med_idt fid, const int paramit, char *const paramname, med_parameter_type *const paramtype, char *const description, char *const dtunit, med_int *const nstep)
Cette routine permet la lecture des informations relatives à un paramètre scalaire via un itérateur.
MEDC_EXPORT med_err MEDparameterValueRd(const med_idt fid, const char *const paramname, const med_int numdt, const med_int numit, unsigned char *const value)
Cette routine permet la lecture de la valeur d'un paramètre numérique scalaire.
int main(int argc, char **argv)
Definition test22.c:38