机器视觉基础—高斯滤波
创作时间:
作者:
@小白创作中心
机器视觉基础—高斯滤波
引用
CSDN
1.
https://blog.csdn.net/weixin_46167190/article/details/146697973
高斯滤波是机器视觉和图像处理中的重要技术,主要用于图像平滑和噪声去除。本文将详细介绍高斯滤波的基本原理,并通过代码示例展示如何使用OpenCV库实现高斯滤波。
机器视觉基础—图像滤波
高斯滤波
高斯核的权重值从中心向边缘按高斯函数衰减:中心像素权重最大,周围像素权重随距离增加而减小。
3x3大小的卷积核的过程:如上所示最后执行一次归一化的操作即可。这里归一化之后得到的权重值,3x3区域大小的部分就是我们的高斯核(3x3大小的高斯核)将其用作卷积核即可。
之后的过程就是使用这个卷积核来进行卷积的处理和深度学习中的卷积的运算是保持一致的情况。
这种特性使得高斯滤波能保留更多低频信息(平滑区域),同时减少高频噪声。
import cv2
import matplotlib.pyplot as plt
def show_reslt(img):
plt.imshow(img)
plt.show()
img = cv2.imread('../exp/occ_result/trackerobj/2/15.png')
img = cv2.cvtColor(img,cv2.COLOR_BGR2RGB)
show_reslt(img)
img = cv2.GaussianBlur(img, (5, 5), 5000)
show_reslt(img)
自定义的形式
下面使用自定义滤波的形式生成同样的结果,代码如下所示。
dst = cv2.filter2D(src, ddepth, kernel[, dst[, anchor[, delta[, borderType]]]])
输入参数:
- src:输入图像(灰度图或彩色图,支持 uint8、float32 等格式)。
- ddepth:输出图像的深度(如 -1 表示与输入相同,cv2.CV_64F 允许负值输出)。
- kernel:卷积核(单通道浮点型矩阵,如 np.float32)。
可选参数:
- anchor:核的锚点位置(默认 (-1, -1) 表示核中心)。
- delta:卷积后添加到每个像素的偏移值(默认为 0)。
- borderType:边界填充方式(如 cv2.BORDER_REFLECT、cv2.BORDER_CONSTANT 等)。
import cv2
import matplotlib.pyplot as plt
def show_reslt(img):
plt.imshow(img)
plt.show()
img = cv2.imread('../exp/occ_result/trackerobj/2/15.png')
img = cv2.cvtColor(img,cv2.COLOR_BGR2RGB)
show_reslt(img)
# 定义高斯核
# 定义参数
ksize = 5 # 整数,非元组
sigma = 500
# 生成一维高斯核
gaussian_1D = cv2.getGaussianKernel(ksize, sigma, cv2.CV_32F)
# 生成二维高斯核
gaussian_2D = gaussian_1D @ gaussian_1D.T # 外积
# 应用滤波
blurred = cv2.filter2D(img, -1, gaussian_2D)
show_reslt(blurred)
通过掩码的方式在指定的区域上进行高斯滤波
np.where(mask, blurred, img) 会根据掩模 mask 的值选择对应的像素:
- 如果 mask 中的值为 1,则选择 blurred 中的像素。
- 如果 mask 中的值为 0,则选择 img 中的像素。
这样可以将目标区域替换为高斯滤波后的结果,而其他区域保持不变。
import numpy as np
import cv2
import matplotlib.pyplot as plt
def show_reslt(img):
plt.imshow(img)
plt.show()
img = cv2.imread('../exp/occ_result/trackerobj/2/15.png')
img = cv2.cvtColor(img,cv2.COLOR_BGR2RGB)
show_reslt(img)
mask = np.zeros_like(img)
mask[50:150, 0:100] = 1 # 定义目标区域
blurred = cv2.GaussianBlur(img, (5,5), 500,None,10000)
result = np.where(mask, blurred, img) # 合并结果
show_reslt(result)
这里经过高斯滤波的处理之后,黑色以外的一些点即为模块处理的部分。
对于离散的点进行高斯滤波的处理
如果把遮挡区域的散点使用高斯滤波进行一下区域的扩散,然后在和之前的做差背景中的一写点应该可以看作是遮挡区域。
热门推荐
重庆长寿区十大景点全攻略:从古镇到湖景,尽显巴渝风情
如何与HR谈薪资:实用指南
《雍正王朝》:盘点剧中那些可圈可点的台词
排班管理软件用法有哪些技巧?
不要总是怀疑自己的另一半,因为信任是感情的基础
2024专科警校出来干什么 能做什么工作
红薯、紫薯、白薯的营养价值有区别吗?为啥紫薯最贵?
宠物定位器追踪器:功能解析与使用技巧
内蒙古通辽文物古迹全览:千年文化遗存见证历史辉煌
如何理解房产行业的发展态势?这种发展态势受哪些因素影响?
如何快速给文档分段
爸爸B型血,妈妈O型血,宝宝可能是A型血吗?
醋溜白菜制作全攻略:从选材到出锅的每一个细节
2025年旅行与旅游的未来:拥抱可持续与包容性增长报告
如何解决唱歌跑调的问题
喝热水喝出来的!这种习惯真有可能致癌!
10个快速通过机场安检小技巧
肝阳上亢吃什么?五种食物助你调理
成都社保缴费标准(持续更新)
每日中药本草:砂仁,调理脾胃必备:砂仁的健脾开胃功效与食疗方
如何缓解精神疲劳?六步指南助你重获活力
购物中心(商场)如何开展招商工作:如何挖掘品牌客户,途径
发生交通事故后如何紧急处理
呼吸困难怎么办?医生推荐这些药物见效快
最早的发光动物是什么?新研究带来线索
“笨人”能够顿悟吗?普通人如何才能像王阳明那样开窍悟道?
游泳健身:高效燃脂与心肺提升
急行军突袭需要怎样隐蔽?除了昼伏夜行以外,这些要点更重要
孔子与释迦牟尼,为何都回避解答这类问题?答案可能出乎你意料
iOS缓存清理技巧:释放存储空间,提高设备性能