计算一幅图像的信噪比

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

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

适用情况

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

计算步骤

  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呢?请看另一篇博客,代码简洁、可读性高。

目录
相关文章
|
8月前
|
算法
【MATLAB】语音信号识别与处理:卷积滑动平均滤波算法去噪及谱相减算法呈现频谱
【MATLAB】语音信号识别与处理:卷积滑动平均滤波算法去噪及谱相减算法呈现频谱
135 0
|
5月前
|
计算机视觉
【图像处理】 Halcon 实现图像亚像素边缘检测
如何在Halcon软件中实现图像亚像素边缘检测,包括读取图片、图像阈值化、边界提取、区域扩张、亚像素边缘提取、轮廓拟合和彩色绘图等步骤,并提供了相应的Halcon代码实现和检测效果展示。
155 2
|
7月前
|
算法 计算机视觉
图像处理之Lanczos采样放缩算法
图像处理之Lanczos采样放缩算法
108 0
|
7月前
|
算法 计算机视觉
图像处理之基于采样距离变换算法
图像处理之基于采样距离变换算法
45 0
|
7月前
|
算法 C语言 计算机视觉
图像处理之图像快速插值放缩算法
图像处理之图像快速插值放缩算法
42 0
使用纹理滤波器对图像进行纹理分割
说明如何根据纹理识别和分割区域。
95 0
|
计算机视觉 Python
图像的傅里叶变换(二)
图像的傅里叶变换(二)
115 0
|
数据安全/隐私保护 Python
图像的傅里叶变换(一)
图像的傅里叶变换
129 0
|
机器学习/深度学习 传感器 算法
【图像误差测量】测量 2 张图像之间的差异,并测量图像质量(Matlab代码实现)
【图像误差测量】测量 2 张图像之间的差异,并测量图像质量(Matlab代码实现)
|
机器学习/深度学习 人工智能 算法
OpenCV-差分法实现绿叶识别(图像差分+颜色通道)
OpenCV-差分法实现绿叶识别(图像差分+颜色通道)
211 0

热门文章

最新文章

下一篇
开通oss服务