目录
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的精细控制,可以在满足性能要求的同时,优化资源使用,实现高性能和高效率的设计解决方案。