首页 技术 正文
技术 2022年11月16日
0 收藏 719 点赞 3,549 浏览 1813 个字
 # -*- coding: utf-8 -*-
"""
Created on Sun Jan 20 11:25:29 2019 @author: zhen
""" import numpy as np
from keras.datasets import mnist
from keras.models import Sequential
from keras.layers import Dense
from keras.layers import Dropout
from keras.layers import Flatten
from keras.layers.convolutional import Conv2D
from keras.layers.convolutional import MaxPooling2D # 加载数据
(x_train, y_train), (x_test, y_test) = mnist.load_data("../test_data_home")
# 转化训练数据为四维张量形式
x_train = x_train.reshape(x_train.shape[0], 28, 28, 1).astype("float32")
x_test = x_test.reshape(x_test.shape[0], 28, 28, 1).astype("float32")
# 归一化
x_train /= 255
x_test /= 255 #转化为one hot 编码
def to_one_hot(y):
y_one_hot = np.zeros(10) # 生成全零向量
y_one_hot[y] = 1
return y_one_hot # 重置标签
y_train_one_hot = np.array([to_one_hot(y_train[i]) for i in range(len(y_train))])
y_test_one_hot = np.array([to_one_hot(y_test[i]) for i in range(len(y_test))])
# 搭建卷积神经网络
model = Sequential()
model.add(Conv2D(filters=32, kernel_size=(3, 3), strides=(1, 1), padding='same', input_shape=(28, 28, 1),
activation='relu'))
# 添加最大池化层
model.add(MaxPooling2D(pool_size=(2, 2)))
# 添加Dropout层
model.add(Dropout(0.2))
# 构建深度网络
model.add(Conv2D(64, kernel_size=(3, 3), strides=(1, 1), padding='same', activation='relu'))
model.add(MaxPooling2D(pool_size=(2, 2)))
model.add(Dropout(0.2))
model.add(Conv2D(128, kernel_size=(3, 3), strides=(1, 1), padding='same', activation='relu'))
model.add(MaxPooling2D(pool_size=(2, 2)))
model.add(Dropout(0.2))
# 展开
model.add(Flatten())
# 构造全连接层
model.add(Dense(128, activation='relu'))
model.add(Dense(64, activation='relu'))
model.add(Dense(32, activation='relu'))
model.add(Dense(10, activation='softmax'))
# 定义损失函数
model.compile(loss='categorical_crossentropy', optimizer='adagrad',
metrics=['accuracy'])
# 训练
model.fit(x_train, y_train_one_hot, validation_data=(x_test, y_test_one_hot),
epochs=2, batch_size=128)
# 评估
# verbose : 0表示不显示数据,1表示显示进度
scores = model.evaluate(x_test, y_test_one_hot, verbose=0)
print(scores)

结果:

Keras实现卷积神经网络

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,085
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,560
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,409
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,182
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,819
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,902