See code in GitLab.
Author: Clara Sales Bellés csales@unizar.es, Hermenegild Arevalo hermenegild@simula.no, Christian Götz christian.goetz@partner.kit.edu, Pascal Maierhofer pascal.maierhofer@kit.edu, Moritz Linder moritz.linder@kit.edu
cd ${TUTORIALS}/02_EP_tissue/22_ParaView_visualisation
The mesh geometry as well as the additionally required files were obtained from ${TUTORIALS}/02_EP_tissue/02_stimulation
and stored in the folder called meshes
. In order to visualise the excitation on the mesh in ParaView, the transmembrane voltage, which is stored in the .igb
file and the mesh file were merged with meshtool collect. The following command can be used to display all the options offered by meshtool collect.
meshtool collect
As previously mentioned, the first step is to merge the time series of the transmembrane voltage (.igb
file) and the mesh geometry (block_i
) into one file using meshtool collect. In this case, the merged file is simply called result.case
and the default file format (ens_bin
) is used.
The resulting file format can be changed by specifying the -ofmt
option. However, for large meshes, keeping the merged file as small as possible is advisable to ensure high visualisation quality at all times. After the files have been merged with meshtool collect, the results can be assessed in ParaView. Therefore, select the .case
file and load it into ParaView. The time course of the transmembrane voltage can be observed after pressing the play button.
Note: In case the mesh is very large, the conversion to other file formats should be considered.
Here, we present a method for handling large meshes and files with extensive temporal data by converting them into the recently designed VTKHDF file format, which ensures seamless compatibility with ParaView (version 5.12.0 or later). VTKHDF supports the storage of both static and dynamic meshes along with associated temporal data in a single file. For the sake of simplicity, we use the same example as above for demonstration.
This example works for static meshes only. For dynamic meshes, please refer to https://www.kitware.com/how-to-write-time-dependent-data-in-vtkhdf-files/ or contact one of the example authors.
For visualization of temporal data with more than 10,000 time steps, ParaView's GUI slows down the rendering time drastically causing stuttering animations. In this case, we recommend to either increase the stride (reduce total amount of time steps) or use PvPython, which is not affected by the performance limitations of the GUI and is capable of rendering meshes with 600,000 elements and 100,000 time steps (64 GB) still at 25 fps.
Here is an example script for the visualization using PvPython:
Add to examples (visualizations using PvPython): visualize_vtkhdf.py
Add to carputils (conversion from igb to vtkhdf): igb_to_vtkhdf.py
This python file collects geometrical (pts, elem) and temporal (igb) data into a single file in VTKHDF format. Temporal data can be read and written sequentially using any desired chunk / RAM size. This allows for conversion of very large files and smooth visualizations using PvPython. Temporal data can also be downsampled during conversion.
Paraview offers various functions that help you to automate your workflow or make it reproducible. One of these is the trace function. Using the trace function, you can record certain steps or patterns you take in the graphical user interface, such as a rotation around the azimuth axis, for which Paraview automatically generates python code. The generated code can then be further customised or imported directly and applied to other meshes. The following code example was generated automatically after activating the trace function (Tools --> Start Trace
). As it is not easy to rotate a mesh by exactly -60° using only the mouse, the rotation was carried out and then the value was adjusted to -60°, subsequently.
# trace generated using paraview version 5.11.1
#### import the simple module from the paraview
from paraview.simple import *
#### disable automatic camera reset on 'Show'
paraview.simple._DisableFirstRenderCameraReset()
# get active view
renderView1 = GetActiveViewOrCreate('RenderView')
renderView1.ResetActiveCameraToNegativeZ()
# reset view to fit data
renderView1.ResetCamera(False)
renderView1.AdjustAzimuth(-60.0)
#================================================================
# addendum: following script captures some of the application
# state to faithfully reproduce the visualization during playback
#================================================================
# get layout
layout1 = GetLayout()
#--------------------------------
# saving layout sizes for layouts
# layout/tab size in pixels
layout1.SetSize(2228, 1506)
With the help of the trace function you can intuitively figure out keywords, function names and arguments that you can use as the basis for your customised python script.
© Copyright 2020 openCARP project Supported by DFG and EuroHPC Contact Imprint and data protection