Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/fabulani/augmented_reality_app

Marker-based augmented reality app made with Python and OpenCV.
https://github.com/fabulani/augmented_reality_app

Last synced: 25 days ago
JSON representation

Marker-based augmented reality app made with Python and OpenCV.

Awesome Lists containing this project

README

        

# Augmented Reality App

[![Code style: black](https://img.shields.io/badge/code%20style-black-000000.svg)](https://github.com/psf/black)

Marker-based augmented reality app made with Python and OpenCV.
- Rectangle detector: detects the marker by detecting the four rectangle corners, then renders the 3D model after applying homography.

![AR App Demo](./docs/demo.gif "AR App Demo")

![Result: diagonal](./docs/result_hiro-diagonal.png "Result: diagonal")
![Result: front](./docs/result_hiro-front.png "Result: front")
![Result: webcam](./docs/result_hiro-webcam.png "Result: webcam")

- Feature-based: uses feature detection and matching to identify the marker.

![Result: hiro1 matches](./docs/result_feature_hiro1-matches.png "Result: hiro1 matches")
![Result: hiro1](./docs/result_feature_hiro1.png "Result: hiro1")
![Result: hiro2 matches](./docs/result_feature_hiro2-matches.png "Result: hiro2 matches")
![Result: hiro2](./docs/result_feature_hiro2.png "Result: hiro2")
![Result: me matches](./docs/result_feature_me1-matches.png "Result: me matches")
![Result: me](./docs/result_feature_me1.png "Result: me")

# Requirements
- Python 3.8

# Known issues
- Docker doesn't have access to the webcam, so `main.py` doesn't work.
- Rectangle-based AR doesn't work well. A TODO is to implemented contour-based detection using the Douglas-Pucker algorithm.

# Problems and solutions

This sections documents the many problems I faced during development of this project, and the solutions I opted for.

1. Lines detected in the border -> extra intersections -> bigger problems.
- This problem originated from the edge detection section of the pipeline, where the Canny algorithm was detecting the corner pixels of the image as edges. The surface that the marker was put on was also causing edges to show up.
- Fix: parameter tuning of the Canny algorithm thresholds.

![Problem: lines detected in the border](./docs/problem_line-detected-in-the-border.png "Problem: lines detected in the border")

2. Overlapping detected intersections.
- Some overlapping intersections were being returned, causing a lot of problems down the pipeline, since every intersection is considered when evaluating for rectangles.
- Fix: apply a check for minimum threshold distance between intersections.

![Problem: overlapping intersections](./docs/problem_overlapping-intersections.png "Problem: overlapping intersections")
![Fix: overlapping intersections](./docs/fix_overlapping-intersections.png "Fix: overlapping intersections")

3. Polygons instead of rectangles.
- When detecting rectangles, I was exhautively tracing every intersection and getting all possibilities. This was stored in a variable called `squares`, with each element being a list of 4 points (i.e., intersections). I couldn't figure out the proper conditions and restrictions to only return actual rectangles instead of all kinds of polygons. At first, it'd return around 5k squares, but with each iteration of new conditions and rules being added, it returned less: 4k, then 2k, then 1k, then 53, then 2, then 1, and currently none. The "best" one was with 53 squares, but after plotting them, I noticed that none of the 53 squares fit the marker properly (the big white square and the black square inside it). I basically had to start from scratch for this step of the pipeline.
- Fix: scratched the rectangle identification. Now I use only the intersections for the marker corner and then apply homography.

![Problem: polygons instead of rectangles](./docs/problem_polygons-instead-of-rects-2.png "Problem: polygons instead of rectangles")

4. Overlapping lines for rectangle identification
- After getting the list of "squares" (more like polygons), I'd use its lines to check if they're what I want, i.e. the marker. Many of these would have lines overlapping or crossing eachother, which doesn't make sense for a rectangle. This problem could be related to Problem 3.
- fix: scratched the rectangle identification. Now I use only the intersections for the marker corner and then apply homography.

![Problem: overlapping lines for rectangle identification](./docs/problem_overlapping-lines.png "Problem: overlapping lines for rectangle identification")

5. Too many intersections (I only want 4: the corners of the marker)
- I was frequently getting 16 or more intersections. It'd detect both square corners, but also erroneously detect intersections below the corners.
- Fix: I increased the `min_intersection_distance` from 10 to 150. This works for the current image, but probably will cause problems in the video feed part, plus if the marker gets smaller in the source image. The previous value of 10 was used to fix overlapping intersections.

![Problem: too many intersections](./docs/problem_too-many-intersections.png "Problem: too many intersections")
![Fix: too many intersections](./docs/fix_too-many-intersections.png "Fix: too many intersections")

6. Homography sligthly wrong
- The homography calculations were resulting in a slightly wrong position. It seemed like the scale was wrong.
- Fix: adjusted the coordinates of the source (the 4 marker corners).

![Problem: Homography sligthly wrong](./docs/problem_homography-wrong-scale.png "Problem: Homography sligthly wrong")
![Fix: Homography sligthly wrong](./docs/fix_homography-wrong-scale.png "Fix: Homography sligthly wrong")

7. Intersection order affects homography
- The order of the intersection points in `intersection` affects homography, since the points from the reference image are directly mapped to the intersections. In the real-time webcam version, this causes major issues as even if the marker is correctly detected, the model will flicker and warp all over the place due to the intersection order changing.
- Fix: no clue, for now I've setup two distinct sets of `src_points` for the notebook images.

![Problem: Intersection order affects homography](./docs/problem_intersection-order-affects-homography.png "Problem: Intersection order affects homography")
![Problem: Intersection order affects homography 2](./docs/problem_intersection-order-affects-homography-2.png "Problem: Intersection order affects homography 2")

8. Feature method doesn't work on video
- Feature method seems to never work. Model keeps flickering and flying all over the screen. Even the simplest of inputs doesn't work.
- Fixed this by adjusting some parameters and fixing return values of functions. Didn't test on video.

![Problem: Feature detection doesn't work on video](./docs/problem_feature-matching-fail.png "Problem: Feature detection doesn't work on video")

# Credits

Code adapted from https://github.com/mafda/augmented_reality_101

"Scrap Auto Turret [Low-poly]" (https://skfb.ly/oCRyJ) by fizikoldun is licensed under Creative Commons Attribution (http://creativecommons.org/licenses/by/4.0/).