HLS实现图像二值化

最近在学习HLS语言,所以就自己摸索尝试了用HLS实现了图像二值化,把这个内容总结一下,分享出来。

首先打开HLS,然后新建一个Project,之后再在Source栏点击右键,选择New File...,创建名为pixelBinary.cpp和pixelBinary.h这两个文件。

这个是pixelBinary.cpp文件的内容:

#include "pixelBinary.h"
#include <stdio.h>
#include <iostream>using namespace std;void hls::pixelBinary(GRAY_IMAGE &src, GRAY_IMAGE &dst)
{uchar pixelValue;GRAY_PIXEL src_data;GRAY_PIXEL dst_data;LOOP_ROW:for(int idxRow = 0; idxRow < IMG_HEIGHT; idxRow++){LOOP_COL:for(int idxCol = 0; idxCol < IMG_WIDTH; idxCol++){#pragma HLS PIPELINE II=1src >> src_data;pixelValue = src_data.val[0];dst_data.val[0] = pixelValue > 128 ? 255 : 0;dst << dst_data;}}
}void hlsMain(AXI_STREAM& src_axi, AXI_STREAM& dst_axi)
{#pragma HLS INTERFACE axis port=src_axi bundle=INPUT_STREAM#pragma HLS INTERFACE axis port=dst_axi bundle=OUTPUT_STREAMGRAY_IMAGE img_src;GRAY_IMAGE img_dst;#pragma HLS dataflowhls::AXIvideo2Mat(src_axi,img_src);hls::pixelBinary(img_src,img_dst);hls::Mat2AXIvideo(img_dst,dst_axi);
}

这个是pixelBinary.h文件的内容:

#ifndef _PIXELBINARY_H_
#define _PIXELBINARY_H_#include "hls_video.h"
#include "hls_math.h"
#include "ap_int.h"
#include "ap_fixed.h"// maximum image size
#define IMG_WIDTH 184
#define IMG_HEIGHT 273// I/O Image Settings
#define INPUT_IMAGE "input_image.png"
#define OUTPUT_IMAGE "output_image.png"// typedef video library core structures
typedef unsigned char uchar;
typedef hls::stream<ap_axiu<8,1,1,1> > AXI_STREAM;
typedef hls::Mat<IMG_HEIGHT, IMG_WIDTH, HLS_8UC1> GRAY_IMAGE;
typedef hls::Scalar<1, uchar> GRAY_PIXEL;// typedef HLS namespace
namespace hls
{void pixelBinary(GRAY_IMAGE &src, GRAY_IMAGE &dst);
}//top level function for HW synthesis
void hlsMain(AXI_STREAM& src_axi, AXI_STREAM& dst_axi);#endif

有了这两个文件之后,就可以进行综合了,这里首先要进行顶层函数定义,Project -> Project Settings -> Synthesis -> 在Top Function那里选择hlsMain,点击OK进行确定。然后点击HLS界面的C Synthesis,如下是综合完的结果。

从综合结果可知,pixelBinary的Latency和Interval的值是一样的,都是50235,我们的图片尺寸是184*273 = 50232,Latency和Interval的值比图片像素数多3,关于Latency和Interval具体的含义,我还是没有很明白,这两个值到底是怎么来进行计算的,等弄明白了再来分享。

这是一个综合的结果,也就是把我们的HLS代码综合成了Verilog或者VHDL代码了,你再solution下面的syn文件夹下就可以看到生成的Verilog或者VHDL代码了。

然后接下去是仿真,在TestBench下新建文件,文件名为testbench.cpp,代码为:

#include "iostream"
#include "hls_opencv.h"
#include "pixelBinary.h"using namespace std;
using namespace cv;int main()
{//获取图像数据IplImage* src = cvLoadImage(INPUT_IMAGE,CV_LOAD_IMAGE_GRAYSCALE);//获取仿真图片并直接转为灰度图像IplImage* dst = cvCreateImage(cvGetSize(src), src->depth, src->nChannels);AXI_STREAM src_axi, dst_axi;IplImage2AXIvideo(src, src_axi);hlsMain(src_axi, dst_axi);AXIvideo2IplImage(dst_axi, dst);cvSaveImage(OUTPUT_IMAGE,dst);//释放内存cvReleaseImage(&src);cvReleaseImage(&dst);return 0;
}

这个仿真代码的意思就是读取图像,然后进行处理,并将处理完的结果输出,为了能够仿真,需要在TestBench下添加图像文件,图像文件名为input_image.png,最后会输出output_image.png这么一个图像。如下分别为输入图像数据和输出图像数据,最终生成的图像数据在 .\solution_pixelBinary\sim\wrapc文件夹下

但其实呢,我觉得这样的testbench并不好,看过Example里的TestBench,写法都是Software的结果和Hardware的结果进行对比,如果能对上,就说明写的代码没问题,不过图像处理的话,直接看处理后的图像差不多也行。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/12684.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

[ 内网渗透实战篇-1 ] 单域环境搭建与安装域环境判断域控定位CS插件装载CS上线

&#x1f36c; 博主介绍 &#x1f468;‍&#x1f393; 博主介绍&#xff1a;大家好&#xff0c;我是 _PowerShell &#xff0c;很高兴认识大家~ ✨主攻领域&#xff1a;【渗透领域】【数据通信】 【通讯安全】 【web安全】【面试分析】 &#x1f389;点赞➕评论➕收藏 养成习…

通过物流分拣系统来理解RabbitMQ的消息机制

RabbitMQ作为一个消息中间件&#xff0c;通过队列和路由机制&#xff0c;帮助应用程序高效传递消息。而它的消息流转过程&#xff0c;其实可以用物流分拣系统来直观理解。 在一个典型的物流分拣系统中&#xff0c;包裹会经过多个节点&#xff08;比如分拣中心、配送站&#xf…

别再乱搜了 这 5个宝藏AE模板网站,小白也能做出大片级动画

Hello&#xff0c;大家好&#xff0c;我是后期圈&#xff01; 今天来聊聊一个后期人都绕不开的话题&#xff1a;AE模板网站&#xff01;模板可是后期人的福音&#xff0c;无论你是想要惊艳的开场动画&#xff0c;酷炫的转场效果&#xff0c;还是个性化的文字特效&#xff0c;一…

CSS 编写位置详解及优先级分析

在前端开发中,CSS 的编写位置对项目的组织结构和维护性至关重要。不同的编写位置不仅影响代码的可读性和复用性,还决定了样式应用的优先级。 本文将根据编写位置的不同,详细介绍其定义、使用场景和优先级。 行内样式(Inline Styles) 行内样式(又称:内联样式)是将 CS…

ChatGPT 搜索 vs Google 搜索

原文&#xff1a;Amanda Caswell - 2024.11.01 随着 OpenAI 推出的实时搜索功能&#xff0c;ChatGPT 正在逐步成为像 Google 这样的传统搜索引擎的竞争对手。ChatGPT 以其对话式的回答方式而闻名&#xff0c;它能够在没有广告干扰的情况下提供实时的上下文信息。 我迫不及待地…

多进程的操作和案例

文章目录 高效编程一、多任务原理二、进程1、概念2、使用进程3、全局变量在多个子进程中不能共享4、启动大量子进程5、map方法6、单进程与多进程复制文件对比7、进程间通信8、进程实现生产者消费者9、案例&#xff08;抓取斗图&#xff09; 高效编程 一、多任务原理 概念 现代…

【更新中】《硬件架构的艺术》笔记(二):时钟与复位

本章主要针对ASIC设计给出建议&#xff0c;独立于CAD工具以及工艺&#xff0c;主要针对模块设计和存储器接口。 同步设计 这是对时钟域控制最安全的方法&#xff0c;单个主时钟和单个主置位/复位信号驱动设计中所有时序器件。 避免使用行波计数器 行波计数器&#xff1a;用…

Spring Boot编程训练系统:架构设计与技术选型

3系统分析 3.1可行性分析 通过对本编程训练系统实行的目的初步调查和分析&#xff0c;提出可行性方案并对其一一进行论证。我们在这里主要从技术可行性、经济可行性、操作可行性等方面进行分析。 3.1.1技术可行性 本编程训练系统采用SSM框架&#xff0c;JAVA作为开发语言&#…

DAY111PHP开发框架THIKNPHP反序列化POP利用链RCE执行文件删除

一、文件删除利用链分析 1、__destruct发现调用$this->removeFiles(); 2、removeFiles();函数方法file_exists&#xff0c;unlink($filename);文件删除功能 3、unserialize(base64_decode($_GET[id])); 有可控变量 4、pop文件删除利用链的使用 只有在这个类中调用 Files可…

如何使用亿图脑图MindMaster大纲功能

亿图脑图MindMaster作为一款出色的思维导图软件&#xff0c;具备丰富的编辑和展示功能。就拿大纲模式而言&#xff0c;用户可以清晰地浏览思维导图上的内容。因为大纲功能可以将思维导图上的内容以文档归纳的形式呈现出来&#xff0c;便于用户分类记忆。 自由切换思维导图模式…

Python的Eval函数执行结果和Lua脚本中LuaFunction的执行结果有何异同

最近在维护一个项目的时候&#xff0c;同时用到了Python和Lua两种脚本语言&#xff0c;发现很多有意思的东西&#xff0c;比如Python的Eval函数和Lua的LuaFunction函数&#xff0c;他们都是返回目标函数的句柄&#xff0c;那么在用法和机制上又有什么不同呢&#xff1f;为了全面…

DQN强化训练agent玩是男人就下xx层小游戏

游戏代码参考Python是男人就下一百层小游戏源代码_是男人就下一百层完整代码python-CSDN博客 在游戏作者代码基础上修改了下使该游戏在失败后能自动重新开始&#xff0c;方便后续能不间断训练 def reset_game(self):self.score 0self.end Falseself.last 6 * SIDEself.dire …

2024最新版JavaScript逆向爬虫教程-------基础篇之面向对象

目录 一、概念二、对象的创建和操作 2.1 JavaScript创建对象的方式2.2 对象属性操作的控制2.3 理解JavaScript创建对象 2.3.1 工厂模式2.3.2 构造函数2.3.3 原型构造函数 三、继承 3.1 通过原型链实现继承3.2 借用构造函数实现继承3.3 寄生组合式继承 3.3.1 对象的原型式继承…

网络编程示例之网络socket程序编程

注意&#xff1a;学习资料可在ElfBoard官方网站“资料”专区获取。 本节用到的源码路径&#xff1a;ELF 1开发板资料包->03-例程源码->03-1 命令行例程源码->05_elf1_cmd_net tcp协议程序 tcp_server.c 服务端仍然是按照如下顺序进行编写&#xff1a; socket()//创…

标准的渠道治理方法

在当今竞争激烈的市场环境中&#xff0c;品牌的渠道管理犹如一座大厦的基石&#xff0c;至关重要。而其中&#xff0c;对渠道价格的治理更是关键环节&#xff0c;直接关系到品牌的生死存亡与长远发展。 当品牌渠道中不幸出现低价、窜货链接时&#xff0c;一场关乎品牌未来走向…

双指针算法的妙用:提高代码效率的秘密(3)

双指针算法的妙用&#xff1a;提高代码效率的秘密&#xff08;3&#xff09; 前言&#xff1a; 小编在昨日讲述了关于双指针算法的两个题目&#xff0c;今日继续分享两个题目的解析&#xff0c;我相信&#xff0c;我只要坚持每天啥刷题&#xff0c;算法能力终究会提高的&…

动力商城-03 Idea集成apifox Mybatis-Plus字段策略

1.Idea下载apifox插件 2.新建令牌放入Idea 3.右键上传到对应接口 4.设置前置url 插件能够自动识别swagger注解 Mybatis-Plus字段策略 1、FieldStrategy作用 Mybatis-Plus字段策略FieldStrategy的作用主要是在进行新增、更新时&#xff0c;根据配置的策略判断是否对实体对…

11.11--final关键字和抽象类

一 java 1.final 关键字-----放在 访问修饰符后面 1&#xff09;防止被继承 2&#xff09;防止 父类方法 被重写 3&#xff09;防止 类中的 属性 被修改 4&#xff09;防止 局部属性 被修改 1.2.细节 1&#xff09;final 修饰属性 必须赋初值 ------------------------------…

IntelliJ+SpringBoot项目实战(三)---基于源代码直接生成漂亮的接口文档

在SpringBoot中可以集成代码插件自动生成接口文档&#xff0c;而且生成的文档很漂亮&#xff0c;除了接口功能介绍、传入参数、响应参数&#xff0c;还具体类似postman的功能&#xff0c;可调用接口进行测试&#xff0c;另外还可以下单WORD版、.md,html格式的文档。下面我们先看…

TemplatesImpl 在Shiro中的利用链学习1

一、前言 在前面的学习中&#xff0c;我们学习了CC1、CC6链&#xff0c;其中CC1链受限于Java8u71版本&#xff0c;而CC6则是通杀的利用链&#xff1b;后来又将 TemplateImpl 融入到 CommonsCollections 利用链中&#xff0c;绕过了 InvokerTransformer 不能使用的限制&#xf…