图像img2img任务任务中评估指标

2023-12-01 11:52

本文主要是介绍图像img2img任务任务中评估指标,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  1. 均方误差(Mean Squared Error,MSE):计算两个图像像素之间的平均差异的平方。MSE越小,表示两个图像越接近。

  2. 均方根误差(Root Mean Squared Error,RMSE):MSE的平方根。RMSE也用于衡量两个图像之间的差异,与MSE类似,但更易于解释。

  3. 均方根对数似然比误差(Root Mean Square Logarithmic Error,RMSLE):计算两个图像像素值的对数之间的均方根差异。RMSLE通常在图像处理和计算机视觉任务中使用。

  4. 结构相似性指数(Structural Similarity Index,SSIM):衡量两个图像在结构、纹理和亮度方面的相似性。SSIM值介于0和1之间,值越接近1表示图像越相似。

  5. 峰值信噪比(Peak Signal-to-Noise Ratio,PSNR):衡量图像失真程度的指标,常用于图像和视频压缩评估。PSNR值越高,表示图像质量越好。

  6. 结构相位相似性(Structural Phase Similarity,SPS):类似于SSIM,但在相位信息上进行比较。SPS测量了两个图像在结构和纹理方面的相似性。

  7. 多尺度结构相似性(Multi-Scale Structural Similarity,MS-SSIM):对图像进行多尺度分解,并计算每个尺度上的SSIM值,然后进行加权平均得到最终的相似性指数。

这些指标可以根据具体需求选择使用,不同的指标适用于不同的应用场景。

峰值信噪比(Peak Signal-to-Noise Ratio,PSNR): PSNR是衡量重建图像与原始图像之间峰值信噪比的指标,数值越高表示重建图像质量越好。

import torch
import torch.nn.functional as Fdef psnr(img1, img2):mse = F.mse_loss(img1, img2)psnr = 10 * torch.log10(1 / mse)return psnrdef psnr(img1, img2):mse = F.mse_loss(img1, img2)psnr = 10 * torch.log10(255** 2 / mse)return psnr

结构相似性指数(Structural Similarity Index,SSIM): SSIM可以衡量重建图像与原始图像之间结构相似性的指标,数值越接近1表示重建图像质量越好

import torch
import torch.nn.functional as Fdef ssim(img1, img2, window_size=11, size_average=True):# 设置窗口参数channels = img1.size(1)window = create_window(window_size, channels).to(img1.device)# 计算图像均值、方差和协方差mu1 = F.conv2d(img1, window, padding=window_size//2, groups=channels)mu2 = F.conv2d(img2, window, padding=window_size//2, groups=channels)mu1_sq = mu1.pow(2)mu2_sq = mu2.pow(2)mu1_mu2 = mu1 * mu2sigma1_sq = F.conv2d(img1 * img1, window, padding=window_size//2, groups=channels) - mu1_sqsigma2_sq = F.conv2d(img2 * img2, window, padding=window_size//2, groups=channels) - mu2_sqsigma12 = F.conv2d(img1 * img2, window, padding=window_size//2, groups=channels) - mu1_mu2# 计算SSIM值C1 = (0.01 * 255)**2C2 = (0.03 * 255)**2numerator = (2 * mu1_mu2 + C1) * (2 * sigma12 + C2)denominator = (mu1_sq + mu2_sq + C1) * (sigma1_sq + sigma2_sq + C2)ssim_map = numerator / denominatorif size_average:return ssim_map.mean()else:return ssim_map.mean(1).mean(1).mean(1)def gaussian(window_size, sigma):gauss = torch.exp(-(torch.arange(window_size) - window_size//2)**2 / (2*sigma**2))return gauss / gauss.sum()def create_window(window_size, channels):_1D_window = gaussian(window_size, 1.5).unsqueeze(1)_2D_window = _1D_window.mm(_1D_window.t()).float().unsqueeze(0).unsqueeze(0)window = _2D_window.expand(channels, 1, window_size, window_size).contiguous()return window# 示例用法
img1 = torch.randn(1, 3, 256, 256)  # 输入图像1
img2 = torch.randn(1, 3, 256, 256)  # 输入图像2ssim_value = ssim(img1, img2)
print(ssim_value)

其它

import torch
import torch.nn.functional as Fdef rmse(img1, img2):mse = F.mse_loss(img1, img2)rmse_value = torch.sqrt(mse)return rmse_valuedef sps(img1, img2):fft1 = torch.fft.fftn(img1)fft2 = torch.fft.fftn(img2)phase_corr = torch.cos(fft1.angle() - fft2.angle())sps_value = torch.mean(phase_corr)return sps_value计算RMSLE时,使用1加上两个图像像素值之间的差异的平方。这里加1的目的是为了避免当差异为0时取对数的问题。如果两个像素值相等,即img1 - img2 = 0,那么计算log(1 + (img1 - img2)**2)时,如果没有加1,就会变成log(0),这将导致无穷大或错误的结果。通过加1,我们确保了即使差异为0,取对数时也不会出现问题。
因此,在计算RMSLE时,通常会在差异平方的基础上加1,以确保计算的稳定性和正确性。def rmsle(img1, img2):log_diff = torch.log(1 + (img1 - img2)**2)rmsle_value = torch.sqrt(torch.mean(log_diff))return rmsle_value# 示例用法
img1 = torch.randn(1, 3, 256, 256)  # 输入图像1
img2 = torch.randn(1, 3, 256, 256)  # 输入图像2rmse_value = rmse(img1, img2)
sps_value = sps(img1, img2)
rmsle_value = rmsle(img1, img2)print("RMSE:", rmse_value)
print("SPS:", sps_value)
print("RMSLE:", rmsle_value)

这篇关于图像img2img任务任务中评估指标的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/441060

相关文章

OpenCV图像形态学的实现

《OpenCV图像形态学的实现》本文主要介绍了OpenCV图像形态学的实现,包括腐蚀、膨胀、开运算、闭运算、梯度运算、顶帽运算和黑帽运算,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起... 目录一、图像形态学简介二、腐蚀(Erosion)1. 原理2. OpenCV 实现三、膨胀China编程(

SpringQuartz定时任务核心组件JobDetail与Trigger配置

《SpringQuartz定时任务核心组件JobDetail与Trigger配置》Spring框架与Quartz调度器的集成提供了强大而灵活的定时任务解决方案,本文主要介绍了SpringQuartz定... 目录引言一、Spring Quartz基础架构1.1 核心组件概述1.2 Spring集成优势二、J

Redis实现延迟任务的三种方法详解

《Redis实现延迟任务的三种方法详解》延迟任务(DelayedTask)是指在未来的某个时间点,执行相应的任务,本文为大家整理了三种常见的实现方法,感兴趣的小伙伴可以参考一下... 目录1.前言2.Redis如何实现延迟任务3.代码实现3.1. 过期键通知事件实现3.2. 使用ZSet实现延迟任务3.3

Linux中的计划任务(crontab)使用方式

《Linux中的计划任务(crontab)使用方式》:本文主要介绍Linux中的计划任务(crontab)使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、前言1、linux的起源与发展2、什么是计划任务(crontab)二、crontab基础1、cro

Spring定时任务只执行一次的原因分析与解决方案

《Spring定时任务只执行一次的原因分析与解决方案》在使用Spring的@Scheduled定时任务时,你是否遇到过任务只执行一次,后续不再触发的情况?这种情况可能由多种原因导致,如未启用调度、线程... 目录1. 问题背景2. Spring定时任务的基本用法3. 为什么定时任务只执行一次?3.1 未启用

如何使用Python实现一个简单的window任务管理器

《如何使用Python实现一个简单的window任务管理器》这篇文章主要为大家详细介绍了如何使用Python实现一个简单的window任务管理器,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起... 任务管理器效果图完整代码import tkinter as tkfrom tkinter i

Spring Boot 集成 Quartz 使用Cron 表达式实现定时任务

《SpringBoot集成Quartz使用Cron表达式实现定时任务》本文介绍了如何在SpringBoot项目中集成Quartz并使用Cron表达式进行任务调度,通过添加Quartz依赖、创... 目录前言1. 添加 Quartz 依赖2. 创建 Quartz 任务3. 配置 Quartz 任务调度4. 启

Java使用多线程处理未知任务数的方案介绍

《Java使用多线程处理未知任务数的方案介绍》这篇文章主要为大家详细介绍了Java如何使用多线程实现处理未知任务数,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 知道任务个数,你可以定义好线程数规则,生成线程数去跑代码说明:1.虚拟线程池:使用 Executors.newVir

Spring Boot中定时任务Cron表达式的终极指南最佳实践记录

《SpringBoot中定时任务Cron表达式的终极指南最佳实践记录》本文详细介绍了SpringBoot中定时任务的实现方法,特别是Cron表达式的使用技巧和高级用法,从基础语法到复杂场景,从快速启... 目录一、Cron表达式基础1.1 Cron表达式结构1.2 核心语法规则二、Spring Boot中定

使用Python开发一个图像标注与OCR识别工具

《使用Python开发一个图像标注与OCR识别工具》:本文主要介绍一个使用Python开发的工具,允许用户在图像上进行矩形标注,使用OCR对标注区域进行文本识别,并将结果保存为Excel文件,感兴... 目录项目简介1. 图像加载与显示2. 矩形标注3. OCR识别4. 标注的保存与加载5. 裁剪与重置图像