Skip to main content

Stereo vision made simple

Project description

SimpleStereo

Stereo vision made Simple.

SimpleStereo is a high level framework for stereo vision applications. It is written in Python 3, with C++ extensions. Documentation is available at https://decadenza.github.io/SimpleStereo/

Dependencies

  • Python 3 (tested with 3.9.2)
  • NumPy
  • SciPy
  • OpenCV
  • matplotlib (for data visualisation)

Installation

Before starting, be sure to have the latest setuptools package by running pip install --upgrade setuptools. Then proceed with one of the two options below.

Option 1

Install package from PyPI with:

pip3 install simplestereo

Option 2

Clone or download the latest version and unzip. Then, from the root folder (the one containing pyproject.toml), run:

pip3 install .

Troubleshooting

I am aware of some issues while installing SimpleStereo. If you have errors during installation, please open an issue.

Windows users troubleshooting

If during installation you get, together with other messages, the following error:

error: Microsoft Visual C++ 14.0 or greater is required. Get it with "Microsoft C++ Build Tools": https://visualstudio.microsoft.com/visual-cpp-build-tools/

Please install the Microsoft C++ Build Tools as indicated. These are required to build C++ extensions that are part of SimpleStereo. More information about compiling on Windows is available at https://wiki.python.org/moin/WindowsCompilers.

Basic example

SimpleStereo helps you with common tasks. You can calibrate two cameras and initialise a stereoRig with:

import simplestereo as ss

# Path to your images
images = [
    ("0_left.png", "0_right"),
    ("1_left.png", "1_right"),
    ("2_left.png", "2_right"),
    ...
    ]

# Calibrate and build StereoRig object
rig = ss.calibration.chessboardStereo( images, chessboardSize=(7,6), squareSize=60.5 )

# Save rig object to file
rig.save("myRig.json")

# Optionally print some info
print("Reprojection error:", rig.reprojectionError)
print("Centers:", rig.getCenters())
print("Baseline:", rig.getBaseline())

More examples available in the examples folder.

Features

General

  • StereoRig, RectifiedStereoRig and StructuredLightRig classes to easily manage your stereo rigs and their calibration
  • Basic stereo capture using OpenCV cv2.videoCapture
  • Export and import point cloud to PLY file

Calibration algorithms

  • Chessboard calibration (one and two cameras)
  • Camera-projector calibration adapted (Moreno D. et al.), adapted from procam (ss.calibration.chessboardProCam)
  • Camera-projector calibration alternative version (ss.calibration.chessboardProCamWhite)

Stereo rectification algorithms

  • Fusiello et al., A compact algorithm for rectification of stereo pairs, 2000 (ss.rectification.fusielloRectify)
  • Wrapper of OpenCV algorithm (ss.rectification.stereoRectify)
  • Loop and Zhang, Computing rectifying homographies for stereo vision, 1999 (ss.rectification.loopRectify)
  • Lafiosca and Ceccaroni, Rectifying homographies for stereo vision: analytical solution for minimal distortion, 2022, https://doi.org/10.1007/978-3-031-10464-0_33 (ss.rectification.directRectify, see also DirectStereoRectification)

Passive stereo matching algorithms

  • Adaptive Support Weight algorithm (K. Yoon et al., Adaptive support-weight approach for correspondence search, 2006)
  • Geodesic Support Weight algorithm (simplified implementation, credits Asmaa Hosni et al.)

Active and Structured light algorithms

Unwrapping algorithms

Documentation

Documentation follows numpydoc style guide.

Install documentation prerequisites with:

pip install Sphinx numpydoc

Build documentation with:

cd sphinx-documentation-generator
sh BUILD_SCRIPT.sh
cd ..

Deploy

After building the documentation and pulled changes in master branch, assign a version in pyproject.toml. Tag the commit accordingly.

Then, build *.tar.gz distribution package:

python3 -m build --sdist

Test upload on PyPI test repository:

python3 -m twine upload --repository testpypi dist/*

Finally, upload to PyPI officially repository:

python3 -m twine upload dist/*

Future work

  • Fix distortion coefficient issue (OpenCV related) when using 12 coefficients (currently 0, 4, 5, 8 and 14 are supported).
  • Add support for fisheye cameras.
  • Adapt structured light algorithms to work with two cameras.
  • ArUco camera calibration algorithm.

Contributions

Reporting issues and proposing integrations of other stereo vision algorithms is highly encouraged and it will be acknowledged. Please share your issues!

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

simplestereo-1.0.8.tar.gz (69.6 kB view details)

Uploaded Source

File details

Details for the file simplestereo-1.0.8.tar.gz.

File metadata

  • Download URL: simplestereo-1.0.8.tar.gz
  • Upload date:
  • Size: 69.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.2

File hashes

Hashes for simplestereo-1.0.8.tar.gz
Algorithm Hash digest
SHA256 1f7fec810a04bac4ab0c49cd8265779b95b7b907615d7d6d5f7f484b76d92f7a
MD5 5fd2ea946e8e94e9c208a2526306eac2
BLAKE2b-256 229e78c5f5e6e5c58b6ba9414db650964d25620afa8d426f986cf61d01f37d97

See more details on using hashes here.

Supported by

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