Real-time wavefront reconstruction and turbulence characterization from Shack-Hartmann sensor data
Built for the ISRO Bharatiya Antariksh Hackathon 2026
Quick Start Β· Architecture Β· Algorithms Β· Benchmarks Β· Documentation Β· Contributing
Turbulence in the atmosphere distorts a plane-parallel wavefront propagating through it. A Shack-Hartmann Wavefront Sensor (SH-WFS) samples this distorted wavefront using an array of small lenslets (Microlens Array - MLA). The MLA creates a spot-field on the camera detector, and the spatial deviation of these spots from their reference positions is used to derive the reconstructed wavefront and its associated Zernike coefficients.
The conjugate of this reconstructed wavefront is typically used to generate an actuator command map (in units of actuator stroke length) which is then fed to a Deformable Mirror (DM) to correct for this distortion in real-time.
RIPRA employs a modular, layered architecture that separates physical hardware inputs, high-speed C-native computations, and predictive deep learning inference loops:
The calculations, rendering, training, and compilation suites detailed in this project are fully interactive and can be executed via the notebooks located in the notebook/ folder:
kaggle_synthetic_shwfs_generator.ipynb:- Rebuilds the end-to-end WFS pipeline. Renders physical frames, configures system directories, trains the ML reconstructors, and compiles/executes the C POSIX integration test suites.
V1_Simulation_TEST.ipynb:- The reference execution notebook housing pre-calculated outputs and static telemetry diagrams.
Kaggle_RIPRA_WFS_Predictive_AO_Pipeline.ipynb:- Implements the deep-learning sequence model pipeline, training LSTM predictors for loop lag compensation, turbulence regime classification, and parameter estimation.
Kaggle_RIPRA_ML_Pipeline.ipynb:- Training pipeline to map centroid displacements to Zernike modal coefficients.
Kaggle_RIPRA_ML_Pipeline_baseline.ipynb:- Training pipeline for baseline model configurations.
Below are the key visual outcomes of the physical simulation and closed-loop control loops.
- Description: Renders the 2D reconstructed phase screen ($W(x,y)$) alongside a 3D elevation map showing peaks (positive phase delay) and valleys (negative phase delay) of the optical aberration.
- Impact: Confirms high-fidelity reconstruction of low-order modes (Tip, Tilt, Defocus) across the circular pupil boundary.
- Description: Displays MLP vs. CNN training loss convergence, defocus mode regression accuracy, and mode-by-mode Pearson correlation comparison.
-
Impact: The Conv2D CNN reconstructor achieves a test MSE of
$0.001957$ (mean correlation of$99.97%$ ), representing a$4.6\times$ accuracy gain over the MLP baseline.
-
Description: Trains an LSTM predictor on historical Zernike sequences. Under 1-frame latency, a standard integrator control loop diverges (green curve), whereas the LSTM predictor (blue curve) remains stable, reducing residual RMS error by
$6.6%$ . - Impact: Prevents loop instability in high-speed optical systems operating under hardware delay.
The RIPRA real-time control interface mockup consolidates WFS spot coordinates, the reconstructed 3D wavefront screen, corresponding Deformable Mirror actuator commands, and system telemetry metrics:
π³ Docker (recommended β includes CUDA, GCC, and the full Python ML stack)
git clone https://github.com/PxA-Labs/Project-RIPRA.git
cd Project-RIPRA
docker build -t rippra:latest .
docker run --rm -it --gpus all rippra:latestRun the C reconstructor benchmark directly:
docker run --rm rippra:latest rippra/build_and_test.shπ§ Linux (manual build)
cd rippra
mkdir -p build
gcc -O2 -fopenmp -c src/io.c -o build/io.o -Iinclude
gcc -O2 -fopenmp -c src/la.c -o build/la.o -Iinclude
gcc -O2 -fopenmp -c src/centroid.c -o build/centroid.o -Iinclude
gcc -O2 -fopenmp -c src/recon.c -o build/recon.o -Iinclude
gcc -O2 -fopenmp -c src/rippra_api.c -o build/rippra_api.o -Iinclude
ar rcs build/librippra.a build/io.o build/la.o build/centroid.o build/recon.o build/rippra_api.o
gcc -O2 -fopenmp tests/test_full_pipeline.c build/io.o build/la.o build/centroid.o build/recon.o build/rippra_api.o -Iinclude -lm -o build/test_full_pipeline
gcc -O2 -fopenmp tests/test_recon.c build/io.o build/la.o build/centroid.o build/recon.o build/rippra_api.o -Iinclude -lm -o build/test_reconπͺ Windows
Use WSL2 with the Linux instructions above, or MSYS2/MinGW-w64 with an equivalent gcc toolchain and OpenMP support. Native MSVC build scripts are not yet provided β see Roadmap.
π macOS
Install a real gcc (Apple's clang shim does not support OpenMP by default) via Homebrew: brew install gcc libomp, then follow the Linux build steps, substituting gcc-13 (or your installed version) for gcc.
π Python / ML environment
pip install torch numpy matplotlib pandas scipy onnx onnxruntime
jupyter notebookFor GPU-accelerated inference, install onnxruntime-gpu instead of onnxruntime (requires a CUDA-capable GPU and matching drivers, as used in the Docker image).
# 1. Clone
git clone https://github.com/PxA-Labs/Project-RIPRA.git
cd Project-RIPRA
# 2. Build the C core + tests (see Installation for full flags)
cd rippra && mkdir -p build && \
gcc -O2 -fopenmp -c src/*.c -Iinclude -o build/ && \
ar rcs build/librippra.a build/*.o
# 3. Run the verification suite
./build/test_full_pipeline
./build/test_recon
# 4. Reproduce the full pipeline end-to-end (build + calibrate + train + validate)
python rippra/tools/reproduce_all.pyExpect the C tests to report centroiding RMSE < 0.25 px and reconstruction RMSE < 0.5 rad against synthetic ground truth (see Benchmarks for the measured figures).
The real-time pipeline executes in sub-milliseconds on standard CPU threads, making it fully qualified for high-frequency (
| Pipeline Phase | Algorithm | Latency ( |
|---|---|---|
| Centroiding | Thresholded Center of Gravity (TCoG) | |
| Reconstruction | Fried Geometry Zonal Matrix Solver | |
| DM Actuator Mapping | Influence Coupling Matrix multiplication | |
| Total Latency | End-to-End Loop |
Compile the static archive librippra.a and the integration tests using GCC with OpenMP support:
cd rippra
mkdir -p build
# Compile object files
gcc -O2 -fopenmp -c src/io.c -o build/io.o -Iinclude
gcc -O2 -fopenmp -c src/la.c -o build/la.o -Iinclude
gcc -O2 -fopenmp -c src/centroid.c -o build/centroid.o -Iinclude
gcc -O2 -fopenmp -c src/recon.c -o build/recon.o -Iinclude
gcc -O2 -fopenmp -c src/rippra_api.c -o build/rippra_api.o -Iinclude
# Link static archive
ar rcs build/librippra.a build/io.o build/la.o build/centroid.o build/recon.o build/rippra_api.o
# Build test suites
gcc -O2 -fopenmp tests/test_full_pipeline.c build/io.o build/la.o build/centroid.o build/recon.o build/rippra_api.o -Iinclude -lm -o build/test_full_pipeline
gcc -O2 -fopenmp tests/test_recon.c build/io.o build/la.o build/centroid.o build/recon.o build/rippra_api.o -Iinclude -lm -o build/test_reconVerify centroiding accuracy, zonal/modal solvers, and closed-loop DM convergence:
./build/test_full_pipeline
./build/test_reconInstall dependencies and launch the Jupyter Notebook environment:
pip install torch numpy matplotlib pandas scipy
jupyter notebookOpen notebook/kaggle_synthetic_shwfs_generator.ipynb to customize parameters, render new calibration frames, or train models.
- ISRO Bharatiya Antariksh Hackathon 2026 for the problem statement and evaluation framework.
- The adaptive optics open-source community (HCIPy, AOtools, OOPAO, COMPASS) for prior art in reconstruction algorithms.
For questions, open a GitHub Issue or start a Discussion.






%20frame.webp)
