tf.data加载NumPy

tf.data加载NumPy

代码

# -*- coding: utf-8 -*-
"""
Created on  2020/11/20 16:33
@Author: CY
@email: 5844104706@qq.com
"""
import numpy as np
import tensorflow as tf
import tensorflow_datasets as tfds

#从 NumPy 数组加载到 tf.data.Dataset 的示例 本示例从一个 .npz 文件中加载 MNIST 数据集
print("#1. 加载数据")
DATA_URL = 'https://storage.googleapis.com/tensorflow/tf-keras-datasets/mnist.npz'

path = tf.keras.utils.get_file('mnist.npz', DATA_URL)
with np.load(path) as data:
    train_examples = data['x_train']
    train_labels = data['y_train']
    test_examples = data['x_test']
    test_labels = data['y_test']

train_dataset = tf.data.Dataset.from_tensor_slices((train_examples, train_labels))
test_dataset = tf.data.Dataset.from_tensor_slices((test_examples, test_labels))
#使用该数据集
#打乱和批次化数据集
BATCH_SIZE = 64
SHUFFLE_BUFFER_SIZE = 100

train_dataset = train_dataset.shuffle(SHUFFLE_BUFFER_SIZE).batch(BATCH_SIZE)
test_dataset = test_dataset.batch(BATCH_SIZE)

print("2.建立和训练模型")
model = tf.keras.Sequential([
    tf.keras.layers.Flatten(input_shape=(28, 28)),
    tf.keras.layers.Dense(128, activation='relu'),
    tf.keras.layers.Dense(10, activation='softmax')
])

model.compile(optimizer=tf.keras.optimizers.RMSprop(),
              loss=tf.keras.losses.SparseCategoricalCrossentropy(),
              metrics=[tf.keras.metrics.SparseCategoricalAccuracy()])
model.fit(train_dataset, epochs=10)

model.evaluate(test_dataset)

结果

#1. 加载数据
2.建立和训练模型
Epoch 1/10
938/938 [==============================] - 1s 1ms/step - loss: 3.4181 - sparse_categorical_accuracy: 0.8768
Epoch 2/10
938/938 [==============================] - 1s 1ms/step - loss: 0.5796 - sparse_categorical_accuracy: 0.9224
Epoch 3/10
938/938 [==============================] - 1s 1ms/step - loss: 0.4212 - sparse_categorical_accuracy: 0.9424
Epoch 4/10
938/938 [==============================] - 1s 1ms/step - loss: 0.3490 - sparse_categorical_accuracy: 0.9521
Epoch 5/10
938/938 [==============================] - 1s 1ms/step - loss: 0.2969 - sparse_categorical_accuracy: 0.9582
Epoch 6/10
938/938 [==============================] - 1s 1ms/step - loss: 0.2884 - sparse_categorical_accuracy: 0.9623
Epoch 7/10
938/938 [==============================] - 1s 1ms/step - loss: 0.2572 - sparse_categorical_accuracy: 0.9669
Epoch 8/10
938/938 [==============================] - 1s 1ms/step - loss: 0.2216 - sparse_categorical_accuracy: 0.9708
Epoch 9/10
938/938 [==============================] - 1s 1ms/step - loss: 0.2193 - sparse_categorical_accuracy: 0.9723
Epoch 10/10
938/938 [==============================] - 1s 1ms/step - loss: 0.2087 - sparse_categorical_accuracy: 0.9740
157/157 [==============================] - 0s 597us/step - loss: 0.6257 - sparse_categorical_accuracy: 0.9610

Process finished with exit code 0

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

ynchyong

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

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

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

打赏作者

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

抵扣说明:

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

余额充值