MED fichier
f/test21.f
1 C* This file is part of MED.
2 C*
3 C* COPYRIGHT (C) 1999 - 2023 EDF R&D, CEA/DEN
4 C* MED is free software: you can redistribute it and/or modify
5 C* it under the terms of the GNU Lesser General Public License as published by
6 C* the Free Software Foundation, either version 3 of the License, or
7 C* (at your option) any later version.
8 C*
9 C* MED is distributed in the hope that it will be useful,
10 C* but WITHOUT ANY WARRANTY; without even the implied warranty of
11 C* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 C* GNU Lesser General Public License for more details.
13 C*
14 C* You should have received a copy of the GNU Lesser General Public License
15 C* along with MED. If not, see <http://www.gnu.org/licenses/>.
16 C*
17 
18 C******************************************************************************
19 C* - Nom du fichier : test21.f
20 C*
21 C* - Description : ecriture de valeurs scalaires numeriques dans un fichier MED
22 C*
23 C ******************************************************************************
24  program test21
25 C
26  implicit none
27  include 'med.hf'
28 C
29  integer*8 fid
30  integer cret
31  character*16 edtuni,dtunit1
32  character*64 nom1, nom2
33  character*200 desc1, desc2
34  integer vali1, vali2
35  real*8 valr1,dt
36 C
37  parameter(nom1="VariableEntiere")
38  parameter(nom2="VariableFlottante")
39  data desc1 / "Une premiere description" /
40  data desc2 / "Une seconde description" /
41  parameter(vali1 = 56,vali2 = -789)
42  parameter(valr1 = 67.98d0)
43 
44  parameter(edtuni=" "
45  1 ,dtunit1="ms")
46 C
47 C
48 C Creation du fichier test21.med
49 C
50  call mfiope(fid,'test21.med',med_acc_rdwr, cret)
51  print *,cret
52  if (cret .ne. 0 ) then
53  print *,'Erreur creation du fichier'
54  call efexit(-1)
55  endif
56  print *,'Creation du fichier test21.med'
57 C
58 C Creation d'une variable scalaire entiere
59 C
60  call mprcre(fid,nom1,med_int,desc1,dtunit1,
61  & cret)
62  print *,cret
63  if (cret .ne. 0 ) then
64  print *,'Erreur creation variable scalaire'
65  call efexit(-1)
66  endif
67  print *,'Creation d une variable scalaire entiere'
68 C
69 C Ecriture d'une valeur sans pas de temps ni numero d'ordre
70 C
71  call mprivw(fid,nom1,med_no_dt,med_no_it,med_undef_dt,
72  & vali1,cret)
73  print *,cret
74  if (cret .ne. 0 ) then
75  print *,'Erreur ecriture valeur scalaire'
76  call efexit(-1)
77  endif
78  print *,'Ecriture valeur entiere sans pas de temps'
79 C
80 C Ecriture d'une valeur avec pas de temps et sans numero d'ordre
81 C
82  dt = 5.5d0
83  call mprivw(fid,nom1,1,med_no_it,dt,vali2,cret)
84  print *,cret
85  if (cret .ne. 0 ) then
86  print *,'Erreur ecriture valeur scalaire'
87  call efexit(-1)
88  endif
89  print *,'Ecriture valeur entiere avec pas de temps'
90 C
91 C Creation d'une variable scalaire flottante
92 C
93  call mprcre(fid,nom2,med_float64,desc2,dtunit1,
94  & cret)
95  print *,cret
96  if (cret .ne. 0 ) then
97  print *,'Erreur creation variable sclaire'
98  call efexit(-1)
99  endif
100  print *,'Creation d une variable scalaire flottante'
101 C
102 C Ecriture d'une valeur flottante avec pas de temps et numero d'ordre
103 C
104  call mprrvw(fid,nom2,1,2,dt,valr1,cret)
105  print *,cret
106  if (cret .ne. 0 ) then
107  print *,'Erreur ecriture valeur scalaire'
108  call efexit(-1)
109  endif
110  print *,'Ecriture valeur entiere avec pas de temps'
111 C
112 C Fermeture du fichier
113 C
114  call mficlo(fid,cret)
115  if (cret .ne. 0 ) then
116  print *,'Erreur fermeture du fichier'
117  call efexit(-1)
118  endif
119  print *,cret
120  print *,'Fermeture du fichier test21.med'
121 C
122  end
123 C
test21
program test21
Definition: test21.f:24
med_int
int med_int
Definition: med.h:344
mprivw
subroutine mprivw(fid, name, numdt, numit, dt, val, cret)
Cette routine permet l'écriture de la valeur d'un paramètre numérique scalaire.
Definition: medparameter.f:56
mficlo
subroutine mficlo(fid, cret)
Fermeture d'un fichier MED.
Definition: medfile.f:82
mprcre
subroutine mprcre(fid, name, type, des, dtunit, cret)
Cette routine permet la création d'un paramètre numérique scalaire.
Definition: medparameter.f:19
med_float64
double med_float64
Definition: med.h:339
mprrvw
subroutine mprrvw(fid, name, numdt, numit, dt, val, cret)
Cette routine permet l'écriture de la valeur d'un paramètre numérique scalaire.
Definition: medparameter.f:38
mfiope
subroutine mfiope(fid, name, access, cret)
Ouverture d'un fichier MED.
Definition: medfile.f:42