利用OpenCV4.9制作自己的线性滤波器!

 返回:OpenCV系列文章目录(持续更新中......)

上一篇:OpenCV4.9使用 inRange 的阈值操作

下一篇 :OpenCV系列文章目录(持续更新中......)

目标

在本教程中,您将学习如何:

  • 使用 OpenCV 函数 filter2D()建您自己的线性过滤器。

理论

注意:

下面的解释属于 Bradski 和 Kaehler 的 Learning OpenCV 一书。

相关

从非常一般的意义上讲,关联是图像的每个部分与运算符(内核)之间的操作。

什么是内核?

内核本质上是一个固定大小的数值系数数组,以及该数组中的锚点,该锚点通常位于中心。

与内核的关联是如何工作的?

假设您想知道图像中特定位置的结果值。相关性的值按以下方式计算:

  1. 将内核锚点放在确定的像素上,内核的其余部分覆盖图像中相应的局部像素。
  2. 将核系数乘以相应的图像像素值,然后对结果求和。
  3. 将结果放置在输入图像中锚点的位置。
  4. 通过扫描整个图像上的内核,对所有像素重复该过程。

以等式的形式表示上述过程,我们将得到:

幸运的是,OpenCV 为您提供了 filter2D()函数,因此您不必编写所有这些操作。

这个程序是做什么的?

  • 加载图像
  • 执行规范化的框筛选器。例如,对于大小为 (size = 3) 的内核,内核为:

该程序将对大小为 3、5、7、9 和 11 的内核执行过滤器操作。

  • 筛选器输出(包括每个内核)将在 500 毫秒内显示

代码:

C++

教程代码如下行所示。

您也可以从这里下载

#include "opencv2/imgproc.hpp"
#include "opencv2/imgcodecs.hpp"
#include "opencv2/highgui.hpp"using namespace cv;int main ( int argc, char** argv )
{// Declare variablesMat src, dst;Mat kernel;Point anchor;double delta;int ddepth;int kernel_size;const char* window_name = "filter2D Demo";const char* imageName = argc >=2 ? argv[1] : "lena.jpg";// Loads an imagesrc = imread( samples::findFile( imageName ), IMREAD_COLOR ); // Load an imageif( src.empty() ){printf(" Error opening image\n");printf(" Program Arguments: [image_name -- default lena.jpg] \n");return EXIT_FAILURE;}// Initialize arguments for the filteranchor = Point( -1, -1 );delta = 0;ddepth = -1;// Loop - Will filter the image with different kernel sizes each 0.5 secondsint ind = 0;for(;;){// Update kernel size for a normalized box filterkernel_size = 3 + 2*( ind%5 );kernel = Mat::ones( kernel_size, kernel_size, CV_32F )/ (float)(kernel_size*kernel_size);// Apply filterfilter2D(src, dst, ddepth , kernel, anchor, delta, BORDER_DEFAULT );imshow( window_name, dst );char c = (char)waitKey(500);// Press 'ESC' to exit the programif( c == 27 ){ break; }ind++;}return EXIT_SUCCESS;
}

解释

C++

加载图像

 const char* imageName = argc >=2 ? argv[1] : "lena.jpg";// Loads an imagesrc = imread( samples::findFile( imageName ), IMREAD_COLOR ); // Load an imageif( src.empty() ){printf(" Error opening image\n");printf(" Program Arguments: [image_name -- default lena.jpg] \n");return EXIT_FAILURE;}

初始化参数

 // Initialize arguments for the filteranchor = Point( -1, -1 );delta = 0;ddepth = -1;

循环

执行无限循环,更新内核大小,并将线性滤波器应用于输入图像。让我们更详细地分析一下:

  • 首先,我们定义过滤器将使用的内核。在这里:
 // Update kernel size for a normalized box filterkernel_size = 3 + 2*( ind%5 );kernel = Mat::ones( kernel_size, kernel_size, CV_32F )/ (float)(kernel_size*kernel_size);

第一行是将kernel_size更新为以下范围内的奇数值:[3,11]。第二行实际上是通过将其值设置为填充1's 的矩阵并通过将其除以元素数对其进行归一化来构建内核的。

  • 设置完内核后,我们可以使用函数 filter2D()生成过滤器:
 // Apply filterfilter2D(src, dst, ddepth , kernel, anchor, delta, BORDER_DEFAULT );
  • 参数表示:
    • src:源图片
    • dst:目标图像
    • ddepthdst 的深度。负值(如 \(-1\))表示深度与源相同。
    • kernel:要通过图像扫描的内核
    • anchor:锚点相对于其内核的位置。位置 Point(-1, -1) 默认表示中心。
    • delta:在关联期间要添加到每个像素的值。默认情况下,它是 \(0\)
    • BORDER_DEFAULT:我们默认允许此值(以下教程中的更多详细信息)
  • 我们的程序将实现一个 while 循环,每 500 毫秒,我们过滤器的内核大小将在指示的范围内更新。

结果

  1. 编译上面的代码后,您可以执行它,并给出图像的路径作为参数。结果应为显示被归一化滤镜模糊的图像的窗口。每 0.5 秒,内核大小就会发生变化,如下面的一系列快照所示:

参考文献:

1:《Making your own linear filters!》---- Ana Huamán


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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

爬虫零基础学习,第一天,安装环境,requests库常用命令的讲解

Python爬虫 爬虫学习思路 URL内容获取,requests的基本常用语法 import requests # 先向目标网站发送请求 url "http://www.baidu.com" r requests.get(url) # 可以用看一下访问码返回值是不是200,若是200则表示访问成功 print(r.status_…

RustGUI学习(iced)之小部件(一):如何使用按钮和文本标签部件

前言 本专栏是学习Rust的GUI库iced的合集,将介绍iced涉及的各个小部件分别介绍,最后会汇总为一个总的程序。 iced是RustGUI中比较强大的一个,目前处于发展中(即版本可能会改变),本专栏基于版本0.12.1. 概述…

前端CSS基础8(盒子模型(margin、border、padding、content))

前端CSS基础8(盒子模型(margin、border、padding、content)) CSS盒子模型CSS中常用的长度单位元素的分类,各个元素的显示模式修改元素的显示模式(类型)盒子模型的组成部分盒子内容区-contentCSS…

关于分布式锁的释放和spring事务提交时机不符合预期从而带来的数据不一致的问题

提要 首先注意,本文探讨的不是分布式事务,请读者注意区分! 在我们的日常开发种,分布式锁和spring事务是常见的两种控制数据一致性的方式。 分布式锁和spring事务各自的作用就不做阐述了,不是本文重点,本文…

AIGC技术的发展现状与未来趋势

AIGC(人工智能生成内容)技术是近年来快速发展的领域之一,它涉及使用人工智能来创建或编辑内容,包括文本、图像、音乐和视频等。这项技术的进步为各个行业带来了革命性的变化,同时也引发了一系列伦理和风险问题。 一、技…

宜搜科技死磕港交所上市:从搜索引擎到广告投放,业绩疲态凸显

近日,宜搜科技控股有限公司(下称“宜搜科技”)向港交所递交招股书,计划在香港主板上市,中银国际为其独家保荐人。 值得注意的是,宜搜科技已在资本市场辗转多年。该公司曾于2014年向纽交所递交上市申请&…

CentOS7编译jsoncpp静态库

1. 官网下载源码 github地址:GitHub - open-source-parsers/jsoncpp at update 2. 编译 Unzip jsoncpp-master.zip Cd jsoncpp-master mkdir -p ./build/debug cd ./build/debug/ cmake -DCMAKE_BUILD_TYPEdebug -DBUILD_SHARED_LIBSOFF -DCMAKE_ARCHIVE_OUTPUT_D…

docker快速搭建部署mqtt

文章目录 前言一、mqtt是什么?二、使用步骤1.引入库2.创建临时容器3.创建挂在目录4.将临时容器的配置挂载到宿主机中5.删除临时容器6.运行容器并挂载文件7.登录EMQX内置的管理控制台 总结 前言 一、mqtt是什么? MQTT(Message Queuing Teleme…

Ts类型体操详讲 之 extends infer (下)

目录 1、函数 (1)提取参数类型 (2)提取返回值类型 2、构造器 (1)提取构造器返回值 (2)提取构造器参数类型 3、索引类型 本章我们继续上节的内容继续,展示我们对ex…

提升你的C编程技能:使用cURL下载Kwai视频

概述 本文将介绍如何利用C语言以及cURL库来实现Kwai视频的下载。cURL作为一个功能强大的网络传输工具,能够在C语言环境下轻松地实现数据的传输。我们还将探讨如何运用代理IP技术,提升爬虫的匿名性和效率,以适应Kwai视频平台的发展趋势。 正…

报告!这里发现了一个赛博炼丹的神级平台!

众所周知,“赛博炼丹”是一个AI开发研究领域古老又神秘的活动,它往往对炼丹平台有很高的要求。如果你也是一路从“炼丹小白”成长到“资深AI算法工程师”,那你一定懂我在说什么?说好了,天台见! GpuMall智算…

力扣HOT100 - 108. 将有序数组转换为二叉搜索树

解题思路: 二叉搜索树一般使用中序遍历 class Solution {public TreeNode sortedArrayToBST(int[] nums) {return helper(nums,0,nums.length-1);}public TreeNode helper(int[] nums,int left,int right){if(left>right) return null;//确定根节点//总是选择中…

【缓存服务】⭐️自定义实现一个简易的数据缓存

目录 🍸前言 🍻手写缓存服务 (1)缓存实体类 (2)缓存工具类 (3)测试缓存服务 🍷已有的缓存工具 🍹章末 🍸前言 俗话说 有轮子不用 就是玩 开个…

条件生成对抗网络(cGAN)在AI去衣技术中的应用探索

随着深度学习技术的飞速发展,生成对抗网络(GAN)作为其中的一个重要分支,在图像生成、图像修复等领域展现出了强大的能力。其中,条件生成对抗网络(cGAN)通过引入条件变量来控制生成模型的输出&am…

Spring SpringBoot(详解)

1. Spring简介 1.1 Spring 核心设计思想 1.1.1 Spring 是什么? Spring 是包含了众多⼯具⽅法的 IoC 容器。Spring 指的是 Spring Framework(Spring 框架),它是⼀个开源框架,Spring ⽀持⼴泛的应⽤场景,它…

手撕AVL树(map和set底层结构)(1)

troop主页 今日鸡汤:Action may out always bring happiness;but there is no happiness without action. 行动不一定能带来快乐,但不行动一定不行 C之路还很长 手撕AVL树 一 AVL树概念二 模拟实现AVL树2.1 AVL节点的定义 三 插入更新平衡因子&#xff0…

SpringBoot学习之Kafka下载安装和启动【Mac版本】(三十三)

一、配置Java环境变量 在启动Kafka之前,你需要先正确配置好你的Java环境变量。可以在终端输入java -version检查java环境变量是否配置正确,在Mac上如何配置java环境变量,请读者自行网上搜索操作之,此处不赘叙。 二、下载安装Kafka 1、下载Kafka:Apache Kafka,这两个版本…

四川赢涟电子商务有限公司深耕抖音电商服务

在当今数字化、网络化高速发展的时代,电子商务行业异军突起,成为推动经济增长的重要力量。四川赢涟电子商务有限公司凭借其敏锐的市场洞察力和创新精神,专注于抖音电商服务,致力于为广大消费者提供便捷、高效、个性化的购物体验&a…

Paddle 1.8 与 Paddle 2.0 API 映射表

安装2.6的paddlepaddle之后总是报fluid的错误,查询得知这个接口已经弃用了,但是一直找不到替换接口,偶然查询报错信息的时候找到了映射表,转存一下。 Paddle 1.8 与 Paddle 2.0 API 映射表

如何优雅地Spring事务编程

本文已收录至Github,推荐阅读 👉 Java随想录 微信公众号:Java随想录 在开发中,有时候我们需要对 Spring 事务的生命周期进行监控,比如在事务提交、回滚或挂起时触发特定的逻辑处理。那么如何实现这种定制化操作呢&am…