图像峰值信噪比PSNR计算模板

本文介绍了两种计算图像峰值信噪比(PSNR)的方法,包括基本公式和修改版,通过PIL库操作图像并计算img1与img2之间的PSNR,适用于图像处理质量评估。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

参考博客 https://blog.youkuaiyun.com/u010886794/article/details/84784453

import numpy as np
import math
from PIL import Image


def psnr1(img1, img2):
    mse = np.mean((img1 - img2) ** 2)
    if mse < 1.0e-10:
        return 100
    return 10 * math.log10(255.0 ** 2 / mse)


def psnr2(img1, img2):
    mse = np.mean((img1 - img2) ** 2)
    if mse < 1.0e-10:
        return 100
    PIXEL_MAX = 255
    return 20 * math.log10(PIXEL_MAX / math.sqrt(mse))

if __name__ == "__main__":
    img1 = Image.open("img1.jpg")
    img2 = Image.open("img2.jpg")
    img1 = img1.resize((300,500))
    img2 = img2.resize((300,500))

    img1 = np.array(img1)
    img2 = np.array(img2)

    psnr1 = psnr1(img1, img2)
    psnr2 = psnr2(img1, img2)
    print(psnr1)
    print(psnr2)

img1

img2

计算结果 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值