Chapter5 Arbitrary Precision Types(抽象精度类型)
一、C++原生数据类型
-
C++/C提供的原生数据类型均是以8-bit为边界的,但是在实际的硬件设计时,这样对数据类型的选择灵活性很差。一方面它有时会造成额外的硬件资源开销,更严重的是,更高的数据位宽会造成更高的计算时延,使得有可能需要更多的时钟周期来得到计算结果。
-
在设计报告的分析中,可以看到浮点运算耗用了大部分的设计执行时间。
二、使用抽象精度类型
- 此设计和一中不同的地方在于使用了抽象精度类型,打开头文件定义可以看到这样的数据类型定义。
注意看**typedef ap_fixed<W_IN,IW_IN> win_fn_in_t;**这一行关于抽象精度类型的定义,首先ap_fixed类型和float和double一样支持整数和小数位的表示。
这里的抽象精度类型含义如下:
W_IN:变量的总字长
IW_IN:整数所占的位宽
显然小数部分的位宽就是W_IN - IW_IN了
使用抽象数据类型可以使运算规模更小,使用的资源开销更少,花费的时钟周期更少。