This repository contains algorithms for stereo vision and creating 3D maps from it
The folder 2001 contains the images used for the different methods to find disparity
The ipynb files contains cencus transform, Sum of absolute difference and the Normalized correlation method which use the multi block or the single block matching methods.
This repo has 2 main folders, there is the python implementation of the new model we propose for and methods like census transform and Sum of absolute difference have been analysed.
There is a also a ros package that has the implementation of the method on a custom robot desinged, the methods have also been written in cpp and kept within header files so they can be easily reused.
3D mapping is a very useful technology in present days. One of the best benefits of 3D mapping is that it provides the latest technical methods for visualization and gathering information. Knowledge visualization and science mapping become easier when a 3D map is available for the area under study. In this project we want to implement a robot which can map a 3D model of a room or an area and simultaneously avoid mapping humans or any other animal. We have implemented our code from scratch and have optimized the code to give us better features and faster computational time.
Done by:
Chandravaran Kunjeti
Saikumar Dande
There are various ways which can be used to find the depth of an object like LIDAR, InfraRed, Stereo matching etc. In this project we use the stereo based approach to calculate the depth of an object. Stereo matching aims to identify the corresponding points and retrieve their displacement to reconstruct the geometry of the scene as a depth map.
Let us go through the different topics needed for stereo vision one by one
If we want understand the point in an image we need to know what transforms are involved in the process, there are many types of parameters which are as follows:
- Rotation matrix
- Translation matrix
- Intrinsic matrix
- Focal length
- Optical centre
After the images are rectified, the disparity between the left and right images is found. Disparity refers to the distance between two corresponding points in the left and right image of a stereo pair. Disparity between the left and right image occurs because the cameras are placed with a certain amount of distance between them. This disparity is more for the objects that are closer to the camera than the objects which are farther. Using this principle, we can find the depth map or the disparity map of the images.
Depth of the images is then found using the formulawhere
Base_length = Distance between left and right camera
Disparity map is found through Multiple Block Matching. Block matching is where we use a block of pixels for mathcing, instead of trying to find a single pixel in the right image. Here we take a certain number of pixels surrounding the pixel in the left image and try to find a closest match for the block of pixels in the right image. After finding the right match, the disparity is calculated by using the formula XL-XR, where XL is the horizontal distance of the pixel in the left image and XR is the match that is found in the right image.
Multiple block matching takes blocks of different sizes and shapes and integrates them for a better disparity map. Single block matching technique does not work well in case where the disparity values within the matching block vary drastically, for example in the case of a highly slanted surface like road, it becomes difficult using single block matching technique. The problem can be resolved by using blocks of different sizes like vertical block or horizontal block which give better correlation or matches as compared to single block matching.The closest match between the blocks of the left and the right image can be found through three different methods namely Sum of Absolute Difference(SAD), Normalized Correlation(NC), and Census Transform(CT).
The results shown above are obtained when we use SAD and LCDM to obtain the disparity map using the single block matching method.
This image shows us the results of the SAD and LCDM but using multi block matching method.
The above obtained disparity maps are from Normalised correlation and filtering by LCDM.
The above image gives us the results obtained from using cencus transform, we can absorve that initially it does not give very good results, but on applying LCDM we see the error dropping, and giving us the best results.
As we are aiming for real time mapping we need to understand how long each method is taking, it was observed that pure SAD had the least time but not such a great result, so we went ahead and choose Cencus transform with LCDM as the time and the error percentage were within marginal values.
This gives us a final view of all the methods and there percentage of BAD Error
The final output of the implementation on gazebo
Visualisation of the depth map using point cloud.
Result obtained (Left), Ground truth (Right) For visualisation we useed open3d to get an understanding how well the algorithm was performing when compared to the groundtruth, and it can be seen that the performance was good.
Video of the robot moving around, taking images from the stereo camera and finding depth map can be found here. Due to the pandemic we choose to test our algorithm in a simulator called Gazebo, the whole robot was designed by us forthis specific task. Due to the high computation time we only took pictures at different instances and found the depth map,we are working on making the algorithm faster!!
-
L. Ma, J. Li, J. Ma and H. Zhang, "A Modified Census Transform Based on the Neighborhood Information for Stereo Matching Algorithm," 2013 Seventh International Conference on Image and Graphics, Qingdao, China, 2013, pp. 533-538, doi: 10.1109/ICIG.2013.113.
-
N. Einecke and J. Eggert, "A multi-block-matching approach for stereo," 2015 IEEE Intelligent Vehicles Symposium (IV), Seoul, Korea (South), 2015, pp. 585-592, doi: 10.1109/IVS.2015.7225748.
-
Yang, Q., Yang, R., Davis, J., & Nister, D. (2007). Spatial-Depth Super Resolution for Range Images. 2007 IEEE Conference on Computer Vision and Pattern Recognition. doi:10.1109/cvpr.2007.383211