图像平滑处理

文章目录

一、理解图像平滑处理的意义

图像平滑处理,也称为图像模糊处理,是一种用于减少图像噪声和细节的图像处理技术。平滑处理的目的通常是为了消除图像中的随机噪声,减少图像中的高频成分,或者在保持图像整体外观的同时减少图像的对比度。常见的图像平滑技术:均值滤波、高斯滤波、模糊滤波等。

通过图像平滑处理,可以减少或消除图像中的随机噪声,减少图像的细节,例如在压缩图像前进行平滑处理,在去除噪声的同时尽量保留图像的边缘信息。

用以下这张图片来展示:

可以看到图片中有很多白色的小斑点。

二、均值滤波

bash 复制代码
# 导入OpenCV库,用于图像处理
import cv2
# 导入matplotlib的pyplot模块,用于图像显示
import matplotlib.pyplot as plt
# 导入numpy库,用于数值计算
import numpy as np

# 使用cv2.imread()函数读取位于指定路径的图像文件
img = cv2.imread("E:\\XUEXI\\Python_learn\\tupian\\6.jpg")

# 定义一个函数cv_show,用于显示图像
def cv_show(name, img):
    # 使用cv2.imshow()函数显示图像,名称为name
    cv2.imshow(name, img)
    # 使用cv2.waitKey(0)函数等待,直到用户按下任意键
    cv2.waitKey(0)
    # 使用cv2.destroyAllWindows()函数关闭所有OpenCV创建的窗口
    cv2.destroyAllWindows()

# 使用cv2.blur()函数对图像进行均值滤波
# (3, 3)指定了滤波器的大小,即3x3的邻域窗口
blur = cv2.blur(img, (3, 3))

# 调用cv_show函数显示均值滤波后的图像
cv_show("blur", blur)

cv2.blur()函数对图像进行均值滤波

blur = cv2.blur(img, (3, 3))(3, 3)指定了滤波器的大小,即3x3的邻域窗口,如果是均值滤波,那么就是要(3x3)中的所有值全部加起来,然后除以9,来求得均值。

运行结果:

可以看到图片中的小白点被淡化了许多。

三、方框滤波

方框滤波基本和均值滤波一样,但是能选择是否归一化

bash 复制代码
# 导入OpenCV库,用于图像处理
import cv2
# 导入matplotlib的pyplot模块,用于图像显示
import matplotlib.pyplot as plt
# 导入numpy库,用于数值计算
import numpy as np

# 使用cv2.imread()函数读取位于指定路径的图像文件
img = cv2.imread("E:\\XUEXI\\Python_learn\\tupian\\6.jpg")

# 定义一个函数cv_show,用于显示图像
def cv_show(name, img):
    # 使用cv2.imshow()函数显示图像,名称为name
    cv2.imshow(name, img)
    # 使用cv2.waitKey(0)函数等待,直到用户按下任意键
    cv2.waitKey(0)
    # 使用cv2.destroyAllWindows()函数关闭所有OpenCV创建的窗口
    cv2.destroyAllWindows()

# 使用cv2.boxFilter()函数对图像进行均值滤波
# 第一个参数是输入图像
# 第二个参数-1表示输出图像的深度与输入图像相同
# (3, 3)是滤波器的大小,即3x3的邻域窗口
# normalize=True表示滤波器的权重之和为1,这是均值滤波的要求
box = cv2.boxFilter(img, -1, (3, 3), normalize=True)

# 调用cv_show函数显示均值滤波后的图像
cv_show("box", box)

box = cv2.boxFilter(img, -1, (3, 3), normalize=True)python当中,指定一个值为-1,一般就是自动计算的意思。

方框滤波多一个参数(normalize),这个参数可以做归一化操作,就是当数值超过255后,就会除以相加数的总和,如果是(3x3)那就是除以9,做了归一化后就是跟均值滤波是一样效果的。

运行结果与均值滤波相同:

如果不选择做归一化,那么越界的值就直接取到255,也就是最高曝光的值:

bash 复制代码
#不同算子的差异
import cv2
import matplotlib.pyplot as plt
import numpy as np

img = cv2.imread("E:\\XUEXI\\Python_learn\\tupian\\6.jpg")

def cv_show(name, img):
    cv2.imshow(name, img)
    cv2.waitKey(0)
    cv2.destroyAllWindows()

box = cv2.boxFilter(img, -1, (3, 3), normalize=False)

cv_show("box",box)

运行结果:

四、高斯滤波

高斯滤波基于高斯分布(Gaussian Distribution),也称为正态分布,是一种在自然现象中普遍存在的连续概率分布。

高斯滤波的操作是将高斯核与图像进行卷积,即对图像中的每个像素,用其邻域内的像素值乘以对应的高斯核权重,然后求和得到新的像素值。

高斯模糊的卷积核里的数字是满足高斯分布, 相当与更重视中间的

正态分布是下面第三个图,越靠近中心值,其相关程度就越明显。

如上图,如果将204作为卷积核的中心,那么就会计算与中心值相近的其他8个值的重要程度。

bash 复制代码
# 导入OpenCV库,用于图像处理
import cv2
# 导入matplotlib的pyplot模块,用于图像显示
import matplotlib.pyplot as plt
# 导入numpy库,用于数值计算
import numpy as np

# 使用cv2.imread()函数读取位于指定路径的图像文件
img = cv2.imread("E:\\XUEXI\\Python_learn\\tupian\\6.jpg")

# 定义一个函数cv_show,用于显示图像
def cv_show(name, img):
    # 使用cv2.imshow()函数显示图像,名称为name
    cv2.imshow(name, img)
    # 使用cv2.waitKey(0)函数等待,直到用户按下任意键
    cv2.waitKey(0)
    # 使用cv2.destroyAllWindows()函数关闭所有OpenCV创建的窗口
    cv2.destroyAllWindows()

# 使用cv2.GaussianBlur()函数对图像进行高斯滤波
# (5, 5)是高斯核的大小,即5x5的邻域窗口
# 1是高斯核的标准差,控制着核的宽度,较大的值会导致更强的平滑效果
aussian = cv2.GaussianBlur(img, (5, 5), 1)

# 调用cv_show函数显示高斯滤波后的图像
cv_show("aussian", aussian)

运行结果:

五、中值滤波

中值滤波相当于用中值代替,如果是(3x3)的核,就是取这9个数的中间值来计算。

bash 复制代码
# 导入OpenCV库,用于图像处理
import cv2
# 导入matplotlib的pyplot模块,用于图像显示
import matplotlib.pyplot as plt
# 导入numpy库,用于数值计算
import numpy as np

# 使用cv2.imread()函数读取位于指定路径的图像文件
img = cv2.imread("E:\\XUEXI\\Python_learn\\tupian\\6.jpg")

# 定义一个函数cv_show,用于显示图像
def cv_show(name, img):
    # 使用cv2.imshow()函数显示图像,名称为name
    cv2.imshow(name, img)
    # 使用cv2.waitKey(0)函数等待,直到用户按下任意键
    cv2.waitKey(0)
    # 使用cv2.destroyAllWindows()函数关闭所有OpenCV创建的窗口
    cv2.destroyAllWindows()

# 使用cv2.medianBlur()函数对图像进行中值滤波
# 5是滤波器的半径,表示考虑的邻域大小为5x5
median = cv2.medianBlur(img, 5)

# 调用cv_show函数显示中值滤波后的图像
cv_show("median", median)

运行结果:

将均值滤波,高斯滤波,中值滤波三者结合起来观察:

bash 复制代码
#不同算子的差异
import cv2
import matplotlib.pyplot as plt
import numpy as np

img = cv2.imread("E:\\XUEXI\\Python_learn\\tupian\\6.jpg")

def cv_show(name, img):
    cv2.imshow(name, img)
    cv2.waitKey(0)
    cv2.destroyAllWindows()

blur = cv2.blur(img, (3, 3))
aussian = cv2.GaussianBlur(img, (5, 5), 1)
median = cv2.medianBlur(img, 5)

res = np.hstack((blur, aussian, median))
cv_show("res", res)
相关推荐
Java技术小馆4 分钟前
为什么你的 AI 效率没翻倍?避开这 5 个落地深坑
人工智能
贫民窟的勇敢爷们10 分钟前
qBittorrent:37k 星的开源 BT 客户端,如何用 C++ 打造无广告的 P2P 下载神器】
人工智能
lizhihai_9913 分钟前
股市学习心得—商业航天10大核心材料供应商
大数据·人工智能·学习
wxin_VXbishe13 分钟前
springboot新能源车充电站管理系统小程序-计算机毕业设计源码29213
java·c++·spring boot·python·spring·django·php
Peter·Pan爱编程14 分钟前
第四篇:Cursor 深度评测 —— Composer 模式下的全栈 vibe 体验
人工智能·ai编程·composer
好运的阿财19 分钟前
OpenClaw工具拆解之memory_search+memory_get
人工智能·python·ai编程·openclaw·openclaw工具
crazy_wsp20 分钟前
使用AI从0到1上线微信小程序
人工智能·微信小程序·小程序
AI科技星24 分钟前
光子本源三元结构定理(《全域数学·物理原本》)【乖乖数学】
人工智能·机器学习·数学建模·数据挖掘·agi
逻辑君30 分钟前
认知神经科学研究报告【20260023】
人工智能·神经网络·机器学习
2zcode31 分钟前
基于集成学习的心肺听诊音自动分类系统设计与实现
机器学习·分类·集成学习