1 # Python script for testing T5.10 task
2 # ###########################################
4 #% Test structured mesh (GRID) reading from file test19.med
5 #% test19.med can be obtained by running test19_c.out executable
6 # or locally in MEDMEM directory create_grid
8 from libMEDMEM_Swig import *
12 #befor running this script, please be sure about the path the file fileName
14 filePath=os.environ["MED_ROOT_DIR"]
15 filePath=filePath+"/share/salome/resources/"
17 medFile = filePath + "test19.med"
18 print "Read file", medFile
22 mdDriver = MED_MED_RDONLY_DRIVER(medFile,md)
25 mdDriver.readFileStruct()
28 nbMeshes = md.getNumberOfMeshes()
29 print "Nb meshes:", nbMeshes
31 raise RuntimeError, "Can't read med file"
33 ##############################
35 ##############################
37 mesh_name = md.getMeshName(0)
38 mesh = md.getMesh(mesh_name)
39 print "Read", mesh_name
42 if mesh.getIsAGrid() == 0:
43 raise RuntimeError, "Mesh 0 is not a grid"
45 grid = createGridFromMesh(mesh)
47 I = grid.getArrayLength(1)
48 print "_iArrayLength", I
50 raise RuntimeError, "Error in grid.getArrayLength(1)"
52 J = grid.getArrayLength(2)
53 print "_jArrayLength", J
55 raise RuntimeError, "Error in grid.getArrayLength(2)"
57 K = grid.getArrayLength(3)
58 print "_kArrayLength", K
60 raise RuntimeError, "Error in grid.getArrayLength(3)"
62 grid_type = grid.getGridType()
63 print "grid_type =", grid_type
64 if grid_type != MED_GRILLE_CARTESIENNE:
65 raise RuntimeError, "Wrong grid type"
67 spaceDim = grid.getSpaceDimension()
68 print "spaceDim =", spaceDim
70 raise RuntimeError, "Wrong space dimention"
72 meshDim = grid.getMeshDimension()
73 print "meshDim =", meshDim
74 if spaceDim != meshDim:
75 raise RuntimeError, "Wrong mesh dimention"
77 nbNodes = grid.getNumberOfNodes()
78 print "nbNodes =", nbNodes
80 raise RuntimeError, "Wrong nb of nodes"
82 coordSyst = grid.getCoordinatesSystem()
83 print "coordSyst =", coordSyst
84 if coordSyst != "CARTESIAN":
85 raise RuntimeError, "Wrong coordinates system"
87 coordinates = grid.getCoordinates(MED_FULL_INTERLACE)
88 print "coordinates =", coordinates
89 xy = [ grid.getArrayValue(1, I-1 ) , grid.getArrayValue(2, J-1 ) ]
90 xy2 = coordinates[(nbNodes-1)*spaceDim:(nbNodes*spaceDim)]
92 raise RuntimeError, "Error in grid.getCoordinates(MED_FULL_INTERLACE)"
94 nbTypesCell = grid.getNumberOfTypes(MED_CELL)
95 print "nbTypesCell =", nbTypesCell
97 raise RuntimeError, "Wrong nbTypesCell"
99 types = grid.getTypes(MED_CELL)
100 print "Cell types =", types
102 raise RuntimeError, "Wrong Cell types"
104 nbElemType = grid.getNumberOfElements(MED_CELL,types[0])
105 print "Nb cells =", nbElemType
107 raise RuntimeError, "Wrong Nb cells"
109 print "getEntityPosition : convert node number to i,j,k"
111 n1 = grid.getEntityPosition(MED_NODE,10)
112 n2 = grid.getEntityPosition(MED_NODE,16)
114 if n1 == [1,2]: o1 = "Ok"
116 if n2 == [3,3]: o2 = "Ok"
119 print "Node 10 -> i,j = ", n1, " : ", o1
120 print "Node 16 -> i,j = ", n2, " : ", o2
122 print "getEntityPosition : convert cell number to i,j,k"
124 n1 = grid.getEntityPosition(MED_CELL,3)
125 n2 = grid.getEntityPosition(MED_CELL,4)
127 if n1 == [2,0]: o1 = "Ok"
129 if n2 == [0,1]: o2 = "Ok"
132 print "Cell 3 -> i,j = ", n1, " : ", o1
133 print "Cell 4 -> i,j = ", n2, " : ", o2
135 print "getEntityPosition : convert face number to i,j,k"
137 n1 = grid.getEntityPosition(MED_FACE,6)
138 n2 = grid.getEntityPosition(MED_FACE,8)
140 if n1 == [1,2,1]: o1 = "Ok"
142 if n2 == [1,1,2]: o2 = "Ok"
145 print "Face 6 -> i,j = ", n1, " : ", o1
146 print "Face 8 -> i,j = ", n2, " : ", o2
148 print "getNodeNumber : convert i,j,k to node number"
150 n1 = grid.getNodeNumber(2,1,0)
151 n2 = grid.getNodeNumber(1,2,0)
153 if n1 == 7: o1 = "Ok"
155 if n2 == 10: o2 = "Ok"
158 print "getNodeNumber 2,1,0 = ", n1, " : ", o1
159 print "getNodeNumber 1,2,0 = ", n2, " : ", o2
161 print "getCellNumber : convert i,j,k to cell number"
163 n1 = grid.getCellNumber(1,0,0)
164 n2 = grid.getCellNumber(2,1,0)
166 if n1 == 2: o1 = "Ok"
168 if n2 == 6: o2 = "Ok"
171 print "getCellNumber 1,0,0 = ", n1, " : ", o1
172 print "getCellNumber 2,1,0 = ", n2, " : ", o2
174 print "getFaceNumber : convert i,j,k to face number"
176 n1 = grid.getFaceNumber(0,0,2,0)
177 n2 = grid.getFaceNumber(0,1,1,0)
179 if n1 == 7: o1 = "Ok"
181 if n2 == 5: o2 = "Ok"
184 print "getFaceNumber 1,0,2,0 = ", n1, " : ", o1
185 print "getFaceNumber 1,1,1,0 = ", n2, " : ", o2
188 n1 = grid.getNodeNumber(0,0,0)
189 n2 = grid.getNodeNumber(1,0,0)
190 n3 = grid.getNodeNumber(1,1,0)
191 n4 = grid.getNodeNumber(0,1,0)
193 conn1 = [n1,n2,n3,n4]
195 Connectivity = grid.getConnectivity(MED_FULL_INTERLACE,MED_NODAL,MED_CELL,types[0])
196 print "connectivity =", Connectivity
198 print "Cell 1 nodes:", conn1, Connectivity[0:4]
199 if conn1 != Connectivity[0:4]:
200 raise RuntimeError, "Wrong nodal connectivity"
203 ReverseConnectivity = grid.getReverseConnectivity(MED_NODAL)
204 ReverseConnectivityIndex = grid.getReverseConnectivityIndex(MED_NODAL)
206 beg = ReverseConnectivityIndex[n-1]-1
207 end = ReverseConnectivityIndex[n]-1
208 print "Node",n,"rev connectivity =",ReverseConnectivity[beg:end]
210 raise RuntimeError, "Wrong reverse connectivity"
211 if ReverseConnectivity[beg] != 1:
212 raise RuntimeError, "Wrong reverse connectivity"
215 grid.calculateConnectivity(MED_FULL_INTERLACE,MED_DESCENDING,MED_CELL)
216 Connectivity = grid.getConnectivity(MED_FULL_INTERLACE,MED_DESCENDING,MED_CELL,MED_ALL_ELEMENTS)
217 ConnectivityIndex = mesh.getConnectivityIndex(MED_DESCENDING,MED_CELL)
219 beg = ConnectivityIndex[n-1]-1
220 end = ConnectivityIndex[n]-1
221 print "Element",n,"descending connectivity -->",Connectivity[beg:end]
222 if Connectivity[beg:end] != [1, 4, 13, 14]:
223 raise RuntimeError, "Wrong descending connectivity"
225 print "getReverseConnectivity(MED_DESCENDING)", grid.getReverseConnectivity(MED_DESCENDING)
226 print "grid.getReverseConnectivityIndex(MED_DESCENDING)",grid.getReverseConnectivityIndex(MED_DESCENDING)
228 ##############################
230 ##############################
232 mesh_name = md.getMeshName(1)
233 mesh = md.getMesh(mesh_name)
234 print "Read", mesh_name
237 if mesh.getIsAGrid() == 0:
238 raise RuntimeError, "Mesh 1 is not a grid"
240 grid = createGridFromMesh(mesh)
242 I = grid.getArrayLength(1)
243 print "_iArrayLength", I
245 raise RuntimeError, "Error in grid.getArrayLength(1)"
247 J = grid.getArrayLength(2)
248 print "_jArrayLength", J
250 raise RuntimeError, "Error in grid.getArrayLength(2)"
252 K = grid.getArrayLength(3)
253 print "_kArrayLength", K
255 raise RuntimeError, "Error in grid.getArrayLength(3)"
257 grid_type = grid.getGridType()
258 print "grid_type =", grid_type
259 if grid_type != MED_GRILLE_STANDARD:
260 raise RuntimeError, "Wrong grid type"
262 spaceDim = grid.getSpaceDimension()
263 print "spaceDim =", spaceDim
265 raise RuntimeError, "Wrong space dimention"
267 meshDim = grid.getMeshDimension()
268 print "meshDim =", meshDim
269 if spaceDim != meshDim:
270 raise RuntimeError, "Wrong mesh dimention"
272 nbNodes = grid.getNumberOfNodes()
273 print "nbNodes =", nbNodes
275 raise RuntimeError, "Wrong nb of nodes"
277 coordSyst = grid.getCoordinatesSystem()
278 print "coordSyst =", coordSyst
279 if coordSyst != "CARTESIAN":
280 raise RuntimeError, "Wrong coordinates system"
282 nbTypesCell = grid.getNumberOfTypes(MED_CELL)
283 print "nbTypesCell =", nbTypesCell
285 raise RuntimeError, "Wrong nbTypesCell"
287 types = grid.getTypes(MED_CELL)
288 print "Cell types =", types
290 raise RuntimeError, "Wrong Cell types"
292 nbElemType = grid.getNumberOfElements(MED_CELL,types[0])
293 print "Nb cells =", nbElemType
295 raise RuntimeError, "Wrong Nb cells"
297 Connectivity = grid.getConnectivity(MED_FULL_INTERLACE,MED_NODAL,MED_CELL,types[0])
298 print "connectivity =", Connectivity
299 n1 = grid.getNodeNumber(0,0,0)
300 n2 = grid.getNodeNumber(1,0,0)
301 n3 = grid.getNodeNumber(1,1,0)
302 n4 = grid.getNodeNumber(0,1,0)
303 conn1 = [n1,n2,n3,n4]
304 print "Cell 1 nodes:", conn1, Connectivity[0:4]
305 if conn1 != Connectivity[0:4]:
306 raise RuntimeError, "Wrong nodal connectivity"
308 ##############################################
309 # test "maa1" which in fact is not a pure GRID
310 ##############################################
312 mesh_name = md.getMeshName(2)
313 mesh = md.getMesh(mesh_name)
314 print "Read", mesh_name
317 if mesh.getIsAGrid() == 0:
318 print "Mesh ",mesh_name," is not a grid"
320 print "END of the Pyhton script ..... Ctrl D to exit"