syn.directive.loop_tripcount - 2024.1 简体中文

Vitis 统一软件平台文档 应用加速开发 (UG1393)

Document ID
UG1393
Release Date
2024-07-03
Version
2024.1 简体中文

描述

循环次数”是指循环执行的迭代总数。Vitis HLS 可报告每个循环的总时延(执行循环的所有迭代所需周期数)。因此,此循环时延为循环次数(循环迭代次数)的函数。

重要: syn.directive.loop_tripcount 仅用于分析,不影响综合结果。

循环次数可为常量值。它取决于循环表达式(例如,x<y)中使用的变量值或循环内使用的控制语句。

在某些情况下,Vitis HLS 无法判定循环次数。例如,如果用于判定循环次数的变量属于:

  • 输入实参,或者
  • 采用动态运算来计算的变量

在以下示例中,for 循环的最大迭代次数由输入 num_samples 的值来确定。在 C 语言函数中不定义 num_samples 的值,该值从外部进入函数。

void foo (num_samples, ...) {
   int i;
   ...
   loop_1: for(i=0;i< num_samples;i++) {
     ...
     result = a + b;
   }
}

如果循环时延未知或者无法计算,那么 syn.directive.loop_tripcount 允许您指定循环迭代次数的最小、最大和平均值。这样该工具即可分析循环时延给报告中的设计总时延造成的影响,并帮助您为设计决定合适的最优化措施。

提示: 如果使用 C 语言断言宏来限制循环变量的大小,那么 Vitis HLS 可将其用于定义循环限制以供报告之用,并根据这些限制创建大小精确的硬件。

语法

syn.directive.loop_tripcount=[OPTIONS] <location>
  • <location> 表示循环中指定循环次数的位置(格式为 function[/label])。

选项

avg=<integer>
指定平均迭代次数。
max=<integer>
限制最大迭代次数。
min=<integer>
限制最小迭代次数。

示例

函数 foo 中的 loop_1 的最小循环次数指定为 12,最大循环次数则为 16:
syn.directive.loop_tripcount=min=12 max=16 avg=14 foo/loop_1