keras读取图片

from keras.preprocessing.image import ImageDataGenerator, load_img, img_to_array 
img = load_img(path+file,target_size=(48,48)) # this is a PIL image # 
# 将图片转为数组 # 
x = img_to_array(img) # 扩充一个维度 
image = np.expand_dims(image, axis=0)

image = image.astype('float32')

image /= 255

跑实验时候,要准备自己的数据集,keras的接口方式还是比较友善的,对图像的数据预处理有两种方式:一种是.flow(),另一种是.flow_from_directory(directory)。

关键导入包:

import keras
from tensorflow.keras.preprocessing.image import ImageDataGenerator
import keras.utils as np_utils


.flow()的方式

此时数据集是已经处理成了数组的形式,如我们从网上下载的公开数据集(nums, col,row,channel)。

(X_train, y_train), (X_test, y_test) = cifar10.load_data()
Y_train = np_utils.to_categorical(y_train, nb_classes)
Y_test = np_utils.to_categorical(y_test, nb_classes)
 
datagen = ImageDataGenerator(
    featurewise_center=True,
    featurewise_std_normalization=True,
    rotation_range=20,
    width_shift_range=0.2,
    height_shift_range=0.2,
    horizontal_flip=True)
 
# compute quantities required for featurewise normalization
# (std, mean, and principal components if ZCA whitening is applied)
datagen.fit(X_train)
 
# fits the model on batches with real-time data augmentation:
model.fit_generator(datagen.flow(X_train, Y_train, batch_size=32),
                    samples_per_epoch=len(X_train), nb_epoch=nb_epoch)
 
# here's a more "manual" example(手动分批次训练)
for e in range(nb_epoch):
    print 'Epoch', e
    batches = 0
    for X_batch, Y_batch in datagen.flow(X_train, Y_train, batch_size=32):
        loss = model.train(X_batch, Y_batch)
        batches += 1
        if batches >= len(X_train) / 32:
            # we need to break the loop by hand because
            # the generator loops indefinitely
            break


.flow_from_directory(directory)的方式

这种方式是从文件夹里读入图片,此时传入的文件夹(directory)的路径是数据集总路径,里面包含若干个直接以分类类别命名的子文件夹,各个类别的图片放好在各自所属类别的文件夹里面。代码读入数据成矩阵的同时,根据类别文件夹名字把数据集的class字典做好。目录结构如下图:

└─train
    ├─class1_name
    │      xxr.jpg
    │      xxx.jpg
    │
    ├─class2_name
    │      xxr.jpg
    │      xxx.jpg
    │
    └─class3_name
            xxr.jpg
            xxx.jpg

train_datagen = ImageDataGenerator(
        rescale=1./255,
        shear_range=0.2,
        zoom_range=0.2,
        horizontal_flip=True)
 
test_datagen = ImageDataGenerator(rescale=1./255)
 
train_generator = train_datagen.flow_from_directory(
        'data/train',
        target_size=(150, 150),
        batch_size=32,
        class_mode='binary')
 
validation_generator = test_datagen.flow_from_directory(
        'data/validation',
        target_size=(150, 150),
        batch_size=32,
        class_mode='binary')
 
model.fit_generator(
        train_generator,
        samples_per_epoch=2000,
        nb_epoch=50,
        validation_data=validation_generator,
        nb_val_samples=800)


当然,更多信息可以直接看中文文档:https://keras-cn.readthedocs.io/en/latest/

原文链接:https://blog.csdn.net/u010420283/article/details/103228567

  • 7
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
好的,针对您的问题,我可以为您提供以下步骤来使用 Keras Sequential 进行图像识别: 1. 导入必要的库和模块: ``` import keras from keras.models import Sequential from keras.layers import Conv2D, MaxPooling2D, Flatten, Dense ``` 2. 加载数据集: ``` from keras.datasets import mnist (train_x, train_y), (test_x, test_y) = mnist.load_data() ``` 3. 对于图像数据,需要将其转换为模型可以处理的格式,即将每个像素点的值缩放到 0~1 之间,并将数据集的维度调整为 (样本数,长,宽,通道数): ``` train_x = train_x.reshape(train_x.shape[0], 28, 28, 1) test_x = test_x.reshape(test_x.shape[0], 28, 28, 1) train_x = train_x.astype('float32') test_x = test_x.astype('float32') train_x /= 255 test_x /= 255 ``` 4. 构建模型: ``` model = Sequential() model.add(Conv2D(32, (3, 3), activation='relu', input_shape=(28, 28, 1))) model.add(MaxPooling2D((2, 2))) model.add(Conv2D(64, (3, 3), activation='relu')) model.add(MaxPooling2D((2, 2))) model.add(Conv2D(64, (3, 3), activation='relu')) model.add(Flatten()) model.add(Dense(64, activation='relu')) model.add(Dense(10, activation='softmax')) ``` 5. 编译模型: ``` model.compile(optimizer='rmsprop', loss='categorical_crossentropy', metrics=['accuracy']) ``` 6. 训练模型: ``` model.fit(train_x, keras.utils.to_categorical(train_y), epochs=5, batch_size=64, validation_data=(test_x, keras.utils.to_categorical(test_y))) ``` 7. 评估模型: ``` test_loss, test_acc = model.evaluate(test_x, keras.utils.to_categorical(test_y)) print('Test accuracy:', test_acc) ``` 以上就是使用 Keras Sequential 进行图像识别的一般步骤,您可以根据您的具体需求进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

AI算法网奇

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值