BP神经网络——交叉熵作代价函数
Sigmoid函数
当神经元的输出接近 1时,曲线变得相当平,即σ′(z)的值会很小,进而也就使∂C/∂w和∂C/∂b会非常小。造成学习缓慢,下面有一个二次代价函数的cost变化图,epoch从15到50变化很小。


引入交叉熵代价函数
针对上述问题,希望对输出层选择一个不包含sigmoid的权值更新,使得

由链式法则,得到

由σ′(z) = σ(z)(1− σ(z))以及σ(z)=a,可以将上式转换成


对方程进行关于a的积分,可得

对样本进行平均之后就是下面的交叉熵代价函数

对比之前的输出层delta,相当于去掉了前面的

相应的代码仅改动了一行(58->59),新的cost变化图如下。
在训练和测试数据各5000个时,识别正确数从4347稍提高到4476。

# coding:utf8
import cPickle
import numpy as np
import matplotlib.pyplot as plt class Network(object):
def __init__(self, sizes):
self.num_layers = len(sizes)
self.sizes = sizes
self.biases = [np.random.randn(y, 1) for y in sizes[1:]] # L(n-1)->L(n)
self.weights = [np.random.randn(y, x)
for x, y in zip(sizes[:-1], sizes[1:])] def feedforward(self, a):
for b_, w_ in zip(self.biases, self.weights):
a = self.sigmoid(np.dot(w_, a)+b_)
return a def SGD(self, training_data, test_data,epochs, mini_batch_size, eta):
n_test = len(test_data)
n = len(training_data)
plt.xlabel('epoch')
plt.title('cost')
cy=[]
cx=range(epochs)
for j in cx:
self.cost = 0.0
np.random.shuffle(training_data) # shuffle
for k in xrange(0, n, mini_batch_size):
mini_batch = training_data[k:k+mini_batch_size]
self.update_mini_batch(mini_batch, eta)
cy.append(self.cost/n)
print "Epoch {0}: {1} / {2}".format(
j, self.evaluate(test_data), n_test)
plt.plot(cx,cy)
plt.scatter(cx,cy)
plt.show() def update_mini_batch(self, mini_batch, eta):
for x, y in mini_batch:
delta_b, delta_w,cost = self.backprop(x, y)
self.weights -= eta/len(mini_batch)*delta_w
self.biases -= eta/len(mini_batch)*delta_b
self.cost += cost def backprop(self, x, y):
b=np.zeros_like(self.biases)
w=np.zeros_like(self.weights)
a_ = x
a = [x]
for b_, w_ in zip(self.biases, self.weights):
a_ = self.sigmoid(np.dot(w_, a_)+b_)
a.append(a_)
for l in xrange(1, self.num_layers):
if l==1:
# delta= self.sigmoid_prime(a[-1])*(a[-1]-y) # O(k)=a[-1], t(k)=y
delta= a[-1]-y # cross-entropy
else:
sp = self.sigmoid_prime(a[-l]) # O(j)=a[-l]
delta = np.dot(self.weights[-l+1].T, delta) * sp
b[-l] = delta
w[-l] = np.dot(delta, a[-l-1].T)
cost=0.5*np.sum((b[-1])**2)
return (b, w,cost) def evaluate(self, test_data):
test_results = [(np.argmax(self.feedforward(x)), y)
for (x, y) in test_data]
return sum(int(x == y) for (x, y) in test_results) def sigmoid(self,z):
return 1.0/(1.0+np.exp(-z)) def sigmoid_prime(self,z):
return z*(1-z) if __name__ == '__main__': def get_label(i):
c=np.zeros((10,1))
c[i]=1
return c def get_data(data):
return [np.reshape(x, (784,1)) for x in data[0]] f = open('mnist.pkl', 'rb')
training_data, validation_data, test_data = cPickle.load(f)
training_inputs = get_data(training_data)
training_label=[get_label(y_) for y_ in training_data[1]]
data = zip(training_inputs,training_label)
test_inputs = training_inputs = get_data(test_data)
test = zip(test_inputs,test_data[1])
net = Network([784, 30, 10])
net.SGD(data[:5000],test[:5000],50,10, 3.0,) # 4476/5000 (4347/5000)
BP神经网络——交叉熵作代价函数的更多相关文章
- 神经网络(NN)+反向传播算法(Backpropagation/BP)+交叉熵+softmax原理分析
神经网络如何利用反向传播算法进行参数更新,加入交叉熵和softmax又会如何变化? 其中的数学原理分析:请点击这里.
- 交叉熵代价函数——当我们用sigmoid函数作为神经元的激活函数时,最好使用交叉熵代价函数来替代方差代价函数,以避免训练过程太慢
交叉熵代价函数 machine learning算法中用得很多的交叉熵代价函数. 1.从方差代价函数说起 代价函数经常用方差代价函数(即采用均方误差MSE),比如对于一个神经元(单输入单输出,sigm ...
- 最大似然估计 (Maximum Likelihood Estimation), 交叉熵 (Cross Entropy) 与深度神经网络
最近在看深度学习的"花书" (也就是Ian Goodfellow那本了),第五章机器学习基础部分的解释很精华,对比PRML少了很多复杂的推理,比较适合闲暇的时候翻开看看.今天准备写 ...
- 理解交叉熵(cross_entropy)作为损失函数在神经网络中的作用
交叉熵的作用 通过神经网络解决多分类问题时,最常用的一种方式就是在最后一层设置n个输出节点,无论在浅层神经网络还是在CNN中都是如此,比如,在AlexNet中最后的输出层有1000个节点: 而即便是R ...
- 深度学习原理与框架-Tensorflow卷积神经网络-卷积神经网络mnist分类 1.tf.nn.conv2d(卷积操作) 2.tf.nn.max_pool(最大池化操作) 3.tf.nn.dropout(执行dropout操作) 4.tf.nn.softmax_cross_entropy_with_logits(交叉熵损失) 5.tf.truncated_normal(两个标准差内的正态分布)
1. tf.nn.conv2d(x, w, strides=[1, 1, 1, 1], padding='SAME') # 对数据进行卷积操作 参数说明:x表示输入数据,w表示卷积核, stride ...
- BP神经网络算法推导及代码实现笔记zz
一. 前言: 作为AI入门小白,参考了一些文章,想记点笔记加深印象,发出来是给有需求的童鞋学习共勉,大神轻拍! [毒鸡汤]:算法这东西,读完之后的状态多半是 --> “我是谁,我在哪?” 没事的 ...
- 基于BP神经网络的字符识别研究
基于BP神经网络的字符识别研究 原文作者:Andrew Kirillov. http://www.codeproject.com/KB/cs/neural_network_ocr.aspx 摘要:本文 ...
- Python3 BP神经网络
转自麦子学院 """ network.py ~~~~~~~~~~ A module to implement the stochastic gradient descen ...
- NO.2:自学tensorflow之路------BP神经网络编程
引言 在上一篇博客中,介绍了各种Python的第三方库的安装,本周将要使用Tensorflow完成第一个神经网络,BP神经网络的编写.由于之前已经介绍过了BP神经网络的内部结构,本文将直接介绍Tens ...
随机推荐
- C# 使用命令行编译单个CS文件
编译单个CS文件. 1.编译 File.cs 以产生 File.exe: csc File.cs 2.编译 File.cs 以产生 File.dll: ...
- LIST 和 MAP
Collection和Map LIST 集合 arraylist arraylist源代码: 1.ArrayList 底层采用数组实现,当使用不带参数的构造方法生成 ArrayList 对象时,实际上 ...
- PHP CI分页类带多个参数
通过修改system中的pagination.php,给每个<a>都增加了class="pagination". view页面 <div class=" ...
- 让所有浏览器包括IE6即支持最大宽度又支持最小宽度。
让所有浏览器包括IE6即支持最大宽度又支持最小宽度. _height _width:针对ie6 css hack .yangshi{max-width:620px;min-width:1px;_wi ...
- @Html.DropDownListFor 绑定列表项
MVC中为 DropDownListFor 绑定列表项, 一种方案从后台加载列表内容,通过ViewData传递到前台页面. View: <div class="editor-label ...
- 【题解】【数组】【Leetcode】Merge Sorted Array
Given two sorted integer arrays A and B, merge B into A as one sorted array. Note: You may assume th ...
- ARM处理器模式
ARM处理器模式 ARM处理器共有7种运行模式: l 用户模式(User,usr):正常程序执行的模式 l 快速中断模式(FIQ,fiq):用于高速数据传输和通道处理 l 外部中断模式(IRQ, ...
- 如何创建 C# 控制台应用程序
[转] 如何:创建 C# 控制台应用程序 本主题旨在生成最简单形式的 C# 程序(控制台应用程序)熟悉 Visual Studio 2008 开发环境.由于控制台应用程序是在命令行执行其所有的输入和输 ...
- 代码静态分析工具--PMD,Findbugs,CheckStyle
最近学习Mybatis的官方文档,看到了[项目文档]一节有很多内容没有见过,做个笔记,理解一下. PMD 扫描Java源代码,查找潜在的问题,如: 可能的bugs,如空的try/catch/final ...
- sql server 内置ETL工具学习(一) BCP篇
sql server 内置ETL工具学习 常用的导入方式:bcp, BULK INSERT,OPENROWSET和 SSIS. BCP BCP全称BULK COPY PROGRAM 有以下特点: 命令 ...