GitPedia

K wave python

A Python interface to k-Wave GPU accelerated binaries

From waltsims·Updated June 23, 2026·View on GitHub·

A Python implementation of [k-Wave](http://www.k-wave.org/) — an acoustics toolbox for time-domain simulation of acoustic wave fields. Includes a pure NumPy/CuPy solver (`backend="python"`, supports any CUDA-capable GPU) and an interface to the pre-compiled k-Wave C++ binaries (`backend="cpp"`) with NVIDIA GPU support for compute capability 7.5 (Turing) and newer — covers every consumer/datacenter GPU since 2018, including all shipping Blackwell variants (B200/GB200, B300/GB300, Jetson Thor, RTX... The project is written primarily in Python, distributed under the GNU Lesser General Public License v3.0 license, first published in 2022. Key topics include: acoustics, gpu, kwave, neuroscience, python.

Latest release: v0.6.3rc1v0.6.3rc1 (pre-release)
June 21, 2026View Changelog →

k-wave-python

Support
Documentation Status
codecov

A Python implementation of k-Wave — an acoustics toolbox for time-domain simulation of acoustic wave fields. Includes a pure NumPy/CuPy solver (backend="python", supports any CUDA-capable GPU) and an interface to the pre-compiled k-Wave C++ binaries (backend="cpp") with NVIDIA GPU support for compute capability 7.5 (Turing) and newer — covers every consumer/datacenter GPU since 2018, including all shipping Blackwell variants (B200/GB200, B300/GB300, Jetson Thor, RTX 50xx, RTX PRO 6000 Blackwell, GB10/DGX Spark).

Mission

Increase the accessibility and reproducibility of k-Wave simulations for medical imaging, algorithmic prototyping, and testing.

Getting started

A collection of examples covers common simulation scenarios. Run any example locally:

bash
uv run examples/ivp_homogeneous_medium.py

No GPU required — all examples run on CPU with NumPy.

Installation

Using uv (recommended):

bash
uv add k-wave-python

Or with pip:

bash
pip install k-wave-python

Older GPUs (Maxwell, Pascal, Volta)

The backend="cpp" binaries shipped in v0.6.3+ require compute capability 7.5 (Turing) or newer. CUDA Toolkit 13.0 removed offline-compilation support for older architectures, so the following hardware is not covered by the bundled binaries:

  • Maxwell (GTX 9xx, Titan X Maxwell, Tesla M-series, Jetson Nano)
  • Pascal (GTX 10xx, P100, P40, Titan X(p)/Xp, Jetson TX2)
  • Volta (V100, Titan V, Quadro GV100, Jetson AGX Xavier)

Use backend="python" instead (NumPy/CuPy works on every CUDA-capable GPU), or build the C++ backend from source against CUDA Toolkit 12.x.

Development

Development instructions can be found here.

  1. k-Wave: A MATLAB toolbox for the time-domain simulation of acoustic wave fields.
  2. j-wave: Differentiable acoustic simulations in JAX.
  3. ADSeismic.jl: a finite difference acoustic simulator with support for AD
    and JIT compilation in Julia.
  4. stride: a general optimisation framework for medical ultrasound tomography.

Documentation

The documentation for k-wave-python can be found here.

Citation

bibtex
@software{k-Wave-Python, author = {Yagubbayli, Farid and Sinden, David and Simson, Walter}, license = {GPL-3.0}, title = {{k-Wave-Python}}, url = {https://github.com/waltsims/k-wave-python} }

Contact

e-mail walter.a.simson@gmail.com.

Contributors

Showing top 12 contributors by commit count.

View all contributors on GitHub →

This article is auto-generated from waltsims/k-wave-python via the GitHub API.Last fetched: 6/28/2026