python神经网络Keras构建CNN网络训练

作者:Bubbliiiing 时间:2022-08-16 08:42:37 

利用Keras构建完普通BP神经网络后,还要会构建CNN

Keras中构建CNN的重要函数

1、Conv2D

Conv2D用于在CNN中构建卷积层,在使用它之前需要在库函数处import它。

from keras.layers import Conv2D

在实际使用时,需要用到几个参数。

Conv2D(
   nb_filter = 32,
   nb_row = 5,
   nb_col = 5,
   border_mode = 'same',
   input_shape = (28,28,1)
)

其中,nb_filter代表卷积层的输出有多少个channel,卷积之后图像会越来越厚,这就是卷积后图像的厚度。nb_row和nb_col的组合就是卷积器的大小,这里卷积器是(5,5)的大小。border_mode代表着padding的方式,same表示卷积前后图像的shape不变。input_shape代表输入的shape。

2、MaxPooling2D

MaxPooling2D指的是池化层,在使用它之前需要在库函数处import它。

from keras.layers import MaxPooling2D

在实际使用时,需要用到几个参数。

MaxPooling2D(
   pool_size = (2,2),
   strides = (2,2),
   border_mode = 'same'
)

其中,pool_size表示池化器的大小,在这里,池化器的shape是(2,2)。strides是池化器的步长,这里在X和Y方向上都是2,池化后,输出比输入的shape小了1/2。border_mode代表着padding的方式。

3、Flatten

Flatten用于将卷积池化后最后的输出变为一维向量,这样才可以和全连接层连接,用于计算。在使用前需要用import导入。

from keras.layers import Flatten

在实际使用时,在最后一个池化层后直接添加层即可

model.add(Flatten())

全部代码

这是一个卷积神经网络的例子,用于识别手写体,其神经网络结构如下:

卷积层1->池化层1->卷积层2->池化层2->flatten->全连接层1->全连接层2->全连接层3。

单个样本的shape如下:

(28,28,1)->(28,28,32)->(14,14,32)->(14,14,64)->(7,7,64)->(3136)->(1024)->(256)

import numpy as np
from keras.models import Sequential
from keras.layers import Dense,Activation,Conv2D,MaxPooling2D,Flatten ## 全连接层
from keras.datasets import mnist
from keras.utils import np_utils
from keras.optimizers import Adam
(X_train,Y_train),(X_test,Y_test) = mnist.load_data()
X_train = X_train.reshape(-1,28,28,1)
X_test = X_test.reshape(-1,28,28,1)
Y_train = np_utils.to_categorical(Y_train,num_classes= 10)
Y_test = np_utils.to_categorical(Y_test,num_classes= 10)
model = Sequential()
# conv1
model.add(
   Conv2D(
       nb_filter = 32,
       nb_row = 5,
       nb_col = 5,
       border_mode = 'same',
       input_shape = (28,28,1)
   )
)
model.add(Activation("relu"))
# pool1
model.add(
   MaxPooling2D(
       pool_size = (2,2),
       strides = (2,2),
       border_mode = 'same'
   )
)
# conv2
model.add(
   Conv2D(
       nb_filter = 64,
       nb_row = 5,
       nb_col = 5,
       border_mode = 'same'
   )
)
model.add(Activation("relu"))
# pool2
model.add(
   MaxPooling2D(
       pool_size = (2,2),
       strides = (2,2),
       border_mode = 'same'
   )
)
# 全连接层
model.add(Flatten())
model.add(Dense(1024))
model.add(Activation("relu"))
model.add(Dense(256))
model.add(Activation("relu"))
model.add(Dense(10))
model.add(Activation("softmax"))
adam = Adam(lr = 1e-4)
## compile
model.compile(loss = 'categorical_crossentropy',optimizer = adam,metrics = ['accuracy'])
## tarin
print("\ntraining")
cost = model.fit(X_train,Y_train,nb_epoch = 2,batch_size = 32)
print("\nTest")
## acc
cost,accuracy = model.evaluate(X_test,Y_test)
## W,b = model.layers[0].get_weights()
print("accuracy:",accuracy)

实验结果为:

Epoch 1/2
60000/60000 [==============================] - 64s 1ms/step - loss: 0.7664 - acc: 0.9224
Epoch 2/2
60000/60000 [==============================] - 62s 1ms/step - loss: 0.0473 - acc: 0.9858
Test
10000/10000 [==============================] - 2s 169us/step
accuracy: 0.9856

来源:https://blog.csdn.net/weixin_44791964/article/details/101171576

标签:Keras,CNN,训练,python,神经网络
0
投稿

猜你喜欢

  • Python自动化之数据驱动让你的脚本简洁10倍【推荐】

    2022-08-20 12:48:57
  • pytorch:model.train和model.eval用法及区别详解

    2022-07-13 19:22:51
  • Python实现简单的2048小游戏

    2023-04-18 07:19:25
  • Python使用微信接入图灵机器人过程解析

    2022-05-29 04:03:14
  • Linux安装Python3如何和系统自带的Python2并存

    2023-08-25 03:42:09
  • Excel和Access之间的数据交换

    2008-11-20 16:53:00
  • 基于js里调用函数时,函数名带括号和不带括号的区别

    2023-08-24 05:05:41
  • python自动化测试之如何解析excel文件

    2022-08-28 08:24:36
  • SQL Server中单引号的两种处理技巧

    2008-05-23 13:30:00
  • 浅谈flask源码之请求过程

    2023-12-17 10:36:48
  • PHP结构型模式之享元模式详解

    2023-05-27 22:38:40
  • jQuery+php简单实现全选删除的方法

    2023-11-05 20:23:38
  • JavaScript 设计模式 富有表现力的Javascript(一)

    2023-08-25 07:42:15
  • Oracle 下医嘱执行函数

    2009-03-02 10:49:00
  • 详解python中__name__的意义以及作用

    2021-11-20 19:44:24
  • Python OpenCV的基本使用及相关函数

    2022-11-16 11:24:55
  • python使用rabbitmq实现网络爬虫示例

    2022-04-20 20:11:58
  • PHP 应用容器化以及部署方法

    2023-11-14 15:45:06
  • 通过Py2exe将自己的python程序打包成.exe/.app的方法

    2021-07-05 11:05:55
  • Python 创建新文件时避免覆盖已有的同名文件的解决方法

    2023-08-23 23:44:46
  • asp之家 网络编程 m.aspxhome.com