图像的峰值信噪比(PSNR)的计算方法

峰值信噪比经常用作图像压缩等领域中信号重建质量的测量方法,它常简单地通过均方差(MSE)进行定义。两个m×n单色图像IK,如果一个为另外一个的噪声近似,那么它们的的均方差定义为:

\mathit{MSE} = \frac{1}{mn}\sum_{i=0}^{m-1}\sum_{j=0}^{n-1} ||I(i,j) - K(i,j)||^2

峰值信噪比定义为:

\mathit{PSNR} = 10 \cdot \log_{10} \left( \frac{\mathit{MAX}_I^2}{\mathit{MSE}} \right) = 20 \cdot \log_{10} \left( \frac{\mathit{MAX}_I}{\sqrt{\mathit{MSE}}} \right)

其中,MAXI是表示图像点颜色的最大数值,如果每个采样点用 8 位表示,那么就是 255。

 

下图用具体的例子演示了峰值信噪比(PSNR)的计算方法。

其中左侧是图像中的16个像素值,右侧是经过变动的图像的像素值(红色代表像素值有改变)

最下方就是计算两幅图像的 MSE,PSNR

图像的峰值信噪比(PSNR)的计算方法_第1张图片

峰值信噪比(PSNR)是一个表示信号最大可能功率和影响它的表示精度的破坏性噪声功率的比值的工程术语。由于许多信号都有非常宽的动态范围,峰值信噪比常用对数分贝单位来表示。

在图像处理中,要对图像进行客观的评价,常常需要计算PSNR。PSNR是衡量图像失真或是噪声水平的客观标准。2个图像之间PSNR值越大,则越相似。普遍基准为30dB,30dB以下的图像劣化较为明显。

PSNR定义:

其中,MAX表示图像颜色的最大数值,8bit图像最大取值为255。MSE为均方差,定义为:

其中,IK分辨是原始图像和处理后的图像,m*n为量图像的大小。

/********************************************
* 输入格式是cv::Mat类型,I1,I2代表是输入的两幅图像
*/
double getPSNR(const Mat& I1, const Mat& I2)
{
    Mat s1;
    absdiff(I1, I2, s1);       	// |I1 - I2|AbsDiff函数是 OpenCV 中计算两个数组差的绝对值的函数
    s1.convertTo(s1, CV_32F);  	// 这里我们使用的CV_32F来计算,因为8位无符号char是不能进行平方计算
    s1 = s1.mul(s1);           	// |I1 - I2|^2
    Scalar s = sum(s1);        	// 对每一个通道进行加和
    double sse = s.val[0] + s.val[1] + s.val[2]; // sum channels
    if(sse <= 1e-10) 			// 对于非常小的值我们将约等于0
        return 0;
    else {
        double  mse =sse /(double)(I1.channels() * I1.total());	// MSE
        double psnr = 10.0*log10((255*255)/mse);
        return psnr;
    }
}
  1.  

你可能感兴趣的:(图像的峰值信噪比(PSNR)的计算方法)