Here is a video of the Python software which finds a beacon (red and blue circles on paper) in the left and right camera, and outputs the difference in horizontal pixels. Take note that no calculations take place unless the beacon is properly oriented. This is a necessary feature to get rid of all of the detected blobs that are not beacons, i.e noise rejection.
To find the Hue values of the circles I printed out, I used the program pick_and_track.py found here. The color tracking algorithm I use is based on the multi_color_two_object.py example found in the same place. The circle intersection algorithm is based on analysis performed in this document:
It should also be noted that in the video, the left and right camera feeds are "warped" to get rid of lens distortion. This is accomplished by using camera calibration code and a calibration image which can be printed out here. I changed the calibration code a bit so that the first declarations are replaced with:
- board_w=8 # number of horizontal corners
- board_h=5 # number of vertical corners
- n_boards=20 #number of calibration images
- board_n=board_w*board_h #number of total corners
- board_sz=(board_w,board_h) #size of board
This will wait for 20 successful calibration images and the board height and width is declared to work with the sample image I linked. The code was also augmented to calibrate two cameras simultaneously, using the same chessboard locations for the left and right images.
No comments:
Post a Comment