使用keras内置的模型进行图片预测实例


Posted in Python onJune 17, 2020

keras 模块里面为我们提供了一个预训练好的模型,也就是开箱即可使用的图像识别模型

趁着国庆假期有时间我们就来看看这个预训练模型如何使用吧

可用的模型有哪些?

根据官方文档目前可用的模型大概有如下几个

1、VGG16

2、VGG19

3、ResNet50

4、InceptionResNetV2

5、InceptionV3

它们都被集成到了keras.applications 中

模型文件从哪来

当我们使用了这几个模型时,keras就会去自动下载这些已经训练好的模型保存到我们本机上面

模型文件会被下载到 ~/.keras/models/并在载入模型时自动载入

各个模型的信息:

使用keras内置的模型进行图片预测实例

如何使用预训练模型

使用大致分为三个步骤

1、导入所需模块

2、找一张你想预测的图像将图像转为矩阵

3、将图像矩阵放到模型中进行预测

关于图像矩阵的大小

VGG16,VGG19,ResNet50 默认输入尺寸是224x224

InceptionV3, InceptionResNetV2 模型的默认输入尺寸是299x299

代码demo

假设我现在有一张图片

使用keras内置的模型进行图片预测实例

我需要使用预训练模型来识别它

那我们就按照上面的步骤

第一步导入模块

from keras.applications import VGG16
from keras.applications import VGG19
from keras.applications import ResNet50
from keras.applications import InceptionV3
from keras.applications import InceptionResNetV2

第二步将图像转为矩阵

这里我们需要使用 keras.preprocessing.image 里面 img_to_array 来帮我们转

image = cv2.imread(img)
 image = cv2.resize(image, self.dim)
 image = img_to_array(image)
 image = np.expand_dims(image, axis=0)

第三步 将图像矩阵丢到模型中进行预测

predict = model.predict(preprocess)
decode_predict = decode_predictions(predict)

完整代码如下

1、配置文件

2、获取配置文件的模块

3、图像预测模块

配置文件

[image]
image_path=/home/fantasy/Pictures/cat.jpg
[model]
model=vgg16
[weights]
weight=imagenet

获取配置文件的模块

import configparser
cf = configparser.ConfigParser()
cf.read("configs.cnf")
def getOption(section, key):
  return cf.get(section, key)

图像预测模块以及主要实现

# keras 提供了一些预训练模型,也就是开箱即用的 已经训练好的模型
# 我们可以使用这些预训练模型来进行图像识别,目前的预训练模型大概可以识别2.2w种类型的东西
# 可用的模型:
# VGG16
# VGG19
# ResNet50
# InceptionResNetV2
# InceptionV3 
# 这些模型被集成到 keras.applications 中
# 当我们使用了这些内置的预训练模型时,模型文件会被下载到 ~/.keras/models/并在载入模型时自动载入
# VGG16,VGG19,ResNet50 默认输入尺寸是224x224
# InceptionV3, InceptionResNetV2 模型的默认输入尺寸是299x299

# 使用内置的预训练模型的步骤
# step1 导入需要的模型
# step2 将需要识别的图像数据转换为矩阵(矩阵的大小需要根据模型的不同而定)
# step3 将图像矩阵丢到模型里面进行预测
# -------------------------------------------------------
# step1 
import cv2
import numpy as np
from getConfig import getOption
from keras.applications import VGG16
from keras.applications import VGG19
from keras.applications import ResNet50
from keras.applications import InceptionV3
from keras.applications import InceptionResNetV2
from keras.applications import imagenet_utils
from keras.applications.imagenet_utils import decode_predictions
from keras.preprocessing.image import load_img
from keras.preprocessing.image import img_to_array
from keras.applications.inception_v3 import preprocess_input

class ImageTools(object):
  """
  使用keras预训练模型进行图像识别
  """
  def __init__(self, img, model, w):
    self.image = img
    self.model = model
    self.weight = w
    
  # step2
  def image2matrix(self, img):
    """
    将图像转为矩阵
    """
    image = cv2.imread(img)
    image = cv2.resize(image, self.dim)
    image = img_to_array(image)
    image = np.expand_dims(image, axis=0)
    return image

  @property
  def dim(self):
    """
    图像矩阵的维度
    """
    if self.model in ["inceptionv3", "inceptionresnetv2"]:
      shape = (299, 299)
    else:
      shape = (224, 224)

    return shape

  @property
  def Model(self):
    """
    模型
    """
    models = {
      "vgg16": VGG16,
      "vgg19": VGG19,
      "resnet50": ResNet50,
      "inceptionv3": InceptionV3,
      "inceptionresnetv2": InceptionResNetV2
    }
    return models[self.model]

  # step3 
  def prediction(self):
    """
    预测
    """
    model = self.Model(weights=self.weight)
    if self.model in ["inceptionv3", "inceptionresnetv2"]:
      preprocess = preprocess_input(self.image2matrix(self.image))
    else:
      preprocess = imagenet_utils.preprocess_input(self.image2matrix(self.image))

    predict = model.predict(preprocess)

    decode_predict = decode_predictions(predict)

    for (item, (imgId, imgLabel, proba)) in enumerate(decode_predict[0]):
      print("{}, {}, {:.2f}%".format(item + 1, imgLabel, proba * 100))


if __name__ == "__main__":
  image = getOption("image", "image_path")
  model = getOption("model", "model")
  weight = getOption("weights", "weight")
  tools = ImageTools(image, model, weight)
  tools.prediction()

运行起来时会将模型文件下载到本机,因此第一次运行会比较久(有可能出现的情况就是下载不了,被墙了)

使用keras内置的模型进行图片预测实例

我们来看看使用VGG16的模型预测输出的效果如何

使用keras内置的模型进行图片预测实例

最后如果大家需要使用其他模型时修改 配置文件的model 即可

以上这篇使用keras内置的模型进行图片预测实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python处理大数字的方法
May 27 Python
使用url_helper简化Python中Django框架的url配置教程
May 30 Python
浅析AST抽象语法树及Python代码实现
Jun 06 Python
Python实现扣除个人税后的工资计算器示例
Mar 26 Python
python实现windows下文件备份脚本
May 27 Python
判断python对象是否可调用的三种方式及其区别详解
Jan 31 Python
详解Python用三种方式统计词频的方法
Jul 29 Python
Python绘制股票移动均线的实例
Aug 24 Python
QML实现钟表效果
Jun 02 Python
如何使用Django Admin管理后台导入CSV
Nov 06 Python
Python实现位图分割的效果
Nov 20 Python
Python何绘制带有背景色块的折线图
Apr 23 Python
Python虚拟环境库virtualenvwrapper安装及使用
Jun 17 #Python
基于TensorFlow的CNN实现Mnist手写数字识别
Jun 17 #Python
Keras 加载已经训练好的模型进行预测操作
Jun 17 #Python
基于Tensorflow的MNIST手写数字识别分类
Jun 17 #Python
Kears 使用:通过回调函数保存最佳准确率下的模型操作
Jun 17 #Python
Python多线程threading创建及使用方法解析
Jun 17 #Python
Python偏函数Partial function使用方法实例详解
Jun 17 #Python
You might like
《猛禽小队》:DC宇宙的又一超级大烂片
2020/04/09 欧美动漫
PHP PDO函数库详解
2010/04/27 PHP
php 随机排序广告的实现代码
2011/05/09 PHP
php用户注册信息验证正则表达式
2015/11/12 PHP
PHP常用工具类大全附全部代码下载
2015/12/07 PHP
PHP基于自增数据如何生成不重复的随机数示例
2017/05/19 PHP
关于ThinkPHP中的异常处理详解
2018/05/11 PHP
javascript fullscreen全屏实现代码
2009/04/09 Javascript
jQuery创建自定义的选择器用以选择高度大于100的超链接实例
2015/03/18 Javascript
jQuery制作可自定义大小的拼图游戏
2015/03/30 Javascript
jQuery formValidator表单验证
2016/01/07 Javascript
jQuery实现横向带缓冲的水平运动效果(附demo源码下载)
2016/01/29 Javascript
基于Javascript实现返回顶部按钮
2016/02/29 Javascript
在localStorage中存储对象数组并读取的方法
2016/09/24 Javascript
微信小程序 http请求详细介绍
2016/10/09 Javascript
原生js实现焦点轮播图效果
2017/01/12 Javascript
详解使用fetch发送post请求时的参数处理
2017/04/05 Javascript
Node.js  REPL (交互式解释器)实例详解
2017/08/06 Javascript
Three.js开发实现3D地图的实践过程总结
2017/11/20 Javascript
[02:20]DOTA2中文配音宣传片
2013/05/22 DOTA
python中去空格函数的用法
2014/08/21 Python
python消除序列的重复值并保持顺序不变的实例
2018/11/08 Python
详解安装mitmproxy以及遇到的坑和简单用法
2019/01/21 Python
详解Django自定义图片和文件上传路径(upload_to)的2种方式
2020/12/01 Python
H5调用相机拍照并压缩图片的实例代码
2017/07/20 HTML / CSS
英国美术用品购物网站:Cass Art
2019/10/08 全球购物
西部世纪面试题
2014/12/05 面试题
夜大毕业生自我评价分享
2013/11/10 职场文书
英语道歉信范文
2014/01/09 职场文书
十八届三中全会学习方案
2014/02/16 职场文书
商务日语专业自荐信
2014/04/17 职场文书
农民工讨薪标语
2014/06/26 职场文书
个人自荐书怎么写
2015/03/26 职场文书
会计岗位工作总结
2015/08/12 职场文书
中国式结婚:司仪主持词(范文)
2019/07/25 职场文书
Python集合set()使用的方法详解
2022/03/18 Python