TensorFlow 自定义数据集

TensorFlow自定义数据集需要继承的类:tf.keras.utils.Sequence

模板

class SiameseSequence(tf.keras.utils.Sequence):
    def __init__(self):
        pass

    def __len__(self):
        # 数据集长度
        pass
        
    def __getitem__(self, idx):
     	# 获取一批数据(1个batch)
        pass

实际应用

import numpy as np
import tensorflow as tf
import glob
# load_img 加载图像 img_to_array 数据格式转换
from tensorflow.keras.preprocessing import image
# 对 resnet 图像预处理
from tensorflow.keras.applications.vgg16 import preprocess_input
import random

# 训练集
train_classes = glob.glob('dogImages/train/*')

li = []
for i in train_classes:
    # print(i)
    imgs = glob.glob(i + '/*.jpg')
    # print(imgs)
    for j in imgs:
        # print(j)
        li.append(j)
print(len(train_classes))
print(len(li))


class SiameseSequence(tf.keras.utils.Sequence):
    def __init__(self, data_list, file_list, batch_size):
        # 所有文件夹完整路径
        self.data_list = data_list
        # 类别个数
        self.file_list = file_list
        # 一组几个
        self.batch_size = batch_size

    def __len__(self):
        # 数据集总长度 / batch_size
        # 计算有多少个batch_size
        num = (len(self.data_list) / self.batch_size) + 1
        return num

    def preprocess_image(self, filename):
        # 预处理图片
        img = image.load_img(filename, target_size=(224, 224))
        img = image.img_to_array(img)
        img = preprocess_input(img)
        return img

    def __getitem__(self, idx):
        # 获取一批数据(1个batch)

        batch_A = []
        for i in range(self.batch_size):
            batch_A.append(self.preprocess_image(self.data_list[idx]))

        return np.array(batch_A)


traingen = SiameseSequence(li, len(train_classes), 32)

print(traingen[0].shape)

import cv2

# 预处理 解析(这里是归一化)
def changeImg(img):
    max_v = img.max()
    min_v = img.min()
    img = (img - min_v) / max_v
    return img[0]


def cv_show(neme, img):
    # cv2.namedWindow(neme, cv2.WINDOW_NORMAL)
    cv2.imshow(neme, img)
    cv2.waitKey(0)
    cv2.destroyAllWindows()

# traingen[每个数据]
img = changeImg(traingen[1])
print(img.shape)
cv_show('neme', img)

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

默执_

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

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

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

打赏作者

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

抵扣说明:

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

余额充值