使用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使用urllib2模块获取gravatar头像实例
Dec 18 Python
Python Web框架Flask下网站开发入门实例
Feb 08 Python
Python装饰器入门学习教程(九步学习)
Jan 28 Python
Numpy截取指定范围内的数据方法
Nov 14 Python
python 实现UTC时间加减的方法
Dec 31 Python
Scrapy框架爬取西刺代理网免费高匿代理的实现代码
Feb 22 Python
详解使用Python下载文件的几种方法
Oct 13 Python
使用Python的datetime库处理时间(RPA流程)
Nov 24 Python
Python 脚本的三种执行方式小结
Dec 21 Python
基于keras输出中间层结果的2种实现方式
Jan 24 Python
Python基于模块Paramiko实现SSHv2协议
Apr 28 Python
Python万能模板案例之matplotlib绘制甘特图
Apr 13 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
PHP+apc+ajax实现的ajax_upload上传进度条代码
2016/01/25 PHP
jQuery ajax(复习)—Baidu ajax request分离版
2013/01/24 Javascript
js setTimeout()函数介绍及应用以倒计时为例
2013/12/12 Javascript
js中substr,substring,indexOf,lastIndexOf,split,replace的用法详解
2015/11/09 Javascript
JavaScript中三种异步上传文件方式
2016/03/06 Javascript
BootStrap中的table实现数据填充与分页应用小结
2016/05/26 Javascript
AngularJS教程 ng-style 指令简单示例
2016/08/03 Javascript
BootStrap tab选项卡使用小结
2020/08/09 Javascript
js获取地址栏中传递的参数(两种方法)
2017/02/08 Javascript
JS原型与原型链的深入理解
2017/02/15 Javascript
通过js修改input、select默认字体颜色
2017/04/19 Javascript
微信小程序注册60s倒计时功能 使用JS实现注册60s倒计时功能
2017/08/16 Javascript
C#实现将一个字符转换为整数
2017/12/12 Javascript
Vue兼容ie9的问题全面解决方案
2018/06/19 Javascript
通过封装scroll.js 获取滚动条的值
2018/07/13 Javascript
详解JavaScript作用域和作用域链
2019/03/19 Javascript
Javascript实现html转pdf高清版(提高分辨率)
2020/02/19 Javascript
JavaScript鼠标悬停事件用法解析
2020/05/15 Javascript
Python二叉搜索树与双向链表转换实现方法
2016/04/29 Python
Python中文件的读取和写入操作
2018/04/27 Python
python paramiko利用sftp上传目录到远程的实例
2019/01/03 Python
解决python3.5 正常安装 却不能直接使用Tkinter包的问题
2019/02/22 Python
python调用接口的4种方式代码实例
2019/11/19 Python
Python逐行读取文件内容的方法总结
2020/02/14 Python
Python2.7:使用Pyhook模块监听鼠标键盘事件-获取坐标实例
2020/03/14 Python
python 读txt文件,按‘,’分割每行数据操作
2020/07/05 Python
python 视频下载神器(you-get)的具体使用
2021/01/06 Python
伊利莎白雅顿官网:Elizabeth Arden
2016/10/10 全球购物
MVMT手表官方网站:时尚又实惠的高品质手表
2016/12/04 全球购物
茵宝(Umbro)英国官方商店:英国足球服装生产商
2016/12/29 全球购物
联想西班牙官网:Lenovo西班牙
2018/08/28 全球购物
教师工作决心书
2015/02/04 职场文书
采购内勤岗位职责
2015/04/13 职场文书
电信营业员岗位职责
2015/04/14 职场文书
话题作文之诚信
2019/11/28 职场文书
Sql-Server数据库单表查询 4.3实验课
2021/04/05 SQL Server