上位机图像处理和嵌入式模块部署(qmacvisual非opencv算法编写)

【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing @163.com】

我们都知道,qmacvisual本身依赖于qt+opencv的实现。大部分的界面都是依赖于qt的实现。图像算法部分,也是大部分都依赖于opencv本身。但是,也有很多的算法,本身opencv是没有实现的,或者opencv的实现不满足我们的需求。这个时候,就需要我们自己利用cv::Mat结构来对像素进行一个一个的处理。今天,我们可以借着学习图像细化的机会,来看看怎么编写非opencv算法。

1、创建项目和创建流程

首先,还是根据qmacvisual的要求去创建项目和创建流程。

2、导入图像细化控件

图像细化控件的位置,在图像处理下面。用户可以直接用鼠标拖拉过来,如果不出意外,我们就可以看到这样的窗口,

图像中有两个地方需要配置,一个是输入的图像,一个是需要迭代的次数。我们看到,迭代之后的结果就是这样的一个细长的线条。大家可以想象下,它之前的图象是什么样的,

大家可以通过对比发现,整个图像细化的效果还是比较明显的。

3、完善测试流程

一般测试的时候,会添加一个图像显示的插件,这样流程比较完整一点。所以,最后整体的流程是这样的,

4、分析图像实现的实现

如果只是简单地分析功能,整个图像处理的流程还是比较简单的。我们比较关注的,更多的是整个功能怎么实现的。前面说过,它的算法是通过具体像素操作实现的,而不是opencv自带的算法。所以,在对应的实现函数中看到了这样的代码。

访问单个元素的话,可以这样来访问,即通过i和j,

复制代码
cv::Mat dst;
dst.at<uchar>(i, j) = 0;

代码中dst是cv::Mat结构。这种方法看上去没有什么问题,但是如果连续访问的话,效率比较低。因此,还有一种方法,就是通过首地址,即先访问一个元素的地址,后续通过这个地址来访问其他的像素。

复制代码
cv::Mat tmpimg;
uchar* img = tmpimg.data;

5,另外一种需要自定义算法的情形

如果opencv中没有相关的算法,这个时候用c/c++语言来实现,无可厚非。但是还有一种也是比较常见的,那就是opencv本身已经实现了相关的算法,但是我们用c/c++还要实现一遍。甚至很多的时候,还用汇编改写一遍。这里面最大的考虑就是效率。因为opencv里面的算法,主要是基于c/c++高级语言来完成的,它没有办法考虑不同硬件平台的差异。这个时候,为了提高算法的运行效率,最大化使用硬件的性能,改写opencv已有的算法也是常有的事情。

相关推荐
大猪宝宝学AI6 分钟前
【AI Infra】SonicMoE论文笔记
论文阅读·人工智能·性能优化
sww_102613 分钟前
Spring-AI和LangChain4j区别
java·人工智能·spring
Coovally AI模型快速验证21 分钟前
超越Sora的开源思路:如何用预训练组件高效训练你的视频扩散模型?(附训练代码)
人工智能·算法·yolo·计算机视觉·音视频·无人机
GitCode官方32 分钟前
参会预告 | AtomGit 邀您共赴 TritonNext 2026 技术大会,解锁 AI 系统与编译生态新机遇
人工智能·开源·atomgit
MobiusStack41 分钟前
Cursor团队最新文章解读丨动态上下文发现,重新定义AI记忆
人工智能
Rui_Freely1 小时前
Vins-Fusion之 相机—IMU在线标定(十一)
人工智能·算法·计算机视觉
沛沛老爹1 小时前
Web开发者5分钟上手:Agent Skills环境搭建与基础使用实战
java·人工智能·llm·llama·rag·agent skills
DeepFlow 零侵扰全栈可观测1 小时前
3分钟定位OA系统GC瓶颈:DeepFlow全栈可观测平台实战解析
大数据·运维·人工智能·云原生·性能优化
想用offer打牌1 小时前
一站式讲清Spring AI Alibaba的OverAllState和RunnableConfig
人工智能·架构·github
生成论实验室1 小时前
生成论之基:“阴阳”作为元规则的重构与证成——基于《易经》与《道德经》的古典重诠与现代显象
人工智能·科技·神经网络·算法·架构