文章目录
- 深度学习
- 第一章 前言
- 第一部分 应用数学与机器学习基础
- 第二章 线性代数
- 2.1 标量,向量,矩阵和张量
- 2.2 矩阵和向量相乘
- 2.3 单位矩阵和逆矩阵
- 2.4 线性相关和生成子空间
- 2.5 范数
- 2.6 特殊类型的矩阵和向量
- 2.7 特征分解
- 2.8 奇异值分解
- 2.9 Moore-Penrose伪逆
- 2.10 迹运算
- 2.11 行列式
- 2.12 实例:主成分分析
- 第三章 概率与信息论
- 3.1 为什么要使用概率
- 3.2 随机变量
- 3.3 概率分布
- 3.3.1 离散型变量和概率质量函数
- 3.3.2 连续型变量和概率密度函数
- 3.4 边缘概率
- 3.5 条件概率
- 3.6 条件概率的链式法则
- 3.7 独立性和条件独立性
- 3.8 期望,方差,协方差
- 3.9 常用概率分布
- 3.9.1 Bernoulli分布(伯努利分布)
- 3.9.2 Multinoulli分布
- 3.9.3 高斯分布
- 3.9.4 指数分布和Laplace分布
- 3.9.5 Dirac分布和经验分布
- 3.9.6 分布的混合
- 3.10 常用函数的有用性质
- 3.11 贝叶斯规则
- 3.12 连续型变量的技术细节
- 3.13 信息论
- 3.14 结构化概率模型
- 第四章 数值计算
- 4.1 上溢和下溢
- 4.2 病态条件
- 4.3 基于梯度的优化方法
- 4.3.1 梯度之上:Jacobin和Hessian矩阵
- 4.4 约束优化
- 4.5 实例:线性最小二乘
- 第五章 机器学习基础
- 5.1 学习算法
- 5.1.1 任务T
- 5.1.2 性能度量P
- 5.1.3 经验E
- 5.1.4 示例:线性回归
- 5.2 容量,过拟合和欠拟合
- 5.2.1 没有免费午餐定理
- 5.2.2 正则化
- 5.3 超参数和验证集
- 5.3.1 交叉验证
- 5.4 估计,偏差和方差
- 5.4.1 点估计
- 5.4.2 偏差
- 5.4.3 方差和标准差
- 5.4.4 权衡偏差和方差以最小化均方误差
- 5.4.5 一致性
- 5.5 最大似然估计
深度学习
第一章 前言
深度学习(Deep Learning) ∈ 表示学习(Representation Learning) ∈ 机器学习(Machine Learning) ∈ 人工智能(AI)
分类,回归,聚类,降维
神经网络
第一部分 应用数学与机器学习基础
第二章 线性代数
2.1 标量,向量,矩阵和张量
1.标量(scalar)是一个单独的数
2.向量(vector)是一列数,这些数是有序排列的
3.矩阵(matrix)是一个二维数组
4.张量(tensor):一般将超过二维的数组称为张量
- 转置:以对角线为轴的镜像
- 广播:将一个向量隐式的复制到每一行生成矩阵(用于运算)的方式
2.2 矩阵和向量相乘
如果A的形状是m×n,B的形状是n×p,C=AB
,那么C的形状是m×p
具体地,该乘法操作定义为:
注意区分:存在一种两个矩阵对应元素的乘积,叫
Hadamard乘积
,记为A⊙B
性质:
- 分配律
- 结合律
- 矩阵乘积不具有交换律,但是两个向量的点积满足交换律
对于AX=b,可表示
即
2.3 单位矩阵和逆矩阵
单位矩阵:任何向量和单位矩阵相乘,都不会改变
矩阵逆,记作,定义
2.4 线性相关和生成子空间
对于矩阵逆的定义:
可以通过以下步骤求解:
如果能找到一个逆矩阵,那么若。s变量是对变量x的加权线性”混合”。因此,将s定义为变量的线性组合。
- 生成子空间:原始向量的一切线性组合生成的子空间
- 线性无关:一组向量中的任意一个向量都不能表示成其他向量的线性组合,那么这组向量被称为线性无关
如果数组向量中的某一个或多个向量可以由数组内的其余向量通过加法或数乘表达,则该向量组线性相关,反之则线性无关。
- 方阵:行列大小相同的矩阵
2.5 范数
为了衡量一个向量的大小,在机器学习中,我们经常使用范数(norm)的函数衡量。形式上,范数定义如下:
其中
- 范数,是将向量映射到非负值的函数。直观上来说,向量x的范数衡量从原点到点x的距离。更严格的说,范数是满足下列性质的任意函数:
- 当p=2时,范数被称为欧几里得范数。平方范数,也经常用来衡量向量的大小。
- 范数的定义,
- 另一个常在机器学习中出现的范数是范数,也被称为最大范数。这个范数表示向量中具有最大幅值的元素的绝对值:
- Frobenius范数:
两个向量的点积,可以用范数来表示:
其中,表示x和y之间的夹角
2.6 特殊类型的矩阵和向量
对角矩阵:只在主对角线上含有非零元素,其他位置都是零的矩阵。单位矩阵是对角元素都为1的对角矩阵。
- 如果用diag(v)表示一个对角元素由向量v中的元素给定的对角方阵,那么,并且计算对角方阵的逆矩阵也很高效,如果对角方阵的逆矩阵存在,当且仅当对角元素都是非零值,这种情况下有,
- 不是所有的对角矩阵都是方阵,非方阵的对角矩阵没有逆矩阵
对称矩阵是转置和自己相等的矩阵
单位向量是具有单位范数的向量
正交:如果,那么向量x和向量y互相正交,如果两个向量都有非零范数,那么他们之间的夹角为90度。
标准正交:如果这些向量的不仅互相正交,并且范数都为1,那么我们称他们为标准正交
正交矩阵:指行向量和列向量是分别标准正交的方针
补充关于点乘和叉乘:点乘,也叫数量积,结果是一个向量在另一个向量方向上的投影的长度,是一个标量;,点积为0,说明两个向量正交叉乘,也叫向量积,结果是一个和已有两个向量都垂直的向量,向量模长是向量A,B组成平行四边形的面积,即;向量方向垂直于向量A,B组成的平面;
2.7 特征分解
特征分解是使用最广的矩阵分解之一,即我们将矩阵分解成一组特征向量和特征值
- 方阵A的特征向量是指与A相乘后相当于对该向量进行缩放的非零向量v:
,求特征值,其中被称为特征多项式
- 标量λ被称为这个特征向量对应的特征值。如果v是A的特征向量,那么任何缩放后的向量sv(s∈R,s≠0)也是A的特征向量。此外sv和v有相同的特征值。
假设矩阵A有n个线性无关的特征向量
对应着特征值
将特征向量连接成一个矩阵,使得每一列是一个特征向量:
类似地,将特征值连接成一个向量
因此A的特征分解可以记作:
- 特征分解唯一当且仅当所有的特征值都是唯一的
- 矩阵是奇异的当且仅当含有零特征值(奇异:非满秩)
- 正定(所有特征值为正),半正定(所有特征值非负),负定(所有特征值为负),半负定(所有特征值非正)
对于每个实对称矩阵,都可以分解成实特征向量和实特征值
其中Q是A的特征向量组成的正交矩阵,Λ是对角矩阵。特征值对应的特征向量是矩阵Q的第i列,记作
2.8 奇异值分解
奇异值分解:将矩阵分解为奇异向量和奇异值
假设A是一个m×n的矩阵,那么U是一个m×m的矩阵,D是一个m×n的矩阵,V是一个n×n的矩阵,其中U和V是正交矩阵,D是对角矩阵(不一定是方阵)
对角矩阵D对角线上的元素被称为矩阵A的奇异值,矩阵U的列向量被称为左奇异向量(是的特征向量),矩阵V的列向量被称为右奇异向量(是的特征向量)。A的非零奇异值是特征值的平方根,也是特征值的平方根
正交-对角-正交:旋转-拉伸-旋转
例子:
2.9 Moore-Penrose伪逆
对于非方阵,将矩阵A 的伪逆定义为:
实际计算公式
其中,矩阵U,D和V是矩阵A奇异值分解后得到的矩阵,对角矩阵D的伪逆是其非零元素取倒数之后再转置得到的
2.10 迹运算
迹运算返回的是矩阵对角元素的和:
迹运算提供了另一种描述矩阵Frobenius范数的方式
迹运算在转置条件下是不变的
如果多个矩阵相乘交换顺序后仍有定义,那么有
标量的迹运算还是它自己
2.11 行列式
记作det(A),是一个将方阵A映射到实数的函数。行列式等于矩阵特征值的乘积
2.12 实例:主成分分析
主成分分析(PCA,Principle component analysis)是一个简单的机器学习算法,可以通过基础的线性代数知识推导。
假设,在空间中我们有m个点,为了对这些点进行有损压缩,可以采取低维表示(线性降维),对于每个点,会有一个对应的编码向量。如果l比n小,那么便实现了压缩。需要设置一个编码函数,根据输入返回编码,也希望设置一个解码函数,给定编码重构输入,为了简化解码器,使用矩阵乘法将编码映射回,即g©=Dc,其中D∈是定义解码的矩阵
首先,我们需要明确如何根据每一个输入x得到一个最优编码
一种方法是最小化原始输入向量x和重构向量
之间的距离,在PCA中,我们使用L2范数:
arg min f(x) 是指使得函数 f(x) 取得其最小值的所有自变量 x 的集合。
当然也可以用平方L2范数来替代L2范数:
该最小化函数可以简化成:
因为第一项不依赖于c所以我们可以忽略它,得到:
代入g©的定义:
于是,最优编码x只需要一个矩阵-向量乘法操作
PCA重构操作
接下来需要挑选编码矩阵D,所以我们需要最小化所有维数和所有点上的误差矩阵的Frobenius范数:
先考虑l=1的情况,此时D是一个单一向量d
将表示个点的向量堆叠成一个矩阵,记为X∈,其中
原问题可以重新表示为:
暂不考虑约束,可以把Frobenius范数简化成
再考虑约束条件
即,最优的d是X^TX最大特征值对应的特征向量
PCA算法两种实现方法:
(1)基于特征值分解协方差矩阵实现
输入数据集X={x1,x2,x3,…,xn},需要降到k维。
1)去平均值(去中心化),即每一位特征减去各自的平均值
2)计算协方差矩阵
3)用特征值分解方法求协方差矩阵的特征值和特征向量
4)对特征值从大到小排序,选择其中最大的k个,然后将其对应的k个特征向量分别作为行向量组成特征向量矩阵P
5)将数据转换到k个特征向量构建的新空间中,即Y=PX
(2) 基于SVD分解(奇异值分解)协方差矩阵实现PCA算法
第三章 概率与信息论
概率论是用于表示不确定性申明的数学框架
3.1 为什么要使用概率
几乎所有的活动都需要能够再不确定性存在时进行推理
不确定性的三种来源:被建模系统内在的随机性,不完全观测,不完全建模
3.2 随机变量
随机变量时可以随机地取不同值的变量。
3.3 概率分布
概率分布用来描述随机变量或一簇随机变量在每一个可能取到的状态的可能性大小
3.3.1 离散型变量和概率质量函数
- 离散型变量的概率分布可以用概率质量函数(PMF,probability mass function)来描述
- 联合概率分布是多个变量的概率分布
- 如果用P表示概率质量函数,则满足以下条件
- P的定义域必须是随机变量x所有可能状态的集合
- ,不可能发生的事件概率为0,并且不存在比这概率更低的状态。类似的,一定发生的事件概率为1,且不存在比这概率更高的事件。
3.3.2 连续型变量和概率密度函数
对于连续型随机变量,用概率密度函数(PDF,probability density function),如果用p表示概率密度函数,则满足以下条件
- p的定义域必须是x所有可能状态的集合
- .并不要求p(x)≤1
3.4 边缘概率
边缘概率分布,定义在其中一个子集上的概率分布
3.5 条件概率
条件概率,在给定其他事件发生时出现的概率,我们将给定X=x,Y=y发生的条件概率记为P(Y=y|X=x)
计算公式如下
条件概率只在P(X=x)>0时有定义
3.6 条件概率的链式法则
任何多维随机变量的联合概率分布,都可以分解成只有一个变量的条件概率相乘的形式
例如:
P(a,b,c)=P(a|b,c)P(b,c)
P(b,c)=P(b|c)P©
P(a,b,c)=P(a|b,c)P(b|c)P©
3.7 独立性和条件独立性
相互独立:两个随机变量x,y的概率分布可以表示为两个因子的乘积形式,并且一个因子只包含x,另一个只包含y,那么这两个随机变量是相互独立的
条件独立:如果关于x和y的条件概率分布对于z的每一个值都可以写成乘积的形式,那么这两个随机变量x和y在给定随机变量z时是条件独立的
3.8 期望,方差,协方差
(1)期望(expected value)
函数f(x)关于某分布P(x)的期望或者期望值是指,当x由P产生,f作用到x时,f(x)的平均值
离散型随机变量的期望
连续型随机变量的期望
期望是线性的,假设α和β不依赖于x
(2)方差(variance)
方差的平方根被称为标准差
(3)协方差
两个随机变量独立→协方差为0→没有线性关系
但是协方差为0,两个变量不一定独立
协方差矩阵:
协方差矩阵的对角元是方差:
3.9 常用概率分布
3.9.1 Bernoulli分布(伯努利分布)
单个二值随机变量的分布,又名两点分布,0-1分布
- 对于单次随机试验,对于一个随机变量X而言:
- 进行一次伯努利试验,成功(X=1)概率为p(0≤p≤1),失败(X=0)概率为1-p,则称随机变量X服从伯努利分布。伯努利分布是离散型概率分布,其概率质量函数为:
3.9.2 Multinoulli分布
Multinoulli分布,或称范畴分布,是指在具有k个不同状态的单个离散型随机变量上的分布,其中k是一个有限值
Multinoulli分布是多项式分布(Multinomial distribution)的一个特例。多项式分布是中的向量的分布,用于表示当对Multinoulli分布采样n次时k个类中的每一个被访问的次数。即n=1的多项式分布是Multinoulli分布。
Multinoulli分布由向量参数化,其中每一个分量$ p_i $表示第 i 个状态的概率。最后的第k个状态的概率可以通过给出。注意我们必须限制。Multinoulli分布经常用来表示对象分类的分布,所以我们很少假设状态 1 具有数值 1 之类的。因此,我们通常不需要去计算 Multinoulli 分布的随机变量的期望和方差。
Bernoulli 分布和 Multinoulli 分布足够用来描述在它们领域内的任意分布。它们能够描述这些分布,不是因为它们特别强大,而是因为它们的领域很简单。它们可以对那些能够将所有的状态进行枚举的离散型随机变量进行建模。当处理的是连续型随机变量时,会有不可数无限多的状态,所以任何通过少量参数描述的概率分布都必须在分布上加以严格的限制。
3.9.3 高斯分布
高斯分布,也叫正态分布
正态分布的概率密度函数的图象的中心峰的x坐标由μ给出,峰的宽度受σ控制
标准正态分布:μ=0,σ=1
令β为方差的倒数,来控制分布的精度
正态分布可以推广到空间,这种情况下被称为多维正态分布
参数μ仍然表示分布的均值,只不过现在是向量值。参数∑给出了分布的协方差矩阵,但并不是一个很高效的参数化分布的方式,因为要对∑求逆,因此可以使用一个精度矩阵β替换
3.9.4 指数分布和Laplace分布
指数分布,可以用来表示事件的时间间隔的概率,可以由泊松分布推导出来
其概率密度函数
分布函数
Laplace分布,允许我们在任意一点μ处设置概率质量的峰值
3.9.5 Dirac分布和经验分布
概率密度函数
Dirac分布经常作为经验分布的组成部分出现
3.9.6 分布的混合
潜变量:不能直接观测到的随机变量
高斯混合模型,概率密度的万能近似器
先验概率:在观测到x之前计算的
后验概率:在观测到x之后计算的
3.10 常用函数的有用性质
logistic sigmoid函数,在变量取绝对值很大的正值或负值时出现饱和现象
softplus函数,范围(0,∞)
ReLU函数,人工神经网络常用的激活函数
3.11 贝叶斯规则
3.12 连续型变量的技术细节
测度论
零测度
几乎处处
Jacobin矩阵
3.13 信息论
量化信息
- 非常可能发生的事件信息量要比较少,并且极端情况下,确保能够发生的事件没有信息量
- 较不可能发生的事件具有更高的信息量
- 独立事件应具有增量的信息。例如,投掷的硬币两次正面朝上传递的信息量,应该是投掷一次硬币正面朝上信息量的两倍
定义一个事件X=x的自信息为
log为自然对数,底为e,I(x)单位是奈特,一奈特是以1/e概率观测到一个事件时获得的信息量
若以2为底数,单位是比特或者香农
香农熵,一个分布的香农熵时指遵循这个分布的事件所产生的期望信息总量
当x连续,香农熵被称为微分熵
KL散度,用域衡量两个分布的差异
交叉熵
3.14 结构化概率模型
结构化概率模型,又叫图模型
有向
无向
第四章 数值计算
4.1 上溢和下溢
通过有限数量的位表示无限多的实数,总会引入舍入误差,包括了上溢和下溢
对上溢和下溢进行数值稳定的一个例子是softmax函数
4.2 病态条件
条件数表征函数相对于输入的微小变化而变化的快慢程度
考虑函数,当A∈具有特征分解时,其条件数为
4.3 基于梯度的优化方法
(1)优化
大多数深度学习算法涉及某种形式的优化,包括改变x以最小化或最大化某个函数f(x)。通常以最小化指代大多数最优化问题,最大化可以经由-f(x)来实现
目标函数(准则):要最小化或最大化的函数
代价函数(损失函数/误差函数):对其进行最小化时也称之为代价函数
梯度下降:将x往导数反方向移动来减小f(x)
的点称为临界点,驻点
有些临界点既不是最大点也不是最小点,被称为鞍点
(2)偏导,梯度,方向导数
对于多维输入函数,提出了偏导数。偏导数为函数在每个位置处沿着自变量坐标轴方向上的导数(切线斜率)
梯度,写作,当前位置的梯度方向,为函数在该位置处方向导数最大的方向,也是函数值上升最快的方向,反方向为下降最快的方向。当前位置的梯度长度(模),为最大方向导数的值
方向导数,如果是方向不是沿着坐标轴方向,而是任意方向,则为方向导数
4.3.1 梯度之上:Jacobin和Hessian矩阵
1.Jacobin
在向量分析中, 雅可比矩阵是一阶偏导数以一定方式排列成的矩阵, 其行列式称为雅可比行列式. 还有, 在代数几何中, 代数曲线的雅可比量表示雅可比簇:伴随该曲线的一个代数群, 曲线可以嵌入其中.
雅可比矩阵的重要性在于它体现了一个可微方程与给出点的最优线性逼近. 因此, 雅可比矩阵类似于多元函数的导数.
2.Hessian
在数学中, 海森矩阵(Hessian matrix或Hessian)是一个自变量为向量的实值函数的二阶偏导数组成的方块矩阵, 此函数如下:
,如果f的所有二阶导数都存在,那么
Hessian矩阵等价于梯度的Jacobian矩阵
海森矩阵在牛顿法中的应用,牛顿法时一个基于二阶泰勒展开来近似x附近的f(x)的方法
例如:在x0处展开
临界点为
4.4 约束优化
在x的某些集合S中找f(x)的最大值或最小值,称为约束优化
Karush-Kuhn-Tucker(KKT)方法
广义Lagrangian(广义Lagrange函数),通过m个函数g和n个函数h描述S,那么S可以表示为,其中涉及g的等式称为等式约束,涉及h的不等式称为不等式约束,定义如下:
4.5 实例:线性最小二乘
假设我们希望最小化下式中的x值:
首先,计算梯度
假设希望最小化同样的函数,但受的约束
现在,我们解决以下问题
我们可以用Moore-Penrose伪逆。
关于x对Lagrangian微分,得到
解为:
观察
当x的范数超过1时,该导数是正的,所以为了跟随导数上坡并相对λ增加Lagrangian,我们需要增加λ。因为的惩罚系数增加,秋节关于x的线性方程现在将得到具有较小范数的解
第五章 机器学习基础
5.1 学习算法
能够从数据中学习的算法
5.1.1 任务T
通常机器学习任务定义为机器学习系统应该如何处理样本。
样本是我们从希望机器学习系统处理的对象或事件中收集到的已经量化的特征的集合
常见任务:分类,输入缺失分类,回归,转录,机器翻译,结构化输出,异常检测,合成和采样,缺失值填补,去噪,密度估计或概率质量函数估计
5.1.2 性能度量P
为了评估机器学习算法的能力,提出准确率,错误率
使用测试集数据来评估系统性能,将其与训练机器学习系统的训练集数据分开
5.1.3 经验E
机器学习算法分为无监督算法和监督算法
5.1.4 示例:线性回归
5.2 容量,过拟合和欠拟合
5.2.1 没有免费午餐定理
5.2.2 正则化
5.3 超参数和验证集
5.3.1 交叉验证
5.4 估计,偏差和方差
5.4.1 点估计
5.4.2 偏差
5.4.3 方差和标准差
5.4.4 权衡偏差和方差以最小化均方误差
5.4.5 一致性
5.5 最大似然估计