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神经网络——交叉熵作代价函数的更多相关文章

  1. 神经网络(NN)+反向传播算法(Backpropagation/BP)+交叉熵+softmax原理分析

    神经网络如何利用反向传播算法进行参数更新,加入交叉熵和softmax又会如何变化? 其中的数学原理分析:请点击这里.

  2. 交叉熵代价函数——当我们用sigmoid函数作为神经元的激活函数时,最好使用交叉熵代价函数来替代方差代价函数,以避免训练过程太慢

    交叉熵代价函数 machine learning算法中用得很多的交叉熵代价函数. 1.从方差代价函数说起 代价函数经常用方差代价函数(即采用均方误差MSE),比如对于一个神经元(单输入单输出,sigm ...

  3. 最大似然估计 (Maximum Likelihood Estimation), 交叉熵 (Cross Entropy) 与深度神经网络

    最近在看深度学习的"花书" (也就是Ian Goodfellow那本了),第五章机器学习基础部分的解释很精华,对比PRML少了很多复杂的推理,比较适合闲暇的时候翻开看看.今天准备写 ...

  4. 理解交叉熵(cross_entropy)作为损失函数在神经网络中的作用

    交叉熵的作用 通过神经网络解决多分类问题时,最常用的一种方式就是在最后一层设置n个输出节点,无论在浅层神经网络还是在CNN中都是如此,比如,在AlexNet中最后的输出层有1000个节点: 而即便是R ...

  5. 深度学习原理与框架-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 ...

  6. BP神经网络算法推导及代码实现笔记zz

    一. 前言: 作为AI入门小白,参考了一些文章,想记点笔记加深印象,发出来是给有需求的童鞋学习共勉,大神轻拍! [毒鸡汤]:算法这东西,读完之后的状态多半是 --> “我是谁,我在哪?” 没事的 ...

  7. 基于BP神经网络的字符识别研究

    基于BP神经网络的字符识别研究 原文作者:Andrew Kirillov. http://www.codeproject.com/KB/cs/neural_network_ocr.aspx 摘要:本文 ...

  8. Python3 BP神经网络

    转自麦子学院 """ network.py ~~~~~~~~~~ A module to implement the stochastic gradient descen ...

  9. NO.2:自学tensorflow之路------BP神经网络编程

    引言 在上一篇博客中,介绍了各种Python的第三方库的安装,本周将要使用Tensorflow完成第一个神经网络,BP神经网络的编写.由于之前已经介绍过了BP神经网络的内部结构,本文将直接介绍Tens ...

随机推荐

  1. Java基础毕向东day05 对象与对象的区别,匿名内部类,函数的执行流程。

    1.Car c = new Car(); Car c2 = new Car(); 1> c 和 c2之间的区别? public static void main(String[] args) { ...

  2. 为什么SQL语句加 1=1

    是为了链接下面的查询条件条件,也或者是替换没有查询条件的语句.比如:要把检索条件作为一个参数传递给SQL,那么,当这个检索语句不存在的话就可以给它赋值为1=1.这样就避免了SQL出错,也就可以把加条件 ...

  3. php大力力 [001节]2015-08-21.php在百度文库的几个基础教程新手上路日记 大力力php 大力同学 2015-08-21 15:28

    php大力力 [001节]2015-08-21.php在百度文库的几个基础教程新手上路日记 大力力php 大力同学 2015-08-21 15:28 话说,嗯嗯,就是我自己说,做事认真要用表格,学习技 ...

  4. 计算几何----判断空间点是否在一个四面体(tetrahedron)内部

    DESCRIPTION: 判断空间点 P(x, y, z)是否在一个四面体的内部? Let the tetrahedron have vertices V1 = (x1, y1, z1) V2 = ( ...

  5. IOS 作业项目 TableView两个section中cell置顶功能实现

    点击cell会置顶,其他的下移

  6. 步步入佳境---UI入门(4) --简单练习

    一,创建SingleViewApplication 1,UILabel的简单使用 UILabel *label=[[UILabel alloc]initWithFrame:CGRectMake(0, ...

  7. CSS基础:text-overflow:ellipsis溢出文本

    <!DOCTYPE html><html> <head> <title> new document </title> <meta na ...

  8. 【OpenGL】法线变换详解(Normal Transform)[转]

    http://blog.csdn.net/xiajun07061225/article/details/7762711 在图形学中,同样的一个模型视图变换矩阵可以用来变换点.线.多边形以及其它几何体, ...

  9. 第三个sprint第一天

    一.例会人员:李泳江,邵家文,周伟雄,谢洪跃 日期:6月16号   例会内容: 1.更新核心功能 例会地点:宿舍 二.任务展示 编号 名称 时间 已用时间 是否完成 1 画出算法流程图 4小时 4小时 ...

  10. 《JS高程》事件类型学习笔记

    事件类型: UI事件&焦点事件: 鼠标滚轮事件: 键盘与文本事件: 复合事件&变动事件: HTML5事件: 设备事件&触摸与手势事件: