如何利用Vivado HLS处理许多位准确或任意精度数据类型.doc
《如何利用Vivado HLS处理许多位准确或任意精度数据类型.doc》由会员分享,可在线阅读,更多相关《如何利用Vivado HLS处理许多位准确或任意精度数据类型.doc(4页珍藏版)》请在三一文库上搜索。
1、如何利用Vivado HLS处理许多位准确或任意精度数据类型我们在设计硬件时,它往往是要求更精确的位宽。例如,一个filter的输入是12位和一个累加器的结果只需要一个最大范围为27位。然而对于硬件设计来说,使用标准的C数据类型会造成硬件成本的浪费。这就会造成我们要使用更多的LUT和寄存器,延迟甚至可能超过时钟周期和需要更多的周期来计算结果。这往往不是我们需要的结果。因此下面我将介绍如何利用Vivado HLS处理许多位准确或任意精度数据类型,以及允许使用任何(任意)宽度的模型变量。C-base 数据类型我们从硬件的角度来看数据类型,采用C/C+的数据类型都是以8bit为边界,即:? char
2、 (8-bit)? short (16-bit)? int (32-bit)? long long (64-bit)? float (32-bit)? double (64-bit)? 确切的宽度的整数类型如int16_t (16-bit) 和 int32_t (32-bit)注意:char16_t和char32_t在Vivado Hls 中是不支持的从上面发现,C的数据位宽是比较死板的,然而描述RTL里面的位宽是任意的。例如,采用C语言去描述一个18*18 bits的乘法器,那么就需要将输入数据都声明为32 bits(int),结果声明为64 bits(long long),这将会在FPGA
3、中消耗4个DSP48E1,显然这是很浪费资源的。任意精度数据类型 Language Integer Data Type Required HeaderC uint W(1024 bits) .#include ap_cint.h C+ ap_uint W(1024 bits) .#include ap_int.h C+ ap_ufixed W,I,Q,O,N .#include ap_fixed.h其优点有:1.更高的时钟频率 2.更好的数据吞吐率 3.消耗资源更少因此,使用任意精度数据类型能以更少的资源,获得相同的精度,同时可以运行在更高的时钟频率下。注意:在声明任意数据类型的时候,我们往往
4、在头文件里面声明,这会使得我们在做debug的时候会非常有用。C-base 数据类型projectStep1 创建和打开projectI.打开Vivado HLS Command Prompt,按照下图输入命令II.输入vivado_hls -p window_fn_prjStep2 Review Test Bench 和run C SimulaTIonI.在Source打开window_fn_top.cppII.找到window_fn_top.h,按住Control键,并右击,打开window_fn_top.h(头文件)在这里,我们可以看到,本设计所有数据类型的操作都是标准C/C+的浮点型。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 如何利用Vivado HLS处理许多位准确或任意精度数据类型 如何 利用 Vivado HLS 处理 许多 准确 任意 精度 数据类型
链接地址:https://www.31doc.com/p-3421932.html