机器视觉基础—高斯滤波
创作时间:
作者:
@小白创作中心
机器视觉基础—高斯滤波
引用
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)
这里经过高斯滤波的处理之后,黑色以外的一些点即为模块处理的部分。
对于离散的点进行高斯滤波的处理
如果把遮挡区域的散点使用高斯滤波进行一下区域的扩散,然后在和之前的做差背景中的一写点应该可以看作是遮挡区域。
热门推荐
卧室床头摆放禁忌:5个方向需避开,关乎睡眠质量和身体健康
警惕!黄牛诈骗案,三场演唱会门票背后的法律与道德
放射医学和医学影像学区别?附就业方向和前景的区别介绍
种菜不用愁!二十四节气种菜时间表,全年蔬菜安排一目了然!
无损检测方法综合策略大全
问卷调查中有哪些问题类型?
突破性发现:韦伯望远镜在2600光年外发现全新“超轻气体行星”
胎菊的功效与作用
孩子呕吐腹泻怎么办?流感还是诺如?这份应对指南请收好
南京市玄武湖景区几月份去最好?南京市玄武湖景区建议游玩时间
养宠必看:预防小狗寄生虫攻略
2024年出生的女宝宝名字大全:寓意丰富的名字推荐
十万个为什么之绿茶和红茶是不同茶树的叶子吗?
从睡眠到饮食:全方位应对身心疲惫的科学指南
QQ群非法行为举报指南:证据收集与举报流程详解
青椒牛肉 如何炒出嫩滑的牛肉
青椒炒牛肉的秘诀大公开!掌握这些技巧让你秒变大厨!
自古得民心者得天下:公心与私心的永恒博弈
蜜环菌(榛蘑)的营养、药用功能及其物质基础研究
一,什么是胃酸倒流?
爱情的保鲜秘诀:让感情更长久
白癜风手掌太白 白癜风手部初期表现
反流性食管炎:症状、原因及治疗全解析
如何观察黄金外盘的交易情况?这种交易情况如何影响国内市场?
陕西十大泡馍的品尝诀窍
什么是责任认定
蚕豆种植方法:从播种到收获的全程指南
骨病科普:慢性踝关节不稳的全面解析
如何记录出差补助在会计科目中?
英国留学选修课程的选择与策略