Vivado HLs中任意精度数据类型的处理方法

本文探讨了在Vivado HLS中如何处理任意精度数据类型以优化硬件设计。相比于C-base数据类型,任意精度数据类型能提供更高的时钟频率、更好的数据吞吐率和更少的资源消耗。通过实例展示了如何创建和仿真项目,对比了使用标准C数据类型与任意精度数据类型在资源、延迟和性能上的差异,强调了任意精度类型在FPGA设计中的优势。
摘要由CSDN通过智能技术生成

我们在设计硬件时,它往往是要求更精确的位宽。例如,一个filter的输入是12位和一个累加器的结果只需要一个最大范围为27位。然而对于硬件设计来说,使用标准的C数据类型会造成硬件成本的浪费。这就会造成我们要使用更多的LUT和寄存器,延迟甚至可能超过时钟周期和需要更多的周期来计算结果。这往往不是我们需要的结果。因此下面我将介绍如何利用Vivado HLS处理许多位准确或任意精度数据类型,以及允许使用任何(任意)宽度的模型变量。

C-base 数据类型

我们从硬件的角度来看数据类型,采用C/C++的数据类型都是以8bit为边界,即:
• char (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中消耗4个DSP48E1,显然这是很浪费资源的。

任意精度数据类型

Language
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值