Download presentation
Presentation is loading. Please wait.
Published byByron Neal Modified over 9 years ago
1
Elad Hadar Omer Norkin Supervisor: Mike Sumszyk Winter 2010/11, Single semester project. Date:22/4/12 Technion – Israel Institute of Technology Faculty of Electrical Engineering High Speed Digital System Lab (HS DSL)
2
Project motivation Implementing a video analysis designs on GIDEL PROCSTAR III platform that will enable usage and exploration of a new development platform (PART I – PROCHILs, PART II – PROCWIZARD, PROCAPI, PROCMegaFIFO ). Proper usage of development tools throughout all stages of implementation from algorithm to hardware. Preparing a clear user-guide that will enable a fast and simple ramp-up of the tools and the appropriate flow.
3
PROCHILs is a Hardware-In-the-Loop acceleration tool for running Simulink designs on FPGAs. Automatically translate Simulink designs into FPGA code (compatible with the PROC board installed on the target PC) and run it under Simulink.
5
We have measured the input data processing time of the Hardware generated by ProcHIL and the equivalent Software simulation for different length data vectors. There is a significant acceleration of the processing time using the generated Hardware, especially for longer data vectors.
6
Ratio between the Hardware & Software running time for different length input vectors An exponential curve fitting will give us that the ratio converges to ~128.
7
Even when considering the highest processing ratio, we get a rate of which is very low. For 512x512 pixels image it means 1.04 [Frames/Sec] which is insufficient for video streaming. Not suited for applying on streaming data designs (Real-Time designs)
8
A set of functions that provide the means to access PROC boards by supplying methods that enable real-time configuration and querying of the board. Motivation: Learning and practice of effective debug methodology using PROCAPI while streaming video through an image processing design. PROCAPI allows the user to control data transfer between the PC and the PROC board (using a controllable DMA channels). In PROCHIL this ability is transparent to the user.
9
Main goals and phases of work 1)Learning PROC API, PROCMegaFIFO 2)Define and build an integrated DSPbuilder design combining PROCAPI video streaming functions, data channels and PROCMegaFIFO memories.
10
GiDEL PROCAPI (Version 8.8) ALTERA’s DSPBuilder blockset for Simulink (Version 10.1) ProcWizard (Version 8.8) Quartus II (version 10.1) Matlab (Version 2009a) OpenCV (Version 2.1) GiDEL PROCStar III (Altera Stratix III) board (4-FPGA)
11
System block diagram
12
Project flow
13
Prewitt edge detector implementation Controller Prewitt edge detector
16
Pixel neighborhood storing
17
Controller
19
Preventing pipe contamination enableBit and clken are both connected to read_acknowledge from FIFO IN. Data pipeline of the Prewitt edge detector is 512+4 stages long. When FIFO IN is empty: 1.Stop all data propagation in order to avoid garbage in the pipe that will affect the algorithm correctness. 2.The writing will resume only when a new valid pixel arrives at the end of the data pipeline.
20
Interrupt control Two inputs: 1.WE - Is FIFO IN empty? 2.AD – Is the arriving pixel the last pixel of a frame? One output: 1.dmaInterrupt
21
Controller implementation Data may be propagating or stopped. Pixel is not the last pixel of a frame One cycle state interrupt is sent Frame is finished but the FIFO IN is empty AD is always on until New pixel resets the counter
22
Interrupt controller
23
Signal compiler
24
Quartus
25
Source & Header files Read Frame Display Frame
26
C code structure opening camera Setting DMA channels Define new buffers Capturing new frame Write the frame from input buffer to input FIFO Interrupt Show original frame Main function (pre processing) Second thread function (post processing) Loop Write the frame from output FIFO to output buffer Show processed frame Blue-OPENCV function Purple-API function Red-interrupt
27
Frame Rate We used TIC & TOC macros using OpenCV functions to asses the video output stream frame rate. We did so by measuring time elapsed for presenting 30 frames, And thus concluding frame rate. Full Prewitt edge detector design: 12[fps] Empty design- image capture and present- Hardware: 25[fps] Empty design- image capture and present- Simulink: 23[fps]
28
Frame loss detection
29
By creating another version of the Prewitt edge detector, we managed to divide the doubled number back to its value
30
Time delay We have also noticed a time delay between the original input stream and the filtered one. We had 2 hypotheses to the cause of that delay: The delay was caused by the code complexity, by the multiple loops, memory copying. The delay is caused by the FIFO and its size, due to an accumulation of frames in the FIFO waiting to be extracted. Although we made many optimizations in the C++ code, the delay was not reduced at all. When we reduced the FIFOs size from 8MB to1MB the time delay decreased dramatically from about 3 seconds to less than half a second.
31
STRATIX III FPGA DSP-Builder based edge detection design Time delay We assumed that FIFO OUT is always near empty, because the extraction of the processed images is not limited by the hardware’s rate (12[fps]), and performed at the high rate that the DMA can accomplish. The delay is mainly because of the time it takes the images to pass through the 1MB FIFO IN at a rate of 12[fps]. That calculates to 4 images delay, and means 0.333 second delay, as observed by us.
32
Results & Conclusions Frame rate is satisfying - 12 No frames are lost! Time delay is very low – less than half a second
33
Useful outputs An implemented template for all video streaming processing algorithms. Only minimal effort is needed to integrate a new algorithm and run it! A full user-guide which enables a fast and simple ramp-up of the tools, summs up all conclusions made and consists of needed background knowledge.
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.