MED fichier
f/2.3.6/test4.f
1 C* This file is part of MED.
2 C*
3 C* COPYRIGHT (C) 1999 - 2019 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 : test4.f
20 C *
21 C * - Description : ecriture des noeuds d'un maillage MED.
22 C *
23 C *****************************************************************************
24  program test4
25 C
26  implicit none
27  include 'med.hf'
28 C
29 C
30  integer*8 fid
31  integer cret
32 
33 C ** la dimension du maillage **
34  integer mdim
35 C ** nom du maillage de longueur maxi MED_TAILLE_NOM **
36  character*32 maa
37 C ** le nombre de noeuds **
38  integer nnoe
39 C ** table des coordonnees **
40 C profil : (dimension * nombre de noeuds) ici 8 **
41  real*8 coo(8)
42 C ** tables des noms et des unites des coordonnees **
43 C profil : (dimension) **
44  character*16 nomcoo(2)
45  character*16 unicoo(2)
46 C ** tables des noms, numeros, numeros de familles des noeuds **
47 C autant d'elements que de noeuds - les noms ont pout longueur **
48 C MED_TAILLE_PNOM **
49  character*16 nomnoe(4)
50  integer numnoe(4)
51  integer nufano(4)
52 
53  parameter( mdim = 2, maa = "maa1",nnoe = 4 )
54  data coo /0.0, 1.0, 2.0, 3.0, 4.0, 5.0, 6.0, 7.0/
55  data nomcoo /"x","y"/, unicoo /"cm","cm"/
56  data nomnoe /"nom1","nom2","nom3","nom4"/
57  data numnoe /1,2,3,4/, nufano /0,1,2,2/
58 
59 C ** Creation du fichier test4.med **
60  call efouvr(fid,'test4.med',med_lecture_ecriture, cret)
61  print *,cret
62  if (cret .ne. 0 ) then
63  print *,'Erreur creation du fichier'
64  call efexit(-1)
65  endif
66 
67 C ** Creation du maillage maa de dimension 2 **
68 C ** et de type MED_NON_STRUCTURE **
69  call efmaac(fid,maa,mdim,med_non_structure,
70  & 'un maillage pour test4',cret)
71  print *,cret
72  if (cret .ne. 0 ) then
73  print *,'Erreur creation du maillage'
74  call efexit(-1)
75  endif
76 
77 C ** Ecriture des coordonnees en mode MED_FULL_INTERLACE : **
78 C ** (X1,Y1, X2,Y2, X3,Y3, ...) dans un repere cartesien **
79  call efcooe(fid,maa,mdim,coo,med_full_interlace,
80  & nnoe,med_cart,nomcoo,unicoo,cret)
81  print *,cret
82  if (cret .ne. 0 ) then
83  print *,'Erreur ecriture des coordonnees des noeuds'
84  call efexit(-1)
85  endif
86 
87 C ** Ecriture des noms des noeuds (optionnel dans un maillage MED) **
88  call efnome(fid,maa,nomnoe,nnoe,med_noeud,0,cret)
89  print *,cret
90  if (cret .ne. 0 ) then
91  print *,'Erreur ecriture des noms des noeuds'
92  call efexit(-1)
93  endif
94 
95 C ** Ecriture des numeros des noeuds (optionnel dans un maillage MED) **
96  call efnume(fid,maa,numnoe,nnoe,med_noeud,0,cret)
97  print *,cret
98  if (cret .ne. 0 ) then
99  print *,'Erreur ecriture des numeros des noeuds'
100  call efexit(-1)
101  endif
102 
103 
104 C ** Ecriture des numeros de familles des noeuds **
105  call effame(fid,maa,nufano,nnoe,med_noeud,0,cret)
106  print *,cret
107  if (cret .ne. 0 ) then
108  print *,'Erreur ecriture des numeros de famille'
109  call efexit(-1)
110  endif
111 
112 C ** Fermeture du fichier **
113  call efferm (fid,cret)
114  print *,cret
115  if (cret .ne. 0 ) then
116  print *,'Erreur fermeture du fichier'
117  call efexit(-1)
118  endif
119 
120  end
121 
122 
123 
124 
test4
program test4
Definition: test4.f:24