【图像去噪】基于梯度为0法实现图像去噪附matlab代码

简介: 【图像去噪】基于梯度为0法实现图像去噪附matlab代码

✅作者简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,matlab项目合作可私信。

🍎个人主页:Matlab科研工作室

🍊个人信条:格物致知。

更多Matlab仿真内容点击👇

智能优化算法       神经网络预测       雷达通信      无线传感器        电力系统

信号处理              图像处理               路径规划       元胞自动机        无人机

⛄ 内容介绍

近几年,徐立提出的 L0 梯度最小化模型在图像平滑领域得到了广泛的应用和发展[11]. 和以往的局部滤波模型不同的是该模型可以全局的估计图像的像素值,因此,L0 梯度最小化模型在处理图像的同时能够很好的保护图像的边缘.

⛄ 部分代码

function [mssim, ssim_map] = ssim_index(img1, img2, K, window, L)


%========================================================================

%SSIM Index, Version 1.0

%Copyright(c) 2003 Zhou Wang

%All Rights Reserved.

%

%The author is with Howard Hughes Medical Institute, and Laboratory

%for Computational Vision at Center for Neural Science and Courant

%Institute of Mathematical Sciences, New York University.

%

%----------------------------------------------------------------------

%Permission to use, copy, or modify this software and its documentation

%for educational and research purposes only and without fee is hereby

%granted, provided that this copyright notice and the original authors'

%names appear on all copies and supporting documentation. This program

%shall not be used, rewritten, or adapted as the basis of a commercial

%software or hardware product without first obtaining permission of the

%authors. The authors make no representations about the suitability of

%this software for any purpose. It is provided "as is" without express

%or implied warranty.

%----------------------------------------------------------------------

%

%This is an implementation of the algorithm for calculating the

%Structural SIMilarity (SSIM) index between two images. Please refer

%to the following paper:

%

%Z. Wang, A. C. Bovik, H. R. Sheikh, and E. P. Simoncelli, "Image

%quality assessment: From error visibility to structural similarity"

%IEEE Transactios on Image Processing, vol. 13, no. 4, pp.600-612,

%Apr. 2004.

%

%Kindly report any suggestions or corrections to zhouwang@ieee.org

%

%----------------------------------------------------------------------

%

%Input : (1) img1: the first image being compared

%        (2) img2: the second image being compared

%        (3) K: constants in the SSIM index formula (see the above

%            reference). defualt value: K = [0.01 0.03]

%        (4) window: local window for statistics (see the above

%            reference). default widnow is Gaussian given by

%            window = fspecial('gaussian', 11, 1.5);

%        (5) L: dynamic range of the images. default: L = 255

%

%Output: (1) mssim: the mean SSIM index value between 2 images.

%            If one of the images being compared is regarded as

%            perfect quality, then mssim can be considered as the

%            quality measure of the other image.

%            If img1 = img2, then mssim = 1.

%        (2) ssim_map: the SSIM index map of the test image. The map

%            has a smaller size than the input images. The actual size:

%            size(img1) - size(window) + 1.

%

%Default Usage:

%   Given 2 test images img1 and img2, whose dynamic range is 0-255

%

%   [mssim ssim_map] = ssim_index(img1, img2);

%

%Advanced Usage:

%   User defined parameters. For example

%

%   K = [0.05 0.05];

%   window = ones(8);

%   L = 100;

%   [mssim ssim_map] = ssim_index(img1, img2, K, window, L);

%

%See the results:

%

%   mssim                        %Gives the mssim value

%   imshow(max(0, ssim_map).^4)  %Shows the SSIM index map

%

%========================================================================



if (nargin < 2 | nargin > 5)

  ssim_index = -Inf;

  ssim_map = -Inf;

  return;

end


if (size(img1) ~= size(img2))

  ssim_index = -Inf;

  ssim_map = -Inf;

  return;

end


[M N] = size(img1);


if (nargin == 2)

  if ((M < 11) | (N < 11))

  ssim_index = -Inf;

  ssim_map = -Inf;

     return

  end

  window = fspecial('gaussian', 11, 1.5); %

  K(1) = 0.01;      % default settings

  K(2) = 0.03;      %

  L = max(img2(:))-min(img2(:));%255;                                  %

end


if (nargin == 3)

  if ((M < 11) | (N < 11))

  ssim_index = -Inf;

  ssim_map = -Inf;

     return

  end

  window = fspecial('gaussian', 11, 1.5);

  L = max(img2(:))-min(img2(:));%255;

  if (length(K) == 2)

     if (K(1) < 0 | K(2) < 0)

  ssim_index = -Inf;

  ssim_map = -Inf;

  return;

     end

  else

  ssim_index = -Inf;

  ssim_map = -Inf;

  return;

  end

end


if (nargin == 4)

  [H W] = size(window);

  if ((H*W) < 4 | (H > M) | (W > N))

  ssim_index = -Inf;

  ssim_map = -Inf;

     return

  end

  L = max(img2(:))-min(img2(:));%255;

  if (length(K) == 2)

     if (K(1) < 0 | K(2) < 0)

  ssim_index = -Inf;

  ssim_map = -Inf;

  return;

     end

  else

  ssim_index = -Inf;

  ssim_map = -Inf;

  return;

  end

end


if (nargin == 5)

  [H W] = size(window);

  if ((H*W) < 4 | (H > M) | (W > N))

  ssim_index = -Inf;

  ssim_map = -Inf;

     return

  end

  if (length(K) == 2)

     if (K(1) < 0 | K(2) < 0)

  ssim_index = -Inf;

  ssim_map = -Inf;

  return;

     end

  else

  ssim_index = -Inf;

  ssim_map = -Inf;

  return;

  end

end


C1 = (K(1)*L)^2;

C2 = (K(2)*L)^2;

window = window/sum(sum(window));

img1 = double(img1);

img2 = double(img2);


mu1   = filter2(window, img1, 'valid');

mu2   = filter2(window, img2, 'valid');

mu1_sq = mu1.*mu1;

mu2_sq = mu2.*mu2;

mu1_mu2 = mu1.*mu2;

sigma1_sq = filter2(window, img1.*img1, 'valid') - mu1_sq;

sigma2_sq = filter2(window, img2.*img2, 'valid') - mu2_sq;

sigma12 = filter2(window, img1.*img2, 'valid') - mu1_mu2;


if (C1 > 0 & C2 > 0)

  ssim_map = ((2*mu1_mu2 + C1).*(2*sigma12 + C2))./((mu1_sq + mu2_sq + C1).*(sigma1_sq + sigma2_sq + C2));

else

  numerator1 = 2*mu1_mu2 + C1;

  numerator2 = 2*sigma12 + C2;

denominator1 = mu1_sq + mu2_sq + C1;

  denominator2 = sigma1_sq + sigma2_sq + C2;

  ssim_map = ones(size(mu1));

  index = (denominator1.*denominator2 > 0);

  ssim_map(index) = (numerator1(index).*numerator2(index))./(denominator1(index).*denominator2(index));

  index = (denominator1 ~= 0) & (denominator2 == 0);

  ssim_map(index) = numerator1(index)./denominator1(index);

end


mssim = mean2(ssim_map);


return

⛄ 运行结果

⛄ 参考文献

[1]Wen Yunlei, 温云磊, Wang Yuanquan,等. 基于核回归和L0梯度最小化的图像去噪方法[C]// 中国图象图形学学会. 中国图象图形学学会, 2014.

⛳️ 完整代码

❤️部分理论引用网络文献,若有侵权联系博主删除
❤️ 关注我领取海量matlab电子书和数学建模资料



相关文章
|
2天前
|
数据安全/隐私保护
地震波功率谱密度函数、功率谱密度曲线,反应谱转功率谱,matlab代码
地震波格式转换、时程转换、峰值调整、规范反应谱、计算反应谱、计算持时、生成人工波、时频域转换、数据滤波、基线校正、Arias截波、傅里叶变换、耐震时程曲线、脉冲波合成与提取、三联反应谱、地震动参数、延性反应谱、地震波缩尺、功率谱密度
|
2天前
|
数据安全/隐私保护
耐震时程曲线,matlab代码,自定义反应谱与地震波,优化源代码,地震波耐震时程曲线
地震波格式转换、时程转换、峰值调整、规范反应谱、计算反应谱、计算持时、生成人工波、时频域转换、数据滤波、基线校正、Arias截波、傅里叶变换、耐震时程曲线、脉冲波合成与提取、三联反应谱、地震动参数、延性反应谱、地震波缩尺、功率谱密度
基于混合整数规划的微网储能电池容量规划(matlab代码)
基于混合整数规划的微网储能电池容量规划(matlab代码)
|
2天前
|
算法 调度
面向配电网韧性提升的移动储能预布局与动态调度策略(matlab代码)
面向配电网韧性提升的移动储能预布局与动态调度策略(matlab代码)
|
2天前
|
算法 调度
含多微网租赁共享储能的配电网博弈优化调度(含matlab代码)
含多微网租赁共享储能的配电网博弈优化调度(含matlab代码)
|
2天前
|
运维 算法
基于改进遗传算法的配电网故障定位(matlab代码)
基于改进遗传算法的配电网故障定位(matlab代码)
|
2天前
|
Serverless
基于Logistic函数的负荷需求响应(matlab代码)
基于Logistic函数的负荷需求响应(matlab代码)
|
2天前
|
供应链 算法
基于分布式优化的多产消者非合作博弈能量共享(Matlab代码)
基于分布式优化的多产消者非合作博弈能量共享(Matlab代码)
|
2天前
|
算法 调度
基于多目标粒子群算法冷热电联供综合能源系统运行优化(matlab代码)
基于多目标粒子群算法冷热电联供综合能源系统运行优化(matlab代码)
|
2天前
|
算法 调度 SoC
电动汽车充放电V2G模型(Matlab代码)
电动汽车充放电V2G模型(Matlab代码)

热门文章

最新文章