计算一幅图像的信噪比

简介: 计算一幅图像的信噪比

大家好,这是我两年前写的一篇博客修正版本,本来打算删掉了,但是阅读量很多,可能对大家会有一点小小的帮助,就重新放上来吧。

适用情况

本文适用于原始图像(即不含噪声的图像)存在的情况下。

计算步骤

  1. 使用待计算SNR图像(记为A)与原始图像(记为B)做相减运算,得到一幅图像(记为C);
  2. 我们将B视为A的信息部分,将C视为A的噪声部分;
  3. 分别计算B、C的方差;
  4. 计算上述两项之比,得到SNR的值。
  5. 对SNR的值对数化,得到以dB为单位的SNR值。



附matlab代码

A=imread('xx.jpg');
B=imread('original.jpg'); 
C=imsubtract(A,B);
avg1=mean2(C);  %求图像均值
[m,n]=size(C);
s1=0;
for x=1:m
    for y=1:n
    s1=s1+(C(x,y)-avg1)^2; %求得所有像素与均值的平方和。
    end
end
C1=s1/(m*n); %利用方差公式求得
avg2=mean2(B);  %求图像均值
[m,n]=size(B);
s2=0;
for x=1:m
    for y=1:n
    s2=s2+(B(x,y)-avg2)^2; %求得所有像素与均值的平方和。
    end
end
B1=s2/(m*n); %利用方差公式求得
D1=B1/C1;
D1=10*log10(D1);


example


计算结果

SNR=10.1861dB

计算峰值信噪比

如何计算两幅图像之间的PSNR呢?请看另一篇博客,代码简洁、可读性高。

目录
相关文章
|
4月前
|
算法 计算机视觉
使用积分图的自适应二值化算法
使用积分图的自适应二值化算法
|
4月前
|
算法
【MATLAB】语音信号识别与处理:卷积滑动平均滤波算法去噪及谱相减算法呈现频谱
【MATLAB】语音信号识别与处理:卷积滑动平均滤波算法去噪及谱相减算法呈现频谱
87 0
|
3月前
|
算法 API 计算机视觉
图像处理之角点检测与亚像素角点定位
图像处理之角点检测与亚像素角点定位
50 1
|
3月前
|
算法 计算机视觉
图像处理之积分图应用四(基于局部均值的图像二值化算法)
图像处理之积分图应用四(基于局部均值的图像二值化算法)
516 0
|
3月前
|
算法 计算机视觉
图像处理之Lanczos采样放缩算法
图像处理之Lanczos采样放缩算法
35 0
使用纹理滤波器对图像进行纹理分割
说明如何根据纹理识别和分割区域。
68 0
|
9月前
|
计算机视觉 Python
图像的傅里叶变换(二)
图像的傅里叶变换(二)
|
9月前
|
数据安全/隐私保护 Python
|
机器学习/深度学习 传感器 算法
【图像误差测量】测量 2 张图像之间的差异,并测量图像质量(Matlab代码实现)
【图像误差测量】测量 2 张图像之间的差异,并测量图像质量(Matlab代码实现)
|
11月前
|
机器学习/深度学习 人工智能 算法
OpenCV-差分法实现绿叶识别(图像差分+颜色通道)
OpenCV-差分法实现绿叶识别(图像差分+颜色通道)
160 0