MED fichier
Unittest_MEDsupportMesh_3.f
Aller à la documentation de ce fichier.
1C* This file is part of MED.
2C*
3C* COPYRIGHT (C) 1999 - 2020 EDF R&D, CEA/DEN
4C* MED is free software: you can redistribute it and/or modify
5C* it under the terms of the GNU Lesser General Public License as published by
6C* the Free Software Foundation, either version 3 of the License, or
7C* (at your option) any later version.
8C*
9C* MED is distributed in the hope that it will be useful,
10C* but WITHOUT ANY WARRANTY; without even the implied warranty of
11C* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12C* GNU Lesser General Public License for more details.
13C*
14C* You should have received a copy of the GNU Lesser General Public License
15C* along with MED. If not, see <http://www.gnu.org/licenses/>.
16C*
17
18C******************************************************************************
19C * Tests for support mesh module
20C *
21C *****************************************************************************
23C
24 implicit none
25 include 'med.hf'
26C
27C
28 integer cret
29 integer*8 fid
30
31 character*64 fname
32 parameter(fname = "Unittest_MEDsupportMesh_1.med")
33 character*64 smname1
34 integer sdim1,mdim1
35 parameter(sdim1=2, mdim1=2)
36 integer sdim2,mdim2
37 parameter(sdim2=3,mdim2=2)
38 parameter(smname1 = "supportMesh1")
39 character*64 smname2
40 parameter(smname2 = "supportMesh2")
41 character*200 description1
42 parameter(description1="support mesh1 description")
43 character*200 description2
44 parameter(description2="support mesh2 description")
45 character*16 nomcoo2d(2)
46 character*16 unicoo2d(2)
47 data nomcoo2d /"x","y"/, unicoo2d /"cm","cm"/
48 character*16 nomcoo3d(3)
49 character*16 unicoo3d(3)
50 data nomcoo3d /"x","y","z"/, unicoo3d /"cm","cm","cm"/
51 integer atype1, atype2
52 parameter(atype1=med_cartesian, atype2=med_cartesian)
53 integer nsmesh, i
54 character*64 smname
55 character*16 aunit(3), aname(3)
56 character*200 description
57 integer sdim, mdim, atype
58C
59C
60C open file in read only access mode
61 call mfiope(fid,fname,med_acc_rdonly,cret)
62 print *,'Open file in RD_ONLY access mode',cret
63 if (cret .ne. 0 ) then
64 print *,'ERROR : open file in READ_ONLY access mode'
65 call efexit(-1)
66 endif
67C
68C How many mesh in the file ?
69C
70 call msmnsm(fid,nsmesh,cret)
71 print *,'Read number of support mesh : ',nsmesh
72 print *,cret
73 if (cret .ne. 0 ) then
74 print *,'ERROR : read number of support mesh'
75 call efexit(-1)
76 endif
77 if (nsmesh .ne. 2) then
78 print *,'ERROR : number of support mesh'
79 call efexit(-1)
80 endif
81C
82C
83C Read support mesh information and number of axis
84C by iterator
85 do i=1,nsmesh
86 call msmnax(fid,i,sdim,cret)
87 if (cret .ne. 0 ) then
88 print *,'ERROR : read number of axis '
89 call efexit(-1)
90 endif
91 print *,'Number of axis : ',sdim
92c
93 if (i .eq. 1) then
94 if (sdim .ne. sdim1) then
95 print *,'ERROR : support mesh information'
96 call efexit(-1)
97 endif
98 endif
99 if (i .eq. 2) then
100 if (sdim .ne. sdim2) then
101 print *,'ERROR : support mesh information'
102 call efexit(-1)
103 endif
104 endif
105C
106 call msmsmi(fid,i,smname,sdim,mdim,
107 & description,
108 & atype,aname,aunit,cret)
109 print *,'Support mesh information',cret
110 if (cret .ne. 0 ) then
111 print *,'ERROR : read support mesh information'
112 call efexit(-1)
113 endif
114c
115 if (i .eq. 1) then
116 if ((sdim .ne. sdim1) .or.
117 & (mdim .ne. mdim1) .or.
118 & (description .ne. description1) .or.
119 & (atype .ne. atype1) .or.
120 & (aunit(1) .ne. unicoo2d(1)) .or.
121 & (aunit(2) .ne. unicoo2d(2)) .or.
122 & (aname(1) .ne. nomcoo2d(1)) .or.
123 & (aname(2) .ne. nomcoo2d(2))
124 & ) then
125 print *,'ERROR : support mesh information by name'
126 call efexit(-1)
127 endif
128 endif
129c
130 if (i .eq. 2) then
131 if ((sdim .ne. sdim2) .or.
132 & (mdim .ne. mdim2) .or.
133 & (description .ne. description2) .or.
134 & (atype .ne. atype2) .or.
135 & (aunit(1) .ne. unicoo3d(1)) .or.
136 & (aunit(2) .ne. unicoo3d(2)) .or.
137 & (aunit(3) .ne. unicoo3d(3)) .or.
138 & (aname(1) .ne. nomcoo3d(1)) .or.
139 & (aname(2) .ne. nomcoo3d(2)) .or.
140 & (aname(3) .ne. nomcoo3d(3))
141 & ) then
142 print *,'ERROR : support mesh information by name'
143 call efexit(-1)
144 endif
145 endif
146c
147 enddo
148C
149C
150C close file
151 call mficlo(fid,cret)
152 print *,'Close file',cret
153 if (cret .ne. 0 ) then
154 print *,'ERROR : close file'
155 call efexit(-1)
156 endif
157C
158C
159C
160 end
161
program medsupportmesh3
subroutine mfiope(fid, name, access, cret)
Ouverture d'un fichier MED.
Definition medfile.f:42
subroutine mficlo(fid, cret)
Fermeture d'un fichier MED.
Definition medfile.f:82
subroutine msmsmi(fid, it, name, sdim, mdim, desc, atype, aname, aunit, cret)
Cette routine permet de lire les informations relatives à un maillage support dans un fichier.
Definition medsupport.f:84
subroutine msmnsm(fid, n, cret)
Cette routine permet de lire le nombre de maillages support dans un fichier.
Definition medsupport.f:40
subroutine msmnax(fid, it, naxis, cret)
Cette routine permet de lire dans un maillage support le nombre d'axes du repère des coordonnées des ...
Definition medsupport.f:103