OpenCV4.8 开发实战系列专栏之 30 - OpenCV中的自定义滤波器

ops/2025/2/7 16:50:47/

欢迎大家学习OpenCV4.8 开发实战专栏,长期更新,不断分享源码。
专栏代码全部基于C++ 与Python双语演示。

送相关学习资料, V: OpenCVXueTang_Asst

本文关键知识点:OpenCV中的自定义滤波器

图像卷积最主要功能有图像模糊、锐化、梯度边缘等,前面已经分享图像卷积模糊的相关知识点,OpenCV除了支持上述的卷积模糊(均值与边缘保留)还支持自定义卷积核,实现自定义的滤波操作。自定义卷积核常见的主要是均值、锐化、梯度等算子。下面的三个自定义卷积核分别可以实现卷积的均值模糊、锐化、梯度功能。

在这里插入图片描述

在OpenCV中,自定义滤波器是一个强大的工具,它允许用户通过定义特定的卷积核(或称为内核、滤波器核)来实现各种图像卷积操作。这些操作包括图像模糊、锐化、梯度边缘检测等。以下是对这些功能的详细解释:

一、图像模糊

图像模糊通常通过低通滤波器实现,它允许低频信号通过,而高频信号(如边缘和噪点)则被削弱。在OpenCV中,可以使用cv2.filter2D()函数结合自定义的均值卷积核或高斯卷积核来实现图像模糊。

  • 均值模糊:使用均值卷积核,卷积核内的元素值相同,通常都设为1,然后除以卷积核的大小以进行归一化。这种模糊方法会均匀地平滑图像,但可能会导致边缘细节的丢失。
  • 高斯模糊:高斯模糊使用高斯函数作为权重分配的依据,距离中心越近的像素点权重越高。OpenCV提供了cv2.GaussianBlur()函数来直接实现高斯模糊,但也可以通过cv2.filter2D()与自定义的高斯卷积核结合使用。高斯模糊在平滑图像的同时能够更好地保留边缘细节。

二、图像锐化

图像锐化通常通过高通滤波器实现,它增强图像中的高频成分,从而使边缘和细节更加清晰。在OpenCV中,可以使用cv2.filter2D()函数结合自定义的锐化卷积核来实现图像锐化。一个常见的锐化卷积核是:

0 -1  0
-1  5 -1
0 -1  0

这个卷积核通过增加中心像素的权重并减去周围像素的权重来增强边缘。

三、梯度边缘检测

梯度边缘检测是通过计算图像中像素值的变化率来检测边缘的。在OpenCV中,可以使用Sobel算子、Scharr算子或Laplacian算子来实现梯度边缘检测。这些算子都是高通滤波器,能够突出图像中的边缘信息。

  • Sobel算子:Sobel算子是一种离散微分算子,用于计算图像灰度的一阶梯度。它结合了高斯平滑和微分求导,因此能够更好地抵抗噪声。OpenCV提供了cv2.Sobel()函数来直接实现Sobel边缘检测。
  • Scharr算子:Scharr算子是对Sobel算子的优化,它使用了更大的卷积核来提高边缘检测的准确性。在OpenCV中,cv2.Scharr()函数用于实现Scharr边缘检测。
  • Laplacian算子:Laplacian算子是一种二阶微分算子,用于检测图像中的边缘。它计算图像灰度的二阶导数,因此能够更敏感地捕捉到边缘信息。OpenCV提供了cv2.Laplacian()函数来直接实现Laplacian边缘检测。

此外,自定义滤波器还可以通过cv2.filter2D()函数结合自定义的梯度卷积核来实现梯度边缘检测。例如,一个简单的梯度卷积核可以是:

1  0
0 -1

这个卷积核能够计算出图像在水平方向上的梯度。

综上所述,OpenCV中的自定义滤波器通过定义特定的卷积核来实现各种图像卷积操作,包括图像模糊、锐化和梯度边缘检测等。这些操作在图像处理计算机视觉和机器学习等领域具有广泛的应用价值。

演示代码

#include <opencv2/opencv.hpp>
#include <iostream>using namespace cv;
using namespace std;int main(int artc, char** argv) {Mat src = imread("D:/images/test.png");if (src.empty()) {printf("could not load image...\n");return -1;}namedWindow("input", CV_WINDOW_AUTOSIZE);imshow("input", src);Mat kernel1 = Mat::ones(5, 5, CV_32F) / (float)(25);Mat kernel2 = (Mat_<char>(3, 3) << 0, -1, 0,-1, 5, -1,0, -1, 0);Mat kernel3 = (Mat_<int>(2, 2) << 1, 0, 0, -1);Mat dst1, dst2, dst3;filter2D(src, dst1, -1, kernel1);filter2D(src, dst2, -1, kernel2);filter2D(src, dst3, CV_32F, kernel3);convertScaleAbs(dst3, dst3);imshow("blur=5x5", dst1);imshow("shape=3x3", dst2);imshow("gradient=2x2", dst3);waitKey(0);return 0;
}

python 代码演示

import cv2 as cv
import numpy as npsrc = cv.imread("D:/images/test.png")
cv.namedWindow("input", cv.WINDOW_AUTOSIZE)
cv.imshow("input", src)blur_op = np.ones([5, 5], dtype=np.float32)/25.
shape_op = np.array([[0, -1, 0],[-1, 5, -1],[0, -1, 0]], np.float32)
grad_op = np.array([[1, 0],[0, -1]], dtype=np.float32)dst1 = cv.filter2D(src, -1, blur_op)
dst2 = cv.filter2D(src, -1, shape_op)
dst3 = cv.filter2D(src, cv.CV_32F, grad_op)
dst3 = cv.convertScaleAbs(dst3)cv.imshow("blur=5x5", dst1);
cv.imshow("shape=3x3", dst2);
cv.imshow("gradient=2x2", dst3);cv.waitKey(0)
cv.destroyAllWindows()

结束语

学习贵在坚持,学习OpenCV贵在每一天的代码练习,原理跟基本的函数解释,相关知识,后续更新边学边理解,搞技术永远要坚持做长期主义者!我们一起努力!!!

送相关学习资料,V: OpenCVXueTang_Asst


http://www.ppmy.cn/ops/156484.html

相关文章

ubuntu linux 内核锁定

Ubuntu的内核锁定操作&#xff1a; 查看已有内核&#xff1a; sudo dpkg --get-selections | grep linux-查看信息如下&#xff1a; 锁定对应版本内容&#xff1a; sudo apt-mark hold linux-image-<version> sudo apt-mark hold linux-headers-<version> sudo …

MySQL:表的设计原则和聚合函数

所属专栏&#xff1a;MySQL学习 ??1. 表的设计原则 1. 从需求中找到类&#xff0c;类对应到数据库中的实体&#xff0c;实体在数据库中表现为一张一张的表&#xff0c;类中的属性对应着表中的字段 2. 确定类与类的对应关系 3. 使用SQL去创建具体的表 范式&#xff1a;范式描述…

如何本地部署DeepSeek

第一步&#xff1a;安装ollama https://ollama.com/download 打开官网&#xff0c;选择对应版本 第二步&#xff1a;选择合适的模型 https://ollama.com/ 模型名称中的 1.5B、7B、8B 等数字代表模型的参数量&#xff08;Parameters&#xff09;&#xff0c;其中 B 是英文 B…

LabVIEW如何高频采集温度数据?

在LabVIEW中进行高频温度数据采集时&#xff0c;选择合适的传感器&#xff08;如热电偶或热电阻&#xff09;和采集硬件是关键。下面是一些建议&#xff0c;帮助实现高效的温度数据采集&#xff1a; 1. 传感器选择&#xff1a; 热电偶&#xff08;Thermocouple&#xff09;&am…

vim-plug的自动安装与基本使用介绍

vim-plug介绍 Vim-plug 是一个轻量级的 Vim 插件管理器&#xff0c;它允许你轻松地管理 Vim 插件的安装、更新和卸载。相较于其他插件管理器&#xff0c;vim-plug 的优点是简单易用&#xff0c;速度较快&#xff0c;而且支持懒加载插件&#xff08;即按需加载&#xff09; 自动…

Day48_20250130【回校继续打卡】_单调栈part1_739.每日温度|496.下一个更大元素I|503.下一个更大元素II

Day48_20250130_单调栈part1_739.每日温度|496.下一个更大元素I|503.下一个更大元素II 20250130补完 739.每日温度 题目 给定一个整数数组 temperatures &#xff0c;表示每天的温度&#xff0c;返回一个数组 answer &#xff0c;其中 answer[i] 是指对于第 i 天&#xff0…

Java设计模式---策略模式

策略模式&#xff08;Strategy Pattern&#xff09;是一种行为设计模式&#xff0c;它定义了一系列算法&#xff08;或策略&#xff09;&#xff0c;并将每个算法封装起来&#xff0c;使得它们可以互相替换。策略模式允许算法的变化独立于使用算法的客户&#xff08;即客户端代…

【ThreeJS 01】了解 WebGL 以及 ThreeJS

文章目录 01 介绍02 什么是 WebGL&#xff0c;为什么用 ThreeJS什么是 WebGL&#xff1f;Three.js 来帮忙 01 介绍 这个课程的主讲人是 Bruno Simon&#xff0c; 这是他的作品集 他还做了一些有趣的项目&#xff1a; https://my-room-in-3d.vercel.app https://organic-sphe…