iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >Python图片检索之以图搜图
  • 792
分享到

Python图片检索之以图搜图

2024-04-02 19:04:59 792人浏览 独家记忆

Python 官方文档:入门教程 => 点击学习

摘要

目录一、待搜索图二、测试集三、new_similarity_compare.py四、image_similarity_function.py五、结果一、待搜索图 二、测试集 三、

一、待搜索图

在这里插入图片描述

二、测试集

在这里插入图片描述

三、new_similarity_compare.py


# -*- encoding=utf-8 -*-

from image_similarity_function import *
import os
import shutil

# 融合相似度阈值
threshold1 = 0.70
# 最终相似度较高判断阈值
threshold2 = 0.95


# 融合函数计算图片相似度
def calc_image_similarity(img1_path, img2_path):
    """
    :param img1_path: filepath+filename
    :param img2_path: filepath+filename
    :return: 图片最终相似度
    """

    similary_ORB = float(ORB_img_similarity(img1_path, img2_path))
    similary_phash = float(phash_img_similarity(img1_path, img2_path))
    similary_hist = float(calc_similar_by_path(img1_path, img2_path))
    # 如果三种算法的相似度最大的那个大于0.7,则相似度取最大,否则,取最小。
    max_three_similarity = max(similary_ORB, similary_phash, similary_hist)
    min_three_similarity = min(similary_ORB, similary_phash, similary_hist)
    if max_three_similarity > threshold1:
        result = max_three_similarity
    else:
        result = min_three_similarity

    return round(result, 3)


if __name__ == '__main__':

    # 搜索文件夹
    filepath = r'D:\Dataset\cityscapes\leftImg8bit\val\frankfurt'

    #待查找文件夹
    searchpath = r'C:\Users\Administrator\Desktop\cityscapes_paper'

    # 相似图片存放路径
    newfilepath = r'C:\Users\Administrator\Desktop\result'

    for parent, dirnames, filenames in os.walk(searchpath):
        for srcfilename in filenames:
            img1_path = searchpath +"\\"+ srcfilename
            for parent, dirnames, filenames in os.walk(filepath):
                for i, filename in enumerate(filenames):
                    print("{}/{}: {} , {} ".fORMat(i+1, len(filenames), srcfilename,filename))
                    img2_path = filepath + "\\" + filename
                    # 比较
                    kk = calc_image_similarity(img1_path, img2_path)
                    try:
                        if kk >= threshold2:
                            # 将两张照片同时拷贝到指定目录
                            shutil.copy(img2_path, os.path.join(newfilepath, srcfilename[:-4] + "_" + filename))
                    except Exception as e:
                        # print(e)
                        pass

四、image_similarity_function.py


# -*- encoding=utf-8 -*-

# 导入包
import cv2
from functools import reduce
from PIL import Image


# 计算两个图片相似度函数ORB算法
def ORB_img_similarity(img1_path, img2_path):
    """
    :param img1_path: 图片1路径
    :param img2_path: 图片2路径
    :return: 图片相似度
    """
    try:
        # 读取图片
        img1 = cv2.imread(img1_path, cv2.IMREAD_GRAYSCALE)
        img2 = cv2.imread(img2_path, cv2.IMREAD_GRAYSCALE)

        # 初始化ORB检测器
        orb = cv2.ORB_create()
        kp1, des1 = orb.detectAndCompute(img1, None)
        kp2, des2 = orb.detectAndCompute(img2, None)

        # 提取并计算特征点
        bf = cv2.BFMatcher(cv2.NORM_HAMMING)
        # knn筛选结果
        matches = bf.knnMatch(des1, trainDescriptors=des2, k=2)

        # 查看最大匹配点数目
        Good = [m for (m, n) in matches if m.distance < 0.75 * n.distance]
        similary = len(good) / len(matches)
        return similary

    except:
        return '0'


# 计算图片的局部哈希值--pHash
def phash(img):
    """
    :param img: 图片
    :return: 返回图片的局部hash值
    """
    img = img.resize((8, 8), Image.ANTIALIAS).convert('L')
    avg = reduce(lambda x, y: x + y, img.getdata()) / 64.
    hash_value = reduce(lambda x, y: x | (y[1] << y[0]), enumerate(map(lambda i: 0 if i < avg else 1, img.getdata())),
                        0)
    return hash_value


# 计算两个图片相似度函数局部敏感哈希算法
def phash_img_similarity(img1_path, img2_path):
    """
    :param img1_path: 图片1路径
    :param img2_path: 图片2路径
    :return: 图片相似度
    """
    # 读取图片
    img1 = Image.open(img1_path)
    img2 = Image.open(img2_path)

    # 计算汉明距离
    distance = bin(phash(img1) ^ phash(img2)).count('1')
    similary = 1 - distance / max(len(bin(phash(img1))), len(bin(phash(img1))))
    return similary


# 直方图计算图片相似度算法
def make_regalur_image(img, size=(256, 256)):
    """我们有必要把所有的图片都统一到特别的规格,在这里我选择是的256x256的分辨率。"""
    return img.resize(size).convert('RGB')


def hist_similar(lh, rh):
    assert len(lh) == len(rh)
    return sum(1 - (0 if l == r else float(abs(l - r)) / max(l, r)) for l, r in zip(lh, rh)) / len(lh)


def calc_similar(li, ri):
    return sum(hist_similar(l.histogram(), r.histogram()) for l, r in zip(split_image(li), split_image(ri))) / 16.0


def calc_similar_by_path(lf, rf):
    li, ri = make_regalur_image(Image.open(lf)), make_regalur_image(Image.open(rf))
    return calc_similar(li, ri)


def split_image(img, part_size=(64, 64)):
    w, h = img.size
    pw, ph = part_size
    assert w % pw == h % ph == 0
    return [img.crop((i, j, i + pw, j + ph)).copy() for i in range(0, w, pw) \
            for j in range(0, h, ph)]

五、结果

在这里插入图片描述

到此这篇关于python图片检索之以图搜图的文章就介绍到这了,更多相关Python以图搜图内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Python图片检索之以图搜图

本文链接: https://www.lsjlt.com/news/127207.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Python图片检索之以图搜图
    目录一、待搜索图二、测试集三、new_similarity_compare.py四、image_similarity_function.py五、结果一、待搜索图 二、测试集 三、...
    99+
    2024-04-02
  • 如何在PHP中进行智能图片搜索和检索?
    随着互联网的高速发展,图片已经成为网络世界中最具有表现力和感染力的媒介形式之一。然而,大量的图片信息需要我们进行高效的检索和分类,这对于网站管理者和用户来说都是非常重要的。在PHP中,我们可以通过使用一些较新的技术和工具来实现智能图片搜索和...
    99+
    2023-05-20
    PHP 图片搜索 智能检索
  • Python人工智能实战之以图搜图的实现
    目录前言一、实验要求二、环境配置三、代码文件1、vgg.py2、index.py3、test.py四、演示1、项目文件夹2、相似度排序输出3、保存结果五、尾声前言 基于vgg网络和K...
    99+
    2024-04-02
  • Python Pytorch学习之图像检索实践
    目录背景图像表现搜索随着电子商务和在线网站的出现,图像检索在我们的日常生活中的应用一直在增加。 亚马逊、阿里巴巴、Myntra等公司一直在大量利用图像检索技术。当然,只有当通常的信息...
    99+
    2024-04-02
  • 如何实现Python对130w+张图片检索
    本篇内容主要讲解“如何实现Python对130w+张图片检索”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何实现Python对130w+张图片检索”吧!python是什么意思Python是一种...
    99+
    2023-06-09
  • Python人工智能实战之以图搜图怎么实现
    本篇内容介绍了“Python人工智能实战之以图搜图怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、实验要求给出一张图像后,在整个数...
    99+
    2023-06-30
  • Python图片处理之图片裁剪教程
    目录一、操作流程二、代码分析三、懒人一键复制代码一、操作流程 首先复制代码会吧? 1.有张照片 这是网上随便找的一张照片,自行保存测试 2.看看照片 运行代码,其中show_img...
    99+
    2024-04-02
  • Python对130w+张图片检索的实现方法
    任务说明: 130w+张图片,8张excel表里记录了需要检索图片的文件名,现在需要找出对应的图片,将找出的图片按不同的excel分别保存,并且在excel里能够直接打开图片。 任务...
    99+
    2024-04-02
  • 图像检索之IF-IDF,RootSift,VLAD
    TF-IDF TF-IDF是一种用于信息检索的常用加权技术,在文本检索中,用以评估词语对于一个文件数据库中的其中一份文件的重要程度。词语的重要性随着它在文件中出现的频率成正比增加,但...
    99+
    2024-04-02
  • python-图片之乐-ASCII 文本图形
    ASCII:一个简单的字符编码方案 pillow模块:读取图像,访问底层数据 numpy模块:计算平均值 import sys, random, argparseimport numpy as npimport mathfrom PIL i...
    99+
    2023-08-30
    python ascii
  • 怎么用Python构建图片处理搜索引擎
    这篇文章给大家分享的是有关怎么用Python构建图片处理搜索引擎的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。***公司和反向图片搜索有很多***的科技公司把RIQ用得很好。例如...
    99+
    2024-04-02
  • 微软必应聊天正测试以图搜图等视觉搜索功能
    微软广告和网络服务首席执行官米哈伊尔・帕拉欣(Mikhail Parakhin)近日和网友互动中,表示正为必应聊天(Bing Chat)测试图像识别和视觉搜索功能。IT之家在此附上帕拉欣推文如下:微软在 Bing 图片搜索中已引入视觉搜索选...
    99+
    2023-07-14
  • Python图片处理之图片采样处理详解
    目录一.图像采样处理原理二.图像采样实现三.图像局部采样处理四.总结一.图像采样处理原理 图像采样(Image Sampling)处理是将一幅连续图像在空间上分割成M×N...
    99+
    2024-04-02
  • 图形图像处理之简单图片
    决定Android应用是否被用户接受的一个重要的原因就是用户界面,友好的用户界面就需要使用到图形图像处理技术,包括静态图片、动画和游戏都需要大量的图形图像处理,所谓游戏,其实就是提供更逼真,能模拟某种环境的用户界面,并根据某种规则响应用户的...
    99+
    2023-06-04
  • Python图片处理之图片裁剪的示例分析
    小编给大家分享一下Python图片处理之图片裁剪的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!一、操作流程首先会吧?有张照片这是网上随便找的一张照片,自行保存测试看看照片运行代码,其中show_img函数是展示照...
    99+
    2023-06-15
  • Sphinx PHP 高性能搜索引擎对于图片搜索的支持
    随着互联网的快速发展,图片搜索在我们日常生活中变得越来越重要。从电商网站的商品搜索,到社交媒体平台的人脸识别,图片搜索已经渗透到各个领域。为了满足这一需求,Sphinx PHP 高性能搜索引擎提供了强大的图片搜索功能。本文将重点介绍Sphi...
    99+
    2023-10-21
    PHP编程 图片搜索 Sphinx搜索引擎
  • python做图片搜索引擎并保存到本地详情
    前言 我们先说一下思路:先对目标网站发送请求,获取html源码,然后对源码里面的所以图片链接进行筛选,然后再次对图片链接发送请求,然后保存。 思路大致是这样,话不多说,直接上代码: ...
    99+
    2024-04-02
  • Python Pytorch图像检索实例分析
    这篇文章主要介绍“Python Pytorch图像检索实例分析”,在日常操作中,相信很多人在Python Pytorch图像检索实例分析问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Pyt...
    99+
    2023-06-29
  • 搜索引擎图片搜索收录展现基本要求有哪些
    这篇文章主要为大家展示了“搜索引擎图片搜索收录展现基本要求有哪些”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“搜索引擎图片搜索收录展现基本要求有哪些”这篇文章吧。  对于图片搜索,细心的网友很早...
    99+
    2023-06-09
  • java图搜索算法之图的对象化描述示例详解
    目录一、前言二、什么是图三、怎么存储一个图的结构1、邻接矩阵2、邻接表3、图对象化表示四、图的作用你好,我是小黄,一名独角兽企业的Java开发工程师。 校招收获数十个offer,年薪...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作