Python判断两张图片的相似度

在Python中,判断两张以numpyndarray格式存储的图片的相似度,通常可以通过多种方法来实现,包括但不限于直方图比较、像素差比较、结构相似性指数(SSIM)、特征匹配等。以下是一些常见方法的简要介绍和示例代码。

1. 像素差比较

最直接的方法是计算两张图片对应像素之间的差异。然而,这种方法对图片的旋转、缩放等变换非常敏感。

python 复制代码
import numpy as np

def pixel_difference(img1, img2):
    if img1.shape != img2.shape:
        raise ValueError("Images must have the same shape")
    diff = np.sum(np.abs(img1.astype(np.float32) - img2.astype(np.float32)))
    return diff

# 假设 img1 和 img2 是两个相同尺寸的 ndarray 图片
# result = pixel_difference(img1, img2)
# print(f"Pixel Difference: {result}")

2. 直方图比较

通过比较两张图片的直方图来判断它们的相似度。这种方法对颜色分布敏感,但对空间信息不敏感。

python 复制代码
from skimage.exposure import histogram

def histogram_comparison(img1, img2):
    hist1, bin_idx1 = histogram(img1)
    hist2, bin_idx2 = histogram(img2)
    # 这里可以使用多种方法来比较直方图,如计算欧氏距离、巴氏距离等
    diff = np.linalg.norm(hist1 - hist2)
    return diff

# 假设 img1 和 img2 是两个 ndarray 图片
# result = histogram_comparison(img1, img2)
# print(f"Histogram Difference: {result}")

3. 结构相似性指数(SSIM)

SSIM是一种衡量两幅图片视觉相似度的指标,它考虑了亮度、对比度和结构信息。

python 复制代码
from skimage.metrics import structural_similarity as ssim

def compare_ssim(img1, img2):
    # 确保img1和img2是灰度图,如果不是,需要先转换
    if img1.ndim == 3:
        img1 = img1.mean(axis=2)
    if img2.ndim == 3:
        img2 = img2.mean(axis=2)
    (score, diff) = ssim(img1, img2, full=True)
    return score, diff

# 假设 img1 和 img2 是两个 ndarray 图片
# score, diff = compare_ssim(img1, img2)
# print(f"SSIM: {score}, Diff: {diff}")

注意

  • 上述代码中的img1img2应该是相同尺寸和类型的numpy.ndarray
  • 对于颜色图片,一些方法(如SSIM)可能需要先将图片转换为灰度图或使用其他方式处理颜色通道。
  • 在实际应用中,可能需要根据图片的具体情况和需求选择合适的方法。
相关推荐
syker1 分钟前
AIFerric v2.0 项目总结报告
c语言·开发语言·c++
u0109147606 分钟前
JavaScript中类的装饰器提案在属性与方法上的应用
jvm·数据库·python
周杰伦fans12 分钟前
C# CAD二次开发:RotatedDimension 文字边框设置完全指南
开发语言·c#
Absurd58714 分钟前
Laravel Eloquent 中精准检测时间区间重叠的完整实践指南
jvm·数据库·python
djjdjdjdjjdj15 分钟前
如何快速查询SQL中的重复记录:GROUP BY与COUNT统计
jvm·数据库·python
2301_7826591816 分钟前
Redis怎样监控当前发生了多少次内存驱逐
jvm·数据库·python
m0_6178814220 分钟前
如何在新电脑上正确运行已部署的 Django 项目
jvm·数据库·python
u01091476021 分钟前
Golang怎么计算日期差天数_Golang如何计算两个日期之间相差多少天【方法】
jvm·数据库·python
蚰蜒螟24 分钟前
从 pthread_create 到 thread_native_entry:glibc 如何唤醒 Java 线程
java·开发语言
We་ct27 分钟前
LeetCode 300. 最长递增子序列:两种解法从入门到优化
开发语言·前端·javascript·算法·leetcode·typescript