vivado hls 使用mat的流数据完成滤波操作

该博客探讨了在Vivado HLS中使用MAT进行滤波操作所面临的挑战,如MAT类型的顺序存取限制和FPGA资源约束。解决方案是采用line存储策略来复用数据。提供了相关代码示例,包括top.cpp、top.h和test.cpp文件,位于指定路径。
摘要由CSDN通过智能技术生成

hls进行滤波操作的难点和注意点:

1、由于vivado hls中的mat类型,实际上为stream类型,只可以顺序存取,不可以随机存取,因此无法随便怼同一个数据进行复用。

2、同时由于FPGA资源有限,无法将图片的像素值全部存储下来,采用line存储的方式进行存储,方便进行数据的复用。

 

解决代码:

本文主要提供mat类型的数据通过何种的存储方式,进行滤波的代码,以及方法.

文件位于(D:\vivado2018.3\project\2_guassianblur\fiter2d)

 

top.cpp

#include "top.h"

//axis转gray_image,之后调用高斯滤波函数
void hlsfilter3(AXI_STREAM& INPUT_STREAM, AXI_STREAM& OUTPUT_STREAM, int rows, int cols)
{

#pragma HLS INTERFACE axis port=INPUT_STREAM
#pragma HLS INTERFACE axis port=OUTPUT_STREAM

#pragma HLS RESOURCE core=AXI_SLAVE variable=rows metadata="-bus_bundle CONTROL_BUS"
#pragma HLS RESOURCE core=AXI_SLAVE variable=cols metadata="-bus_bundle CONTROL_BUS"
#pragma HLS RESOURCE core=AXI_SLAVE variable=return metadata="-bus_bundle CONTRO
  • 4
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值