【云云怪】项目11后续——自制三层网络的MNIST手写数字识别系统

昨天捣鼓了一天两层网络(一层隐藏层)的MNIST手写数据识别系统,我用尽各种手法,各种图片处理办法,最终实测正确率被锁定在50%上下。这真让人沮丧。。。今天脑子灵光一闪,2层网络性能不行,那就来3层吧!虽然没有现成的代码可以抄,但复制粘贴,举一反三,不就行了。于是,动手操作!首先把 two_layer_net 类改成 three_layer_net,改改形状,加上W3和b3,predict函数多添两行,backward需要修改的比较多,稍微细心一点,也就可以类比出来了。three_layer_n
摘要由CSDN通过智能技术生成

昨天捣鼓了一天两层网络(一层隐藏层)的MNIST手写数据识别系统,我用尽各种手法,各种图片处理办法,最终实测正确率被锁定在50%上下。这真让人沮丧。。。

今天脑子灵光一闪,2层网络性能不行,那就来3层吧!虽然没有现成的代码可以抄,但复制粘贴,举一反三,不就行了。于是,动手操作!

首先把 two_layer_net 类改成 three_layer_net,改改形状,加上W3和b3,predict函数多添两行,backward需要修改的比较多,稍微细心一点,也就可以类比出来了。

three_layer_net.py

import sys, os
from my_fn import *

class ThreeLayerNet:

    def __init__(self, input_size, hidden_size1, hidden_size2, output_size,
                    weight_init_std=0.01):
        # 初始化权重
        self.params = {}
        self.params['W1'] = weight_init_std * np.random.randn(input_size, hidden_size1)
        self.params['b1'] = np.zeros(hidden_size1)
        self.params['W2'] = weight_init_std * np.random.randn(hidden_size1, hidden_size2)
        self.params['b2'] = np.zeros(hidden_size2)
        self.params['W3'] = weight_init_std * np.random.randn(hidden_size2, output_size)
        self.params['b3'] = np.zeros(output_size)

    def predict(self, x):
        W1, W2, W3 = self.params['W1'], self.params['W2'], self.params['W3']
        b1, b2, b3 = self.params['b1'], self.params['b2'], self.params['b3']

        a1 = np.dot(x, W1) + b1
        z1 = sigmoid(a1)
        a2 = np.dot(z1, W2) + b2
        z2 = sigmoid(a2)
        a3 = np.dot(z2, W3) + b3
        y = softmax(a3)

        return y

     # x:输入数据, t:监督数据
    def loss(self, x, t):
        y = self.predict(x)

        return cross_entropy_error(y, t)

    def accuracy(self, x, t):
        y = self.predict(x)
        y = np.argmax(y, axis&#
  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值