MED fichier
f/2.3.6/test23.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 : test23.f
20 C *
21 C * - Description : ecriture de mailles MED_POLYGONE dans un maillage MED
22 C *
23 C ******************************************************************************
24  program test23
25 C
26  implicit none
27  include 'med.hf'
28 C
29  integer*8 fid
30  integer cret, mdim
31  parameter(mdim = 3)
32  character*32 maa
33  integer ni, n
34  parameter(ni=4, n=3)
35  integer index(ni)
36  character*16 nom(n)
37  integer num(n),fam(n)
38  integer con(16)
39 C
40  data con / 1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16 /
41  data nom / "poly1", "poly2", "poly3"/
42  data num / 1,2,3 /, fam /0,-1,-2/
43  data index /1,6,12,17/
44  data maa /"maa1"/
45 
46 C ** Creation du fichier test23.med **
47  call efouvr(fid,'test23.med',med_lecture_ecriture, cret)
48  print *,cret
49  if (cret .ne. 0 ) then
50  print *,'Erreur creation du fichier'
51  call efexit(-1)
52  endif
53  print *,'Creation du fichier test23.med'
54 
55 C ** Creation du maillage **
56  call efmaac(fid,maa,mdim,med_non_structure,
57  & 'un maillage pour test23',cret)
58  print *,cret
59  if (cret .ne. 0 ) then
60  print *,'Erreur creation du maillage'
61  call efexit(-1)
62  endif
63  print *,'Creation du maillage'
64 
65 C ** Ecriture de la connectivite des mailles polygones **
66  call efpgce(fid,maa,index,ni,con,med_maille,med_nod,cret)
67  if (cret .ne. 0 ) then
68  print *,'Erreur ecriture des connectivite polygones'
69  call efexit(-1)
70  endif
71  print *,cret
72  print *,'Ecriture des connectivites des mailles de type
73  & MED_POLYGONE'
74 
75 C ** Ecriture des noms des mailles polygones **
76  call efnome(fid,maa,nom,n,med_maille,med_polygone,
77  & cret)
78  print *,cret
79  if (cret .ne. 0 ) then
80  print *,'Erreur ecriture des noms polygones'
81  call efexit(-1)
82  endif
83  print *,'Ecriture des noms des polygones'
84 
85 C ** Ecriture des numeros des mailles polygones **
86  call efnume(fid,maa,num,n,med_maille,med_polygone,
87  & cret)
88  if (cret .ne. 0 ) then
89  print *,'Erreur ecriture des numeros polygones'
90  call efexit(-1)
91  endif
92  print *,cret
93  print *,'Ecriture des numeros des polygones'
94 
95 C ** Ecriture des numeros des familles des segments **
96  call effame(fid,maa,fam,n,
97  & med_maille,med_polygone,cret)
98  if (cret .ne. 0 ) then
99  print *,'Erreur ecriture des numeros de famille polygones'
100  call efexit(-1)
101  endif
102  print *,cret
103  print *,'Ecriture des numeros de familles des polygones'
104 
105 C ** Fermeture du fichier **
106  call efferm (fid,cret)
107  print *,cret
108  if (cret .ne. 0 ) then
109  print *,'Erreur fermeture du fichier'
110  call efexit(-1)
111  endif
112  print *,'Fermeture du fichier'
113 C
114  end