百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分析 > 正文

Python-OpenCV 9. 图像滤波除噪 python图片滤波

liebian365 2024-10-27 13:19 15 浏览 0 评论

本文主要学习资源《机器学习实践指南》案例应用解析

一、图像平滑

Python可以使用滤波算法实现图像平滑, 是图像增强的一部分。图像平滑是一种区域增强的算法,平滑算法有邻域平均法、中指滤波、边界保持类滤波等,其目的有模糊、削除噪音两种。

滤波的本义是指信号有各种频率的成分,滤掉不想要的成分,即为滤掉常说的噪声,留下想要的成分.这即是滤波的过程,也是目的.

摘自《数字图像处理》

二、均一化滤波

1. 高斯噪声滤波

说明

高斯滤波是一种线性平滑滤波,适用于消除高斯噪声,广泛应用于图像处理的减噪过程。通俗的讲,高斯滤波就是对整幅图像进行加权平均的过程,每一个像素点的值,都由其本身和邻域内的其他像素值经过加权平均后得到。高斯滤波的具体操作是:用一个模板(或称卷积、掩模)扫描图像中的每一个像素,用模板确定的邻域内像素的加权平均灰度值去替代模板中心像素点的值。

高斯滤波(Gauss filter)实质上是一种信号的滤波器,其用途为信号的平滑处理,数字图像用于后期应用,其噪声是最大的问题,因为误差会累计传递等原因,大多图像处理教材会在很早的时候介绍Gauss滤波器,用于得到信噪比SNR较高的图像(反应真实信号)。高斯平滑滤波器对于抑制服从正态分布的噪声非常有效。 (百度百科)

OpenCV提供的blur函数可以进行归一化块滤波操作:

cv2.blur(src,ksize[, dst[, anchor[, borderType[]]]) -> dst

此外,该函数使用了如下脉冲响应函数(核函数):

测试代码

# -*- coding: utf-8 -*-
# coding=utf-8
import cv2
import numpy as np
fn = "test.jpg"
myimg = cv2.imread(fn)
img = cv2.cvtColor(myimg, cv2.COLOR_BGR2GRAY)
# 加上高斯噪声
param=20
# 灰阶范围
grayscale = 256
w = img.shape[1]
h = img.shape[0]
newimg = np.zeros((h,w),np.uint8)
for x in range(0, h):
 for y in range(0, w-1, 2):
 r1 = np.random.random_sample()
 r2 = np.random.random_sample()
 z1 = param*np.cos(2*np.pi*r2)*np.sqrt((-2)*np.log(r1))
 z2 = param*np.sin(2*np.pi*r2)*np.sqrt((-2)*np.log(r1))
 fxy = int(img[x, y]+z1)
 fxy1 = int(img[x, y+1]+z2)
 #f(x,y)
 if fxy<0:
 fxy_val=0
 elif fxy>grayscale-1:
 fxy_val=grayscale-1
 else:
 fxy_val=fxy
 #f(x,y+1)
 if fxy1<0:
 fxy1_val=0
 elif fxy1>grayscale-1:
 fxy1_val=grayscale-1
 else:
 fxy1_val=fxy1
 newimg[x,y]=fxy_val
 newimg[x,y+1]=fxy1_val
# 滤波去噪
lbimg = cv2.blur(newimg, (3, 3))
cv2.imshow('src', newimg)
cv2.imshow('dst', lbimg)
cv2.waitKey()
cv2.destroyAllWindows()

运行结果

如果使用下面脉冲响应函数:

程序代码:

# 滤波去噪
# 图像四个边的像素处理
lbimg=np.zeros((h+2,w+2),np.float32)
tmpimg=np.zeros((h+2,w+2))
myh=h+2
myw=w+2
tmpimg[1:myh-1,1:myw-1]=newimg[0:myh,0:myw]
# 用第3个脉冲响应函数
a = 1/16.0
kernel=a*np.array([[1,2,1],[2,4,2],[1,2,1]])
for y in range(1,myh-1):
 for x in range(1,myw-1):
 lbimg[y,x]=np.sum(kernel*tmpimg[y-1:y+2,x-1:x+2])
 print(".")
resultimg=np.array(lbimg[1:myh-1,1:myw-1],np.uint8)
cv2.imshow('src',newimg)
cv2.imshow('dst',resultimg)
cv2.waitKey()
cv2.destroyAllWindows()

2. 椒盐噪声滤波

代码

# -*- coding: utf-8 -*-
# coding=utf-8
import cv2
import numpy as np
fn = "test.jpg"
myimg = cv2.imread(fn)
img = cv2.cvtColor(myimg, cv2.COLOR_BGR2GRAY)
# 加上椒盐噪声
# 灰阶范围
w = img.shape[1]
h = img.shape[0]
newimg = np.array(img)
# 噪声点数量
noisecount = 100000
for k in range(0, noisecount):
 xi = int(np.random.uniform(0, newimg.shape[1]))
 xj = int(np.random.uniform(0, newimg.shape[0]))
 newimg[xj, xi] = 255
# 滤波除噪
lbimg = cv2.blur(newimg, (5, 5))
cv2.imshow('src', newimg)
cv2.imshow('dst', lbimg)
cv2.waitKey()
cv2.destroyAllWindows()

运行效果:

3. OpenCV 2d滤波器 cv2.filter2D()

使用自定义内核对图像进行卷积。该功能将任意线性滤波器应用于图像。

对于2D图像可以进行低通或者高通滤波操作,低通滤波(LPF)有利于去噪,模糊图像,高通滤波(HPF)有利于找到图像边界。

# -*- coding: utf-8 -*-
import cv2
import numpy as np
img = cv2.imread('test.jpg')
kernel = np.ones((5, 5), np.float32) / 25
dst = cv2.filter2D(img, -1, kernel)
cv2.imshow('dst', dst)
cv2.imshow('source', img)
cv2.waitKey(0)
cv2.destroyAllWindows()

运行效果:

三、邻域平均法

邻域平均法可有效消除高斯噪声,其数学公式如下:

S为邻域,不包括(x,y)(x,y)本身的像素点,核h(x,y)h(x,y)可为:

1. 邻域平均法对椒盐噪声滤波进行处理的操作

代码

# -*- coding: utf-8 -*-
# coding=utf-8
import cv2
import numpy as np
fn = "test.jpg"
myimg = cv2.imread(fn)
img = cv2.cvtColor(myimg, cv2.COLOR_BGR2GRAY)
# 加上椒盐噪声
param = 20
# 灰阶范围
w = img.shape[1]
h = img.shape[0]
newimg = np.array(img)
# 噪声点数量
noisecount = 100000
for k in range(0, noisecount):
 xi = int(np.random.uniform(0, newimg.shape[1]))
 xj = int(np.random.uniform(0, newimg.shape[0]))
 newimg[xj, xi] = 255
# 邻域平均法去噪
# 脉冲响应函数,核函数
# 图像四个边的像素处理
lbimg = np.zeros((h + 2, w + 2), np.float32)
tmpimg = np.zeros((h + 2, w + 2))
myh = h + 2
myw = w + 2
tmpimg[1:myh - 1, 1:myw - 1] = newimg[0:myh, 0:myw]
# 用领域平均法的(设半径为2)脉冲响应函数
a = 1 / 8.0
kernel = a * np.array([[1, 1, 1], [1, 0, 1], [1, 1, 1]])
for y in range(1, myh - 1):
 for x in range(1, myw - 1):
 lbimg[y, x] = np.sum(kernel * tmpimg[y - 1:y + 2, x - 1:x + 2])
 print(".")
resultimg = np.array(lbimg[1:myh - 1, 1:myw - 1], np.uint8)
cv2.imshow('src', newimg)
cv2.imshow('dst', resultimg)
cv2.waitKey()
cv2.destroyAllWindows()

运行效果

2. 邻域平均法对高斯噪声滤波进行处理的操作

代码

# -*- coding: utf-8 -*-
# coding=utf-8
import cv2
import numpy as np
fn = "test.jpg"
myimg = cv2.imread(fn)
img = cv2.cvtColor(myimg, cv2.COLOR_BGR2GRAY)
# 加上高斯噪声
param = 20
# 灰阶范围
grayscale = 256
w = img.shape[1]
h = img.shape[0]
newimg = np.zeros((h, w), np.uint8)
# 加上高斯噪声
param = 20
# 灰阶范围
grayscale = 256
w = img.shape[1]
h = img.shape[0]
newimg = np.zeros((h, w), np.uint8)
for x in range(0, h):
 for y in range(0, w, 2):
 r1 = np.random.random_sample()
 r2 = np.random.random_sample()
 z1 = param * np.cos(2 * np.pi * r2) * np.sqrt((-2) * np.log(r1))
 z2 = param * np.sin(2 * np.pi * r2) * np.sqrt((-2) * np.log(r1))
 fxy = int(img[x, y] + z1)
 fxy1 = int(img[x, y + 1] + z2)
 # f(x,y)
 if fxy < 0:
 fxy_val = 0
 elif fxy > grayscale - 1:
 fxy_val = grayscale - 1
 else:
 fxy_val = fxy
 # f(x,y+1)
 if fxy1 < 0:
 fxy1_val = 0
 elif fxy1 > grayscale - 1:
 fxy1_val = grayscale - 1
 else:
 fxy1_val = fxy1
 newimg[x, y] = fxy_val
 newimg[x, y + 1] = fxy1_val
 print("-")
# 邻域平均法去噪
# 脉冲响应函数,核函数
# 图像四个边的像素处理
lbimg = np.zeros((h + 2, w + 2), np.float32)
tmpimg = np.zeros((h + 2, w + 2))
myh = h + 2
myw = w + 2
tmpimg[1:myh - 1, 1:myw - 1] = newimg[0:myh, 0:myw]
# 用领域平均法的(设半径为2)脉冲响应函数
a = 1 / 8.0
kernel = a * np.array([[1, 1, 1], [1, 0, 1], [1, 1, 1]])
for y in range(1, myh - 1):
 for x in range(1, myw - 1):
 lbimg[y, x] = np.sum(kernel * tmpimg[y - 1:y + 2, x - 1:x + 2])
 print(".")
resultimg = np.array(lbimg[1:myh - 1, 1:myw - 1], np.uint8)
cv2.imshow('src', newimg)
cv2.imshow('dst', resultimg)
cv2.waitKey()
cv2.destroyAllWindows()

运行结果

四、中值滤波

中值滤波与邻域平均法类似,但计算的是中值,而不是平均值。具体算法是:将图像的每个像素用邻域(以当前像素为中心的正方形区域)像素的中值来代替。

1. 中值滤波对椒盐噪声除噪

代码

# -*- coding: utf-8 -*-
# 中值滤波
import cv2
import numpy as np
fn = "test.jpg"
myimg = cv2.imread(fn)
img = cv2.cvtColor(myimg, cv2.COLOR_BGR2GRAY)
# 加上椒盐噪声
# 灰价范围
w = img.shape[1]
h = img.shape[0]
newimg = np.array(img)
# 噪声点数量
noisecount = 50000
for k in range(0, noisecount):
 xi = int(np.random.uniform(0, newimg.shape[1]))
 xj = int(np.random.uniform(0, newimg.shape[0]))
 newimg[xj, xi] = 255
# 滤波去噪
# 脉冲响应函数 核函数
# 图像四个边的像素处理
lbimg = np.zeros((h + 2, w + 2), np.float32)
tmpimg = np.zeros((h + 2, w + 2))
myh = h + 2
myw = w + 2
tmpimg[1:myh - 1, 1:myw - 1] = newimg[0:myh, 0:myw]
# 用中值法
for y in range(1, myh - 1):
 for x in range(1, myw - 1):
 lbimg[y, x] = np.median(tmpimg[y - 1:y + 2, x - 1:x + 2])
 print(".")
resultimg = np.array(lbimg[1:myh - 1, 1:myw - 1], np.uint8)
cv2.imshow('src', newimg)
cv2.imshow('dst', resultimg)
cv2.waitKey()
cv2.destroyAllWindows()

运行结果

OpenCv2有medianBlur函数实现中值滤波:

cv2.medianBlur(src, ksize[, dst]) -> dst

代码:

# -*- coding: utf-8 -*-
# code:
# 中值滤波
import cv2
import numpy as np
fn = "test.jpg"
myimg = cv2.imread(fn)
img = cv2.cvtColor(myimg, cv2.COLOR_BGR2GRAY)
# 加上椒盐噪声
# 灰价范围
w = img.shape[1]
h = img.shape[0]
newimg = np.array(img)
# 噪声点数量
noisecount = 50000
for k in range(0, noisecount):
 xi = int(np.random.uniform(0, newimg.shape[1]))
 xj = int(np.random.uniform(0, newimg.shape[0]))
 newimg[xj, xi] = 255
# 滤波去噪
# 脉冲响应函数 核函数
# 图像四个边的像素处理
lbimg = cv2.medianBlur(newimg, 3)
cv2.imshow('src', newimg)
cv2.imshow('dst', lbimg)
cv2.waitKey()
cv2.destroyAllWindows()

相关推荐

4万多吨豪华游轮遇险 竟是因为这个原因……

(观察者网讯)4.7万吨豪华游轮搁浅,竟是因为油量太低?据观察者网此前报道,挪威游轮“维京天空”号上周六(23日)在挪威近海发生引擎故障搁浅。船上载有1300多人,其中28人受伤住院。经过数天的调...

“菜鸟黑客”必用兵器之“渗透测试篇二”

"菜鸟黑客"必用兵器之"渗透测试篇二"上篇文章主要针对伙伴们对"渗透测试"应该如何学习?"渗透测试"的基本流程?本篇文章继续上次的分享,接着介绍一下黑客们常用的渗透测试工具有哪些?以及用实验环境让大家...

科幻春晚丨《震动羽翼说“Hello”》两万年星间飞行,探测器对地球的最终告白

作者|藤井太洋译者|祝力新【编者按】2021年科幻春晚的最后一篇小说,来自大家喜爱的日本科幻作家藤井太洋。小说将视角放在一颗太空探测器上,延续了他一贯的浪漫风格。...

麦子陪你做作业(二):KEGG通路数据库的正确打开姿势

作者:麦子KEGG是通路数据库中最庞大的,涵盖基因组网络信息,主要注释基因的功能和调控关系。当我们选到了合适的候选分子,单变量研究也已做完,接着研究机制的时便可使用到它。你需要了解你的分子目前已有哪些...

知存科技王绍迪:突破存储墙瓶颈,详解存算一体架构优势

智东西(公众号:zhidxcom)编辑|韦世玮智东西6月5日消息,近日,在落幕不久的GTIC2021嵌入式AI创新峰会上,知存科技CEO王绍迪博士以《存算一体AI芯片:AIoT设备的算力新选择》...

每日新闻播报(September 14)_每日新闻播报英文

AnOscarstatuestandscoveredwithplasticduringpreparationsleadinguptothe87thAcademyAward...

香港新巴城巴开放实时到站数据 供科技界研发使用

中新网3月22日电据香港《明报》报道,香港特区政府致力推动智慧城市,鼓励公私营机构开放数据,以便科技界研发使用。香港运输署21日与新巴及城巴(两巴)公司签署谅解备忘录,两巴将于2019年第3季度,开...

5款不容错过的APP: Red Bull Alert,Flipagram,WifiMapper

本周有不少非常出色的app推出,鸵鸟电台做了一个小合集。亮相本周榜单的有WifiMapper's安卓版的app,其中包含了RedBull的一款新型闹钟,还有一款可爱的怪物主题益智游戏。一起来看看我...

Qt动画效果展示_qt显示图片

今天在这篇博文中,主要实践Qt动画,做一个实例来讲解Qt动画使用,其界面如下图所示(由于没有录制为gif动画图片,所以请各位下载查看效果):该程序使用应用程序单窗口,主窗口继承于QMainWindow...

如何从0到1设计实现一门自己的脚本语言

作者:dong...

三年级语文上册 仿写句子 需要的直接下载打印吧

描写秋天的好句好段1.秋天来了,山野变成了美丽的图画。苹果露出红红的脸庞,梨树挂起金黄的灯笼,高粱举起了燃烧的火把。大雁在天空一会儿写“人”字,一会儿写“一”字。2.花园里,菊花争奇斗艳,红的似火,粉...

C++|那些一看就很简洁、优雅、经典的小代码段

目录0等概率随机洗牌:1大小写转换2字符串复制...

二年级上册语文必考句子仿写,家长打印,孩子照着练

二年级上册语文必考句子仿写,家长打印,孩子照着练。具体如下:...

一年级语文上 句子专项练习(可打印)

...

亲自上阵!C++ 大佬深度“剧透”:C++26 将如何在代码生成上对抗 Rust?

...

取消回复欢迎 发表评论: