首页 > 其他分享 >OpenCV 图像处理中滤波技术介绍

OpenCV 图像处理中滤波技术介绍

时间:2024-08-25 21:54:27浏览次数:18  
标签:滤波器 Mat image 滤波 OpenCV 图像处理 图像 cv

VS2022配置OpenCV环境

  1. 关于OpenCV在VS2022上配置的教程可以参考:VS2022 配置OpenCV开发环境详细教程

图像处理中滤波技术

图像滤波是图像处理中的一种重要技术,用于改善图像质量或提取图像中的特定特征。以下是一些常见的图像滤波技术:

  1. 均值滤波(Mean Filter)

    • 简单且广泛使用的线性滤波器,用于平滑图像并减少噪声。
    • 通过将每个像素值替换为该像素周围邻域内像素值的平均值来实现。
  2. 高斯滤波(Gaussian Filter)

    • 一种权重滤波器,使用高斯函数作为权重,对图像进行平滑处理。
    • 高斯滤波器对图像的边缘和细节有较好的保留效果。
  3. 中值滤波(Median Filter)

    • 一种非线性滤波器,通过替换每个像素值为其邻域内的中值来减少噪声。
    • 对于椒盐噪声(salt-and-pepper noise)特别有效。
  4. 锐化滤波(Sharpening Filter)

    • 通过增强图像中的高频成分来提高图像的清晰度。
    • 常用的锐化滤波器包括拉普拉斯滤波器。
  5. 拉普拉斯滤波(Laplacian Filter)

    • 用于边缘检测,通过突出图像中的二阶导数来实现。
    • 拉普拉斯滤波器可以增强图像的边缘,但也可能放大噪声。
  6. 双边滤波(Bilateral Filter)

    • 结合了均值滤波和高斯滤波的优点,同时保留了边缘信息。
    • 它根据像素的强度和空间距离进行加权,以平滑图像而不模糊边缘。
  7. 高通滤波(High-pass Filter)

    • 允许高频信号通过,阻止低频信号。
    • 在图像处理中,通常用于突出边缘和细节。
  8. 低通滤波(Low-pass Filter)

    • 与高通滤波器相反,允许低频信号通过,阻止高频信号。
    • 用于图像平滑和去噪。
  9. 傅里叶变换滤波(Fourier Transform Filtering)

    • 使用傅里叶变换将图像从空间域转换到频率域。
    • 在频率域中应用滤波器,然后通过逆傅里叶变换将图像转换回空间域。
  10. 形态学滤波(Morphological Filtering)

    • 包括膨胀(Dilation)、腐蚀(Erosion)、开运算(Opening)、闭运算(Closing)等。
    • 用于图像的形态学操作,如去除小的不规则性或连接断裂的区域。

每种滤波技术都有其特定的应用场景和效果。选择合适的滤波器取决于图像的特性和处理目标。例如,高斯滤波适合于平滑图像和去除高斯噪声,而中值滤波则更适合于去除椒盐噪声。在实际应用中,可能需要结合多种滤波技术来达到最佳效果。

均值滤波

  1. 介绍:均值滤波是最简单的滤波器之一,它将每个像素的值替换为其邻域内所有像素值的平均值。
  2. 函数:blur()
  3. c++ demo:
#include <opencv2/opencv.hpp>

int main() {
    cv::Mat image, blur_image;
    image = cv::imread("amy.png", cv::IMREAD_COLOR);
    cv::blur(image, blur_image, cv::Size(5, 5)); // 5x5的均值滤波
    cv::imshow("blur_image", blur_image);
    cv::waitKey(0); // 等待用户按键
    return 0;
}
  • 结果:
    在这里插入图片描述

高斯滤波

  1. 介绍: 高斯滤波使用高斯函数作为权重来计算邻域内像素的平均值,对图像进行平滑。
  2. 函数:GaussianBlur()
  3. c++ demo
#include <opencv2/opencv.hpp>

int main() {
    cv::Mat image, gaussian_image;
    image = cv::imread("amy.png", cv::IMREAD_COLOR);
    cv::GaussianBlur(image, gaussian_image, cv::Size(5, 5), 0); // 5x5的高斯滤波
    cv::imshow("gaussian_image", gaussian_image);
    cv::waitKey(0); // 等待用户按键
    return 0;
}
  • 结果:
    在这里插入图片描述

中值滤波

  1. 介绍:中值滤波是一种非线性滤波器,它将每个像素替换为其邻域内所有像素值的中值,对椒盐噪声非常有效。
  2. 函数:medianBlur()
  3. c++ demo
#include <opencv2/opencv.hpp>

int main() {
    cv::Mat image, median_image;
    image = cv::imread("amy.png", cv::IMREAD_COLOR);
    cv::medianBlur(image, median_image, 5); // 5x5的中值滤波
    cv::imshow("median_image", median_image);
    cv::waitKey(0); // 等待用户按键
    return 0;
}
  • 结果:
    在这里插入图片描述

双边滤波

  1. 介绍:双边滤波在平滑图像的同时保留边缘,它根据像素值的接近度和空间距离来加权。
  2. 函数:bilateralFilter()
  3. c++ demo
#include <opencv2/opencv.hpp>

int main() {
    cv::Mat image, bilateral_image;
    image = cv::imread("amy.png", cv::IMREAD_COLOR);
    cv::bilateralFilter(image, bilateral_image, 9, 75, 75); // 9x9的双边滤波
    cv::imshow("bilateral_image", bilateral_image);
    cv::waitKey(0); // 等待用户按键
    return 0;
}
  • 结果:
    在这里插入图片描述

锐化滤波

  1. 介绍:锐化滤波通过增强图像的高频分量来使图像看起来更清晰。
  2. 函数:filter2D()
  3. c++ demo
#include <opencv2/opencv.hpp>

int main() {
    cv::Mat image, sharpen_image;
    image = cv::imread("amy.png", cv::IMREAD_COLOR);
    cv::Mat kernel = (cv::Mat_<char>(3, 3) << 0, -1, 0,
        -1, 5, -1,
        0, -1, 0);
    cv::filter2D(image, sharpen_image, image.depth(), kernel);
    cv::imshow("sharpen_image", sharpen_image);
    cv::waitKey(0); // 等待用户按键
    return 0;
}
  • 结果:
    在这里插入图片描述

拉普拉斯滤波

  1. 介绍:拉普拉斯滤波是一种边缘增强的线性滤波器,它使用拉普拉斯算子来突出图像的二阶导数。
  2. 函数
  3. c++ demo:
#include <opencv2/opencv.hpp>

int main() {
    cv::Mat image, laplacian_image;
    image = cv::imread("amy.png", cv::IMREAD_COLOR);
    cv::Laplacian(image, laplacian_image, CV_16S, 1);
    cv::convertScaleAbs(laplacian_image, laplacian_image); // 转换为无符号8位
    cv::imshow("laplacian_image", laplacian_image);
    cv::waitKey(0); // 等待用户按键
    return 0;
}
  • 结果:
    在这里插入图片描述

方框滤波

  1. 介绍:方框滤波是一种简单的线性滤波器,它将每个像素的值替换为其邻域内所有像素值的总和除以邻域大小。
  2. 函数:blur()
  3. c++ demo
#include <opencv2/opencv.hpp>

int main() {
    cv::Mat src_image, box_image;
    src_image = cv::imread("amy.png", cv::IMREAD_COLOR);
    cv::blur(src_image, box_image, cv::Size(3, 3), cv::Point(-1, -1), 
    cv::BORDER_DEFAULT);
    cv::imshow("box_image", box_image);
    cv::waitKey(0); // 等待用户按键
    return 0;
}
  • 结果:
    在这里插入图片描述

自定义滤波器

  1. 介绍:可以创建自定义的滤波器核来应用特定的效果。

  2. 函数:filter2D

  3. c++ demo

#include <opencv2/opencv.hpp>

int main() {
    cv::Mat src_image, custom_filtered_image;
    src_image = cv::imread("amy.png", cv::IMREAD_COLOR);
    cv::Mat custom_kernel = (cv::Mat_<float>(3, 3) << 1, 1, 1,
        1, 0, 1,
        1, 1, 1);
    cv::filter2D(src_image, custom_filtered_image, src_image.depth(), custom_kernel);
    cv::imshow("custom_filtered_image", custom_filtered_image);
    cv::waitKey(0); // 等待用户按键
    return 0;
}
  • 结果:
    在这里插入图片描述

标签:滤波器,Mat,image,滤波,OpenCV,图像处理,图像,cv
From: https://blog.csdn.net/yanceyxin/article/details/141535002

相关文章

  • 《机器学习》—— OpenCV 对图片的各种操作
    文章目录1、安装OpenCV库2、读取、显示、查看图片3、对图片进行切割4、改变图像的大小5、图片打码6、图片组合7、图像运算8、图像加权运算1、安装OpenCV库使用pip是最简单、最快捷的安装方式pipinstallopencv-python==3.4.2还需要安装一个包含了其他一些图像......
  • opencv-python图像增强十五:高级滤镜实现
    文章目录前言二、鲜食滤镜三、巧克力滤镜三,冷艳滤镜:前言在之前两个滤镜文章中介绍了六种简单的滤镜实现,它们大多都是由一个单独函数实现的接下来介绍五种结合了之前图像增强文章提的的算法的复合滤镜。本案例中的算法来自于文章一,文章二,文章三,感兴趣的小伙伴可以看......
  • 最全!万字长文总结opencv-python常用函数(一)
    文章目录一,简介:二,图像的基础操作:2.1,图像的读取显示与保存2.1.1图像的读取cv2.imread:2.1.2图像的显示cv2.imshow与等待cv2.waitKey:2.1.3图像保存cv2.imwrite:2.2,图像属性获取:2.3,图像裁剪cv2.selectROI:2.4,图像通道的拆分cv2.split:2.5,图像通道的合并cv2.merge:三,图像的数值......
  • win10系统c++与opencv 依赖环境配置
    一、VSC++配置opencv库1、下载opencv(https://sourceforge.net/projects/opencvlibrary/files/opencv-win/3.3.0/)2、在官网下载opencv3.3.0.exe文件然后解压到D盘D:\opencv3、配置系统环境:①添加环境变量:控制面板-系统-高级系统设置-环境变量-系统变量Path中添加下......
  • 017、二级Java知识点之Java Applet与图像处理:从基础到应用
    JavaApplet与图像处理:从基础到应用1.题目解析先来详细解析题目中给出的代码示例:importjava.____.*;importjava.awt.*;importjava.net.*;publicclassImageDemoextendsApplet{privateImageimage;publicvoid______(){Stringimage......
  • 十五、OpenCVSharp实现相机标定
    文章目录简介一、相机模型1.针孔相机模型2.畸变模型(径向畸变、切向畸变)二、标定板的设计和使用1.常见的标定板类型(如棋盘格、圆形标定板)2.标定板图像的采集要求三、相机标定的步骤1.角点检测和提取2.求解相机内参和外参3.标定结果的评估和优......
  • 机器视觉学习笔记和过程记录:下载安装OpenCv
    下载安装opencv1、本机已经安装了anaconda,打开对应的环境下的命令行窗口,输入python后回车,会显示python版本,本机是3.8.3:2、打开链接:Linksforopencv-python ,在网页中查找与python版本和操作系统对应的opencv版本: 本机python是3.8,系统是64位win10,所以选择opencv_python-3......
  • OpenCV——第三章(图形的绘制)
    1.线段的绘制line()方法的语法格式如下:img=cv2.line(img,pt1,pt2,color,thickness)#参数说明#img:画布#pt1:线段的起点坐标#pt2:线段的终点坐标#color:线条颜色#thickness:线条宽度接下来我们使用该方法绘制一个图形吧!!!importnumpyasnpimportcv2......
  • 计算机毕业设计opencv+pytorch疲劳驾驶检测系统 自动驾驶 面部多信息特征融合的疲劳驾
    创新点:算法模型训练、可视化、深度学习框架、疲劳监测、模拟自动驾驶检测驾驶员疲劳核心算法:基于多信息特征指标融合建立驾驶员疲劳评价体系通过构建一种驾驶员面部多信息特征融合综合评价方法,为了能够将系统检测结果更直观的体现,研究了基于一种改进的粗糙集理论对各项特征结......
  • 【漫谈C语言和嵌入式027】探索信号处理的秘密:低通滤波器与高通滤波器的深度解析
            在嵌入式系统和数字信号处理领域,滤波器(Filter)是至关重要的工具。它们是用于处理和优化信号的基础组件,能够有效地控制信号的频率分布。滤波器的类型多种多样,其中最为基础且常用的便是低通滤波器(Low-PassFilter,LPF)和高通滤波器(High-PassFilter,HPF)。本文将......