Skip to main content

Refractive multi-camera calibration for underwater arrays with Snell's law modeling

Project description

AquaCal

AquaCal ray trace

Build Coverage PyPI Python License DOI

Refractive multi-camera calibration for underwater arrays. AquaCal calibrates cameras in air viewing through a flat water surface, using Snell's law to achieve accurate 3D reconstruction in refractive environments.

Features

  • Snell's law refractive projection — Accurate ray-tracing through air-water interfaces
  • Multi-camera pose graph — BFS-based extrinsic initialization for camera arrays
  • Joint bundle adjustment — Simultaneous optimization of extrinsics, interface distances, and board poses
  • Sparse Jacobian optimization — Scalable to 10+ cameras with column grouping
  • ChArUco board detection — Robust corner detection for calibration targets

Installation

pip install aquacal

Quick Start

  1. Install AquaCal:

    pip install aquacal
    
  2. Generate a configuration file from your calibration videos:

    aquacal init --intrinsic-dir videos/intrinsic/ --extrinsic-dir videos/extrinsic/
    
  3. Run calibration:

    aquacal calibrate config.yaml
    

Results are saved to output/calibration.json with camera intrinsics, extrinsics, interface distances, and diagnostics.

Documentation

Full documentation is available at aquacal.readthedocs.io:

Citation

If you use AquaCal in your research, please cite:

@software{aquacal,
  title = {AquaCal: Refractive Multi-Camera Calibration},
  author = {Lancaster, Tucker},
  year = {2026},
  url = {https://github.com/tlancaster6/AquaCal},
  version = {1.0.0}
}

See CITATION.cff for full citation metadata. A DOI will be available via Zenodo after the first release.

Contributing

We welcome contributions! See CONTRIBUTING.md for guidelines.

License

MIT License. See LICENSE for details.

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

aquacal-1.3.0.tar.gz (107.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

aquacal-1.3.0-py3-none-any.whl (124.8 kB view details)

Uploaded Python 3

File details

Details for the file aquacal-1.3.0.tar.gz.

File metadata

  • Download URL: aquacal-1.3.0.tar.gz
  • Upload date:
  • Size: 107.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for aquacal-1.3.0.tar.gz
Algorithm Hash digest
SHA256 b9c5284b1cac1c91739b762aff82dd780f74578fd6dbd9330eb168529b9a7933
MD5 93e3132c5a6a5fd6613f68c78bcf8ecf
BLAKE2b-256 0f2df44eb406ad4b1f916c47a27f5773ea3c133f04db90586d2cb672bdbd3552

See more details on using hashes here.

Provenance

The following attestation bundles were made for aquacal-1.3.0.tar.gz:

Publisher: publish.yml on tlancaster6/AquaCal

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file aquacal-1.3.0-py3-none-any.whl.

File metadata

  • Download URL: aquacal-1.3.0-py3-none-any.whl
  • Upload date:
  • Size: 124.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for aquacal-1.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c5447f001e03ff8b09dcf00493e92bdd7d932c147bf783bd6c37d702ff06abb4
MD5 3fab5d5b1ebdc714cfb3373e36948787
BLAKE2b-256 02aa4cd493339a6312a9b28931f94ee166ee1dcdbca998d573a01a57c3bb9c85

See more details on using hashes here.

Provenance

The following attestation bundles were made for aquacal-1.3.0-py3-none-any.whl:

Publisher: publish.yml on tlancaster6/AquaCal

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page