Vitis HLS 学习笔记--FRP自由运行流水线

2024-06-02 13:36

本文主要是介绍Vitis HLS 学习笔记--FRP自由运行流水线,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 简介

在Vitis HLS中,FRP自由运行流水线(Free Running Pipeline)是一种流水线风格的架构,它即使在没有输入数据的情况下也会运行。这种架构优化了频率,因为它减少了寄存器使能信号的扇出,简化了流水线控制逻辑。FRP流水线通常用于需要避免因为停滞而导致的性能下降或死锁的场合。

FRP流水线与传统的可刷新流水线(flushable pipeline)相比,有以下优点:

  • 没有使用限制:不会因为缺少输入数据而停滞。
  • 资源使用最少:通常情况下,FRP流水线会使用较少的资源,但这并不是绝对的。
  • 更好的时序:由于减少了流水线控制信号的扇出,可以获得更好的时序性能。

FRP流水线也有一些限制和缺点,例如:

  • 不可刷新:如果下一次迭代的输入数据缺失,已经计算出的输出可能无法被传递。
  • 可能导致数据流中的死锁:在数据流架构中,如果流水线停滞,可能会导致死锁。
  • 对于MAXI接口不支持:FRP流水线不支持MAXI接口,这可能限制了其在某些应用场景中的使用。

要实现FRP流水线,可以使用#HLS pragma pipeline style=frp指令来指定特定流水线的风格,或者使用config_compile -pipeline_style frp全局配置。

2. 代码分析

#include "ap_axi_sdata.h"
#include "hls_stream.h"int accumulate(double A[]) {
#pragma HLS inline offdouble acc = 0.0;for (int i = 0; i < 8; i++) {std::cout << "A: " << A[i] << std::endl;acc += A[i];}return acc;
}void process(hls::stream<double>& strm_in, hls::stream<double>& strm_out) {
#pragma HLS inline offfor (int i = 0; i < 8; i++) {double tmp;tmp = strm_in.read();strm_out.write(tmp);}
}void inner(double A[8], hls::stream<double>& stream_in, double* out) {
#pragma HLS pipeline#pragma HLS INTERFACE ap_fifo port = stream_indouble regA[8];
#pragma HLS ARRAY_PARTITION variable = regA completefor (int i = 0; i < 8; i++) {double tmp;tmp = stream_in.read();regA[i] = A[i] + tmp;}*out = accumulate(regA);
}void free_pipe_mult(double A[8], hls::stream<double>& strm, double* out) {
#pragma HLS DATAFLOW
#pragma HLS INTERFACE ap_fifo port = strmdouble B[8];for (int i = 0; i < 8; i++)B[i] = A[i] + i;hls::stream<double> strm_out;process(strm, strm_out);inner(B, strm_out, out);
}

 代码功能解释:

  • accumulate 函数功能:计算一个双精度浮点数数组的累加和。 
  • process 函数功能:从输入流中读取数据,并将其写入输出流。
  • inner 函数功能:从输入流中读取数据,与数组 A 中的数据相加,然后调用 accumulate 函数计算结果。
  • free_pipe_mult 函数功能:实现数据流模型,将数组 A 的每个元素与其索引相加,然后通过流处理和 inner 函数计算最终结果。

 需要配置编译指令:

# Set any optimization directives
config_dataflow -default_channel fifo -fifo_depth 16
config_compile -pipeline_style frp
set_directive_interface -mode ap_fifo "free_pipe_mult" B
set_directive_interface -mode ap_fifo "free_pipe_mult" out
# End of directives

 

3. 总结

FRP自由运行流水线是一种高效的硬件架构风格,它通过持续运行来优化性能,即使在没有新的输入数据时也不会停滞。这种设计简化了控制逻辑,减少了资源使用,并提高了时序性能。然而,FRP流水线也有其局限性,如不支持MAXI接口,且在某些情况下可能导致死锁。

代码示例展示了如何在Vitis HLS中使用FRP流水线和数据流指令来优化硬件设计。accumulate 函数计算数组的累加和,process 函数处理数据流,inner 函数结合输入流和数组数据进行计算,而 free_pipe_mult 函数则整合了这些操作,展示了一个完整的数据流模型。这些函数通过HLS指令进行了优化,以实现并行执行和性能提升。这段代码和FRP流水线的概念为硬件设计师提供了一种提高硬件性能和效率的方法。

这篇关于Vitis HLS 学习笔记--FRP自由运行流水线的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1024116

相关文章

51单片机学习记录———定时器

文章目录 前言一、定时器介绍二、STC89C52定时器资源三、定时器框图四、定时器模式五、定时器相关寄存器六、定时器练习 前言 一个学习嵌入式的小白~ 有问题评论区或私信指出~ 提示:以下是本篇文章正文内容,下面案例可供参考 一、定时器介绍 定时器介绍:51单片机的定时器属于单片机的内部资源,其电路的连接和运转均在单片机内部完成。 定时器作用: 1.用于计数系统,可

问题:第一次世界大战的起止时间是 #其他#学习方法#微信

问题:第一次世界大战的起止时间是 A.1913 ~1918 年 B.1913 ~1918 年 C.1914 ~1918 年 D.1914 ~1919 年 参考答案如图所示

[word] word设置上标快捷键 #学习方法#其他#媒体

word设置上标快捷键 办公中,少不了使用word,这个是大家必备的软件,今天给大家分享word设置上标快捷键,希望在办公中能帮到您! 1、添加上标 在录入一些公式,或者是化学产品时,需要添加上标内容,按下快捷键Ctrl+shift++就能将需要的内容设置为上标符号。 word设置上标快捷键的方法就是以上内容了,需要的小伙伴都可以试一试呢!

Tolua使用笔记(上)

目录   1.准备工作 2.运行例子 01.HelloWorld:在C#中,创建和销毁Lua虚拟机 和 简单调用。 02.ScriptsFromFile:在C#中,对一个lua文件的执行调用 03.CallLuaFunction:在C#中,对lua函数的操作 04.AccessingLuaVariables:在C#中,对lua变量的操作 05.LuaCoroutine:在Lua中,

AssetBundle学习笔记

AssetBundle是unity自定义的资源格式,通过调用引擎的资源打包接口对资源进行打包成.assetbundle格式的资源包。本文介绍了AssetBundle的生成,使用,加载,卸载以及Unity资源更新的一个基本步骤。 目录 1.定义: 2.AssetBundle的生成: 1)设置AssetBundle包的属性——通过编辑器界面 补充:分组策略 2)调用引擎接口API

Javascript高级程序设计(第四版)--学习记录之变量、内存

原始值与引用值 原始值:简单的数据即基础数据类型,按值访问。 引用值:由多个值构成的对象即复杂数据类型,按引用访问。 动态属性 对于引用值而言,可以随时添加、修改和删除其属性和方法。 let person = new Object();person.name = 'Jason';person.age = 42;console.log(person.name,person.age);//'J

大学湖北中医药大学法医学试题及答案,分享几个实用搜题和学习工具 #微信#学习方法#职场发展

今天分享拥有拍照搜题、文字搜题、语音搜题、多重搜题等搜题模式,可以快速查找问题解析,加深对题目答案的理解。 1.快练题 这是一个网站 找题的网站海量题库,在线搜题,快速刷题~为您提供百万优质题库,直接搜索题库名称,支持多种刷题模式:顺序练习、语音听题、本地搜题、顺序阅读、模拟考试、组卷考试、赶快下载吧! 2.彩虹搜题 这是个老公众号了 支持手写输入,截图搜题,详细步骤,解题必备

eclipse运行springboot项目,找不到主类

解决办法尝试了很多种,下载sts压缩包行不通。最后解决办法如图: help--->Eclipse Marketplace--->Popular--->找到Spring Tools 3---->Installed。

《offer来了》第二章学习笔记

1.集合 Java四种集合:List、Queue、Set和Map 1.1.List:可重复 有序的Collection ArrayList: 基于数组实现,增删慢,查询快,线程不安全 Vector: 基于数组实现,增删慢,查询快,线程安全 LinkedList: 基于双向链实现,增删快,查询慢,线程不安全 1.2.Queue:队列 ArrayBlockingQueue:

22.手绘Spring DI运行时序图

1.依赖注入发生的时间 当Spring loC容器完成了 Bean定义资源的定位、载入和解析注册以后,loC容器中已经管理类Bean 定义的相关数据,但是此时loC容器还没有对所管理的Bean进行依赖注入,依赖注入在以下两种情况 发生: 、用户第一次调用getBean()方法时,loC容器触发依赖注入。 、当用户在配置文件中将<bean>元素配置了 lazy-init二false属性,即让