MED fichier
test20.f
Aller à la documentation de ce fichier.
1 C* This file is part of MED.
2 C*
3 C* COPYRIGHT (C) 1999 - 2016 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 : test20.f
20 C *
21 C * - Description : montage/demontage de fichiers MED.
22 C *
23 C ******************************************************************************
24  program test20
25 C
26  implicit none
27  include 'med.hf'
28 C
29 C
30  integer cret, fid, ncha, nmaa, mid, mid2
31  integer i, ncomp, type
32  character*16 comp(3), unit(3), dtunit
33  character*64 nomcha,nommaa
34  integer lmesh, ncst
35 C
36 C ** Ouverture du fichier test2.med en mode lecture ajout
37  call mfiope(fid,'test2.med',med_acc_rdext, cret)
38  print *,cret
39  if (cret .ne. 0 ) then
40  print *,'Erreur ouverture du fichier'
41  call efexit(-1)
42  endif
43  print *,'On ouvre le fichier test2.med'
44 C
45 C ** Lecture du nombre de champ
46  call mfdnfd(fid,ncha,cret)
47  print *,cret
48  if (cret .ne. 0 ) then
49  print *,'Erreur lecture du nombre de champ'
50  call efexit(-1)
51  endif
52  print *,'Nombre de champs dans test2.med : ',ncha
53 C
54 C ** Montage du fichier test10.med (acces aux champs et maillages)
55  call mfiomn(fid, 'test10.med', med_field, mid, cret)
56  print *,cret
57  if (cret .ne. 0 ) then
58  print *,'Erreur montage du fichier'
59  call efexit(-1)
60  endif
61  print *,'On monte les champs du fichier test10.med'
62 C
63 C ** Lecture du nombre de champ apres montage
64  call mfdnfd(fid,ncha,cret)
65  print *,cret
66  if (cret .ne. 0 ) then
67  print *,'Erreur lecture du nombre de champ'
68  call efexit(-1)
69  endif
70  print *,'Nombre de champs dans test2.med apres montage : ',ncha
71 C
72 C ** Acces a tous les champs de test10.med a travers le point de
73 C ** montage
74 C
75  do 10 i = 1,ncha
76 C
77 C ** Lecture du nombre de composante dans le champ
78  call mfdnfc(fid,i,ncomp,cret)
79  print *,cret
80  if (cret .ne. 0 ) then
81  print *,'Erreur lecture du nombre de composante'
82  call efexit(-1)
83  endif
84 C
85  10 continue
86 C
87 C
88 C ** Demontage de test10.med
89  call mfioun(fid, mid, med_field, cret)
90  print *,cret
91  if (cret .ne. 0 ) then
92  print *,'Erreur demontage du fichier'
93  call efexit(-1)
94  endif
95  print *,'On demonte le fichier test10.med'
96 C
97 C ** Lecture du nombre de champ apres demontage
98  call mfdnfd(fid,ncha,cret)
99  print *,cret
100  if (cret .ne. 0 ) then
101  print *,'Erreur lecture du nombre de champ'
102  call efexit(-1)
103  endif
104  print *,'Nombre de champs apres demontage : ',ncha
105 C
106 C ** Fermeture du fichier
107  call mficlo(fid,cret)
108  print *, cret
109  if (cret .ne. 0 ) then
110  print *,'Erreur fermeture du fichier'
111  call efexit(-1)
112  endif
113  print *,'On ferme le fichier test2.med'
114 C
115 C ** Creation du fichier test20.med
116  call mfiope(fid,'test20.med',med_acc_rdwr,cret)
117  print *,cret
118  if (cret .ne. 0 ) then
119  print *,'Erreur creation du fichier'
120  call efexit(-1)
121  endif
122  print *,'Creation du fichier test20.med'
123 C
124 C ** Montage du fichier test2.med (acces aux maillages)
125  call mfiomn(fid, 'test2.med', med_mesh, mid, cret)
126  print *,cret
127  if (cret .ne. 0 ) then
128  print *,'Erreur montage du fichier'
129  call efexit(-1)
130  endif
131  print *,'On monte le fichier test2.med'
132 C
133 C ** Lecture du nombre de maillage apres montage
134  call mmhnmh(fid,nmaa,cret)
135  print *,cret
136  if (cret .ne. 0 ) then
137  print *,'Erreur lecture du nombre de maillage'
138  call efexit(-1)
139  endif
140  print *,'Nombre de maillage apres montage : ', nmaa
141 C
142 C ** Montage du fichier test10.med (acces aux champs)
143  call mfiomn(fid, 'test10.med', med_field, mid2, cret)
144  print *,cret
145  if (cret .ne. 0 ) then
146  print *,'Erreur montage du fichier'
147  call efexit(-1)
148  endif
149  print *,'On monte le fichier test10.med'
150 C
151 C ** Lecture du nombre de champs apres montage
152  call mfdnfd(fid,ncha,cret)
153  print *,cret
154  if (cret .ne. 0 ) then
155  print *,'Erreur lecture du nombre de champ'
156  call efexit(-1)
157  endif
158  print *,'Nombre de champ apres montage : ',ncha
159 C
160 C ** Demontage de test10.med
161  call mfioun(fid, mid2,med_field,cret)
162  print *,cret
163  if (cret .ne. 0 ) then
164  print *,'Erreur demontage du fichier'
165  call efexit(-1)
166  endif
167  print *,'On demonte test10.med'
168 C
169 C ** Demontage de test2.med
170  call mfioun(fid, mid,med_mesh,cret)
171  print *,cret
172  if (cret .ne. 0 ) then
173  print *,'Erreur demontage du fichier'
174  call efexit(-1)
175  endif
176  print *,'On demonte test2.med'
177 C
178 C ** Fermeture du fichier
179  call mficlo(fid,cret)
180  print *,cret
181  if (cret .ne. 0 ) then
182  print *,'Erreur fermeture du fichier'
183  call efexit(-1)
184  endif
185  print *,'Fermeture du fichier test20.med'
186 C
187  end
188 C
subroutine mficlo(fid, cret)
Fermeture d'un fichier MED.
Definition: medfile.f:80
subroutine mmhnmh(fid, n, cret)
Cette routine permet de lire le nombre de maillages dans un fichier.
Definition: medmesh.f:40
program test20
Definition: test20.f:24
subroutine mfiomn(fid, fname, class, mid, cret)
Cette routine permet de monter dans le fichier courant un type de données (exemples les maillages...
Definition: medfile.f:180
subroutine mfdnfc(fid, ind, n, cret)
Cette fonction lit le nombre de composantes d'un champ.
Definition: medfield.f:194
subroutine mfioun(fid, mid, class, cret)
Une fois le démontage effectué, les données précédemment montées ne sont plus accessibles.
Definition: medfile.f:203
subroutine mfdnfd(fid, n, cret)
Cette fonction permet de lire le nombre de champs dans un fichier.
Definition: medfield.f:173
subroutine mfiope(fid, name, access, cret)
Ouverture d'un fichier MED.
Definition: medfile.f:41