Vivado HLS(High-level Synthesis)笔记七:函数层面的优化

一. 代码风格

在这里插入图片描述

  • 从函数这个角度来说代码风格,主要是看参数的数据类型,C++中的数据类型是以8为边界的,而实际硬件中我们可能会遇到任意精度的数据类型,因此我们一定在C++中定义为任意精度的数据类型;

二. lnline

在这里插入图片描述在这里插入图片描述

  • 对函数的Inline实际是去除函数的层次化,带来的好处是可以改善资源,不再需要调用函数的相关逻辑,对于小函数HLS会自动Inline,如果我们不希望,可以通过directive中的 -off这个选型来实现;

三. Allocation

在这里插入图片描述在这里插入图片描述

  • allocation定义了函数与相应的RTL model之间的关系;
  • allocation的影响,它实际上是在Latency和Area上做折衷;

四. Task Level Pipelining: Dataflow

在这里插入图片描述在这里插入图片描述在这里插入图片描述

  • 实际上是做并行处理,可以看到用到了channel,channel可以是ping-pong RAM,也可以是FIFO;
  • Dataflow可以作用于一些顺序处理的任务,比如函数或者循环,或者两者都有;
  • Dataflow是将顺序处理变为并行处理,使得当前任务不需要前面的任务结束才执行,可以并行处理,所以Dataflow允许任务之间有交叠,提高了数据吞吐量,降低了Latency;

总结:
在这里插入图片描述

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值