3.5 平滑滤波
请注意:笔记内容片面粗浅,请读者批判着阅读!
一、引言
平滑空间滤波是数字图像处理中用于降低噪声和模糊细节的核心技术,常用于图像预处理或特定场景下的视觉效果优化。其核心思想是通过邻域像素的加权平均或统计操作,抑制高频噪声,保留低频主体信息。本节将结合理论分析与Python代码,探讨常见的平滑滤波方法及其应用。
二、平滑空间滤波原理
1. 基本概念
- 空间滤波:在图像平面局部区域内,通过模板(核)与像素值的运算实现处理。
- 平滑目标:削弱噪声(如高斯噪声、椒盐噪声)或模糊无关细节(如背景纹理)。
- 核心公式:
g ( x , y ) = ∑ ( i , j ) ∈ S w ( i , j ) ⋅ f ( x + i , y + j ) g(x,y) = \sum_{(i,j)\in S} w(i,j) \cdot f(x+i,y+j) g(x,y)=(i,j)∈S∑w(i,j)⋅f(x+i,y+j)
其中, w ( i , j ) w(i,j) w(i,j)为滤波器权重, S S S为邻域范围。
2. 平滑空间滤波器分类
主要分平滑线性滤波器和统计排序(非线性)滤波器。
三、平滑线性滤波器
定义与特性
平滑线性滤波器是基于线性运算的空间滤波方法,通过对邻域像素进行加权平均实现噪声抑制。其核心特征是输出像素值为邻域像素的线性组合。
主要的线性滤波器有均值滤波器、高斯滤波器以及方框滤波器。
1. 均值滤波器(Mean Filter)
原理
通过邻域像素的均值代替中心像素值,权重均匀分布。数学表达式为:
g ( x , y ) = 1 m n ∑ ( i , j ) ∈ S f ( x + i , y + j ) g(x,y) = \frac{1}{mn} \sum_{(i,j)\in S} f(x+i,y+j) g(x,y)=mn1(i,j)∈S∑f(x+i,y+j)
其中 S S S 为邻域窗口, m × n m \times n m×n 为窗口大小。
特点
- 计算简单,但会导致边缘模糊
- 适用于均匀噪声(如高斯噪声)
OpenCV实现
import cv2
blur_img = cv2.blur(src_img, (5,5)) # 使用5×5均值滤波核
2. 高斯滤波器(Gaussian Filter)
原理
权重按二维高斯函数分布,中心像素权重最大,边缘权重衰减。公式为:
w ( i , j ) = 1 2 π σ 2 e − i 2 + j 2 2 σ 2 w(i,j) = \frac{1}{2\pi\sigma^2}e^{-\frac{i^2+j^2}{2\sigma^2}} w(i,j)=2πσ21e−2σ2i2+j2
特点
- 保留边缘信息,平滑效果更自然
- 适用于自然图像降噪
Opencv实现
gaussian_img = cv2.GaussianBlur(src_img, (5,5), sigmaX=1.5) # 5×5核,σ=1.5
3. 方框滤波器(Box Filter)
原理
均值滤波的扩展形式,允许选择是否归一化。若归一化,等效于均值滤波;否则为邻域像素直接求和。
特点
- 可灵活选择归一化,适合自定义加权场景
- 非归一化时易导致像素值溢出
Opencv实现
# 归一化方框滤波(等效均值滤波)
box_norm = cv2.boxFilter(src_img, -1, (5,5), normalize=True)
# 非归一化方框滤波(直接求和)
box_non_norm = cv2.boxFilter(src_img, -1, (5,5), normalize=False)
滤波器对比与选择建议
| 滤波器类型 | 核心特点 | 适用场景 |
|---|---|---|
| 均值滤波 | 计算快,边缘模糊明显 | 快速去噪,均匀噪声处理 |
| 高斯滤波 | 边缘保留较好,平滑效果自然 | 自然图像降噪,预处理 |
| 方框滤波 | 可控制归一化,灵活性高 | 自定义加权或非归一化场景 |
综合示例:OpenCV实现对比
import cv2
import numpy as np# 读取图像并添加高斯噪声
src_img = cv2.imread('lena.jpg')
noise_img = src_img.copy()
cv2.randn(noise_img, 0, 30) # 添加标准差30的高斯噪声# 应用不同滤波器
mean_img = cv2.blur(noise_img, (5,5))
gaussian_img = cv2.GaussianBlur(noise_img, (5,5), 1.5)
box_img = cv2.boxFilter(noise_img, -1, (5,5), normalize=True)# 显示结果对比
cv2.imshow('Noisy vs Mean vs Gaussian vs Box', np.hstack([noise_img, mean_img, gaussian_img, box_img]))
cv2.waitKey(0)

应用场景与参数调优
- 核尺寸选择:
- 小核(3×3)适合细节保留,大核(9×9)适合强噪声抑制
- 高斯滤波参数:
- σ越大,平滑范围越广,但计算复杂度增加(建议σ=0.3×((ksize-1)/2))
- 实时性要求:
- 均值滤波计算最快,高斯滤波次之,方框滤波灵活但需注意溢出问题
四、统计排序(非线性)滤波器
定义与特性
统计排序滤波器属于非线性滤波,基于邻域像素值的排序结果选择输出值。其核心公式为:
g ( x , y ) = 排序 { f ( x + i , y + j ) } ( i , j ) ∈ S → 选择特定序位值 g(x,y) = \text{排序}\{f(x+i,y+j)\}_{(i,j)\in S} \rightarrow \text{选择特定序位值} g(x,y)=排序{f(x+i,y+j)}(i,j)∈S→选择特定序位值
主要类型
| 滤波器类型 | 噪声抑制能力 | 边缘保留 | 计算效率 | 适用场景示例 |
|---|---|---|---|---|
| 中值滤波 | 强(脉冲) | 优秀 | 中 | 医学影像、工业缺陷检测 |
| 最大值/最小值 | 弱 | 中等 | 高 | 天文图像增强 |
| 中点滤波 | 中等 | 良好 | 中 | 自然图像混合噪声 |
| 修正阿尔法均值 | 强(混合) | 良好 | 低 | 复杂噪声环境 |
1. 中值滤波器(Median Filter)
- 原理:取邻域像素排序后的中间值作为输出,有效消除孤立噪声点(如椒盐噪声)。
- 特点:不依赖极端值,边缘保留优于均值滤波,计算复杂度较高(需排序操作)。
- 适用场景:医学影像去噪、工业检测中的脉冲噪声抑制。
2. 最大值滤波器(Maximum Filter)
- 原理:取邻域像素的最大值作为输出,增强图像中的亮区域特征。
- 特点:放大噪声,但可抑制“胡椒噪声”(黑点噪声)。
- 适用场景:天文图像增强亮星点、暗场景中目标检测。
3. 最小值滤波器(Minimum Filter)
- 原理:取邻域像素的最小值作为输出,强化图像中的暗区域特征。
- 特点:抑制“盐粒噪声”(白点噪声),但可能丢失细节。
- 适用场景:检测图像中的暗点或空洞。
4. 中点滤波器(Midpoint Filter)
- 原理:取邻域像素最大值和最小值的平均作为输出,平衡亮暗区域。
- 特点:对高斯噪声有一定抑制,但无法完全消除脉冲噪声。
- 适用场景:需要兼顾亮暗特征的图像预处理。
5. 修正阿尔法均值滤波器(Alpha-Trimmed Mean Filter)
- 原理:去除邻域像素中最大和最小的α个值后取均值。
- 特点:结合排序和均值思想,适用于混合噪声(如高斯+脉冲)。
- 适用场景:复杂噪声环境下的图像恢复。
综合示例:OpenCV实现对比
import cv2
import numpy as np
import matplotlib.pyplot as plt# 中点滤波器
def midpoint_filter(img, ksize=3):max_val = cv2.dilate(img, np.ones((ksize, ksize)))min_val = cv2.erode(img, np.ones((ksize, ksize)))return ((max_val.astype(int) + min_val.astype(int)) // 2).astype(np.uint8)if __name__ == "__main__":noisy = cv2.imread('pepper.png')# 应用不同滤波器median = cv2.medianBlur(noisy, 5) # 中值滤波(5x5)maxfilt = cv2.dilate(noisy, np.ones((3, 3))) # 最大值滤波minfilt = cv2.erode(noisy, np.ones((3, 3))) # 最小值滤波midpoint = midpoint_filter(noisy, 5) # 中点滤波(5x5)# 可视化结果plt.figure(figsize=(14, 8))images = [("Noisy", noisy),("Median Filter", median),("Max Filter", maxfilt),("Min Filter", minfilt),("Midpoint Filter", midpoint)]for i, (title, image) in enumerate(images):plt.subplot(2, 4, i + 1)plt.imshow(image, cmap='gray', vmin=0, vmax=255)plt.title(title)plt.axis('off')plt.tight_layout()plt.show()

五、滤波器对比
| 特性 | 平滑线性滤波器 | 统计排序滤波器 |
|---|---|---|
| 线性/非线性 | 线性 | 非线性 |
| 噪声抑制类型 | 高斯噪声、均匀噪声 | 脉冲噪声、离群点 |
| 边缘保留能力 | 较弱(高斯滤波中等) | 强(中值滤波最佳) |
| 计算效率 | 高(可并行计算) | 低(排序操作耗时) |
| 典型应用 | 自然图像预处理 | 医学影像、工业检测 |
六、总结
平滑空间滤波是图像处理的基础操作,需根据噪声类型和场景需求选择合适方法。实际应用中,常需结合多种滤波技术或自适应参数调整以达到最优效果。
相关文章:
3.5 平滑滤波
请注意:笔记内容片面粗浅,请读者批判着阅读! 一、引言 平滑空间滤波是数字图像处理中用于降低噪声和模糊细节的核心技术,常用于图像预处理或特定场景下的视觉效果优化。其核心思想是通过邻域像素的加权平均或统计操作,抑制高频噪…...
自动化测试框架pytest+requests+allure
Pytest requests Allure 这个框架基于python的的 Pytest 进行测试执行,并结合 Allure插件 生成测试报告的测试框架。采用 关键字驱动 方式,使测试用例更加清晰、模块化,同时支持 YAML 文件来管理测试用例,方便维护和扩展。 测试…...
Sympy入门之微积分基本运算
Sympy是一个专注于符号数学计算的数学工具,使得用户可以轻松地进行复杂的符号运算,如求解方程、求导数、积分、级数展开、矩阵运算等。本文,我们将详细讲解Sympy在微积分运算中的应用。 获取方式 pip install -i https://mirrors.tuna.tsin…...
Qemu-STM32(十):STM32F103开篇
简介 本系列博客主要描述了STM32F103的qemu模拟器实现,进行该项目的原因有两点: 作者在高铁上,想在STM32F103上验证一个软件框架时,如果此时掏出开发板,然后接一堆的线,旁边的人估计会投来异样的目光,特别…...
在 ABAP 开发工具 (ADT-ABAP Development Tools) 中创建ABAP 项目
第一步:安装 SAP NetWeaver 的 ABAP 开发工具 (ADT) 开发工具下载地址:https://tools.hana.ondemand.com/#abap 也可以在SAP Development Tools下载工具页面直接跳转到对应公开课教程页面,按课程步骤下载eclipse解压安装即可,过程…...
【架构】单体架构 vs 微服务架构:如何选择最适合你的技术方案?
文章目录 ⭐前言⭐一、架构设计的本质差异🌟1、代码与数据结构的对比🌟2、技术栈的灵活性 ⭐二、开发与维护的成本博弈🌟1、开发效率的阶段性差异🌟2、维护成本的隐形陷阱 ⭐三、部署与扩展的实战策略🌟1、部署模式的本…...
【鸿蒙开发】Hi3861学习笔记- WIFI应用AP建立网络
00. 目录 文章目录 00. 目录01. LwIP简介02. AP模式简介03. API描述3.1 RegisterWifiEvent3.2 UnRegisterWifiEvent3.3 GetStationList3.4 GetSignalLevel3.5 EnableHotspot3.6 DisableHotspot3.7 SetHotspotConfig3.8 GetHotspotConfig3.9 IsHotspotActive 04. 硬件设计05. 模…...
大模型的微调技术(高效微调原理篇)
背景 公司有需求做农业方向的大模型应用以及Agent助手,那么适配农业数据就非常重要。但众所周知,大模型的全量微调对算力资源要求巨大,在现实的限制条件下基本“玩不起”,那么高效微调技术就非常必要。为了更好地对微调技术选型和…...
区间震荡指标
区间震荡指标的逻辑如下: 一、函数注解 1. Summation函数 功能: 计算给定价格序列Price的前Length个数据点的和,或在数据点数量超过Length时,计算滚动窗口内的价格和。 参数: Price(1):价格序列&#…...
HCIE-SLAAC
文章目录 SLAAC 🏡作者主页:点击! 🤖Datacom专栏:点击! ⏰️创作时间:2025年03月21日10点58分 SLAAC 帮助设备发现本地直连链路相连的设备,并获取与地址自动配置的相关前缀和其他…...
JavaScript | 爬虫逆向 | 掌握基础 | 01
一、摘要 实践是最好的导师 二、环境配置 在开始之前,需要确保你的计算机上已经安装了 Node.js。Node.js 是一个开源的、跨平台的 JavaScript 运行时环境,它允许你在服务器端运行 JavaScript 代码。 1. 下载 安装地址:https://nodejs.org…...
【PCIe 总线及设备入门学习专栏 3.2 -- PCIe 在进行大数据搬运时是如何组包的?】
文章目录 Overview1. PCIe数据传输的核心机制(1) 数据分割(2) TLP头部构造(3) 数据链路层封装(4) 物理层传输2. GPU从内存搬运数据的组包流程场景示例:3. 优化机制(1) 大页传输(TLP合并)(2) 流量控制与信用机制(3) 地址对齐优化4. 完整示例5. 性能影响Overview 本文将详细介…...
C++算法代码-植物生长算法求解多目标车辆路径规划问题
为了求解电商物流配送中的车辆路径规划问题,并同时优化多个目标(降低运营总成本、降低碳排放量、降低消费者的不满意程度),我们可以设计一个结合植物生长算法(Plant Growth Algorithm, PGA)、**模拟退火算法(Simulated Annealing, SA)和多目标优化算法(MODAD)**的组合…...
力扣算法Hot100——128. 最长连续序列
题目要求时间复杂度为O(n),因此不能使用两次循环匹配。 首先使用 HashSet 去重,并且 HashSet 查找一个数的复杂度为O(1)外循环还是遍历set集合,里面一重循环需要添加判断,这样才不会达到O( n 2 n^2 n2)判断是否进入最长序列查找循…...
深入解析 Java Stream API:从 List 到 Map 的优雅转换!!!
🚀 深入解析 Java Stream API:从 List 到 Map 的优雅转换 🔧 大家好!👋 今天我们来聊聊 Java 8 中一个非常常见的操作:使用 Stream API 将 List 转换为 Map。🎉 具体来说,我们将深入…...
当全球化成为商业常态,Shopify 如何为品牌生意铺平出海之路?
从独立站搭建到支付履约,从数据分析到生态整合,Shopify 为不同规模的企业提供可扩展的解决方案。 在数字化浪潮的推动下,跨境电商与品牌出海的黄金时代已然到来。然而,看似广阔的市场蓝海背后,是无数企业正在经历的“成…...
集成平台是选择专业iPaaS厂商还是大型软件企业?
在数字化转型的浪潮中,企业对于高效、灵活的集成平台需求日益增长。iPaaS(Integration Platform as a Service)作为当下热门的解决方案,为企业提供了将不同应用和数据源进行整合的云端平台。面对市场上的众多选择,企业…...
RC6在线加密工具
RC6加密算法是一种基于RC5改进的分组密码算法,曾作为AES(高级加密标准)的候选算法之一。它采用了4个32位寄存器,增加了32位整数乘法运算,以增强扩散和混淆特性,提高了安全性。RC6的设计简单、高效ÿ…...
python每日十题(5)
保留字,也称关键字,是指被编程语言内部定义并保留使用的标识符。Python 3.x版本中有35个保留字,分别为:and, as,assert,async,await,break,class,continue,def,del,elif,else, except, False, finally,for,from,global, if,import…...
应用案例 | 核能工业:M-PM助力核工业科研项目
M-PM助力核工业科研项目 一、项目背景 在核工业复杂系统的研发进程中,MBSE(基于模型的系统工程)方法的应用愈发成熟,已然成为推动系统设计与优化的关键力量。如今,各相关设计系统的 MBSE 模型数据呈现出精细化、多元…...
通过 Executors 创建线程池
在Java中,使用线程池来管理和创建线程是一个更为高效和灵活的方法。线程池可以帮助你管理线程的生命周期,避免了频繁创建和销毁线程的开销,从而提高了性能。 Java 提供了java.util.concurrent包来处理线程池的相关操作。常用的线程池类是 Ex…...
4.1、网络安全模型
目录 网络安全体系概述网络安全模型-BLP模型网络安全模型-Biba模型网络安全模型 - 信息流模型信息保障模型能力成熟度模型其它安全模型网络安全原则 网络安全体系概述 网络安全体系是网络安全保证系统的最高层概念抽象,是一个体系,体系一般是一个概念&a…...
ManiWAV:通过野外的音频-视频数据学习机器人操作
24年6月来自斯坦福大学、哥伦比亚大学和 TRI 的论文“ManiWAV: Learning Robot Manipulation from In-the-Wild Audio-Visual Data”。 音频信号通过接触为机器人交互和物体属性提供丰富的信息。这些信息可以简化接触丰富的机器人操作技能学习,尤其是当视觉信息本身…...
可发1区的超级创新思路:基于注意力机制的DSD-CNN时间序列预测模型(功率预测、交通流量预测、故障检测)
首先声明,该模型为原创!原创!原创! 一、应用场景 该模型主要用于时间序列数据预测问题,包含功率预测、电池寿命预测、电机故障检测等等 二、模型整体介绍(本文以光伏功率预测为例) DSD-CNN(Depthwise-Spacewise Separable CNN)结合通道注意力机制,通过以下创新提升…...
IREE 调度机制深度解析:静态编译与动态执行的协同优化
IREE 调度机制深度解析:静态编译与动态执行的协同优化 一、引言 IREE (IR Execution Environment) 作为 TensorFlow 生态的重要成员,通过多层次调度策略实现了跨硬件平台的高效执行。其调度系统融合了编译期静态优化与运行时动态调整,在保证…...
istio 介绍-01-一个用于连接、管理和保护微服务的开放平台 概览
istio istio 一个用于连接、管理和保护微服务的开放平台。 介绍 Istio 是一个开放平台,用于提供统一的方式来集成微服务、管理跨微服务的流量、执行策略和聚合遥测数据。 Istio 的控制平面在底层集群管理平台(例如 Kubernetes)上提供了一…...
详细说明脚本评估和耗时较长的任务
在网页性能优化中,脚本评估和耗时较长的任务是两大关键性能瓶颈。它们直接影响页面的加载速度、交互响应以及用户体验。以下是对这两个概念的详细说明及优化策略: 一、脚本评估(Script Evaluation) 1. 定义 脚本评估指浏览器解析…...
Floyd 算法——97. 小明逛公园
卡码网:97. 小明逛公园https://kamacoder.com/problempage.php?pid=1155 题目描述 小明喜欢去公园散步,公园内布置了许多的景点,相互之间通过小路连接,小明希望在观看景点的同时,能够节省体力,走最短的路径。 给定一个公园景点图,图中有 N 个景点(编号为 1 到 N),…...
QT二 QT使用generate form 生成常用UI,各种UI控件
一 。没有使用general form 和 使用 general form 后,file层面和代码层面的不同比较 file层面的不同 代码层面的不同, 在 使用了general form之后,在主界面的构造方法中,使用ui->setupUi(this),就完成了所有UI的处理。 而之…...
蓝桥每日打卡--打家劫舍4
#蓝桥#JAVA#打家劫舍4 题目描述 沿街有一排连续的房屋。每间房屋内都藏有一定的现金。现在有一位小偷计划从这些房屋中窃取现金。 由于相邻的房屋装有相互连通的防盗系统,所以小偷 不会窃取相邻的房屋 。 小偷的 窃取能力 定义为他在窃取过程中能从单间房屋中窃…...
