上位机图像处理和嵌入式模块部署(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已有的算法也是常有的事情。

相关推荐
萱仔学习自我记录1 小时前
PEFT库和transformers库在NLP大模型中的使用和常用方法详解
人工智能·机器学习
hsling松子4 小时前
使用PaddleHub智能生成,献上浓情国庆福
人工智能·算法·机器学习·语言模型·paddlepaddle
正在走向自律4 小时前
机器学习框架
人工智能·机器学习
好吃番茄5 小时前
U mamba配置问题;‘KeyError: ‘file_ending‘
人工智能·机器学习
CV-King5 小时前
opencv实战项目(三十):使用傅里叶变换进行图像边缘检测
人工智能·opencv·算法·计算机视觉
禁默5 小时前
2024年计算机视觉与艺术研讨会(CVA 2024)
人工智能·计算机视觉
whaosoft-1436 小时前
大模型~合集3
人工智能
Dream-Y.ocean6 小时前
文心智能体平台AgenBuilder | 搭建智能体:情感顾问叶晴
人工智能·智能体
丶21366 小时前
【CUDA】【PyTorch】安装 PyTorch 与 CUDA 11.7 的详细步骤
人工智能·pytorch·python
春末的南方城市7 小时前
FLUX的ID保持项目也来了! 字节开源PuLID-FLUX-v0.9.0,开启一致性风格写真新纪元!
人工智能·计算机视觉·stable diffusion·aigc·图像生成