QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 4361|回复: 0
打印 上一主题 下一主题

[参考文献] 图像的加噪与去噪(python)

[复制链接]
字体大小: 正常 放大
杨利霞        

5273

主题

82

听众

17万

积分

  • TA的每日心情
    开心
    2021-8-11 17:59
  • 签到天数: 17 天

    [LV.4]偶尔看看III

    网络挑战赛参赛者

    网络挑战赛参赛者

    自我介绍
    本人女,毕业于内蒙古科技大学,担任文职专业,毕业专业英语。

    群组2018美赛大象算法课程

    群组2018美赛护航培训课程

    群组2019年 数学中国站长建

    群组2019年数据分析师课程

    群组2018年大象老师国赛优

    跳转到指定楼层
    1#
    发表于 2020-4-28 15:43 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta

    * L4 a" p9 j8 _1 n6 t图像的加噪与去噪(python)高斯噪声(Gaussiannoise)和椒盐噪声(salt-and-peppernoise)均可通过Python库:skimage实现。- `9 A2 q; Q; Q$ m/ {: W

    8 J+ t* f1 J3 r" w# C) _#import os              #import语句的作用是用来导入模块,可以出现在程序任何位置2 u% s% E2 v# F, T
    import cv2 as cv        #导入openCV库! c. p& O- `/ [# |
    import skimage          #导入skimage模块.scikit-image是一个图像处理算法的集合。它是基于scipy的一款图像处理包,它将图片作为numpy数组进行处理,方便进行后续运算。% g0 k7 Q, g6 x
                            #必须首先安装numpy,scipy,matplotlib
    ) t2 q) J$ S3 g' cimport numpy as np      #导入numpy模块。numpy是python扩展程序库,支持数组和矩阵运算,针对数组运算提供大量数学函数库。! D& i1 I: Z6 [

    ) h" X; O! C( u9 v! S: h
    9 y0 @+ V8 L" X, O- ?def boxBlur(img):% ]3 v. s2 c& S
        # 使用5x5的滤波核进行平滑, O7 {4 ]% J+ o5 A0 L7 d1 u; q, ^
        blur = cv.boxFilter(img,-1,(5, 5))    : z" h* C. x3 M4 H1 k
        return blur
    : S: y! O' e1 K3 e
    - A! N0 }; M" Y6 C- c& V% ?- w0 e- e! g1 y
    def gaussianBlur(img):6 v" [  A' c- V5 k( \0 T
        #     使用高斯核进行平滑6 l! F9 M/ [/ @( e/ w; M4 J
        blur = cv.GaussianBlur(img,(5, 5),1.5)
    , i( g1 j9 P6 m! G' _; _& W; ?    return blur
    ( D: h9 b* q  ]- P7 f# _
    ( z9 M+ c$ m0 r* ~4 l+ ]1 V
    " ~/ @/ l" v$ H4 W5 Gdef main():6 T. ^% ?$ I" [. ^# g; N  U
        # 2. 定义图片类img
    1 J$ K5 I5 d. v# j    path = r"C:\Users\98238\Desktop\Lenna.jpg"
    6 e8 c' f" [( B$ P) V$ m" @7 |) [    img = cv.imread(path)4 x0 m9 H' ]# G. |# N9 f" x
        start_t = cv.getTickCount(): G% W8 P, U+ \4 d9 D
        # 5. 加噪声,绘图
    ; p7 U# x' V  C! N- |* l    ##############################################3
    + ]8 K% l( P/ S. S. B    # add gaussian noise
    3 K3 |' @) X; {( B" A, h
    4 [$ I0 m; v) G: [    gauss_noiseImg = skimage.util.random_noise(img, mode='gaussian')# 添加10%的高斯噪声- v' a% v* t. F% ~
        gauss_noiseImg=gauss_noiseImg
    $ P+ h# x" Z+ ^8 p6 X, T1 @    salt_noiseImg = skimage.util.random_noise(img, mode='salt')  # 添加椒盐噪声
    9 U4 @2 N/ W+ c$ P
    $ t+ ]* j1 o7 y: p% u, G    lb_gauss=cv.medianBlur(gauss_noiseImg.astype('float32'), 1)#中值滤波
    : @' Z/ a/ K6 {) a+ t* p7 ?% w7 R5 R! s9 Z
        lb_salt=cv.medianBlur(salt_noiseImg.astype('float32'), 1)#中值滤波9 q- z1 E8 h  S2 \6 z, R
        print(gauss_noiseImg.dtype, "gaussian noisy image dtype")#输出一个注释6 v# G% ]9 s8 F3 W4 `. R
        print(gauss_noiseImg.shape, "gaussian noisy image shape")#输出一个注释
    * e# Y2 W6 d1 l4 w* Z6 B& |$ G! r9 H1 r. `- u
        print(salt_noiseImg.dtype, "salt noisy image dtype")#输出一个注释1 Z8 U& S! J& n# b) z7 `5 u
        print(salt_noiseImg.shape, "salt noisy image shape")#输出一个注释$ c) Y' R7 @! N" o/ S1 K
    ; s+ P" j2 g1 Z& P& G& v* X9 ?3 F

    ; |+ s  Y! g# |" D    cv.namedWindow("Original Image", cv.WINDOW_NORMAL)#输出原图片的标题
    9 T- w) H8 T, ?% K2 l. s% _, s    cv.imshow('Original Image', img)#输出原图片
    % p+ h. I! @4 Z3 u. k9 e8 h2 m8 x. b# X% F
        # Gaussian noisy image* o* ]: n  F  L- m8 m' G- ~! A
        cv.namedWindow("Added Gaussian Noise Image", cv.WINDOW_NORMAL)#输出高斯噪声图片的标题
    8 N! ^; c  ?2 `+ n# A    cv.imshow('Added Gaussian Noise Image', gauss_noiseImg)#输出高斯噪声图片  W& n0 a/ W) ^" o0 @7 h

    ( C/ I. ^8 P* }( C( U* y    # Salt noisy image" q0 a; M, V- v1 b. R  v, c1 D3 K
        cv.namedWindow("Added Salt Noise Image", cv.WINDOW_NORMAL)#输出椒盐噪声图片的标题
    8 O) K5 s4 T, n9 M5 ^1 i1 T    cv.imshow('Added Salt Noise Image', salt_noiseImg)#输出椒盐噪声图片" M" {  }1 ?3 d3 n

    5 {. I" J- Y7 M    #滤波后的图像* n! Y! b4 ?& H9 j! m6 Q5 F
        cv.namedWindow("lbguass Image", cv.WINDOW_NORMAL)#输出滤波后高斯噪声图片标题2 D( `, n* O$ b( I5 S/ y
        cv.imshow('lbguass Image', lb_gauss)#输出滤波后高斯噪声图片$ Y: Z0 ?1 ~5 ^; S  d0 V
        cv.namedWindow("lbsalt Image", cv.WINDOW_NORMAL)#输出滤波后椒盐噪声图片标题
    6 Q0 v0 I8 z* G( P; ~9 J5 A, a) R    cv.imshow('lbsalt Image', lb_salt)#输出滤波后椒盐噪声图片& p9 z5 s4 Q' T3 o# k/ f* \9 v
    : ~7 n' O8 y( t5 X3 G
        #####################################################
    % M' S2 y' Y6 S5 M) ?: P6 p6 H# F6 v9 k) O$ `2 H
        stop_t = ((cv.getTickCount() - start_t) / cv.getTickFrequency()) * 1000#运行时间! t  I# N* x3 ?6 d% e

    6 w/ S  i6 Z4 I6 z2 t    print(stop_t, "ms")#输出时间并加上单位8 H( C+ M- l" F0 A
    % |4 X* D, r* _, F4 w
        cv.waitKey(0)
    $ n4 B& M+ w* g    cv.destroyAllWindows()* h" i8 q; r( k
    . E* x6 y2 ~" C* F3 S/ e2 J3 f
    , G* R" g' n$ w& a; n1 \3 ~* h
    if __name__ == "__main__":
    ) x6 w+ e; a' `* ?    main()$ B3 a- r' j3 M) l! [6 A

    ; T7 N& }1 Q, A# F7 g, Z, t, i原图如下
    : m' D, Q: Y+ `! V2 Y* h2 m
    8 P. {7 a2 ]* K 1.png ; Q9 H# A4 z0 |( g; p0 o( `
    + F+ _4 l1 R. B- Z( N; V$ {& o

    使用10%的高斯噪声、椒盐噪声,以及中值滤波为3 结果图如下

    添加10%高斯噪声后的图片

    2.png , i* b; w5 n  {+ X5 k, C
    1 }' n- j1 V* X" ^7 H+ E$ j4 v
    添加椒盐后的图片
    8 \; p* q7 H- Q- Z0 Q
    6 C2 U3 ?1 E8 p. V# z/ {$ c: l 3.png
    ( f# i0 f: G3 R4 i" p5 L7 G  U
    / v& X: L) }  Q0 L: v! ]使用中值滤波3滤波后的高斯噪声图# A3 e/ |( c& o+ h& i3 s
    4.png ' c: V/ \; l* Z5 o" Z
    2 n6 P/ {0 V$ {  x
    使用中值滤波3滤波后的椒盐噪声图
    + I4 ^  h& _9 L. _ 5.png
    3 z/ d9 {+ o# q) P* y( w/ x0 M( |7 x1 T/ X8 X8 v
    改用中值滤波5 滤波滤波后的高斯噪声图; V# i  j9 U- c9 e/ K, t* T) }4 _
    9 {5 m% V- V; f2 i, ^  B- ]. O
    6.png
    ( W# t% ~' h/ |! V3 J, n$ C7 D( z- J
    2 S9 ]/ T! `, [+ D, e; ?* U' j7 x滤波后的椒盐噪声图' l$ J0 f% O5 v: ^2 G
    2 M* P# ]" q' n
    7.png $ L; b. M7 h# V5 |7 w3 c

    # q; H; x- B7 E8 q1 {0 }4 g结论:
    " E0 V* T8 q6 ^  X经过中值滤波5的滤波后噪声比中值滤波3滤波后的图像少,但是图像也更模糊一些。
    4 w& x5 N  j# k4 o8 m1 G8 v7 J9 U" `, R, ^5 Q; J. e- n$ N
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2026-5-25 18:48 , Processed in 0.458505 second(s), 54 queries .

    回顶部