cifar.py 4.4 KB
Newer Older
D
dangqingqing 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13
# Copyright (c) 2016 PaddlePaddle Authors. All Rights Reserved
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
Y
Yu Yang 已提交
14
"""
Q
qijun 已提交
15 16
CIFAR dataset.

Q
qijun 已提交
17 18 19
This module will download dataset from
https://www.cs.toronto.edu/~kriz/cifar.html and parse train/test set into
paddle reader creators.
Q
qijun 已提交
20

Q
qijun 已提交
21 22 23
The CIFAR-10 dataset consists of 60000 32x32 colour images in 10 classes,
with 6000 images per class. There are 50000 training images and 10000 test
images.
Q
qijun 已提交
24

Q
qijun 已提交
25 26 27
The CIFAR-100 dataset is just like the CIFAR-10, except it has 100 classes
containing 600 images each. There are 500 training images and 100 testing
images per class.
Y
Yu Yang 已提交
28

Y
Yu Yang 已提交
29
"""
D
dangqingqing 已提交
30

31
import pickle
Y
Yu Yang 已提交
32 33
import itertools
import numpy
34
import paddle.dataset.common
Y
Yi Wang 已提交
35
import tarfile
Y
Yu Yang 已提交
36

Y
Your Name 已提交
37
__all__ = ['train100', 'test100', 'train10', 'test10', 'convert']
Y
Yu Yang 已提交
38

Y
Yi Wang 已提交
39 40
URL_PREFIX = 'https://www.cs.toronto.edu/~kriz/'
CIFAR10_URL = URL_PREFIX + 'cifar-10-python.tar.gz'
Y
Yu Yang 已提交
41
CIFAR10_MD5 = 'c58f30108f718f92721af3b95e74349a'
Y
Yi Wang 已提交
42
CIFAR100_URL = URL_PREFIX + 'cifar-100-python.tar.gz'
Y
Yu Yang 已提交
43 44 45
CIFAR100_MD5 = 'eb9058c3a382ffc7106e4002c42a8d85'


46
def reader_creator(filename, sub_name, cycle=False):
Y
Yi Wang 已提交
47 48 49 50
    def read_batch(batch):
        data = batch['data']
        labels = batch.get('labels', batch.get('fine_labels', None))
        assert labels is not None
51
        for sample, label in zip(data, labels):
Y
Yi Wang 已提交
52
            yield (sample / 255.0).astype(numpy.float32), int(label)
Y
Yu Yang 已提交
53

Y
Yi Wang 已提交
54
    def reader():
Y
Yu Yang 已提交
55
        with tarfile.open(filename, mode='r') as f:
Y
Yu Yang 已提交
56 57 58
            names = (each_item.name for each_item in f
                     if sub_name in each_item.name)

59 60
            while True:
                for name in names:
61
                    batch = pickle.load(f.extractfile(name))
62 63 64 65
                    for item in read_batch(batch):
                        yield item
                if not cycle:
                    break
Y
Yu Yang 已提交
66

Y
Yu Yang 已提交
67
    return reader
Y
Yu Yang 已提交
68 69


Y
Yi Wang 已提交
70
def train100():
Q
qijun 已提交
71
    """
Q
qijun 已提交
72
    CIFAR-100 training set creator.
Q
qijun 已提交
73 74 75 76

    It returns a reader creator, each sample in the reader is image pixels in
    [0, 1] and label in [0, 99].

Q
qijun 已提交
77
    :return: Training reader creator
Q
qijun 已提交
78 79
    :rtype: callable
    """
Y
Yi Wang 已提交
80
    return reader_creator(
81
        paddle.dataset.common.download(CIFAR100_URL, 'cifar', CIFAR100_MD5),
R
root 已提交
82
        'train')
Y
Yu Yang 已提交
83 84


Y
Yi Wang 已提交
85
def test100():
Q
qijun 已提交
86
    """
X
xuwei06 已提交
87
    CIFAR-100 test set creator.
Q
qijun 已提交
88 89 90 91 92 93 94

    It returns a reader creator, each sample in the reader is image pixels in
    [0, 1] and label in [0, 9].

    :return: Test reader creator.
    :rtype: callable
    """
R
root 已提交
95
    return reader_creator(
96
        paddle.dataset.common.download(CIFAR100_URL, 'cifar', CIFAR100_MD5),
R
root 已提交
97
        'test')
Y
Yu Yang 已提交
98 99


100
def train10(cycle=False):
Q
qijun 已提交
101
    """
Q
qijun 已提交
102
    CIFAR-10 training set creator.
Q
qijun 已提交
103 104 105 106

    It returns a reader creator, each sample in the reader is image pixels in
    [0, 1] and label in [0, 9].

107 108
    :param cycle: whether to cycle through the dataset
    :type cycle: bool
Q
qijun 已提交
109
    :return: Training reader creator
Q
qijun 已提交
110 111
    :rtype: callable
    """
Y
Yi Wang 已提交
112
    return reader_creator(
113
        paddle.dataset.common.download(CIFAR10_URL, 'cifar', CIFAR10_MD5),
114 115
        'data_batch',
        cycle=cycle)
Y
Yu Yang 已提交
116 117


118
def test10(cycle=False):
Q
qijun 已提交
119
    """
X
xuwei06 已提交
120
    CIFAR-10 test set creator.
Q
qijun 已提交
121 122 123 124

    It returns a reader creator, each sample in the reader is image pixels in
    [0, 1] and label in [0, 9].

125 126
    :param cycle: whether to cycle through the dataset
    :type cycle: bool
Q
qijun 已提交
127 128 129
    :return: Test reader creator.
    :rtype: callable
    """
Y
Yi Wang 已提交
130
    return reader_creator(
131
        paddle.dataset.common.download(CIFAR10_URL, 'cifar', CIFAR10_MD5),
132 133
        'test_batch',
        cycle=cycle)
Y
Yancey1989 已提交
134 135


136
def fetch():
137 138
    paddle.dataset.common.download(CIFAR10_URL, 'cifar', CIFAR10_MD5)
    paddle.dataset.common.download(CIFAR100_URL, 'cifar', CIFAR100_MD5)
R
root 已提交
139 140 141 142 143 144


def convert(path):
    """
    Converts dataset to recordio format
    """
145 146 147 148
    paddle.dataset.common.convert(path, train100(), 1000, "cifar_train100")
    paddle.dataset.common.convert(path, test100(), 1000, "cifar_test100")
    paddle.dataset.common.convert(path, train10(), 1000, "cifar_train10")
    paddle.dataset.common.convert(path, test10(), 1000, "cifar_test10")