Python 不同分辨率图像峰值信噪比[PSNR]
创始人
2024-05-27 06:01:13
0

PNNR:全称为“Peak Signal-to-Noise Ratio”,中文直译为峰值信噪比

前言

一、定义

二、Python代码

1.自定义

2.Tensorflow

总结


前言

峰值信噪比是一种衡量图像质量的指标,描述的是最大值信号与北京噪音之间的关系。

一般来说,PSNR高于40dB说明图像质量极好(即非常接近原始图像);在30—40dB通常表示图像质量是好的(即失真可以察觉但可以接受);在20—30dB说明图像质量差;低于20dB图像不可接受。


一、定义

对于两个m*n的单色图像XY,其均方误差(MSE)定义为

                                MSE=\frac{1}{mn}\sum_{i=0}^{m-1}\sum_{j=0}^{n-1}\left ( X|i,j|-Y|i,j|\right)^{2}

峰值信噪比(PSNR)定义为

                                PSNR=10*lg\left ( \frac{MAX_{I}^{2}}{MSE} \right )=20*lg\left ( \frac{MAX_{I}}{\sqrt{MSE}} \right )

其中MAX_{I}表示图像像素点的最大值,如果每个采样点用8位表示,那么最大值就是255。根据定义可知MSE越小,则PSNR越大,所以PSNR越大,代表图像质量越好。

针对彩色图像,通常有三种方法计算

1、分别计算RGB三个通道的PSNR,然后取平均值

2、计算RGB三通道的MSE,然后除以3

3、将图片转化为YCbCr格式,然后只计算Y分量(亮度分量)的PSNR

二、Python代码

1.自定义

import cv2 as cv 
import math
import numpy as npdef psnr1(img1,img2):#compute mse# mse = np.mean((img1-img2)**2)mse = np.mean((img1/1.0-img2/1.0)**2)#compute psnrif mse < 1e-10:return 100psnr1 = 20*math.log10(255/math.sqrt(mse))return psnr1#像素归一化
def psnr2(img1,img2):mse = np.mean((img1/255.0-img2/255.0)**2)if mse < 1e-10:return 100psnr2 = 20*math.log10(1/math.sqrt(mse))return psnr2imag1 = cv.imread("C:/Users/Server/Desktop/1.jpg")
imag2 = cv.imread("C:/Users/Server/Desktop/2.jpg")
print (imag1.shape)
#print(imag2.shape)
# imag2 = imag2.reshape(352,352,3)
#print(imag2.shape)
res1 = psnr1(imag1,imag2)
print("res1:",res1)
res2 = psnr2(imag1,imag2)
print("res2:",res2)

2.TensorFlow

'''
compute PSNR with tensorflow
'''
import tensorflow as tfdef read_img(path):return tf.image.decode_image(tf.read_file(path))def psnr(tf_img1, tf_img2):return tf.image.psnr(tf_img1, tf_img2, max_val=255)def _main():t1 = read_img('1.jpg')t2 = read_img('2.jpg')with tf.Session() as sess:sess.run(tf.global_variables_initializer())y = sess.run(psnr(t1, t2))print(y)if __name__ == '__main__':_main()

总结

为了更好地展示结果,以下为两张图片的PSNR。

1(女)与1(女)的PSNR: 100
1(女)与2(男)的PSNR: 6.534605344887611

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...