基于tensorflow的mnist的softmax分类

基于tensorflow的mnist的softmax分类

softmax回归是一个简单的分类模型,正确率在mnist测试集上达到91.74%。
主要由以下几个模块构成:

  1. 预处理部分:数据的读取,占位符和变量的定义;
  2. 迭代处理部分:损失函数和优化损失函数的优化方法定义;
  3. 后续评估部分:准确率的定义;
  4. 最后,启动sess实现,通过优化损失函数得到最优的参数,并在测试集上进行预测得到模型准确率。

import os, sys
import tensorflow as tf 
import numpy as np 
from tensorflow.examples.tutorials.mnist import input_data
import cv2

#read data
mnist = input_data.read_data_sets('MNIST_data\\', one_hot=True)

#define variable
x = tf.placeholder(tf.float32, [None, 784])
y_ = tf.placeholder(tf.float32, [None, 10])
W = tf.Variable(tf.zeros([784,10]))
b = tf.Variable(tf.zeros([10]))
y = tf.nn.softmax(tf.matmul(x,W) + b)

# loss and gradientdescent
tmp = tf.reduce_sum(y_ * tf.log(y))
cross_entropy = tf.reduce_mean(-tf.reduce_sum(y_ * tf.log(y)))
train_step = tf.train.GradientDescentOptimizer(0.01).minimize(cross_entropy)

#accuracy
correct_prediction = tf.equal(tf.argmax(y,1), tf.argmax(y_,1))
accuracy = tf.reduce_mean(tf.cast(correct_prediction, tf.float32))

#session
sess = tf.InteractiveSession()
tf.global_variables_initializer().run()
for i in range(5000):
    batch_x, batch_y_ = mnist.train.next_batch(100)
    sess.run(train_step, feed_dict={x:batch_x, y_:batch_y_})
    if (i%10 == 0):
        acc = sess.run(accuracy, feed_dict={x:mnist.test.images,y_:mnist.test.labels})
        print("step ",i,acc)



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是基于 TensorFlow 使用 LeNet-5 实现对 MNIST 手写数字识别分类的步骤: 1. 安装 TensorFlow:可以通过 pip 安装,命令为 `pip install tensorflow`。 2. 导入必要的库: ``` import tensorflow as tf from tensorflow.keras import datasets, layers, models ``` 3. 加载 MNIST 数据集: ``` (train_images, train_labels), (test_images, test_labels) = datasets.mnist.load_data() ``` 4. 对数据进行预处理: ``` train_images = train_images.reshape((60000, 28, 28, 1)) test_images = test_images.reshape((10000, 28, 28, 1)) train_images, test_images = train_images / 255.0, test_images / 255.0 ``` 5. 构建 LeNet-5 模型: ``` model = models.Sequential() model.add(layers.Conv2D(6, (5, 5), activation='relu', input_shape=(28, 28, 1))) model.add(layers.MaxPooling2D((2, 2))) model.add(layers.Conv2D(16, (5, 5), activation='relu')) model.add(layers.MaxPooling2D((2, 2))) model.add(layers.Flatten()) model.add(layers.Dense(120, activation='relu')) model.add(layers.Dense(84, activation='relu')) model.add(layers.Dense(10, activation='softmax')) ``` 6. 编译模型: ``` model.compile(optimizer='adam', loss='sparse_categorical_crossentropy', metrics=['accuracy']) ``` 7. 训练模型: ``` model.fit(train_images, train_labels, epochs=5, validation_data=(test_images, test_labels)) ``` 8. 测试模型: ``` test_loss, test_acc = model.evaluate(test_images, test_labels) print('Test accuracy:', test_acc) ``` 以上就是基于 TensorFlow 使用 LeNet-5 实现对 MNIST 手写数字识别分类的步骤。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值