mindspore中cifar100的数据集读取和处理

import pickle
import numpy as np
from mindspore.dataset import GeneratorDataset
def setup():
    def load(fileName: str):
        with open(file=fileName, mode="rb") as handler:
            data = pickle.load(file=handler, encoding="latin1")
        return data
    trains = load("D:/dataset/cifar-100-python/train")
    tests = load("D:/dataset/cifar-100-python/test")
    metas = load("D:/dataset/cifar-100-python/meta")
    return trains, tests, metas

def train():
    trains, tests, metas = setup()
    print(trains["data"][0],trains["coarse_labels"][0],trains["fine_labels"][0] )
    print(len(trains["coarse_labels"]))
    for key in trains.keys():
        print(f"key = {key}, len(trains[key]) = {len(trains[key])}")
    print("--------------------------------------------------")
    for key in tests.keys():
        print(f"key = {key}, len(tests[key]) = {len(tests[key])}")
    print("--------------------------------------------------")
    for key in metas.keys():
        print(f"key = {key}, len(metas[key]) = {len(metas[key])}")

#
class LoadCifar100Dataset():
    def __init__(self,type):
        self.type = type
        self.trains, self.tests = self.setup()
    def __len__(self):
        if self.type == "train":
            return len(self.trains["coarse_labels"])
        else:
            return len(self.tests["coarse_labels"])
    def __getitem__(self, idx):
        if self.type=="train":
            # return {
            #     "data":np.reshape(self.trains["data"][idx].astype(np.float32), (3,32,32)),
            #     "coarse_labels":self.trains["coarse_labels"][idx],
            #     "fine_labels":self.trains["fine_labels"][idx]
            # }
            #返回的是元组
            return (np.reshape(self.trains["data"][idx].astype(np.float32), (3,32,32)), self.trains["coarse_labels"][idx], self.trains["fine_labels"][idx])
        else:
            return (np.reshape(self.tests["data"][idx].astype(np.float32), (3,32,32)), self.tests["coarse_labels"][idx], self.tests["fine_labels"][idx])

    def setup(self):
        def load(fileName: str):
            with open(file=fileName, mode="rb") as handler:
                data = pickle.load(file=handler, encoding="latin1")
            return data

        trains = load("D:/dataset/cifar-100-python/train")
        tests = load("D:/dataset/cifar-100-python/test")
        return trains, tests

if __name__ == '__main__':
    # train()
    cifar100_train_dataset = LoadCifar100Dataset("train")
    cifar100_test_dataset = LoadCifar100Dataset("test")
    train_generator = GeneratorDataset(cifar100_train_dataset,column_names=["image","coarse_labels","fine_labels"])
    train_generator = train_generator.batch(10)
    size = train_generator.get_dataset_size()
    print(size)
    for i, (imgs, coarse_labels, fine_labels) in enumerate(train_generator.create_tuple_iterator()):
        print(imgs.shape)

数据集下载:

 浏览器打开:https://www.cs.toronto.edu/~kriz/cifar-100-python.tar.gz 进行下载至本地。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

恋上钢琴的虫

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

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

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

打赏作者

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

抵扣说明:

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

余额充值