Skip to main content

Multi-view stereo reconstruction of underwater surfaces with refractive modeling

Project description

AquaMVS reconstruction - multi-view stereo reconstruction of underwater surfaces

PyPI Python CI License: MIT

AquaMVS

Multi-view-stereo (MVS) reconstruction of underwater surfaces viewed through a flat water surface, with Snell's law refraction modeling.

What it does

AquaMVS is a companion library to AquaCal. It consumes calibration output and synchronized video from above-water cameras to produce time-series 3D surface reconstructions. The pipeline handles the unique challenge of cameras positioned in air observing underwater geometry, accounting for refraction at the air-water interface using Snell's law.

Key Features

  • Refractive ray casting through air-water interface (Snell's law)
  • Dual matching pathways: LightGlue (sparse) and RoMa v2 (dense) for different accuracy/speed tradeoffs
  • Multi-view depth fusion with geometric consistency filtering
  • Surface reconstruction (Poisson, heightfield, Ball Pivoting Algorithm)
  • Mesh export (PLY, OBJ, STL, GLTF) with simplification
  • Full CLI and Python API for pipeline users and custom workflow developers

Quick Start

from aquamvs import Pipeline

pipeline = Pipeline("config.yaml")
pipeline.run()

See the full documentation for configuration details, API reference, and examples.

Installation

AquaMVS requires several prerequisites (PyTorch, LightGlue, RoMa v2) to be installed first.

See INSTALL.md for complete installation instructions.

Quick summary:

# 1. Install PyTorch from pytorch.org
pip install torch torchvision --index-url https://download.pytorch.org/whl/cu121

# 2. Install git-based prerequisites
pip install -r requirements-prereqs.txt

# 3. Install AquaMVS
pip install aquamvs

Documentation

Full documentation is available at https://aquamvs.readthedocs.io/

Topics include:

  • Installation guide
  • Configuration reference
  • API documentation
  • Usage examples
  • Extension points for custom workflows

Citation

If you use AquaMVS in your research, please cite:

Lancaster, T. (2026). AquaMVS: Multi-view stereo reconstruction with refractive geometry.
GitHub: https://github.com/tlancaster6/AquaMVS
Example dataset: https://github.com/tlancaster6/AquaMVS/releases/tag/v0.1.0-example-data

A Zenodo DOI will be added in a future release.

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

aquamvs-1.1.3.tar.gz (126.6 kB view details)

Uploaded Source

Built Distribution

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

aquamvs-1.1.3-py3-none-any.whl (110.7 kB view details)

Uploaded Python 3

File details

Details for the file aquamvs-1.1.3.tar.gz.

File metadata

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

File hashes

Hashes for aquamvs-1.1.3.tar.gz
Algorithm Hash digest
SHA256 7d0dcdde46cb655a3c013f65e2b7d0a47352a9e8f674493a7fb037bd0ce89a5a
MD5 19e823677c6a320bd950aa15a83b7ac6
BLAKE2b-256 0dfa68a6497520dc8a691eb71e44c7a3713f92ce1e85efb29c01327933754570

See more details on using hashes here.

Provenance

The following attestation bundles were made for aquamvs-1.1.3.tar.gz:

Publisher: publish.yml on tlancaster6/AquaMVS

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

File details

Details for the file aquamvs-1.1.3-py3-none-any.whl.

File metadata

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

File hashes

Hashes for aquamvs-1.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 714361ac4b6cfe703e121af6834964df38b9a38562093e2b0f46cdfd20aad9b6
MD5 fb50da82b7e701aa162f66e2d180c7a8
BLAKE2b-256 280f76bf40ace4c9e4c7c55cddce5d12cfda866451d7b3d570345c9f32ebfb11

See more details on using hashes here.

Provenance

The following attestation bundles were made for aquamvs-1.1.3-py3-none-any.whl:

Publisher: publish.yml on tlancaster6/AquaMVS

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