File: TestEnSightWriterNodeIdsElementIds.py

package info (click to toggle)
vtk9 9.5.2%2Bdfsg3-4
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 205,916 kB
  • sloc: cpp: 2,336,565; ansic: 327,116; python: 111,200; yacc: 4,104; java: 3,977; sh: 3,032; xml: 2,771; perl: 2,189; lex: 1,787; makefile: 178; javascript: 165; objc: 153; tcl: 59
file content (41 lines) | stat: -rwxr-xr-x 1,451 bytes parent folder | download | duplicates (6)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
#!/usr/bin/env python

"""
vtkEnSightWriter test for writing node IDs and element IDs

This test exercises the WriteNodeIDs and WriteElementIDs
options of vtkEnSightWriter. Since vtkEnSightGoldBinaryReader
currently provides no way to retrieve node/element IDs, we just
test that the files are readable and contain geometry.

"""

import vtk
from vtk.util.misc import vtkGetTempDir
import os.path
VTK_TEMP_DIR = vtkGetTempDir()

cell_type_source = vtk.vtkCellTypeSource()
cell_type_source.SetCellType(vtk.VTK_HEXAHEDRON)
cell_type_source.Update()
reference_mesh = cell_type_source.GetOutput()

for write_node_ids in range(2):
    for write_element_ids in range(2):
        filename = "ensightWriterNodeIDs{}ElementIDs{}".format(write_node_ids, write_element_ids)

        writer = vtk.vtkEnSightWriter()
        writer.SetFileName(os.path.join(VTK_TEMP_DIR, "{}.case".format(filename)))
        writer.SetInputData(reference_mesh)
        writer.SetWriteNodeIDs(write_node_ids)
        writer.SetWriteElementIDs(write_element_ids)
        writer.Write()
        writer.WriteCaseFile(0)

        reader = vtk.vtkEnSightGoldBinaryReader()
        reader.SetCaseFileName(os.path.join(VTK_TEMP_DIR, "{}.0.case".format(filename)))
        reader.Update()
        mesh = reader.GetOutput().GetBlock(0)

        assert mesh.GetNumberOfPoints() == reference_mesh.GetNumberOfPoints()
        assert mesh.GetNumberOfCells() == reference_mesh.GetNumberOfCells()