iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >Python人工智能实战之以图搜图怎么实现
  • 135
分享到

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

2023-06-30 13:06:06 135人浏览 八月长安

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

摘要

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

    --结束END--

    本文标题: Python人工智能实战之以图搜图怎么实现

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

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

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

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

    下载Word文档
    猜你喜欢
    • Python人工智能实战之以图搜图怎么实现
      本篇内容介绍了“Python人工智能实战之以图搜图怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、实验要求给出一张图像后,在整个数...
      99+
      2023-06-30
    • Python人工智能实战之以图搜图的实现
      目录前言一、实验要求二、环境配置三、代码文件1、vgg.py2、index.py3、test.py四、演示1、项目文件夹2、相似度排序输出3、保存结果五、尾声前言 基于vgg网络和K...
      99+
      2024-04-02
    • Python人工智能实战之对话机器人的实现
      目录背景用到的技术主要流程代码模块Joke对象爬虫抓取笑话代码实现保存到sqlite数据库抓取笑话并保存到数据库背景 当我慢慢的开在高速公路上,宽敞的马路非常的拥挤!这时候我喜欢让...
      99+
      2024-04-02
    • Python实战之实现百度智能图片识别
      这是我们最终的效果,那么我们一起来看一看如何实现吧!超简单易上手哦! 首先我们需要先配置pyqt5的资源,这里就不说关于安装包的问题了(pip或者pycharm可以直接添加解决的问...
      99+
      2024-04-02
    • Python人工智能之sg2im文字转图像
      【人工智能项目】sg2im文字转图像 本次主要对github上的sg2im源码进行执行训练,得到结果。 1.从github上下载源码 !git clone https://git...
      99+
      2024-04-02
    • python人工智能human learn绘图怎么用
      这篇文章将为大家详细讲解有关python人工智能human learn绘图怎么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。如今,数据科学家经常给带有标签的机器学习模型数据,以便它可以找出规则...
      99+
      2023-06-25
    • 怎么用python实现人工智能算法
      要使用Python实现人工智能算法,你可以按照以下步骤进行操作:1. 确定算法类型:首先,你需要确定你想要实现的人工智能算法类型,比...
      99+
      2023-10-11
      python 人工智能
    • python人工智能算法之随机森林怎么实现
      这篇文章主要介绍了python人工智能算法之随机森林怎么实现的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇python人工智能算法之随机森林怎么实现文章都会有所收获,下面我们一起来看看吧。随机森林(Random...
      99+
      2023-07-06
    • 人工智能-Python实现岭回归
      1 概述 1.1 线性回归 对于一般地线性回归问题,参数的求解采用的是最小二乘法,其目标函数如下: 1.2 岭回归  岭回归(ridge regression) 是一种...
      99+
      2024-04-02
    • python人工智能使用RepVgg实现图像分类示例详解
      目录摘要安装包安装timm数据增强Cutout和MixupEMA项目结构计算mean和std生成数据集摘要 RepVgg通过结构重参数化让VGG再次伟大。 所谓“VGG式...
      99+
      2024-04-02
    • 人工智能实战项目(python)+多领域实战练手项目
      人工智能实战项目 大家好,我是微学AI,本项目将围绕人工智能实战项目进行展开,紧密贴近生活,实战项目设计多个领域包括:金融、教育、医疗、地理、生物、人文、自然语言处理等;帮助各位读者结合机器学习与深度学习构建智能而且实用的人工智能简单系统,...
      99+
      2023-09-08
      人工智能 深度学习 计算机视觉 知识图谱
    • Python人工智能语音合成功能怎么实现
      今天小编给大家分享一下Python人工智能语音合成功能怎么实现的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、 注册百度A...
      99+
      2023-07-05
    • 人工智能—Python实现线性回归
      1、概述 (1)人工智能学习           (2)机器学习  (3)有监督学习  (4)线...
      99+
      2024-04-02
    • 人工智能-Python实现多项式回归
      目录1、概述1.1 有监督学习1.2 多项式回归2 概念3 案例实现——方法1 3.1 案例分析3.2 代码实现 3.3 结果 ...
      99+
      2024-04-02
    • python实战之百度智能云使人像动漫化
      目录一、目标二、准备工作三、操作流程3.1 阅读官方文档3.2 开始实现鉴权3.3 人像动漫化实现四、完整代码如下五、还能这么玩?一、目标 之前无意中看到有某位博主写过人像动漫化这样...
      99+
      2024-04-02
    • python人工智能算法之线性回归实例
      目录线性回归使用场景分析:总结:线性回归 是一种常见的机器学习算法,也是人工智能中常用的算法。它是一种用于预测数值型输出变量与一个或多个自变量之间线性关系的方法。例如,你可以使用线...
      99+
      2023-03-21
      python 线性回归算法 python 人工智能
    • Python实战之实现获取动态图表
      目录前言开发工具环境搭建百度指数微博指数结果展示前言 利用Python实现获取动态图表,废话不多说~ 让我们愉快地开始吧~ 开发工具 Python版本: 3.6.4 相关模块: re...
      99+
      2024-04-02
    • Python实战之实现截图识别文字
      目录前言一、获取百度智能云token二、百度借口调用三、搭建窗口化的程序以便于使用四、实现截图的自动保存五、将识别到的文字输出显示在窗口文本框中并将文字发送到剪切板六、提取识别后文字...
      99+
      2024-04-02
    • 人工智能是是不是只能用python实现
      这篇文章主要介绍了人工智能是是不是只能用python实现,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一、人工智能只能用python吗?并不是,只是相对其他语言python的...
      99+
      2023-06-14
    • python人工智能算法之人工神经网络怎么使用
      本篇内容介绍了“python人工智能算法之人工神经网络怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!人工神经网络(Artificia...
      99+
      2023-07-05
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作