我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Python人工智能实战之以图搜图怎么实现

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Python人工智能实战之以图搜图怎么实现

本篇内容介绍了“Python人工智能实战之以图搜图怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

    一、实验要求

    给出一张图像后,在整个数据集中(至少100个样本)找到与这张图像相似的图像(至少5张),并把图像有顺序的展示。

    二、环境配置

    解释器:python3.10

    编译器:Pycharm

    必用配置包:

    numpy、h6py、matplotlib、keras、pillow

    三、代码文件

    1、vgg.py

    # -*- coding: utf-8 -*-import numpy as npfrom numpy import linalg as LA from keras.applications.vgg16 import VGG16from keras.preprocessing import imagefrom keras.applications.vgg16 import preprocess_input as preprocess_input_vggclass VGGNet:    def __init__(self):        self.input_shape = (224, 224, 3)        self.weight = 'imagenet'        self.pooling = 'max'        self.model_vgg = VGG16(weights = self.weight, input_shape = (self.input_shape[0], self.input_shape[1], self.input_shape[2]), pooling = self.pooling, include_top = False)        self.model_vgg.predict(np.zeros((1, 224, 224 , 3)))     #提取vgg16最后一层卷积特征    def vgg_extract_feat(self, img_path):        img = image.load_img(img_path, target_size=(self.input_shape[0], self.input_shape[1]))        img = image.img_to_array(img)        img = np.expand_dims(img, axis=0)        img = preprocess_input_vgg(img)        feat = self.model_vgg.predict(img)        # print(feat.shape)        norm_feat = feat[0]/LA.norm(feat[0])        return norm_feat

    2、index.py

    # -*- coding: utf-8 -*-import osimport h6pyimport numpy as npimport argparsefrom vgg import VGGNet def get_imlist(path):    return [os.path.join(path, f) for f in os.listdir(path) if f.endswith('.jpg')] if __name__ == "__main__":    database = r'D:\pythonProject5\flower_roses'    index = 'vgg_featureCNN.h6'    img_list = get_imlist(database)     print("         feature extraction starts")     feats = []    names = []     model = VGGNet()    for i, img_path in enumerate(img_list):        norm_feat = model.vgg_extract_feat(img_path)  # 修改此处改变提取特征的网络        img_name = os.path.split(img_path)[1]        feats.append(norm_feat)        names.append(img_name)        print("extracting feature from image No. %d , %d images in total" % ((i + 1), len(img_list)))     feats = np.array(feats)     output = index    print("      writing feature extraction results ...")     h6f = h6py.File(output, 'w')    h6f.create_dataset('dataset_1', data=feats)    # h6f.create_dataset('dataset_2', data = names)    h6f.create_dataset('dataset_2', data=np.string_(names))    h6f.close()

    3、test.py

    # -*- coding: utf-8 -*-from vgg import VGGNetimport numpy as npimport h6pyimport matplotlib.pyplot as pltimport matplotlib.image as mpimgimport argparse query = r'D:\pythonProject5\rose\red_rose.jpg'index = 'vgg_featureCNN.h6'result = r'D:\pythonProject5\flower_roses'# read in indexed images' feature vectors and corresponding image namesh6f = h6py.File(index, 'r')# feats = h6f['dataset_1'][:]feats = h6f['dataset_1'][:]print(feats)imgNames = h6f['dataset_2'][:]print(imgNames)h6f.close()print("               searching starts")queryImg = mpimg.imread(query)plt.title("Query Image")plt.imshow(queryImg)plt.show() # init VGGNet16 modelmodel = VGGNet()# extract query image's feature, compute simlarity score and sortqueryVec = model.vgg_extract_feat(query)  # 修改此处改变提取特征的网络print(queryVec.shape)print(feats.shape)scores = np.dot(queryVec, feats.T)rank_ID = np.argsort(scores)[::-1]rank_score = scores[rank_ID]# print (rank_ID)print(rank_score)# number of top retrieved images to showmaxres = 6  # 检索出6张相似度最高的图片imlist = []for i, index in enumerate(rank_ID[0:maxres]):    imlist.append(imgNames[index])    print(type(imgNames[index]))    print("image names: " + str(imgNames[index]) + " scores: %f" % rank_score[i])print("top %d images in order are: " % maxres, imlist)# show top #maxres retrieved result one by onefor i, im in enumerate(imlist):    image = mpimg.imread(result + "/" + str(im, 'utf-8'))    plt.title("search output %d" % (i + 1))    plt.imshow(np.uint8(image))    f = plt.gcf()  # 获取当前图像    f.savefig(r'D:\pythonProject5\result\{}.jpg'.format(i),dpi=100)    #f.clear()  # 释放内存    plt.show()

    四、演示

    Python人工智能实战之以图搜图怎么实现

    Python人工智能实战之以图搜图怎么实现

    Python人工智能实战之以图搜图怎么实现

    Python人工智能实战之以图搜图怎么实现

    1、项目文件夹

    Python人工智能实战之以图搜图怎么实现

    数据集

    Python人工智能实战之以图搜图怎么实现

    结果(运行前)

    Python人工智能实战之以图搜图怎么实现

    原图

    Python人工智能实战之以图搜图怎么实现

    2、相似度排序输出

    Python人工智能实战之以图搜图怎么实现

    3、保存结果

    Python人工智能实战之以图搜图怎么实现

    五、尾声

    分享一个实用又简单的爬虫代码,搜图顶呱呱!

    import osimport timeimport requestsimport redef imgdata_set(save_path,word,epoch):    q=0     #停止爬取图片条件    a=0     #图片名称    while(True):        time.sleep(1)        url="https://image.baidu.com/search/flip?tn=baiduimage&ie=utf-8&word={}&pn={}&ct=&ic=0&lm=-1&width=0&height=0".format(word,q)        #word=需要搜索的名字        headers={            'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/88.0.4324.96 Safari/537.36 Edg/88.0.705.56'        }        response=requests.get(url,headers=headers)        # print(response.request.headers)        html=response.text        # print(html)        urls=re.findall('"objURL":"(.*?)"',html)        # print(urls)        for url in urls:            print(a)    #图片的名字            response = requests.get(url, headers=headers)            image=response.content            with open(os.path.join(save_path,"{}.jpg".format(a)),'wb') as f:                f.write(image)            a=a+1        q=q+20        if (q/20)>=int(epoch):            breakif __name__=="__main__":    save_path = input('你想保存的路径:')    word = input('你想要下载什么图片?请输入:')    epoch = input('你想要下载几轮图片?请输入(一轮为60张左右图片):')  # 需要迭代几次图片    imgdata_set(save_path, word, epoch)

    “Python人工智能实战之以图搜图怎么实现”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

    免责声明:

    ① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

    ② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

    Python人工智能实战之以图搜图怎么实现

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

    下载Word文档

    猜你喜欢

    Python人工智能实战之以图搜图怎么实现

    本篇内容介绍了“Python人工智能实战之以图搜图怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、实验要求给出一张图像后,在整个数
    2023-06-30

    python人工智能human learn绘图怎么用

    这篇文章将为大家详细讲解有关python人工智能human learn绘图怎么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。如今,数据科学家经常给带有标签的机器学习模型数据,以便它可以找出规则。这些规则
    2023-06-25

    怎么用python实现人工智能算法

    要使用Python实现人工智能算法,你可以按照以下步骤进行操作:1. 确定算法类型:首先,你需要确定你想要实现的人工智能算法类型,比如机器学习算法(如决策树、神经网络或支持向量机)、深度学习算法(如卷积神经网络或循环神经网络)或其他类型的算
    2023-10-11

    python人工智能算法之随机森林怎么实现

    这篇文章主要介绍了python人工智能算法之随机森林怎么实现的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇python人工智能算法之随机森林怎么实现文章都会有所收获,下面我们一起来看看吧。随机森林(Random
    2023-07-06

    人工智能是如何实现图像版GPT-3的?

    编程学习网:今年年初,OpenAI 图像版 GPT-3、120 亿参数的 DALL-E 刷屏社区,这个大型模型可以将以自然语言形式表达的大量概念转换为合适的图像,效果十分惊艳。
    人工智能是如何实现图像版GPT-3的?
    2024-04-23

    Python人工智能语音合成功能怎么实现

    今天小编给大家分享一下Python人工智能语音合成功能怎么实现的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、 注册百度A
    2023-07-05

    Python怎么实现AI智能人脸识别

    本篇文章为大家展示了Python怎么实现AI智能人脸识别,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。前言现在人脸识别这东西层出不穷,基本上很多东西都用到,比如现在火车站都是用人脸识别来过关卡,确实
    2023-06-02

    C++图搜索算法之双端队列广搜怎么实现

    这篇文章主要介绍“C++图搜索算法之双端队列广搜怎么实现”,在日常操作中,相信很多人在C++图搜索算法之双端队列广搜怎么实现问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C++图搜索算法之双端队列广搜怎么实现
    2023-07-02

    python面积图之怎么实现曲线图的填充

    本篇内容主要讲解“python面积图之怎么实现曲线图的填充”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“python面积图之怎么实现曲线图的填充”吧!用法:Axes.fill_between(x
    2023-07-02

    Python Pandas工具绘制数据图怎么实现

    这篇文章主要为大家展示了“Python Pandas工具绘制数据图怎么实现”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Python Pandas工具绘制数据图怎么实现”这篇文章吧。背景介绍Pa
    2023-06-21

    怎么使用Python对接OpenAi API实现智能QQ机器人

    这篇文章主要介绍“怎么使用Python对接OpenAi API实现智能QQ机器人”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“怎么使用Python对接OpenAi API实现智能QQ机器人”文章能帮
    2023-07-05

    Python数据分析之Matplotlib 3D图怎么实现

    这篇文章主要讲解了“Python数据分析之Matplotlib 3D图怎么实现”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Python数据分析之Matplotlib 3D图怎么实现”吧!M
    2023-06-30

    怎么用Python实现一个简易的截图工具

    这篇文章主要讲解了“怎么用Python实现一个简易的截图工具”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么用Python实现一个简易的截图工具”吧!代码:# # -*- coding:
    2023-07-02

    使用Python怎么实现一个图像分类功能

    今天就跟大家聊聊有关使用Python怎么实现一个图像分类功能,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。Python的优点有哪些1、简单易用,与C/C++、Java、C# 等传统语
    2023-06-14

    编程热搜

    • Python 学习之路 - Python
      一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
      Python 学习之路 - Python
    • chatgpt的中文全称是什么
      chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
      chatgpt的中文全称是什么
    • C/C++中extern函数使用详解
    • C/C++可变参数的使用
      可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
      C/C++可变参数的使用
    • css样式文件该放在哪里
    • php中数组下标必须是连续的吗
    • Python 3 教程
      Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
      Python 3 教程
    • Python pip包管理
      一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
      Python pip包管理
    • ubuntu如何重新编译内核
    • 改善Java代码之慎用java动态编译

    目录