python训练好的图片验证_利用keras加载训练好的.H5文件,并实现预测图片

本文展示了如何利用Keras的load_model函数加载已训练好的.H5模型,并对指定目录下的图片进行预测。首先,加载模型并打印模型摘要,然后定义一个函数将图片标准化为150x150并归一化像素值。接着,遍历预测目录,读取图片并进行预处理,最后调用模型进行预测。
摘要由CSDN通过智能技术生成

我就废话不多说了,直接上代码吧!

import matplotlib

matplotlib.use('Agg')

import os

from keras.models import load_model

import numpy as np

from PIL import Image

import cv2

#加载模型h5文件

model = load_model("C:\\python\\python3_projects\\cat_dog\\cats_dogs_fifty_thousand.h5")

model.summary()

#规范化图片大小和像素值

def get_inputs(src=[]):

pre_x = []

for s in src:

input = cv2.imread(s)

input = cv2.resize(input, (150, 150))

input = cv2.cvtColor(input, cv2.COLOR_BGR2RGB)

pre_x.append(input) # input一张图片

pre_x = np.array(pre_x) / 255.0

return pre_x

#要预测的图片保存在这里

predict_dir = 'C:\python\python3_projects\cat_dog\pics'

#这个路径下有两个文件,分别是cat和dog

test = os.listdir(predict_dir)

#打印后:['ca

  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 可以参考以下代码来写一个Tensorflow2的MobileNet程序,用于训练自己的图片数据:import tensorflow as tf# 加载 MobileNet 模型 model = tf.keras.applications.MobileNet()# 加载自己的图片数据集 data = # 加载数据# 配置 MobileNet 模型 model.compile(optimizer=tf.keras.optimizers.Adam(), loss=tf.keras.losses.sparse_categorical_crossentropy, metrics=["accuracy"])# 训练模型 model.fit(data, epochs=5)# 保存模型 model.save("my_model.h5") ### 回答2: import tensorflow as tf from tensorflow.keras.preprocessing.image import ImageDataGenerator from tensorflow.keras.applications import MobileNetV2 from tensorflow.keras import layers, models # 设置图片数据路径和类别数 train_dir = 'path_to_training_images' validation_dir = 'path_to_validation_images' num_classes = 2 # 假设有2个类别 # 设置图像数据增强参数 train_datagen = ImageDataGenerator( rescale=1./255, rotation_range=20, zoom_range=0.2, horizontal_flip=True ) # 创建训练集和验证集的数据生成器 train_generator = train_datagen.flow_from_directory( train_dir, target_size=(224, 224), batch_size=32, class_mode='categorical' ) validation_generator = train_datagen.flow_from_directory( validation_dir, target_size=(224, 224), batch_size=32, class_mode='categorical' ) # 加载MobileNetV2模型 base_model = MobileNetV2(include_top=False, weights='imagenet', input_shape=(224, 224, 3)) base_model.trainable = False # 构建模型 model = models.Sequential([ base_model, layers.GlobalAveragePooling2D(), layers.Dense(128, activation='relu'), layers.Dense(num_classes, activation='softmax') ]) # 编译模型 model.compile(optimizer='adam', loss='categorical_crossentropy', metrics=['accuracy']) # 训练模型 history = model.fit( train_generator, steps_per_epoch=train_generator.samples // train_generator.batch_size, validation_data=validation_generator, validation_steps=validation_generator.samples // validation_generator.batch_size, epochs=10 ) # 保存和加载模型 model.save('path_to_save_model') loaded_model = tf.keras.models.load_model('path_to_saved_model') ### 回答3: 下面是一个使用TensorFlow 2训练自定义图片数据的MobileNet的Python程序: ```python import tensorflow as tf from tensorflow.keras.applications import MobileNetV2 from tensorflow.keras.preprocessing.image import ImageDataGenerator # 定义模型架构 base_model = MobileNetV2(weights='imagenet', include_top=False, input_shape=(224, 224, 3)) model = tf.keras.Sequential([ base_model, tf.keras.layers.GlobalAveragePooling2D(), tf.keras.layers.Dense(10, activation='softmax') ]) # 编译模型 model.compile(optimizer='adam', loss='categorical_crossentropy', metrics=['accuracy']) # 创建ImageDataGenerator对象,用于进行数据增强和数据预处理 datagen = ImageDataGenerator(rescale=1./255, validation_split=0.2) # 加载自定义图片数据集 train_generator = datagen.flow_from_directory( 'path_to_training_directory', target_size=(224, 224), batch_size=32, class_mode='categorical', subset='training') validation_generator = datagen.flow_from_directory( 'path_to_training_directory', target_size=(224, 224), batch_size=32, class_mode='categorical', subset='validation') # 训练模型 model.fit_generator( train_generator, steps_per_epoch=train_generator.samples/train_generator.batch_size, epochs=10, validation_data=validation_generator, validation_steps=validation_generator.samples/validation_generator.batch_size) # 保存模型 model.save('my_mobilenet_model.h5') ``` 上述程序的大致工作流程如下: 1. 导入必要的库:TensorFlow和相关模块 2. 定义模型架构:使用MobileNetV2作为基础模型构建一个多层次感知机模型,输出10个类别的预测结果。 3. 编译模型:指定优化器、损失函数和评估指标。 4. 创建ImageDataGenerator对象:用于进行数据增强和数据预处理。这里使用了图片归一化处理,并进行了80%训练集和20%验证集的划分。 5. 加载自定义图片数据集:使用flow_from_directory方法加载自定义训练集和验证集的图片数据。 6. 训练模型:使用fit_generator方法进行模型的训练。 7. 保存模型:将训练好的模型保存为h5文件,以便后续使用。 注意:上述程序中的`path_to_training_directory`需替换为你自己的图片数据集的路径。此外,根据需要,还可以进行更多的模型调优和配置。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值