打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
MNIST入门:贝叶斯方法

介绍

这篇教程适用于有兴趣将贝叶斯方法应用于机器学习的读者。我们的目的是教你如何训练你的第一个贝叶斯神经网络,并在TensorFlow上提供了入门示例。

为什么我们需要贝叶斯神经网络呢?传统的神经网络被训练用于产生一些相关变量的点估计。例如,我们可以使用历史数据来训练一个神经网络,预测未来某个时间点的股票价格。单一点估计的局限在于,它不能为我们提供任何关于此次预测中不确定性的度量。如果网络以95%的置信度预测股票将上涨,那么我们也许很容易就决定购买。但是,如果网络给出的置信度只有50%呢?在点估计情况下,我们将无法做出决定。相比之下,贝叶斯神经网络可以通过使用贝叶斯规则来估计预测中的不确定性。

图中显示了在置信度为95%时未来40天内股票价格的点估计(红色圆圈)。由于没有评估不确定性,我们无法判断在交易时将承担多少风险。

关于教程

在本教程中,我们将了解:

想要了解更多关于贝叶斯神经网络的背景知识,Thomas Wiecki关于Bayesian Deep Learning的博客以及Yarin Gal的What my deep model doesn't know... 博客都是非常好的入门参考。

本教程需要 TensorFlow1.1.0版本以及Edward1.3.1版本。

贝叶斯神经网络

要了解贝叶斯神经网络,我们将从贝叶斯统计的简要概述开始。 贝叶斯统计的核心是关于如何根据新的信息来改变人的信念。

贝叶斯法则

假设有两个事件a,b,想要计算在事件b发生的条件下事件a的条件概率,记作P(a|b)。贝叶斯法则定义如下:

其中,P(b|a)是事件a发生的条件下事件b的条件概率。P(a)是事件a的先验概率,P(b)是事件b的先验概率。注意,对于变量a的先验概率是概率分布,并且我们得到的是在给定b的情况下,a的可能值的完整分布而不是单个点估计。

神经网络

那么,贝叶斯法则是如何应用到神经网络的呢?在本节我们将解释传统的神经网络是如何在某个特定假设下使用贝叶斯法则来训练。假定我们有一组数据集D={(x i,y i)}N i=1,由数对输入x i和相应的输出y i组成,其中i=1,2,...,N。我们可以用神经网络来对似然函数P(y|x;ω)进行建模,其中ω是模型的一组可调参数,即网络的权重和偏差。例如对于分类问题,我们可以用标准的前馈网络,yi=f(x i;ω)后面是softmax层来归一化输出,以便它代表一个有效的质量函数P(y i|x i;ω)。

传统的神经网络训练方法通常通过优化权重和偏差来产生点估计,以最小化代价函数,例如分类问题情况下的交叉熵代价函数。从概率的观点来看,这相当于使观测数据P(D|ω)的对数似然最大化,以发现最大似然估计(MLE)Blundell et. al. 2015。

ωMLE=argmaxωlog?P(D|ω)=argmaxω∑i=1 N logP(y i∣x i,ω).

这种优化通常使用某种形式的梯度下降来执行(例如反向传播),之后当权重和偏差确定后,我们对于给定的输入x*预测一个新的输出y*=f(x*;ω)。

以这种方式训练神经网络容易过拟合,因此我们通常引入正则项例如L2。可以看出,对权重进行L2方法正则化等同于对权重进行正态高斯先验P(ω)~(0,I),并且最大化后验估计P(ω|D)。这就给了我们参数的最大后验估计(MAP)(详见MacKay著作的第41章):

ωMAP=argmaxωlogP(ω|D)=argmaxωlogP(D|ω)+logP(ω).

从这一点可以看出,传统的神经网络训练和正则化方法可以使用贝叶斯规则进行推理。贝叶斯神经网络进一步尝试近似整个后验分布P(ω|D)通过使用蒙特卡洛或变分推断技术。教程的余下部分将展示如何使用TensorFlow和Edward来实现这一过程。

数据导入

让我们用TensorFlow方法来导入MNIST images

In[1]:

In[2]:

Extracting MNIST_data/train-images-idx3-ubyte.gz

Extracting MNIST_data/train-labels-idx1-ubyte.gz

Extracting MNIST_data/t10k-images-idx3-ubyte.gz

Extracting MNIST_data/t10k-labels-idx1-ubyte.gz

建模

回想一下,我们的任务是将手写的MNIST数字分类到{0,1,2,...,9}之一,并对分类的不确定性进行度量。我们的机器学习模型是一个简单的soft-max回归,为此我们首先需要选择似然函数来量化给定的一组参数(我们给定的权重和偏差)的观测数据的概率。我们将使用 Categorical似然函数(见第2章, Kevin Murphy的Machine Learning: a Probabilistic Perspective来了解Categorical分布(又称Multinoulli分布)的详细内容)。

接下来我们在TensorFlow中设置一些占位符变量。这遵循与标准神经网络相同的过程,除了我们使用Edward库对权重和偏差引入先验。在下方代码中,我们引入了高斯先验。

In[3]:

In[4]:

变分推断

到现在为止我们已经定义了似然函数P(y|x,;ω)和先验P(ω),接下来我们将使用贝叶斯法则来计算后验P(ω|y,x)。然而我们面临着一个问题,即输出P(y)的概率对于大规模实例而言难于计算,因此我们并不试图直接计算后验。

为了解决这个问题,我们将用变分推断(VI)来代替。在变分推断中,我们选择一组关于参数ω的参数化分布Q(ω;λ)来近似真实的后验,然后优化参数λ,尽可能最佳地匹配真实的后验分布。这种方法的核心思想是将真正的后验P(ω|y,x)和近似分布Q(ω;λ)之间的Kullback-Leibler距离最小化,这可以被当作两个概率分布之间的不相似性的度量。

变分推断(VI)的原理远不是此博客中描述的内容所能涵盖的,更多相关信息可以通过Edward的文档或者Blei等人的论文《Variational Inference: A Review for Statisticians》了解。 MacKay的书也是一个不错的参考。

接下来我们将使用Edward库来设置权重和偏差的近似分布Qω(ω)和Q b(ω):

In[5]:

In[6]:

In[7]:

现在我们准备好执行变分推断了。我们加载了一个TensorFlow的session并开始迭代。这可能需要几分钟的时间...

In[8]:

In[9]:

5000/5000 100%

Elapsed: 5s | Loss: 27902.377

模型评估

现在我们已经准备好在测试数据上运行模型所需要的一切。贝叶斯模型评估的主要区别在于权重和偏差不存在单一值来评估模型。相应的,我们在模型中使用权重和偏差的分布,以便在最终预测中反映这些参数的不确定性。因此,我们不是单一的预测,而是得到一组预测及其准确率。

我们从后验分布中抽取100个样本,得到每个样本的执行结果。采样是一个较慢的过程,需要一段时间!

In[10]:

In[11]:

In[12]:

Out[12]:

我们获得了一组采样的准确率。注意权重和偏差的后验分布反映了从整个MNIST测试数据获得的信息。因此上述直方图表示来自权重和偏差的统计可能范围的准确率。

我们可以执行一个模型平均,并尝试获得一个相当于古典机器学习的模型。我们通过叠加从后验分布中获取的100个样本的预测,然后计算预测的平均值来做到这一点。

In[13]:

预测测试数据的准确率 = 92.44

我们还要看一下后验分布。不幸的是,即使是这样的小问题,维度的数量也是相当大的,因此对其进行可视化是非常棘手的!我们选择前5个维度,并产生一个相关性的三角图。

In[14]:

Out[14]:

我们从测试数据中加载一个图像,从权重和偏差的后验分布中得到的每个样本的分类。

In[15]:

truth = 7

Out[15]:

In[16]:

In[17]:

Out[17]:

正如所看到的,我们的模型对这里的预测非常有信心。对于来自后验的所有样本,我们预测到真实值(由于随机数的产生,这个数值在不同的机器上略微不同)。

模型是如何处理陌生数据的?

如果我们给定与训练数据完全不同的数据,模型将会得到什么样的结果呢?这是一个关键的测试,因为我们不仅需要知道预测结果,还要知道预测结果的置信度。在许多人工智能的应用中,这个信息非常有价值。

第一次测试我们使用字母的非MINST数据,并观察模型对这些数据的反应如何。我们希望的是,如果输入一张陌生的图像,比如字母'D',当模型之前用数字{0,1,...,9}来训练时,那么它应该输出一个分类但不确定是什么。

我们可以从此处下载非MINST图像。如何转换成MNIST格式在此处获得。在此例中,我们使用的是转换后的数据。我们假定所有需要的文件都在notMNIST文件夹下,并且使用TensorFlow方法。

git clone git@github.com:davidflanagan/notMNIST-to-MNIST.git

mkdir notMNIST_data

cp notMNIST-to-MNIST/*.gz notMNIST_data

我们假定notMNIST_data和这篇笔记在同一目录下。因为图像都是MNIST格式,我们可以像之前那样利用TensorFlow来加载图像。

注意如果我们没有在上面执行bash命令,TensorFlow会将MNIST数据下载到notMNIST_data目录下,我们获得的第一张图像将是数字7而非来自notMNIST数据的字母D。请确保执行前notMNIST_data目录下是正确的数据。

In[18]:

Extracting ./notMNIST_data/train-images-idx3-ubyte.gz

Extracting ./notMNIST_data/train-labels-idx1-ubyte.gz

Extracting ./notMNIST_data/t10k-images-idx3-ubyte.gz

Extracting ./notMNIST_data/t10k-labels-idx1-ubyte.gz

In[19]:

现在,我们从notMNIST数据集中加载一张图像并用模型对其进行分类。如往常一样,我们使用后验的样本去执行分类,获得模型预测的置信水平。

In[20]:

truth = 3

Out[20]:

In[21]:

In[22]:

Out[22]:

直方图显示对于新分类而言,模型不再拥有之前的置信水平。这就是对比传统的机器学习方法,贝叶斯方法可以添加许多值的地方。这里我们展示的是权重的后验分布可以被用于检验网络对物体进行分类的置信度。

总结

我们学习了使用TensorFlow和Edward来创建一个简单的贝叶斯统计模型对MNIST图像进行分类。了解统计推断的不确定性对于各种应用来说是非常重要的,我们已经探索出一些对此问题进行可视化的基本方法。

结束前我们对环境做水印。你需要[watermark][iPython扩展]来执行下面的操作。

In[23]:

CPython 3.6.1

IPython 6.0.0

numpy 1.12.1

pandas 0.20.1

edward 1.3.1

tensorflow 1.1.0

seaborn 0.7.1

matplotlib 2.0.2

compiler : GCC 4.4.7 20120313 (Red Hat 4.4.7-1)

system : Linux

release : 4.8.0-53-generic

machine : x86_64

processor : x86_64

CPU cores : 8

interpreter: 64bit

英文原文:https://alpha-i.co/blog/MNIST-for-ML-beginners-The-Bayesian-Way.html

译者:静水青燃

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
Dataset之MNIST:MNIST(手写数字图片识别+ubyte.gz文件)数据集简介、下载、使用方法(包括数据增强)之详细攻略
使用tensorflow创建一个简单的神经网络
TensorFlow 如何避免重复下载数据
什么是深度学习?
Alex Graves新作贝叶斯流网络,解决离散数据生成问题,满论文都是数学公式
《炼数成金》.第七课 递归神经网络LSTM的讲解,以及LSTM网络的使用学习笔记
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服