ParaView 3-D scientific visualization for Gemini. Use Python with ParaView via:
- IPyParaview: Jupyter Notebook
- PV-Python: Python environment installed with the usual standalone ParaView installer
Setup a conda environment with the same version of Python as used by the ParaView installer. For example, ParaView 5.9 uses Python 3.8
conda create -n pv5.9 python=3.8
conda activate pv5.9
conda install numpy ipython jupyter notebook jupyterlab traitlets
git clone https://github.com/nvidia/ipyparaview
cd ipyparaview
./build.sh # Linux / MacOS
./build.ps1 # Windows
On Windows, we use this script "build.ps1" for Windows PowerShell in place of build.sh:
$ErrorActionPreference = "Stop"
Set-Location -Path $PSScriptRoot
pip install -e .
jupyter nbextension install --py --symlink --sys-prefix ipyparaview
jupyter nbextension enable --py --sys-prefix ipyparaview
jupyter labextension install @jupyter-widgets/jupyterlab-manager
jupyter labextension install js
Create an environment variable PARAVIEW_PYTHONPATH
pointing to ParaView's Python site-packages. The path will be like:
- Windows:
C:\Program Files\ParaView 5.9.0-MPI-Windows-Python3.8-msvc2017-64bit\bin\lib\site-packages\
- Linux:
/opt/ParaView-5.9.0-MPI-Linux-Python3.8-64bit/bin/lib/site-packages/
Enviroment variable PARAVIEW_PYTHONPATH
is necessary for running IPyParaView.
IPyParaView examples need these popular Python libraries:
conda install scikit-learn pandas matplotlib
Environment variable PARAVIEW_PYTHONPATH points to ParaView's Python libraries. Before starting Jupyter to use IPyParaview, each time do:
conda activate pv5.9
# Windows PowerShell
$env:PYTHONPATH=$env:PARAVIEW_PYTHONPATH
# Linux / MacOS
export PYTHONPATH=$PARAVIEW_PYTHONPATH
cd notebooks
jupyter notebook
and use the web browser Jupyter Notebook that automatically opens to browse and run the examples. We suggest examples below, which do not require a discrete GPU (they run on a light laptop):
- Hello_Jupyter-ParaView.ipynb
- Iso-Surfaces_with_RTX.ipynb "RTX" requires an appropriate GPU
The example using cuml
"UMAP MNIST Example.ipynb" requires a Linux system with GPU due to
cuml requirements,
which is for advanced users.
cuml is a general machine learning GPU library unrelated to IPyParaView.
Also the Dask example "Dask-MPI_Volume_Render" is for running on Dask-MPI HPC cluster, which would need to be setup by your IT staff perhaps.
ParaView installer comes with a Python 3 Conda environment. MacOS and Linux have only MPI ParaView downloads. Windows Gemini users are already using MS-MPI, so they should also use the Windows ParaView MPI installer.
ParaView expects COARDS / CF format NetCDF4 files. However, non-COARDS, non-CF single variable files can be loaded with the plain NetCDF filter. In the ParaView GUI, select "Volume" and the variable name to actually render the data. An animated camera path can be created.
ParaView can load single-variable NetCDF4 files. To use a grid, which is particularly important for non-uniform gridded ionospheric data, store the NetCDF4 data with the grid data embedded in the file. For PyGemini, the "convert_data" scripts store the grid in the NetCDF file.
The data needs to be filtered to display as a volume in ParaView. In the "Pipeline Browser" right click the .nc filename, Add Filter, Resample as Image Then, in the Properties browser, select Representation: Volume. The data can be sampled with Property "Sampling Dimensions" at higher resolution, but this takes proportionately more GPU resources. If your computer does not have a discrete GPU, using more than about 256 grid points in a dimension may crash ParaView, even with 16 GB RAM. If your computer has a discrete GPU, 1024 or more points per dimension may be possible, with proportionately slower rendering.
A key feature of ParaView is that it gracefully degrades to render 3D output even on modest devices, as long as you don't select too large Sampling Dimensions.
Many of the ParaView examples use Show(); Render()
, which generates a frozen, non-interactive window.
To make the 3D plot interactive, use Interact()
like:
from paraview.simple import *
s = Sphere()
Show()
Interact()
This animated path can be saved as a movie. Note that saving in .ogv format can use 99.5% less disk space than AVI.
If you make a workflow in the ParaView GUI interactively, this state can be rendered to Python .py code by File → Save State and selecting Python file type output.
This may be determined from the ParaView Help → About menu. Scrolling to the bottom of the About windows, example the lines
- OpenGL Vendor
- OpenGL Version
- OpenGL Renderer
For example, if the OpenGL Renderer is "Intel UHD" that is using the non-discrete, low capability GPU inside the CPU, which can render small renderings, not bigger than about 256 grid points per dimension.
If you have an Nvidia GPU, the Nvidia System Management Interface is run from system Terminal like:
nvidia-smi
If the "Processes" section says "No running processes found" while ParaView is open, then you are probably not using the Nvidia GPU.
Detailed GPU status is obtained from
nvidia-smi -q
Look for lines like:
GPU Operation Mode
Current : N/A
Pending : N/A
"N/A" or "Compute" indicates the GPU is not active for visualization. "All On" means the GPU is available for visualization.
- ParaView Python API reference
- ParaView Guide with examples
- Matlab can export data to VTK files via vtkwrite