如何评估graph的性能

描述

Vitis HLS合集来了Vivado合集来了(2018-2019)Vivado合集来了(2020-2021)

评估graph的性能对于kernel接口设计有着非常重要的意义。我们仍以前一篇文章中提到的工程为例。有三种方法可以评估graph的性能。

方法1:利用仿真结果评估AIE仿真结果都会有一个时间戳,如下图所示。这样我们就能从中获知第一个输出数据的时间点和最后一个输出数据的时间点,而仿真过程中总的输入数据量我们是很清楚的,从而可确定graph的吞吐率。

Graph

这里我们用Tcl脚本显示graph吞吐率计算过程。如下图所示。start_time定义了第一个输出数据时间点,单位是ps。stop_time定义了最后一个输出数据时间点。total_time就是处理整个数据所需要的时间。bytes_per_run确定了每次执行所处理的数据量,单位为Byte。iteration_count为执行次数。

Graph

Graph

方法2:利用API进行评估Vitis提供了API用于graph性能评估。event::io_stream_start_to_bytes_transferred_cycles返回处理指定数据量(单位为Byte)所需要的时钟周期个数。event::io_stream_running_event_count在start_profiling和read_profiling之间发生的事件个数。

Graph

在仿真时就会打印出吞吐率,如下图所示。

Graph

方法3:在profile报告中查看性能生成profile报告具体设置如下图所示。

Graph

在profile报告中可以看到每个kernel运行的总时钟周期个数,还可以看到运行一次每个kernel所需要的时钟周期个数。

Graph

Graph

原文标题:AIE(11)—评估graph性能

文章出处:【微信公众号:TeacherGaoFPGAHub】欢迎添加关注!文章转载请注明出处。

  审核编辑:彭菁
 

 

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分