-
Notifications
You must be signed in to change notification settings - Fork 4
Home
Most of the image processing projects in academia has been done on higher-end FPGA's with a considerable amount of resources. The main objective of this project is to implement a reliable embedded system on a lower end FPGA with limited resources. This project is based on Disparity calculation based on SAD (Sum of Absolute Difference) algorithm and creating a depth map.
Hardware used for this project
- Basys 3 FPGA board
- 2x OV7670 image sensor modules
This project has 3 major sections
- Functional verification of disparity generator based on Verilog
- Stereo camera implementation using OV7670 sensors based on VHDL
- Real time disparity generation on Basys3 FPGA
Hardware description languages(HDL) are not meant to be for rapid prototyping. Therefore, in this case, I have used python as the prototyping tool. The SAD algorithm was implemented on python from scratch without using any external library. I refrained from using 2D image arrays to store data because then the HDL implementation is straight forward.
SAD theory Sum of Absolute difference is based on a simple geometric concept. Where they use the stereo vision to calculate the distance to the objects. For the implementation, two cameras should be on the same plane and they should not have any vertical offsets in their alignments.
Python implementation
The python implementation can be found here
Test images used For the functional verification, I have used the most famous stereo image pair "Tsukuba" stereo pair
Tsukuba left image
Tsukuba right image
Python results
For this generation, it took more than 4 seconds using an average laptop computer without any accelerating techniques. Based on the Python implementation Abstract flow chart is generated as follows.
Then this algorithm is directly ported to Verilog. The implementation was done using ISE design suite by Xilinx. The image files were converted to hex and imported to the simulation and the output is directly saved as a Bitmap image.
Timing diagrams at 50MHz
Simulation Output *** these modules are only for simulation purposes, Do not synthesize the code.
The cameras that were used for this project is very inexpensive OV7670 modules. They are commonly available and the output can be configured to 8bit parallel. These cameras are using I2C interface to communicate with the master. We can configure the camera output by changing the internal registers of the cameras.
Camera PINOUTS Connection with BASYS 3
This repo contains VHDL implementation for image read from two cameras and displaying the average of two images from the VGA output.
OV7670 dual camera mount was designed using a cad tool and 3D printed to mount the cameras. STL files for camera mount can be found from here.
When converting the functional verification module into synthesizable code due to limited functionalities in Verilog, VHDL was selected as the developing language.