当前位置: 首页 > news >正文

OpenCV图像平滑处理方法详解

引言
在数字图像处理中,图像平滑是一项基础而重要的预处理技术。它主要用于消除图像中的噪声、减少细节层次,为后续的图像分析(如边缘检测、目标识别等)创造更好的条件。OpenCV作为最流行的计算机视觉库之一,提供了多种图像平滑方法。本文将详细介绍这些方法及其应用场景。

一、什么是图像平滑?
图像平滑(Image Smoothing)是指通过特定的算法对图像进行模糊处理,从而达到降噪、去除细节或预处理的目的。这种处理虽然会使图像变得"模糊",但在许多计算机视觉任务中却能带来更好的处理效果。

二、常见的图像平滑方法
1.先对图片加上噪声点

import cv2
import numpy as np
def add_peppersalt_noise(image,n=1000):result = image.copy()h,w = image.shape[:2]   #获取图片的高和宽for i in range(n):   #生成n个椒盐噪声x = np.random.randint(1,h)y = np.random.randint(1,w)if np.random.randint(0,2) == 0:result[x,y] = 0else:result[x,y] = 255return resultimage = cv2.imread('zhaoyun.jpg')
cv2.imshow('yuantu',image)
cv2.waitKey(0)noise = add_peppersalt_noise(image)
cv2.imshow('noise',noise)
cv2.waitKey(0)

2. 均值滤波(Averaging)

 dst=cv2.blur(src,ksize,anchor,borderType)dst是返回值src是需要处理的图像ksize是滤波核(卷积核)的大小anchor是锚点,默认值是(-1,-1)一般无需更改borderType是边界样式,一般无需更改一般情况下,使用dst=cv2.blur(src,ksize)即可

均值滤波是最简单的线性滤波方法,它用像素点邻域的平均值来代替该像素点的值。

blur_1 = cv2.blur(noise,(3,3))   #卷积核为3,3   效果一般,清晰度一般
cv2.imshow('blur_1',blur_1)
cv2.waitKey(0)blur_2 = cv2.blur(noise,(5,5))   #卷积核为5,5   效果稍好但模糊
cv2.imshow('blur_2',blur_2)
cv2.waitKey(0)
cv2.destroyAllWindows()

特点

  • 算法简单,计算速度快
  • 对高斯噪声有较好的效果
  • 会导致图像边缘模糊

3. 方框滤波(boxFilter)

 dst=cv2.boxFilter(src,deepth,ksize,anchor,normalize,borderType)式中:dst是返回值,表示及进行方框滤波后得到的处理结果。src是需要处理的图像,即原始图像deepth是处理结果图像的图像深度,一般使用-1表示与原始图像使用相同的图像深度。(可以理解为数据类型)ksize是滤波核(卷积核)的大小anchor是锚点(指对应哪个区域),默认值是(-1,-1)一般无需更改normalize 表示在滤波时是否进行归一化。1.当为True时,归一化,用邻域像素值的和除以面级。 此时方框滤波与均值滤波效果相同。2.当为False时,不归一化,直接使用邻域像素值的和。和>255时使用255。

方框滤波在平滑图像的同时能很好地保留边缘信息,结合了空间邻近度和像素值相似度。

boxFilter_1 = cv2.boxFilter(noise,-1,(3,3),normalize=True)
cv2.imshow('boxFilter_1',boxFilter_1)
cv2.waitKey(0)
boxFilter_2 = cv2.boxFilter(noise,-1,(3,3),normalize=False)
cv2.imshow('boxFilter_2',boxFilter_2)
cv2.waitKey(0)

4. 中值滤波(Median Blur)

中值滤波用邻域的中值代替中心像素的值,是一种非线性滤波方法。

medianB = cv2.medianBlur(noise,3)
cv2.imshow('medianBlur',medianB)
cv2.waitKey(0)
cv2.destroyAllWindows()

5. 高斯滤波(Gaussian Blur)

dst=cv2.GaussianBlur(src,ksize[,sigmaX[,sigmaY[,dst]]]) 高斯滤波
# 参数说明:
# src:输入图像,通常是一个NumPy数组
# ksize:滤波器的大小,它是一个元组,表示在水平和垂直方向上的像素数量。例如(5,5)表示一个5×5的滤波器。
# sigmaX和sigmaY:分别表示在X轴和Y轴方向上的标准差。这些值与滤波器大小相同。默认情况下,他们都等于0,这意味着没有高斯模糊。
# dst:输出图像,通常是一个NumPy数组。如果位None,则会创建一个新的数组来存储结果。

高斯滤波是一种加权平均滤波,离中心点越近的像素权重越大,符合高斯分布。

GaussianB = cv2.GaussianBlur(noise,(3,3),1)  
cv2.imshow('GaussianBlur',GaussianB)
cv2.waitKey(0)

特点:
对高斯噪声有很好的去除效果
比均值滤波更能保留边缘信息
是许多计算机视觉任务的首选平滑方法
三、方法比较与选择指南
方法    优点    缺点    适用场景
均值滤波    简单快速    边缘模糊严重    快速预处理,不关心边缘
高斯滤波    平滑效果好,计算较快    对椒盐噪声效果一般    通用平滑处理,特别是高斯噪声
中值滤波    对椒盐噪声效果好    计算量较大    去除椒盐噪声
方框滤波    边缘保持好    计算复杂度高    需要保留边缘的去噪
四、总结
图像平滑是计算机视觉预处理的重要步骤。OpenCV提供了多种平滑方法,各有特点和适用场景。在实际应用中,应根据噪声类型、边缘保持需求和计算资源等因素选择合适的方法。理解这些方法的原理和特点,能够帮助我们在实际项目中做出更合理的选择。

希望本文能帮助您更好地理解和应用OpenCV中的图像平滑技术。在实践中多尝试不同的方法和参数,观察它们的效果差异,这将有助于您掌握这些技术的精髓。

六、2D卷积
​ OpenCV提供了多种滤波方式,来是实现平滑图像的效果,例如均值滤波、方框滤波、高斯滤波、中值滤波等。大多数滤波方式所使用的卷积核都具有一定的灵活性,能够方便地设置卷积核的大小和数量。但是,我们有时候希望使用特定的卷积核来实现卷积操作,例如使用如下卷积核来进行卷积操作。

前面介绍过的滤波函数都无法将卷积核确定为上述形式,这时要使用OpenCV的自定义卷积函数。

​ 在OpenCV中,允许用户自定义卷积核实现卷积操作,使用自定义卷积核实现卷积操作的函数是cv2.filer2D(),其语法格式为:

dst = cv2.filter2D(src, ddepth, kernel, anchor, delta, borderType)

dst:返回值,均值滤波处理后得到的处理结果。

src:需要处理的图像,即原始图像。可以有任意数量的通道,并能对各个通道独立处理。图像的深度应该是CV_8U、CV_16U、CV_16S、CV_32F、CV_64F中的一种。

ddepth:结果图像的图像深度,一般使用-1表示与原始图像使用相同的图像深度。

kenel:卷积核,是一个单通道的数组。如果想在处理彩色图像时,让每个通道使用不同的核,则必须将彩色图像分解后使用不同的核进行操作。

anchor:锚点,其默认值是(-1,-1), 表示当前计算均值的点位于核的中心点位置,改制使用默认值即可,在特殊情况下可以指定不同的点作为锚点。

delta:修正值。可选项,如果该值存在,会在基础滤波的结果上加上该值作为最终的滤波处理结果。

borderType:边界样式,该值决定了以何种方式来处理边界。一般情况下,不需要考虑该值,直接采用默认值。

通常情况下,使用滤波函数cv2.filter2D()时,对于参数anchor、delta、borderType直接采用默认值即可。

示例: 自定义一个卷积核,通过函数cv2.filter2D()应用该卷积核对图像进行滤波操作,并显示滤波结果。

http://www.lryc.cn/news/620755.html

相关文章:

  • tp5集成elasticsearch笔记
  • 开疆智能Ethernet转ModbusTCP网关连接UR机器人配置案例
  • ComfyUI工作流不动了?
  • OpenCV 形态学操作
  • Spring AI PagePdfDocumentReader 全解析:基于 Apache PdfBox 的按页 PDF 读取实战
  • COLMAP进行密集重建,三维重建的步骤
  • [机器学习]08-基于逻辑回归模型的鸢尾花数据集分类
  • AUTOSAR汽车电子嵌入式编程精讲300篇-【自动驾驶】硬件在环(HIL)(二)
  • 第四天~在CANFD或CAN2.0的ARXML文件中实现Multiplexor多路复用信号实战
  • 依托AR远程协助,沟通协作,高效流畅
  • 读From GPT-2 to gpt-oss: Analyzing the Architectural Advances
  • 第四天-创建一个Classic CAN(经典CAN2.0)/CANFD的系统描述ARXML文件
  • IDEA、Pycharm、DataGrip等激活破解冲突问题解决方案之一
  • 学习设计模式《二十二》——职责链模式
  • 深入了解linux系统—— 线程概念
  • 深入解析 Spring IOC 容器在 Web 环境中的启动机制
  • 嵌入式学习Day27
  • stm32项目(29)——基于stm32的智能眼镜设计
  • 【代码随想录day 20】 力扣 108.将有序数组转换为二叉搜索树
  • SwiftUI 页面弹窗操作
  • Linux网络编程:应用层自定义协议与序列化
  • Flutter sqflite插件
  • 支付域——账户系统设计
  • 支持pcm语音文件缓存顺序播放
  • 解剖HashMap的put <四> jdk1.8
  • OpenCv(二)——边界填充、阈值处理
  • Nacos 配置热更新:Spring Boot Bean 自动获取最新配置
  • flutter3.7.12版本设置TextField的contextMenuBuilder的文字颜色
  • MixOne在macOS上安装碰到的问题
  • 解决SQL Server连接失败:Connection refused: connect