So I managed to start using my stereo camera to seeing some depth and got the first steps working to generating a point cloud of the scene.
|
Top row: Left and right images (rectified). and disparity image is lower left using the block matching algorithm. |
The new camera uses adjustable screws, see image below:
|
New camera setting with adjustable screws |
I used the code/app from
http://blog.martinperis.com/2011/01/opencv-stereo-camera-calibration.html to calibrate the cameras and work out there matrices/ rectifying values for each feed. Once the feeds are rectified (another way to describe this would be to normalize the images, so that they can be interpreted correctly) then the block matching algorithm can be used to determine the disparity map. Next would be to calculate the actual distance of each point from the camera and then we can generate a point cloud. The algorithm only runs at about 5 fps right now on the HD frame on my NVS 4200. I checked with NVIDIA nsight profiling and the block matching kernel takes 188ms, which is the reason for the poor perf. See image below
|
Profile using NVIDIA nsight of stereo block matching |
As always, the code is up at
https://github.com/arcanon/raspbot. I know, it won't really compile, which I hope to fix. Next I want to generate the point cloud and then I will make everything easily compile-able. well as easy as you can get, because its using a whole bunch of complicated libraries...
No comments:
Post a Comment