python实现图像降噪

作者:名剑求瑕 时间:2022-03-09 06:36:38 

本文实例为大家分享了python实现图像降噪的具体代码,供大家参考,具体内容如下

任务描述

背景

图像在数字化和传输等过程中会产生噪声,从而影响图像的质量,而图像降噪技术可以有效地减少图像中的噪声。如下图所示,左图是一幅包含噪声的图像(图中的黑点即为噪声),右图是降噪后的结果(黑点显著减少)。

python实现图像降噪

中值滤波是一种常用的图像降噪方法,对于一幅带噪声的图像 1(设分辨率为 w×h),降噪方法如下:

1)将图像1转换成灰度图,仍称为图像1;
2)新建图像2,图像2为灰度图,分辨率与图像1相同;
3)对于图像 1 中坐标为 (x,y) 的像素 p,求 p 的中值 c,然后将图像 2 中 (x,y) 处的像素值设置成 c,其中,1≤x≤w−2、1≤y≤h−2;
4)保存图像 2,图像 2 即存放了降噪后的结果。

其中,第 3 步要计算 (x,y) 处像素 p 的中值 c,计算方法如下:

python实现图像降噪

1)选取以 p 为中心的 3×3 图像区域,如上图所示,每个小方格代表一个像素,数字表示像素的灰度值,像素 p 的坐标为 (x,y),则选取的图像区域为黄色底纹区域;
2)对步骤 1 中选取的 9 个像素的颜色值进行升序排列,如上图所示例子排序后为:11、12、13、14、15、16、17、18、99;
3)在步骤 2 得到的排序结果中,排在最中间一个值即为中值 c,如上图所示例子中像素 p 的中值为 15。

任务

本关任务是补全程序,使其能进行图像降噪,说明如下:
1)排序操作可利用列表中的sort函数进行;
2)关于代码的相关说明见注释。

相关知识

略。

编程要求

在 Begin-End 区间补全代码,具体要求见上。

测试说明

测试集正确结果如下:

(1  , 1 ) -> 255
(72 , 42) -> 191
(120, 45) -> 127
(164, 49) -> 89
(235, 49) -> 38

你的图像与正确答案相同!

说明如下:

1)系统会调用你编写的median函数,并以“像素坐标 -> 中值”的格式打印结果,如测试集第 1 行的(1 , 1 ) -> 255表示:(1,1) 处像素的中值为255;
2)此外,系统会检查程序生成的图像文件,若正确则在测试集最后一行打印你的图像与正确答案相同!。

开始你的任务吧,祝你成功!

from PIL import Image

# 求图像img中(x,y)处像素的中值c
def median(img, x, y):
    ########## Begin ##########
    L = []
    xl = [x-1,x,x+1]
    yl = [y-1,y,y+1]
    for i in xl:
        for j in yl:
            gray = img.getpixel((i, j))  # 取出灰度值
            L.append(gray)
    L.sort()
    c = L[4]
    ########## End ##########
    return c

# 对图像文件1进行降噪,并将结果保存为图像文件2
# 图像文件1和2的路径分别为path1和path2
def denoise(path1, path2):
    img1 = Image.open(path1)  # 图像1
    img1 = img1.convert('L')  # 将图像1转换为灰度图
    w, h = img1.size
    img2 = Image.new('L', (w, h), 'white')  # 图像2
    for x in range(1, w - 1):
        for y in range(1, h - 1):
            c = median(img1, x, y)  # 求中值
            img2.putpixel((x, y), c)  # 将灰度设置为中值
    img2.save(path2)

path1 = 'step4.bmp'  # 带噪声的图像
path2 = 'step4_2.bmp'  # 降噪后的图像
denoise(path1, path2)

python实现图像降噪

来源:https://blog.csdn.net/qq_42833469/article/details/121581439

标签:python,图像降噪
0
投稿

猜你喜欢

  • Python新手如何进行闭包时绑定变量操作

    2021-05-01 15:23:55
  • 使用JS批量选中功能实现更改数据库中的status状态值(批量展示)

    2024-01-28 00:18:38
  • mysql中如何设置大小写不敏感

    2024-01-15 08:10:43
  • 减少用户的思考

    2010-09-07 12:14:00
  • Python tkinter的grid布局及Text动态显示方法

    2023-06-28 14:54:00
  • python字符串常用方法

    2023-07-12 19:01:50
  • 原生js封装的一些jquery方法(详解)

    2024-04-19 09:47:01
  • Python最大连续区间和动态规划

    2023-02-13 09:40:32
  • python读取视频流提取视频帧的两种方法

    2023-04-04 15:10:22
  • 解决python将xml格式文件转换成txt文件的问题(xml.etree方法)

    2021-10-21 02:51:13
  • 基础语音识别-食物语音识别baseline(CNN)

    2023-04-05 22:44:11
  • 刚学完怎么用Python实现定时任务,转头就跑去撩妹!

    2022-07-09 06:50:02
  • JavaScript实现简单的tab选项卡切换

    2024-06-17 06:22:43
  • JavaScript中layim之整合右键菜单的示例代码

    2024-04-18 09:42:29
  • 对json字符串与python字符串的不同之处详解

    2023-11-22 04:35:39
  • 网页绿色系配色应用实例

    2008-08-26 11:51:00
  • Python flask使用ajax上传文件的示例代码

    2021-06-25 17:40:29
  • python人工智能tensorflow常用激活函数Activation Functions

    2023-08-01 12:45:02
  • 基于Python制作一个简单的文章搜索工具

    2021-07-08 02:16:28
  • python中统计相同字符的个数方法实例

    2021-04-21 00:28:58
  • asp之家 网络编程 m.aspxhome.com