keras多层感知器识别手写数字

一、进行数据预处理

步骤1:导入所需模块

import tensorflow as tf
import tensorflow.keras
import numpy as np
import pandas as pd
from tensorflow.keras.utils import to_categorical
np.random.seed(10)

步骤2:读取MNIST数据

from tensorflow.keras.datasets import mnist
(x_train_image, y_train_label), \
(x_test_image, y_test_label) = mnist.load_data()

步骤3:将features(数字图像特征值)以reshape转换

x_train=x_train_image.reshape(60000,784).astype('float32')
x_test=x_test_image.reshape(10000,784).astype('float32')

步骤4:将features(数字图像特征值)标准化

x_train_normalize = x_train/255
x_test_normalize = x_test/255

步骤5:label(数字真实的值)以One-Hot Encoding进行转换

y_trainonehot =tf.keras.utils. to_categorical(y_train_label)
y_testonehot = tf.keras.utils.to_categorical(y_test_label)

二、建立模型
1.导入所需模块

from tensorflow.keras.models import Sequential
from tensorflow.keras.layers import Dense

2.建立Sequential模型
建立“输出层”和“隐藏层”

model = Sequential()
model.add(Dense(units=256,
               input_dim=784,
               kernel_initializer='normal',
               activation='relu'))
model.add(Dense(units=10,
               kernel_initializer='normal',
               activation='softmax'))

3.查看模型的摘要

print(model.summary())

三、进行训练

1.定义训练方式

model.compile(loss='categorical_crossentropy',optimizer='adam',metrics=['accuracy'])

2.开始训练

train_history=model.fit(x=x_train_normalize,
                       y=y_trainonehot,
                       validation_split=0.2
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值