优达学城深度学习之三(下)——卷积神经网络

简介: 优达学城深度学习之三(下)——卷积神经网络

one-hot编码


计算机在表示多结果的分类时,使用One-Hot编码是比较常见的处理方式。即每个对象都有对应的列。

84097ae8d3e4c7d697af25efb44a386b.jpg

最大似然率


下面是两幅图像,比较两幅图像,试通过概率的方法来讨论一下为什么右边的模型会更好。

6f013a5e4778eada5d0b0de53009879f.jpg

假设第一幅图像的每个点是对应颜色的概率为下图:

952efcc387155f320ab2e109c7271dfe.jpg

如果假设点的颜色是相互独立的,则整个图表的概率为相互乘积:0.6*0.1*0.7*0.2=0.0084,低于1%

第二个图概率如下图所示:

5ec197d09582edbf0e1d8d2286ad6576.jpg

则整个图表的概率为相互乘积:0.6*0.8*0.9*0.7=0.3024约等于30%。由此可知,右边的模型更靠谱。

b73ae79fe97491c3d3dbad4b24bfa2a2.jpg

如果我们可以通过一种方式最大化这个概率,则这种方法叫最大似然法。

最大化概率


交叉熵1:损失函数


e04d388ee891de3c29b19857663a0253.jpg

对他们每个点的概率进行对数运算,然把他们的相反数进行求和,我们称之为交叉熵。好的模型交叉熵比较低,坏的模型交叉熵会比较高。如下图的两个模型。

95a09e72cf75cfb6291557f5652f142e.jpg

我们遇到了某种规律,概率和误差函数之间肯定有一定的联系,这种联系叫做交叉熵。这个概念在很多领域都非常流行,包括机器学习领域。下图表示三个门后面有礼物的概率,分别为0.8、0.7、0.1,当后面有礼物时,yi=1,所以交叉熵如下图所示:

2d5cb8a9ddbd3330768bdf64886f1328.jpg

代码实现:

importnumpyasnp# Write a function that takes as input two lists Y, P,# and returns the float corresponding to their cross-entropy.defcross_entropy(Y, P):
Y=np.float_(Y)
P=np.float_(P)
return-np.sum(Y*np.log(P) + (1-Y) *np.log(1-P))

由单个类推出多种类别,假设每个门后面有三种不同的生物,概率不一样,则每种动物的概率和交叉熵如下图所示:

fbc1954913512187677777590563c092.jpg

d03fc7b6da1ec655c3c2ca4f7284e2ad.jpg

532f1259c6cd7798bc9cd79ffa1dae5e.jpg

则 Cross-Entropy = ∑ ∑ [ yij ln(Pij) ] ( i = 1, 2, 3 ... n ) ( j = 1, 2, 3 ...m ) = ∑ [ y1j ln(P1j) + y2j ln(P2j) + ..... yij ln(Pij) ] 且 ( P1j + P2j + P3j + ......Pij = 1 )

logistic回归


现在,我们终于要讲解机器学习中最热门和最有用的算法之一,它也是所有机器学习的基石——对数几率回归算法。基本上是这样的:

  • 获得数据
  • 选择一个随机模型
  • 计算误差
  • 最小化误差,获得更好模型
  • 完成

计算随机误差


4ceecd70f703f82f2f47945530b4de7d.jpg

备注:图片中的 log 应全为 ln。

d249e370741d8489f2f2cd10eaf053ef.jpg

最小化误差函数:梯度下降法


696c7494eacda87103e8f2d57afde72c.jpg

误差函数为△E。

在上几个视频中,我们了解到为了最小化误差函数,我们需要获得一些导数。我们开始计算误差函数的导数吧。首先要注意的是 s 型函数具有很完美的导数。即

2f175708656e0bbe15508ee646aeab1b.png

度运算如下图:

b736271f34f8dc7f113bf2fac6c8b970.jpg

c2e35479a9ebcf6facb5c7e73378373a.jpg

a91836cc93960fbe2e25082d451892de.jpg


相关文章
|
1月前
|
机器学习/深度学习 数据采集 人工智能
m基于深度学习网络的手势识别系统matlab仿真,包含GUI界面
m基于深度学习网络的手势识别系统matlab仿真,包含GUI界面
38 0
|
1月前
|
机器学习/深度学习 算法 计算机视觉
基于yolov2深度学习网络的火焰烟雾检测系统matlab仿真
基于yolov2深度学习网络的火焰烟雾检测系统matlab仿真
|
1月前
|
机器学习/深度学习 算法 计算机视觉
基于yolov2深度学习网络的视频手部检测算法matlab仿真
基于yolov2深度学习网络的视频手部检测算法matlab仿真
|
1月前
|
机器学习/深度学习 人工智能 TensorFlow
人工智能与图像识别:基于深度学习的卷积神经网络
人工智能与图像识别:基于深度学习的卷积神经网络
31 0
|
6天前
|
机器学习/深度学习 算法 PyTorch
【动手学深度学习】深入浅出深度学习之线性神经网络
【动手学深度学习】深入浅出深度学习之线性神经网络
45 9
|
1月前
|
机器学习/深度学习 并行计算 算法
m基于深度学习网络的瓜果种类识别系统matlab仿真,带GUI界面
m基于深度学习网络的瓜果种类识别系统matlab仿真,带GUI界面
30 0
|
7天前
|
机器学习/深度学习 自然语言处理 算法
|
1月前
|
机器学习/深度学习 运维 算法
|
1月前
|
机器学习/深度学习 数据采集 算法
m基于深度学习网络的花朵种类识别系统matlab仿真,包含GUI界面
m基于深度学习网络的花朵种类识别系统matlab仿真,包含GUI界面
30 6
|
1月前
|
机器学习/深度学习 PyTorch TensorFlow
python实现深度学习模型(如:卷积神经网络)。
【2月更文挑战第14天】【2月更文挑战第38篇】实现深度学习模型(如:卷积神经网络)。

热门文章

最新文章