MED fichier
test22.c
Aller à la documentation de ce fichier.
1 /* This file is part of MED.
2  *
3  * COPYRIGHT (C) 1999 - 2023 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 
38 int 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 }
MED_ACC_RDONLY
Definition: med.h:122
MED_COMMENT_SIZE
#define MED_COMMENT_SIZE
Definition: med.h:81
MED_SNAME_SIZE
#define MED_SNAME_SIZE
Definition: med.h:84
med_idt
hid_t med_idt
Definition: med.h:333
MEDparameterValueRd
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.
Definition: MEDparameterValueRd.c:37
MESSAGE
#define MESSAGE(chaine)
Definition: med_utils.h:324
med_int
int med_int
Definition: med.h:344
med_field_type
med_field_type
Definition: med.h:167
ISCRUTE
#define ISCRUTE(entier)
Definition: med_utils.h:313
med_float
double med_float
Definition: med.h:338
IFORMAT
#define IFORMAT
Definition: med_utils.h:145
MED_NO_DT
#define MED_NO_DT
Definition: med.h:322
main
int main(int argc, char **argv)
Definition: test22.c:37
MEDfileClose
MEDC_EXPORT med_err MEDfileClose(med_idt fid)
Fermeture d'un fichier MED.
Definition: MEDfileClose.c:30
SSCRUTE
#define SSCRUTE(chaine)
Definition: med_utils.h:323
MED_FLOAT64
Definition: med.h:168
MED_NAME_SIZE
#define MED_NAME_SIZE
Definition: med.h:83
med_utils.h
MEDparameterComputationStepInfo
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...
Definition: MEDparameterComputationStepInfo.c:38
med.h
MED_NO_IT
#define MED_NO_IT
Definition: med.h:323
MEDparameterInfo
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.
Definition: MEDparameterInfo.c:37
MEDfileOpen
MEDC_EXPORT med_idt MEDfileOpen(const char *const filename, const med_access_mode accessmode)
Ouverture d'un fichier MED.
Definition: MEDfileOpen.c:42
MEDnParameter
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.
Definition: MEDnParameter.c:34