• 图像小波变换去噪——MATLAB实现


    clear;                   
    [A,map]=imread('C:UserswangdDocumentsMATLAB1.jpg');                
    X=rgb2gray(A);  
    %画出原始图像  
    subplot(2,2,1);imshow(X);
    title('原始图像');  
    %产生含噪图像  
    x=imnoise(X ,'gaussian',0,0.003);
    %画出含噪图像  
    subplot(2,2,2);imshow(x);  
    title('含噪声图像');  
    %下面进行图像的去噪处理  
    %用小波函数sym4对x进行2层小波分解  
    [c,s]=wavedec2(x,2,'sym4');  
    %提取小波分解中第一层的低频图像,即实现了低通滤波去噪  
    a1=wrcoef2('a',c,s,'sym4');  % a1为 double 型数据;
    %画出去噪后的图像  
    subplot(2,2,3); imshow(uint8(a1)); % 注意 imshow()和image()显示图像有区别,imshow()不能显示 double 型数据,必须进行转换 uint8(a1);
    title('第一次去噪图像');           % 并且image() 显示图像有坐标;
    %提取小波分解中第二层的低频图像,即实现了低通滤波去噪  
    %相当于把第一层的低频图像经过再一次的低频滤波处理  
    a2=wrcoef2('a',c,s,'sym4',2);  
    %画出去噪后的图像  
    subplot(2,2,4); imshow(uint8(a2)); %image(a2);
    title('第二次去噪图像');
    %保存图像  
    imwrite(x,'C:UserswangdDesktop2.jpg');
    imwrite(uint8(a1),'C:UserswangdDesktop3.jpg'); %imwrite()保存图像,也需要将数据类型转化为uint8
    imwrite(uint8(a2),'C:UserswangdDesktop4.jpg');
  • 相关阅读:
    PHP chgrp() 函数
    PHP basename() 函数
    PHP user_error() 函数
    PHP trigger_error() 函数
    my.cnf需要改的参数
    WPF 使用 Direct2D1 画图入门
    win10 uwp 如何开始写 uwp 程序
    win10 uwp 如何开始写 uwp 程序
    C# 快速释放内存的大数组
    C# 快速释放内存的大数组
  • 原文地址:https://www.cnblogs.com/warmbeast/p/7809728.html
Copyright © 2020-2023  润新知