我维护a little Python package,可以在用于网格表示的不同格式之间进行转换
这些文件可能会变得非常大,因此在使用Python阅读它们时,有效地执行它们非常重要。
最常用的格式之一是来自msh的Gmsh。不幸的是,它的数据布局可能不是最好的。示例文件:
$MeshFormat
2.2 0 8
$EndMeshFormat
$Nodes
8
1 -0.5 -0.5 -0.5
2 0.5 -0.5 -0.5
3 -0.5 0.5 -0.5
4 0.5 0.5 -0.5
5 -0.5 -0.5 0.5
6 0.5 -0.5 0.5
7 -0.5 0.5 0.5
8 0.5 0.5 0.5
$EndNodes
$Elements
2
1 4 2 1 11 1 2 3 5
2 4 2 1 11 2 5 6 8
$EndElements
对于$Nodes
:
第一个数字(8
)是要遵循的节点数。
在每个节点行中,第一个数字是索引(格式的其余部分实际上不需要,ü),然后按照三个空间坐标。 / p>
到目前为止,我还没有在islice
循环中提出比for
更好的东西,这很慢。
# The first line is the number of nodes
line = next(islice(f, 1))
num_nodes = int(line)
#
points = numpy.empty((num_nodes, 3))
for k, line in enumerate(islice(f, num_nodes)):
points[k, :] = numpy.array(line.split(), dtype=float)[1:]
line = next(islice(f, 1))
assert line.strip() == '$EndNodes'
对于$Elements
:
第一个数字(2
)是要遵循的元素数量。
在每个元素行中,第一个数字是索引,然后是元素类型的枚举(4
用于四面体)。然后遵循此元素的整数标记数(2
,在这种情况下,1
和11
)。对应于元素类型,此行中的最后几个条目对应于构成元素的 $Node
索引 - 对于四面体,最后四个条目。
由于标签的数量可能因元素而异(即,行到行),就像元素类型和节点索引的数量一样,每行可能有不同的整数。
对于$Nodes
和$Elements
,我们非常感谢您快速阅读这些数据。
答案 0 :(得分:5)
这是一个基于NumPy的有点奇怪的实现:
f = open('foo.msh')
f.readline() # '$MeshFormat\n'
f.readline() # '2.2 0 8\n'
f.readline() # '$EndMeshFormat\n'
f.readline() # '$Nodes\n'
n_nodes = int(f.readline()) # '8\n'
nodes = numpy.fromfile(f,count=n_nodes*4, sep=" ").reshape((n_nodes,4))
# array([[ 1. , -0.5, -0.5, -0.5],
# [ 2. , 0.5, -0.5, -0.5],
# [ 3. , -0.5, 0.5, -0.5],
# [ 4. , 0.5, 0.5, -0.5],
# [ 5. , -0.5, -0.5, 0.5],
# [ 6. , 0.5, -0.5, 0.5],
# [ 7. , -0.5, 0.5, 0.5],
# [ 8. , 0.5, 0.5, 0.5]])
f.readline() # '$EndNodes\n'
f.readline() # '$Elements\n'
n_elems = int(f.readline()) # '2\n'
elems = numpy.fromfile(f,sep=" ")[:-1] # $EndElements read as -1
# This array must be reshaped based on the element type(s)
# array([ 1., 4., 2., 1., 11., 1., 2., 3., 5., 2., 4.,
# 2., 1., 11., 2., 5., 6., 8.])
答案 1 :(得分:3)
为什么不在Gmsh SDK中使用gmsh python API?例如,使用文件explore.py
(位于SDK tarball中,gmsh-<\ version> -Linux64 / share / doc / gmsh / demos / api / explore.py)读取您的示例(我将其命名为test.msh
。
$ python explore.py test.msh
输出:
Info : No current model available: creating one
Info : Reading 'test.msh'...
Info : 8 vertices
Info : 2 elements
Info : Done reading 'test.msh'
6 mesh nodes and 2 mesh elements on entity (3, 11) Discrete volume
- Element type: Tetrahedron 4, order 1
with 4 nodes in param coord: [0. 0. 0. 1. 0. 0. 0. 1. 0. 0. 0. 1.]
节点和元素存储为numpy数组。