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