Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kylesayrs/pyslam-d
pySLAM-D is a real-time SLAM algorithm for UAV aerial stitching. Includes additional features and refactored code on top of BU's implementation https://github.com/armandok/pySLAM-D
https://github.com/kylesayrs/pyslam-d
computer-vision gtsam opencv real-time slam stitching uav visual-odometry
Last synced: 15 days ago
JSON representation
pySLAM-D is a real-time SLAM algorithm for UAV aerial stitching. Includes additional features and refactored code on top of BU's implementation https://github.com/armandok/pySLAM-D
- Host: GitHub
- URL: https://github.com/kylesayrs/pyslam-d
- Owner: kylesayrs
- Created: 2023-10-18T05:23:08.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-05-23T04:33:43.000Z (8 months ago)
- Last Synced: 2024-05-23T05:33:23.119Z (8 months ago)
- Topics: computer-vision, gtsam, opencv, real-time, slam, stitching, uav, visual-odometry
- Language: Python
- Homepage:
- Size: 8.28 MB
- Stars: 2
- Watchers: 2
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# PySLAM-D #
PySLAM-D is a UAV-tailored SLAM stitching inspired by [pySLAM-D](https://github.com/armandok/pySLAM-D) which was developed in partnership with GreenSight Agronomics. This implementation significantly increases the robustness and usability of the initial design, includes functional documentation, and implements additional matching options and parameters.
## Technical explaination ##
The Pyslam-D live stitching algorithm works by generating a factor graph whose nodes are each camera’s pose in georeferenced 3D space and whose edges (factors) are the relative pose transformations from one node to another. During the optimization step, the nodes of the factor graph are optimized for spatial consistency, meaning that even noisy sensor measurements can still reinforce one another to produce a consistent estimation of camera poses.The first factor type, odometry factors, are determined by performing visual odometry between neighboring images and using point cloud registration to estimate the pose transformation between the two images. These factors can be computationally expensive, but help neighboring images “mesh” with each other independently of instrument noise.
The second factor type, gps factors, help to determine the camera's absolute position. These factors are often noisy, but are valuable for compensating for bad odometry estimates. The error produced by GPS, unlike relative odometry error, is independent of flight duration, meaning that these factors prevent images from drifting away from their true, georeferenced positions over time.
The third factor type, attitude factors, incorporate attitude measurements from the drone when the picture was taken. These factors improve estimates of image rotation and can be used as a prior for the odometry area of overlap, making odometry matching faster and increasing robustness to low overlap and high attitude datasets.
One known bug is that this implementation projects images directly downwards from the camera position. Future work will project the image with respect to the orientation of the camera, therefore better supporting non-gimbaled payloads.
## Installation ##
1. Install pyslamd
```bash
git clone https://github.com/kylesayrs/pySLAM-D
python3 -m pip install -e .
```
2. Install [GTSAM](https://gtsam.org)
3. Install [TEASER-plusplus](https://github.com/MIT-SPARK/TEASER-plusplus)Use cmake .. -DENABLE_DIAGNOSTIC_PRINT=OFF to turn off debug messages for teaser
## Usage ##
Edit `src/pyslamd/Settings.py` to adjust stitching settings. In the future these
settings will be documented as script arguments```bash
pyslamd.stitch path/to/image/directory
```
Images must be geotagged with gps coordinates in order to georeference frame poses within a real world coordinate frame.