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

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
    评论
Vivado HLS 中,可以使用数据的方式输出数组,具体步骤如下: 1. 在函数原型中定义输出数组的指针类型和数组大小,例如: ```c++ void function_name(data_type* output_array, int array_size); ``` 2. 在函数内部,使用 `#pragma HLS INTERFACE s_axilite port=output_array bundle=control` 指令将输出数组标记为数据接口,并指定它属于哪个 AXI4-Lite 控制总线。 3. 在输出结果之前,使用 `#pragma HLS STREAM variable=output_array depth=depth_value` 指令将输出数组标记为数据变量,并设置数据深度。 4. 在函数结束前,使用 `#pragma HLS INTERFACE ap_ctrl_none port=return` 指令将函数返回值标记为无控制端口。 下面是一个示例代码: ```c++ #include <hls_stream.h> void function_name(data_type* output_array, int array_size) { #pragma HLS INTERFACE s_axilite port=output_array bundle=control #pragma HLS INTERFACE s_axilite port=array_size bundle=control #pragma HLS INTERFACE ap_ctrl_none port=return #pragma HLS STREAM variable=output_array depth=10 hls::stream<data_type> output_stream("output_stream"); // 数据逻辑 for (int i = 0; i < array_size; i++) { data_type output_data = ...; output_stream.write(output_data); } // 从数据中读取数据到输出数组 for (int i = 0; i < array_size; i++) { output_array[i] = output_stream.read(); } } ``` 在这个示例代码中,我们使用了 `hls::stream` 类型来实现数据输出。我们首先将输出数组标记为数据接口,并使用 `#pragma HLS STREAM` 指令将其标记为数据变量。然后,我们使用 `hls::stream` 类型创建了一个输出数据 `output_stream`,并在数据逻辑中将计算结果写入数据。最后,我们从数据中读取数据到输出数组中,并将函数返回值标记为无控制端口。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值