MED fichier
Unittest_MEDsupportMesh_2.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 Read number of axis by name
69C
70 call msmnan(fid,smname1,sdim,cret)
71 print *,'Number of axis (by name) : ',sdim
72 if (cret .ne. 0 ) then
73 print *,'ERROR : read number of axis (by name)'
74 call efexit(-1)
75 endif
76 if (sdim .ne. sdim1) then
77 print *,'ERROR : number of axis (by name)'
78 call efexit(-1)
79 endif
80
81 call msmnan(fid,smname2,sdim,cret)
82 print *,'Number of axis (by name) : ',sdim
83 if (cret .ne. 0 ) then
84 print *,'ERROR : read number of axis (by name)'
85 call efexit(-1)
86 endif
87 if (sdim .ne. sdim2) then
88 print *,'ERROR : number of axis (by name)'
89 call efexit(-1)
90 endif
91C
92C Read support mesh information by name
93C
94 call msmsni(fid,smname1,sdim,mdim,
95 & description,atype,
96 & aname, aunit, cret)
97 print *,'Support mesh information by name',cret
98 if (cret .ne. 0 ) then
99 print *,'ERROR : read support mesh information by name'
100 call efexit(-1)
101 endif
102 if ((sdim .ne. sdim1) .or.
103 & (mdim .ne. mdim1) .or.
104 & (description .ne. description1) .or.
105 & (atype .ne. atype1) .or.
106 & (aunit(1) .ne. unicoo2d(1)) .or.
107 & (aunit(2) .ne. unicoo2d(2)) .or.
108 & (aname(1) .ne. nomcoo2d(1)) .or.
109 & (aname(2) .ne. nomcoo2d(2))
110 & ) then
111 print *,'ERROR : support mesh information by name'
112 call efexit(-1)
113 endif
114C
115C
116C
117 call msmsni(fid,smname2,sdim,mdim,
118 & description,atype,
119 & aname, aunit, cret)
120 print *,'Support mesh information by name',cret
121 if (cret .ne. 0 ) then
122 print *,'ERROR : read support mesh information by name'
123 call efexit(-1)
124 endif
125 if ((sdim .ne. sdim2) .or.
126 & (mdim .ne. mdim2) .or.
127 & (description .ne. description2) .or.
128 & (atype .ne. atype2) .or.
129 & (aunit(1) .ne. unicoo3d(1)) .or.
130 & (aunit(2) .ne. unicoo3d(2)) .or.
131 & (aunit(3) .ne. unicoo3d(3)) .or.
132 & (aname(1) .ne. nomcoo3d(1)) .or.
133 & (aname(2) .ne. nomcoo3d(2)) .or.
134 & (aname(3) .ne. nomcoo3d(3))
135 & ) then
136 print *,'ERROR : support mesh information by name'
137 call efexit(-1)
138 endif
139C
140C
141C close file
142 call mficlo(fid,cret)
143 print *,'Close file',cret
144 if (cret .ne. 0 ) then
145 print *,'ERROR : close file'
146 call efexit(-1)
147 endif
148C
149C
150C
151 end
152
program medsupportmesh2
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 msmnan(fid, name, 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:125
subroutine msmsni(fid, name, sdim, mdim, desc, atype, aname, aunit, cret)
Cette routine permet de lire les informations relatives à un maillage support en précisant son nom.
Definition medsupport.f:64