python神经网络学习使用Keras进行简单分类

作者:Bubbliiiing 时间:2023-09-18 04:37:23 

学习前言

上一篇讲了如何构建回归算法,这一次将怎么进行简单分类。

Keras中分类的重要函数

1、np_utils.to_categorical

np_utils.to_categorical用于将标签转化为形如(nb_samples, nb_classes)的二值序列。

假设num_classes = 10。

如将[1,2,3,……4]转化成:

[[0,1,0,0,0,0,0,0]
[0,0,1,0,0,0,0,0]
[0,0,0,1,0,0,0,0]
……
[0,0,0,0,1,0,0,0]]

这样的形态。

如将Y_train转化为二值序列,可以用如下方式:

Y_train = np_utils.to_categorical(Y_train,num_classes= 10)

2、Activation

Activation是激活函数,一般在每一层的输出使用。

当我们使用Sequential模型构建函数的时候,只需要在每一层Dense后面添加Activation就可以了。

Sequential函数也支持直接在参数中完成所有层的构建,使用方法如下。

model = Sequential([
   Dense(32,input_dim = 784),
   Activation("relu"),
   Dense(10),
   Activation("softmax")
   ]
)

其中两次Activation分别使用了relu函数和softmax函数。

3、metrics=[‘accuracy’]

在model.compile中添加metrics=[‘accuracy’]表示需要计算分类精确度,具体使用方式如下:

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

全部代码

这是一个简单的仅含有一个隐含层的神经网络,用于完成手写体识别。在本例中,使用的优化器是RMSprop,具体可以使用的优化器可以参照Keras中文文档。

import numpy as np
from keras.models import Sequential
from keras.layers import Dense,Activation ## 全连接层
from keras.datasets import mnist
from keras.utils import np_utils
from keras.optimizers import RMSprop
# 获取训练集
(X_train,Y_train),(X_test,Y_test) = mnist.load_data()
# 首先进行标准化
X_train = X_train.reshape(X_train.shape[0],-1)/255
X_test = X_test.reshape(X_test.shape[0],-1)/255
# 计算categorical_crossentropy需要对分类结果进行categorical
# 即需要将标签转化为形如(nb_samples, nb_classes)的二值序列
Y_train = np_utils.to_categorical(Y_train,num_classes= 10)
Y_test = np_utils.to_categorical(Y_test,num_classes= 10)
# 构建模型
model = Sequential([
   Dense(32,input_dim = 784),
   Activation("relu"),
   Dense(10),
   Activation("softmax")
   ]
)
rmsprop = RMSprop(lr = 0.001,rho = 0.9,epsilon = 1e-08,decay = 0)
## compile
model.compile(loss = 'categorical_crossentropy',optimizer = rmsprop,metrics=['accuracy'])
print("\ntraining")
cost = model.fit(X_train,Y_train,nb_epoch = 2,batch_size = 32)
print("\nTest")
cost,accuracy = model.evaluate(X_test,Y_test)
## W,b = model.layers[0].get_weights()
print("accuracy:",accuracy)

实验结果为:

Epoch 1/2
60000/60000 [==============================] - 12s 202us/step - loss: 0.3512 - acc: 0.9022
Epoch 2/2
60000/60000 [==============================] - 11s 183us/step - loss: 0.2037 - acc: 0.9419
Test
10000/10000 [==============================] - 1s 108us/step
accuracy: 0.9464

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

标签:python,神经网络,Keras,分类
0
投稿

猜你喜欢

  • Pygame改编飞机大战制作兔子接月饼游戏

    2023-04-09 02:57:22
  • python opencv 图像拼接的实现方法

    2021-06-21 19:11:51
  • Django websocket原理及功能实现代码

    2023-04-18 16:49:11
  • python通过elixir包操作mysql数据库实例代码

    2024-01-26 04:12:16
  • 使用Python编写一个模仿CPU工作的程序

    2021-04-28 05:28:25
  • ASP常见错误详解及解决方案小结 推荐第1/2页

    2011-02-24 11:19:00
  • Python字符串的全排列算法实例详解

    2023-04-30 17:01:05
  • JavaScript实现带自动提示的文本框效果代码

    2011-02-05 11:13:00
  • Python纯代码通过神经网络实现线性回归的拟合方式

    2022-07-12 23:54:59
  • php数组转换js数组操作及json_encode的用法详解

    2024-05-03 15:13:44
  • 手写个小组件(组件入门)asp版

    2013-06-01 20:29:25
  • Python实现socket非阻塞通讯功能示例

    2022-05-16 03:18:25
  • Python函数基础

    2022-09-11 11:36:43
  • Python实现文件内容批量追加的方法示例

    2021-11-13 13:47:40
  • Python图形绘制操作之正弦曲线实现方法分析

    2023-07-05 11:18:59
  • TCP协议用在python和wifi模块之间详解

    2021-02-04 05:43:08
  • js编写的语法高亮引擎工具

    2008-05-25 13:27:00
  • gorm操作MySql数据库的方法

    2024-01-20 14:15:00
  • Python中列表的基本操作汇总

    2021-08-20 23:21:27
  • vue开发心得和技巧分享

    2024-04-30 10:30:27
  • asp之家 网络编程 m.aspxhome.com