Commit 7a199903 authored by Sabyasachi Mondal's avatar Sabyasachi Mondal
Browse files

Update README.md

parent 3aff78b0
# FPGA in Image Feature detection and comparison with CPU
#### Group4: Sabyasachi Mondal , Ravi Yadav
fpga for streamlining of computation intensive tasks. In this case we take an hyperspectral image which is generally analysed by satellites or drones mostly consisting of single band image data. This can be used for both maritime and vehicular navigation.
#### I Have tried to build a implementation from scratch where all code structure were created so we can have much higher control over design
| Title | Content |
| ------ | ------ |
| Overview | Why do we use FPGA |
| Problem background | Where can we apply our methods and get results |
| Objective | Our vision of the solution |
| Implementation | The Hardware architechture and HLS code constructs |
| Robert's cross | The algorithm we implemented |
| What we achieved and Caveats | Objectives sucessful and limitations |
| Future Scope | Possible use in multiagent robot control using continous streaming |
fpga for streamlining of computation intensive tasks. Like in cases where signals or images from sensors are procesed continously.
### I Have tried to build a implementation from scratch where all code structure were created so we can have much higher control over design. It was sucessful and for very large images and continous streams FPGA performance shoots up as much as 3 times.
|Index| Title | Content |
|1| ------ | ------ |
|2| Overview | Why do we use FPGA |
|3| Problem background | Where can we apply our methods and get results |
|4| Objective | Our vision of the solution |
|5| Implementation | The Hardware architechture and HLS code constructs |
|6| Robert's cross | The algorithm we implemented |
|7| What we achieved and Caveats | (RESULTS) Objectives sucessful and limitations |
|8| Future Scope | Possible use in multiagent robot control using continous streaming |
|9| Tasks , Errors , References | Epilogue |
## Overview
We want to use FPGA for implementing an algorithm in hardware to perform computation more effeciently. CPU hardware is non-flexible so the code runs using the same set of registers and ALU , we cant optimize the harware as per our code. Our objective here is to harware a processing unit (something smilar to a flexible ALU using the CLBs) in the FPGA using High level code.
## Problem background
<b>*For applications like real time image processing, using CPU resource can be expensive, and the reaction time may increase in applications where decisions are based on calculations. We need a dedicated hardware that can process continous process of data coming in from sensors or camera endlessly.*</b>
<b>*For applications like real time image processing, using CPU resource can be expensive. The reaction time may increase in applications where decisions are based on calculations (see ). We need a dedicated hardware that can process continous process of data coming in from sensors or camera endlessly.*</b>
<b>*FPGA should be able to process multiple streams in synchronized manner. We want to process the streams coming from an image and process them through a convolution algorithm (Robert's matrix) and then use another function to filter out relevant parts*</b>
......@@ -81,12 +83,17 @@ We use two blocks to process the streams but that doesnot mean we use one thread
<b>*Our main goal is to ensure such a architechture runs faster in FPGA and it was reasonably fast; most importantly it can be scaled up to handle multiple streams.*</b>
#### An Important observation was that for very large images (greater then 1 MB) our resizer is almost 3 times faster, thoguh its about 0.2 times fast for lower size images.
<b>*CPU Average for images was at about 25s and FPGA at about 10s for 6 images*</b>
<b>*CPU Average for images was at about 25s and FPGA at about 10s for 6 images for smaller images*</b>
![Speed comparison in single images](https://mygit.th-deg.de/sm11312/fpga_final_project/-/raw/main/Speed_table.JPG "Speed comparison in single images")
But the best part of the result is summarized in the following:
#### An Important observation was that for very large images (greater then 1 MB) our resizer is almost 3 times faster, thoguh its about 0.2 times fast for lower size images.
Note the image below (2,3 are the smaller images) :
<img src="
">
## Future scope
*This is a new idea and has no previous references except implementaton guides.*
......
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment