Vitis HLS 学习笔记--对于启动时间间隔(II)的理解

目录

1. II的重要性

2. 案例分析

3. 总结


1. II的重要性

在Vitis HLS(High-Level Synthesis)中,启动时间间隔(II,Iteration Interval)是一个非常关键的概念,对于实现高性能的硬件加速器设计至关重要。启动时间间隔,或称为迭代间隔,指的是连续启动两个操作之间的时间间隔。

II时间间隔可以影响设计的性能和吞吐量。如果任务之间的启动时间间隔太短,FPGA设备可能无法处理任务并引起冲突。而如果任务之间的启动时间间隔太长,则可能会浪费FPGA设备的资源,从而导致性能低下。

2. 案例分析

有如下 for 循环:

  • 循环体包含三个操作:读、算、存。
  • 每个操作都是在一个周期完成。

用三个颜色表示其运算过程。

考虑 II=3 的这种情况,每次迭代,需要读、算、存操作完毕,完成循环需要9个时钟周期。

 

考虑 II=1 的这种情况,仅需5个周期。

 

3. 总结

  • 启动下一次循环迭代所需的周期数称为流水打拍循环的启动时间间隔 (Initiation Interval, II)。
  • II = 3 表示循环的下一次迭代会在当前迭代的 3 个周期后启动。
  • II = 1 是理想情况,即每个周期内都会启动一次循环迭代。
  • 如果不指定目标 II,那么默认情况下编译器将尝试实现 II=1。
  • 当循环体的迭代次数超过了64次,自动开启流水线,config_compile默认值。
  • 如果循环内部存在数据依赖关系,则可能无法实现 II = 1。

通过对II的精细控制,可以在满足性能要求的同时,优化资源使用,实现高性能和高效率的设计解决方案。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值