Ray tracing using CUDA accessible from Python
Project description
RTXpy
GPU-accelerated terrain analysis for the xarray ecosystem. Compute hillshade, viewshed, slope — get DataArrays back. Build a Dataset, then explore it interactively in 3D. Built-in data fetching (DEM, buildings, roads, water, fire, wind) makes it easy to go from a bounding box to a full scene.
Real-time viewshed analysis with GPU-accelerated ray tracing. Green areas are visible from the observer position (blue dot). Run python examples/playground.py to try it interactively.
Quick Start
Fetch terrain, analyze, and explore — all from a bounding box:
from rtxpy import fetch_dem
import rtxpy
# Download 30m terrain (cached after first run)
dem = fetch_dem(
bounds=(-122.3, 42.8, -121.9, 43.0),
output_path='crater_lake.zarr',
source='copernicus',
)
dem = dem.rtx.to_cupy()
# Analysis results are standard xarray DataArrays
hillshade = dem.rtx.hillshade(shadows=True)
viewshed = dem.rtx.viewshed(x=500, y=300, observer_elev=2)
# Interactive 3D terrain exploration
dem.rtx.explore()
Build a Dataset with multiple layers, then explore them together:
import xarray as xr
from xrspatial import slope, aspect
from rtxpy import fetch_dem, fetch_buildings, fetch_roads
bounds = (-122.3, 42.8, -121.9, 43.0)
dem = fetch_dem(bounds, 'terrain.zarr', source='srtm', crs='EPSG:5070')
dem = dem.rtx.to_cupy()
ds = xr.Dataset({
'elevation': dem,
'slope': slope(dem),
'aspect': aspect(dem),
})
# Fetch and place vector features
roads = fetch_roads(bounds, crs='EPSG:5070')
ds.rtx.place_roads(roads, z='elevation')
bldgs = fetch_buildings(bounds, source='overture', crs='EPSG:5070')
ds.rtx.place_buildings(bldgs, z='elevation')
# G cycles layers, N toggles geometry, U drapes satellite tiles
ds.rtx.explore(z='elevation', mesh_type='voxel')
Prerequisites
- NVIDIA GPU: Maxwell architecture or newer (GTX 900+ / RTX series)
- NVIDIA driver: 455.28+ (Linux) or 456.71+ (Windows)
- CUDA: 12.x or newer
See INSTALL.md for detailed instructions and troubleshooting.
Installation
Conda (recommended)
conda create -n rtxpy python=3.12 -y
conda activate rtxpy
conda install -c makepath -c conda-forge rtxpy
# Additional deps for examples and interactive viewer
conda install -c conda-forge \
xarray rioxarray xarray-spatial \
pyproj pillow pyglfw moderngl scipy \
"duckdb<1.4" requests matplotlib
Pip + Conda hybrid (from source)
# GPU foundation via conda
conda create -n rtxpy-dev python=3.12 -y
conda activate rtxpy-dev
conda install -c conda-forge cupy numba zarr
# OptiX SDK headers (needed for pyoptix-contrib build and PTX compilation)
git clone --depth 1 https://github.com/NVIDIA/optix-dev.git /tmp/optix-dev
CMAKE_PREFIX_PATH=/tmp/optix-dev \
pip install pyoptix-contrib
# Install rtxpy (editable)
pip install -e ".[all]"
Development
# After completing the pip + conda hybrid setup above:
pip install -e ".[tests]"
pytest -v rtxpy/tests
Features
- Analysis arrays —
hillshade(),slope(),aspect(),viewshed()return xarray DataArrays that fit into your existing Dataset - Data fetching —
fetch_dem(),fetch_buildings(),fetch_roads(),fetch_water(),fetch_wind(),fetch_firms()— go from a bounding box to real data with automatic caching - 3D feature placement — extrude buildings, drape roads, scatter custom meshes on terrain
- Interactive viewer —
explore()renders your Dataset in 3D with keyboard/mouse controls, satellite tiles, wind particles, and real-time viewshed - Rendering — perspective camera with shadows, fog, AO, depth-of-field, colormaps for static images and GIF animations
- Mesh I/O — load GLB/OBJ/STL, save/load zarr scenes, export STL
Documentation
- Getting Started — installation, prerequisites, first example, how the accessor works
- User Guide — task-oriented workflows for analysis, placement, rendering, and the interactive viewer
- API Reference — complete method signatures, parameters, and return values
- Examples — annotated walkthrough, quick recipes, and example scripts
Low-Level API
For custom ray tracing without the xarray accessor:
import numpy as np
from rtxpy import RTX
rtx = RTX()
verts = np.float32([0,0,0, 1,0,0, 0,1,0, 1,1,0])
triangles = np.int32([0,1,2, 2,1,3])
rtx.build(0, verts, triangles)
rays = np.float32([0.33, 0.33, 100, 0, 0, 0, -1, 1000])
hits = np.float32([0, 0, 0, 0])
rtx.trace(rays, hits, 1)
print(hits) # [100.0, 0.0, 0.0, 1.0]
Building the PTX Kernel
GPU_ARCH=$(nvidia-smi --query-gpu=compute_cap --format=csv,noheader | tr -d '.')
nvcc -ptx -o rtxpy/kernel.ptx cuda/kernel.cu \
-arch=sm_${GPU_ARCH} \
-I/path/to/OptiX-SDK/include \
-I cuda \
--use_fast_math
Building with Conda
conda install conda-build
conda build conda-recipe
conda install --use-local rtxpy
Auto-detects GPU architecture, downloads OptiX headers, compiles PTX, and installs everything. Override with GPU_ARCH=86 or OPTIX_VERSION=8.0.0. See conda-recipe/README.md for details.
WSL2 Support
See Getting Started — WSL2 Setup for instructions on getting OptiX working on WSL2.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file rtxpy-0.1.0.tar.gz.
File metadata
- Download URL: rtxpy-0.1.0.tar.gz
- Upload date:
- Size: 236.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
909c4345137f1727ab0983d80971d4c45f6e9577382b96f7dadbaa9a1cb08d63
|
|
| MD5 |
7741bc192c7d9e232e7cc69bfab5bea6
|
|
| BLAKE2b-256 |
b62e2f0e3af45bc6fffe2d4b3df3e79f080933bea27504ae5c392f4b09d58727
|
File details
Details for the file rtxpy-0.1.0-py3-none-any.whl.
File metadata
- Download URL: rtxpy-0.1.0-py3-none-any.whl
- Upload date:
- Size: 247.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4454f699020bf8b0909a022c90ec4fe7cce1bb772fe8cb7e14a234e90afca48a
|
|
| MD5 |
0431497143a04478c7c2c421841b1deb
|
|
| BLAKE2b-256 |
23120512e7d69c42b61a0bb922f4e5189204f9c95359d4af99f70f0d5e5837af
|