UG871 Reading Notes(4)

Chapter5 Arbitrary Precision Types(抽象精度类型)
一、C++原生数据类型

  1. C++/C提供的原生数据类型均是以8-bit为边界的,但是在实际的硬件设计时,这样对数据类型的选择灵活性很差。一方面它有时会造成额外的硬件资源开销,更严重的是,更高的数据位宽会造成更高的计算时延,使得有可能需要更多的时钟周期来得到计算结果。

  2. 在设计报告的分析中,可以看到浮点运算耗用了大部分的设计执行时间。

图4 浮点运算占据了大部分延时

二、使用抽象精度类型

  1. 此设计和中不同的地方在于使用了抽象精度类型,打开头文件定义可以看到这样的数据类型定义。
    在这里插入图片描述
    注意看**typedef ap_fixed<W_IN,IW_IN> win_fn_in_t;**这一行关于抽象精度类型的定义,首先ap_fixed类型和float和double一样支持整数和小数位的表示。
    这里的抽象精度类型含义如下:
    W_IN:变量的总字长
    IW_IN:整数所占的位宽
    显然小数部分的位宽就是W_IN - IW_IN了
    使用抽象数据类型可以使运算规模更小,使用的资源开销更少,花费的时钟周期更少。

猜你喜欢

转载自blog.csdn.net/zzy980511/article/details/111354721