## Hardware/Software Codesign – Project part 2

## João Pedro Reis Teixeira

The video processing accelerator was implemented using Vivado HLS. Firstly, the standard data types were converted to HLS specific arbitrary precision data types, such as *ap\_fixed<96,32*, *AP\_RND*, *AP\_SAT>* for data processing and *ap\_uint* with different bit sizes for different purposes. To speed up the implementation, the HLS directive **ARRAY\_PARTITION** with a factor of 64 was used to enable parallel memory access for the histogram computation. The **PIPELINE** directive was used with an Initiation Interval (II) of 2, overlapping loop iterations in a safe manner, as 1 would be too low and inefficient. These directives allowed the code to obtain much better results in terms of timing, reducing the estimated duration of a clock cycle from 8.763 ns to 6.022 ns and latency, which was reduced by approximately 19.7%. Resource utilization also improved. Apart from DSPs, all other components had a big increase in their utilization, meaning that the solution with the directives utilizes more efficiently the resources it has available to it. Figure 1 shows the results for the implementation without the HLS directives and Figure 2 the results for the implementation with the HLS directives. Both implementations had an II of 2.



Figure 1: Results for the implementation without HLS directives



Figure 2: Results for the implementation with HLS directives

As for the testing of this accelerated implementation, it wasn't able to be done. Although it was tried, problems with the resolution of the available monitors (especially the active signal resolution, which led to the correct resolution of 1280x720 not being transmitted to the board, even when set to that value) didn't allow this implementation to run correctly. With this said, it would be predictable that this version would be significantly faster than the version implemented in the first part of this project, as evidenced by the results of running the synthesis with Vivado HLS in Figure 2.