Installation | GPU Drivers | Examples | Contributing
A fast plotting library built using the pygfx
render engine utilizing Vulkan, DX12, or Metal via WGPU, so it is very fast! We also aim to be an expressive plotting library that enables rapid prototyping for large scale explorative scientific visualization.
Higher resolution demo: https://github.com/kushalkolar/fastplotlib/assets/9403332/1df06d4d-9a7e-4f0d-aad8-8d2e9b387647
fastplotlib
can run on anything that pygfx
can also run, this includes:
✔️ Jupyter lab
, using jupyter_rfb
✔️ PyQt
and PySide
✔️ glfw
✔️ wxPython
Notes:
✔️ You can use a non-blocking glfw
canvas from a notebook, as long as you're working locally or have a way to forward the remote graphical desktop (such as X11 forwarding).
❕ We do not officially support jupyter notebook
through jupyter_rfb
, this may change with notebook v7
😞 jupyter_rfb
does not work in collab, for a detailed discussion see: vispy/jupyter_rfb#57
Note
fastplotlib
is currently in the early alpha stage with breaking changes every ~week, but you're welcome to try it out or contribute! See our Roadmap for 2023.
http://fastplotlib.readthedocs.io/
The Quickstart guide is not interactive. We recommend cloning/downloading the repo and trying out the desktop
or notebook
examples: https://github.com/kushalkolar/fastplotlib/tree/master/examples
If someone wants to integrate pyodide
with pygfx
we would be able to have live interactive examples! 😃
Questions, ideas? Post an issue or chat on gitter.
Install using pip
.
pip install fastplotlib
pip install "fastplotlib[notebook]"
Optional: install simplejpeg
for much faster notebook visualization, you will need C compilers and libjpeg-turbo to install it:
pip install simplejpeg
Note
fastplotlib
andpygfx
are fast evolving projects, the version available through pip might be outdated, you will need to follow the "For developers" instructions below if you want the latest features. You can find the release history on pypi here: https://pypi.org/project/fastplotlib/#history
git clone https://github.com/kushalkolar/fastplotlib.git
cd fastplotlib
# install all extras in place
pip install -e ".[notebook,docs,tests]"
Note
fastplotlib
andpygfx
are fast evolving, you may require the latestpygfx
andfastplotlib
from github to use the examples in the master branch.
First clone or download the repo to try the examples
git clone https://github.com/kushalkolar/fastplotlib.git
# most dirs within examples contain example code
cd examples/desktop
# simplest example
python image/image_simple.py
cd examples/notebooks
jupyter lab
Start out with simple.ipynb
.
import fastplotlib as fpl
import numpy as np
plot = fpl.Plot()
data = np.random.rand(512, 512)
plot.add_image(data=data)
plot.show()
import fastplotlib as fpl
import numpy as np
plot = fpl.Plot()
data = np.random.rand(512, 512)
image = plot.image(data=data)
def update_data():
new_data = np.random.rand(512, 512)
image.data = new_data
plot.add_animations(update_data)
plot.show()
Interactive visualization of large imaging datasets in the notebook.
You will need a relatively modern GPU (newer integrated GPUs in CPUs are usually fine). Generally if your GPU is from 2017 or later it should be fine.
For more information see: https://wgpu-py.readthedocs.io/en/stable/start.html#platform-requirements
Vulkan drivers should be installed by default on Windows 11, but you will need to install your GPU manufacturer's driver package (Nvidia or AMD). If you have an integrated GPU within your CPU, you might still need to install a driver package too, check your CPU manufacturer's info.
We also recommend installing C compilers so that you can install simplejpeg
which improves remote frame buffer performance in notebooks.
Debian based distros:
sudo apt install mesa-vulkan-drivers
# for better performance with the remote frame buffer install libjpeg-turbo
sudo apt install libjpeg-turbo
For other distros install the appropriate vulkan driver package, and optionally the corresponding libjpeg-turbo
package for better remote-frame-buffer performance in jupyter notebooks.
If you do not have a GPU you can perform limited software rendering using lavapipe. This should get you everything you need for that on Debian or Ubuntu based distros:
sudo apt install llvm-dev libturbojpeg* libgl1-mesa-dev libgl1-mesa-glx libglapi-mesa libglx-mesa0 mesa-common-dev mesa-vulkan-drivers
As far as I know, WGPU uses Metal instead of Vulkan on Mac. You will need at least Mac OSX 10.13.
We welcome contributions! See the contributing guide: https://github.com/kushalkolar/fastplotlib/blob/master/CONTRIBUTING.md
You can also take a look at our Roadmap for 2023 and Issues for ideas on how to contribute!