使用Keras中的ImageDataGenerator进行批次读图方式
作者:bendaxi 发布时间:2023-07-02 03:49:50
ImageDataGenerator位于keras.preprocessing.image模块当中,可用于做数据增强,或者仅仅用于一个批次一个批次的读进图片数据.一开始以为ImageDataGenerator是用来做数据增强的,但我的目的只是想一个batch一个batch的读进图片而已,所以一开始没用它,后来发现它是有这个功能的,而且使用起来很方便.
ImageDataGenerator类包含了如下参数:(keras中文教程)
ImageDataGenerator(featurewise_center=False, #布尔值。将输入数据的均值设置为 0,逐特征进行
samplewise_center=False, #布尔值。将每个样本的均值设置为 0
featurewise_std_normalization=False, #布尔值。将输入除以数据标准差,逐特征进行
samplewise_std_normalization=False, #布尔值。将每个输入除以其标准差
zca_whitening=False, #是否进行ZAC白化
zca_epsilon=1e-06, #ZCA 白化的 epsilon 值
rotation_range=0, #整数。随机旋转的度数范围
width_shift_range=0.0,
height_shift_range=0.0,
brightness_range=None,
shear_range=0.0, #浮点数。剪切强度(以弧度逆时针方向剪切角度)
zoom_range=0.0, #浮点数 或 [lower, upper]。随机缩放范围。如果是浮点数,[lower, upper] = [1-zoom_range, 1+zoom_range]。
channel_shift_range=0.0, #浮点数。随机通道转换的范围
fill_mode='nearest', #输入边界以外的点的模式填充
cval=0.0, #当 fill_mode = "constant",边界点的填充值
horizontal_flip=False, #随机水平翻转
vertical_flip=False, #随机垂直翻
rescale=None, #默认为 None。如果是 None 或 0,不进行缩放,否则将数据乘以所提供的值(在应用任何其他转换之前)
preprocessing_function=None, #应用于每个输入的函数。这个函数会在任何其他改变之前运行。这个函数需要一个参数:一张图像(秩为 3 的 Numpy 张量),并且应该输出一个同尺寸的 Numpy 张量。
data_format=None, #图像数据格式,{"channels_first", "channels_last"} 之一
validation_split=0.0,
dtype=None) #生成数组使用的数据类型
虽然包含了很多参数,但实际应用时用到的并不会很多,假设我的目的只是一个batch一个batch的读进图片,那么,我在实例化对象的时候什么参数都不需要设置,然后再调用ImageDataGenerator类的成员函数flow_from_directory()就可以从目录中读图.
我放图片的目录如下图,在train文件夹中包含了两个子文件夹,然后在两个子文件夹里面分别包含了猫和狗的图片.
先看看flow_from_directory()的参数.需要注意的是,第一个参数directory不是图片的路径,而是子文件夹的路径,还有就是第四个参数classes,它填写是子文件夹的名称,比如此处的为['cat', 'dog'],然后该函数就会自动把两个子文件夹看成是2个类别,cat文件夹里面所有图片的标签都为0,dog文件夹里面所有图片的标签都为1.而且可以通过设置第5个参数class_mode把标签设置为ont-hot形式(默认的categorical就是one-hot 形式).可以看出,这个函数有多方便,直接把标签和原图对应起来了.
def flow_from_directory(self,
directory, #子文件夹所在的目录
target_size=(256, 256), #输出的图片的尺寸
color_mode='rgb', #单通道还是三通道
classes=None, #类别,有多少个子文件夹就有多少个类别,填写的是子文件夹的名称
class_mode='categorical', #通常默认,表示标签采用one-hot形式,
batch_size=32,
shuffle=True, #是否随机打乱顺序
seed=None,
save_to_dir=None, #把图片保存,输入的是路径
save_prefix='', #图像前缀名,
save_format='png', #图像后缀名
follow_links=False,
subset=None,
interpolation='nearest')
接下来看一个例子,部分代码.
from tensorflow.keras.preprocessing.image import ImageDataGenerator #我是直接装tensorflow,然后使用里面的keras的,
#实例化对象datagen
datagen=ImageDataGenerator()
#读训练集图片
train_generator = datagen.flow_from_directory(
'/home/hky/folder/kaggle/DataGenerator/train',
classes=['cat','dog'],
target_size=(227, 227),
class_mode='categorical',
batch_size=batch_size)
#读验证集图片
validation_generator = datagen.flow_from_directory(
'/home/hky/folder/kaggle/DataGenerator/validation',
classes=['cat','dog'],
target_size=(227, 227),
class_mode='categorical',
batch_size=batch_size)
'''开始训练'''
#steps_per_epoch是为了判断是否完成了一个epoch,这里我训练集有20000张图片,然后batch_size=16,所以是10000/16
#同样,validation_steps=2496/16是因为我的验证集有2496张图片
model.fit_generator(generator=train_generator,steps_per_epoch=20000/16,epochs=10,validation_data=validation_generator,validation_steps=2496/16)
下面是完整代码,实现了一个AlexNet模型.
import tensorflow as tf
from tensorflow.keras.models import Sequential
from tensorflow.keras.preprocessing import image
from tensorflow.keras.callbacks import EarlyStopping
from tensorflow.keras import optimizers
from tensorflow.keras.preprocessing.image import ImageDataGenerator
import numpy as np
import cv2
import yaml
from tensorflow.keras.models import model_from_yaml
batch_size = 16
''' 搭建模型'''
l=tf.keras.layers
model=Sequential()
#第一层卷积和池化
model.add(l.Conv2D(filters=96,kernel_size=(11,11),strides=(4,4),padding='valid',input_shape=(227,227,3),activation='relu'))
model.add(l.BatchNormalization())
model.add(l.MaxPooling2D(pool_size=(3,3),strides=(2,2),padding='valid'))
#第二层卷积和池化
model.add(l.Conv2D(256,(5,5),(1,1),padding='same',activation='relu'))
model.add(l.BatchNormalization())
model.add(l.MaxPooling2D((3,3),(2,2),padding='valid'))
#第三层卷积
model.add(l.Conv2D(384,(3,3),(1,1),'same',activation='relu'))
#第四层卷积
model.add(l.Conv2D(384,(3,3),(1,1),'same',activation='relu'))
#第五层卷积和池化
model.add(l.Conv2D(256,(3,3),(1,1),'same',activation='relu'))
model.add(l.MaxPooling2D((3,3),(2,2),'valid'))
#全连接层
model.add(l.Flatten())
model.add(l.Dense(4096,activation='relu'))
model.add(l.Dropout(0.5))
model.add(l.Dense(4096,activation='relu'))
model.add(l.Dropout(0.5))
model.add(l.Dense(1000,activation='relu'))
model.add(l.Dropout(0.5))
#输出层
model.add(l.Dense(2,activation='softmax'))
model.compile(optimizer='sgd',loss='categorical_crossentropy',metrics=['accuracy'])
'''导入图片数据'''
#利用ImageDataGenerator生成一个batch一个batch的数据
datagen=ImageDataGenerator(samplewise_center=True,rescale=1.0/255) #samplewise_center:使输入数据的每个样本均值为0,rescale:归一化
train_generator = datagen.flow_from_directory(
'/home/hky/folder/kaggle/DataGenerator/train',
classes=['cat','dog'],
target_size=(227, 227),
class_mode='categorical',
batch_size=batch_size)
validation_generator = datagen.flow_from_directory(
'/home/hky/folder/kaggle/DataGenerator/validation',
classes=['cat','dog'],
target_size=(227, 227),
class_mode='categorical',
batch_size=batch_size)
'''开始训练'''
model.fit_generator(generator=train_generator,steps_per_epoch=20000/16,epochs=10,validation_data=validation_generator,validation_steps=2496/16)
yaml_string = model.to_yaml() # 保存模型结构到yaml文件
open('./model_architecture.yaml', 'w').write(yaml_string)
model.save_weights('./AlexNet_model.h5') #保存模型参数
'''导入模型'''
#model = model_from_yaml(open('./model_architecture.yaml').read())
#model.load_weights('./AlexNet_model.h5')
'''随便输入一张图片测试一下'''
imgs=[]
img=cv2.imread('/home/hky/folder/kaggle/test/120.jpg')
img=cv2.resize(img,(227,227))
imgs.append(img)
a=np.array(imgs)
result=model.predict(a)
idx=np.argmax(result)
if idx==0:
print('the image is cat\n')
else:
print('the image is dog\n')
cv2.imshow("image",img)
cv2.waitKey(0)
来源:https://blog.csdn.net/bendaxi/article/details/89704729


猜你喜欢
- Python docx库代码演示安装需要lxml pip install python-docx主业务代码from openpyxl imp
- 一、概述dba在工作中避不开的两个问题,sql使用绑定变量到底会有多少的性能提升?数据库的审计功能如果打开对数据库的性能会产生多大的影响?最
- 说明1.windows上安装安卓模拟器,安卓版本5.1以上2.模拟器里下载安装最新的微信6.6.13.最好使用python2.7,pytho
- 大家好,我是丁小杰!今天和大家分享Pandas中四种有关数据透视的通用函数,在数据处理中遇到这类需求时,能够很好地应对。pandas.mel
- 和C语言一样,引号属于特殊功能字符,不能够像普通字符那样直接通过print打印,需要进行一些处理,比如说反斜杠转义等。这里介绍几种打印三引号
- 1、使用系统函数__import_()stringmodule = __import__('string')2、使用imp
- 自控烟花升空 实现效果描述效果代码地址解析main.pycore.pyfireworks.py 写在最后实现效果描述这大过年的不弄点有意思的
- 0x01 iframe的跳出框架0x02 iframe样式设置0x03 iframe重置高度1、首先来一个,跳出iframe的好方法,直接可
- 在IE6中背景属性加 a 与 a:hover 两者的伪类结合,在正常逻辑下为何不起作用?测试这问题存在IE6及以下浏览器,这问题我经常遇到在
- 介绍毫无疑问,任何一个试图使用 CSS 的网页设计师和开发人员都会发现不同的浏览器要求不同的样式声明。这些烦恼归咎于各浏览器及其各版本不同程
- 前言Always On 可用性组活动辅助功能包括支持在辅助副本上执行备份操作。 备份操作可能会给 I/O 和 CPU 带来很大的压力(使用备
- 本教程为大家分享了oracle 11g r2安装教程,供大家参考,具体内容如下一、环境脚本简单配置#!/bin/bashmv /etc/yu
- 前言本文主要给大家介绍了关于python中用Future对象回调别的函数的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的
- 废话就不多说了,直接上内容。<form action="/home/search" method="ge
- 一、引入方式from itertools import cycle二、使用方法我们先来看看它的源码cycle它接收一个可迭代对象,可以将一个
- 实例的背景说明假定一个个人信息系统,需要记录系统中各个人的故乡、居住地、以及到过的城市。数据库设计如下:Models.py 内容如下:&nb
- 首先我们利用NodeJs先构建一个基本的服务器。 index.js var requestHandler = require(".
- 从ResNet到DenseNet上图中,左边是ResNet,右边是DenseNet,它们在跨层上的主要区别是:使用相加和使用连结。最后,将这
- Ajax 技术改变了大型商业 Web 应用程序的外观,但是许多较小的 Web 站点都不具备足够的资源重新构建完整的用户界面(UI)。Ajax
- dictionary对象和数组有点相似,但无需用redim来改变dictionary的大小,dictionary也没有多维,dictiona