MED fichier
f/2.3.6/test6.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 : test6.f
20 C *
21 C * - Description : exemples d'ecriture d'elements dans un maillage MED
22 C *
23 C ******************************************************************************
24  program test6
25 C
26  implicit none
27  include 'med.hf'
28 C
29 C
30  integer*8 fid
31  integer cret
32 
33  integer mdim,nse2,ntr3
34  parameter(nse2 = 5, ntr3 = 2, mdim = 2)
35  integer se2 (2*nse2)
36  character*16 nomse2(nse2)
37  integer numse2(nse2),nufase2(nse2)
38 
39  integer tr3 (3*ntr3)
40  character*16 nomtr3(ntr3)
41  integer numtr3(ntr3), nufatr3(ntr3)
42  character*32 maa
43 
44  data se2 / 1,2,1,3,2,4,3,4,2,3 /
45  data nomse2 /"se1","se2","se3","se4","se5" /
46  data numse2 / 1,2,3,4,5 /, nufase2 /-1,-1,0,-2,-3/
47  data tr3 /1,2,-5,-5,3,-4 /, nomtr3 /"tr1","tr2"/,
48  & numtr3 /4,5/
49  data nufatr3 /0,-1/, maa /"maa1"/
50 
51 C ** Ouverture du fichier **
52  call efouvr(fid,'test6.med',med_lecture_ecriture, cret)
53  print *,cret
54  if (cret .ne. 0 ) then
55  print *,'Erreur creation du fichier'
56  call efexit(-1)
57  endif
58 
59 C ** Creation du maillage maa de dimension 2 **
60  call efmaac(fid,maa,mdim,med_non_structure,
61  & 'un maillage pour test6',cret)
62  print *,cret
63  if (cret .ne. 0 ) then
64  print *,'Erreur creation du maillage'
65  call efexit(-1)
66  endif
67 
68 C ** Ecriture des connectivites des segments **
69  call efcone(fid,maa,mdim,se2,med_no_interlace,
70  & nse2,med_arete,
71  & med_seg2,med_desc,cret )
72  print *,cret
73  if (cret .ne. 0 ) then
74  print *,'Erreur ecriture de la connectivite'
75  call efexit(-1)
76  endif
77 
78 C ** Ecriture (optionnelle) des noms des segments **
79  call efnome(fid,maa,nomse2,nse2,med_arete,
80  & med_seg2 ,cret)
81  print *,cret
82  if (cret .ne. 0 ) then
83  print *,'Erreur ecriture des noms'
84  call efexit(-1)
85  endif
86 
87 C ** Ecriture (optionnelle) des numeros des segments **
88  call efnume(fid,maa,numse2,nse2,
89  & med_arete ,med_seg2,cret)
90  print *,cret
91  if (cret .ne. 0 ) then
92  print *,'Erreur ecriture des numeros'
93  call efexit(-1)
94  endif
95 
96 C ** Ecriture des numeros des familles des segments **
97  call effame(fid,maa,nufase2,nse2,
98  & med_arete,med_seg2,cret)
99  print *,cret
100  if (cret .ne. 0 ) then
101  print *,'Erreur ecriture des numéros de famille'
102  call efexit(-1)
103  endif
104 
105 C ** Ecriture des connectivites des triangles **
106  call efcone(fid,maa,mdim,tr3,med_no_interlace,
107  & ntr3,med_maille,
108  & med_tria3,med_desc,cret )
109  print *,cret
110  if (cret .ne. 0 ) then
111  print *,'Erreur ecriture de la connectivite'
112  call efexit(-1)
113  endif
114 
115 C ** Ecriture (optionnelle) des noms des triangles **
116  call efnome(fid,maa,nomtr3,ntr3,med_maille,
117  & med_tria3,cret)
118  print *,cret
119  if (cret .ne. 0 ) then
120  print *,'Erreur ecriture des noms'
121  call efexit(-1)
122  endif
123 
124 C ** Ecriture (optionnelle) des numeros des triangles **
125  call efnume(fid,maa,numtr3,ntr3,med_maille,
126  & med_tria3,cret)
127  print *,cret
128  if (cret .ne. 0 ) then
129  print *,'Erreur ecriture des numeros'
130  call efexit(-1)
131  endif
132 
133 C ** Ecriture des numeros des familles des triangles **
134  call effame(fid,maa,nufatr3,ntr3,med_maille,
135  & med_tria3,cret)
136  print *,cret
137  if (cret .ne. 0 ) then
138  print *,'Erreur ecriture des numeros de famille'
139  call efexit(-1)
140  endif
141 
142 C ** Fermeture du fichier **
143  call efferm (fid,cret)
144  print *,cret
145  if (cret .ne. 0 ) then
146  print *,'Erreur a la fermeture du fichier'
147  call efexit(-1)
148  endif
149 C
150  end