python实现平滑线性滤波器——数字图像处理

原理:

平滑线性滤波器是一种在图像处理中广泛使用的工具,主要用于降低图像噪声或模糊细节。这些滤波器的核心原理基于对图像中每个像素及其邻域像素的线性组合。

邻域平均:

平滑线性滤波器通过对目标像素及其周围邻域像素的强度值取平均来工作。这个操作使得图像中的每个像素值变得更加接近其邻域的平均值。

滤波器核(Kernel):

滤波器通过一个称为"核"或"掩膜"的小窗口来应用。这个核定义了邻域的大小和形状,通常是一个小的、方形的矩阵。

核中的每个值(权重)决定了相应像素在平均过程中的重要性。
卷积操作

平滑过程是通过卷积操作实现的,即将核在图像上滑动,并在每个位置上应用加权平均。

对于图像中的每个像素,核覆盖的区域内的像素值与核的相应权重相乘,然后求和得到新的像素值。

常见的平滑线性滤波器
均值滤波器:

最简单的平滑线性滤波器是均值滤波器,它使用的核具有相等的权重,即所有邻域像素的权重相同。

高斯滤波器:

高斯滤波器使用的核基于高斯函数,它为中心像素赋予更高的权重,而远离中心的像素权重较低。

这种类型的滤波器在保留边缘信息的同时,对噪声的平滑效果更好。
应用

平滑线性滤波器主要用于去噪和图像模糊化。在去除噪声时,它们可以帮助减少图像中随机的颜色波动。但是,这种平滑也可能导致图像细节的损失,特别是在边缘区域。因此,选择合适的核大小和类型对于平衡去噪和保持图像细节非常重要。

使用python实现下列过程

提示

采用的平滑模板大小分别为3,5,9,15,35,大小为3的模板

其余大小模板类似。可以写一个函数实现图像与模板卷积(相关)的过程,步骤包括:根据模板大小为图像填充0边界;双层for循环遍历图像的每个像素点,每次取与模板大小相同的图像块与模板相乘并求和,np.multiply可以实现矩阵逐元素相乘,np.sum实现矩阵求和。

python代码

python 复制代码
import cv2
import numpy as np
from matplotlib import pyplot as plt


def correl2d(img, window):
    m = window.shape[0]
    n = window.shape[1]

    # 图像边界填0扩展
    img_border = np.zeros((img.shape[0] + m - 1, img.shape[1] + n - 1))
    img_border[(m - 1) // 2:img.shape[0] + (m - 1) // 2, (n - 1) // 2:img.shape[1] + (n - 1) // 2] = img
    img_result = np.zeros(img.shape)
    for i in range(img.shape[0]):
        for j in range(img.shape[1]):
            temp = img_border[i:i + m, j:j + n]
            img_result[i, j] = np.sum(np.multiply(temp, window))
    return img_result


img = cv2.imread('Fig0333.tif', 0)

img_list = [img]
img_name_list = ['original']
size = [3, 5, 9, 15, 35]
for m in size:
    window = np.ones((m, m)) / (m ** 2)
    img_result = correl2d(img, window)
    img_list.append(img_result)
    img_name_list.append('m=' + str(m))

_, axs = plt.subplots(2, 3)

for i in range(2):
    for j in range(3):
        axs[i, j].imshow(img_list[i * 3 + j], cmap='gray')
        axs[i, j].set_title(img_name_list[i * 3 + j])
        axs[i, j].axis('off')

plt.savefig('box_filter.jpg')
plt.show()

结果展示

相关推荐
乐言361几秒前
Jmeter中的BeanShell如何使用?
python·jmeter·压力测试
Blossom.1184 分钟前
探索边缘计算:赋能物联网的未来
开发语言·人工智能·深度学习·opencv·物联网·机器学习·边缘计算
-曾牛5 分钟前
Spring AI 与 Hugging Face 深度集成:打造高效文本生成应用
java·人工智能·后端·spring·搜索引擎·springai·deepseek
MaisieKim_21 分钟前
python与nodejs哪个性能高
前端·python·node.js
modest —YBW27 分钟前
Ollama+OpenWebUI+docker完整版部署,附带软件下载链接,配置+中文汉化+docker源,适合内网部署,可以局域网使用
人工智能·windows·docker·语言模型·llama
迪捷软件32 分钟前
从概念表达到安全验证:智能驾驶功能迎来系统性规范
大数据·人工智能
非凡ghost36 分钟前
透视相机:创意摄影新体验,解锁照片无限可能
人工智能·数码相机
林鸿风采1 小时前
内网服务器之间传输单个大文件最佳解决方案
linux·python·文件传输
森叶1 小时前
从 JIT 即时编译一直讲到CGI|FastGGI|WSGI|ASGI四种协议的实现细节
python·php·web
weixin_307779131 小时前
使用FastAPI微服务在AWS EKS中构建上下文增强型AI问答系统
人工智能·python·云计算·fastapi·aws