摘要
机器学习所使用的交叉熵损失函数与信息论里的交叉熵的推导与思考
正文
信息论中的交叉熵定义
在 $ p,q $ 是离散分布时, 上式等价为
其中, $x_i$ 是 $p,q$ 分布共同样本空间的同一个样本点,样本空间的大小为 $K$
机器学习中的交叉熵定义
机器学习进行优化时, 会把所有样本的交叉熵值求平均,假设有 $N$ 个样本
而信息论中的交叉熵仅仅是针对一个样本
因为交叉熵常用于解决分类问题,而分类问题的概率本质是计算类别变量的广义的伯努利分布,所以机器学习采用的是交叉熵的离散形式
其中,$t_i$ 是期望的类别标签,$s_i$ 是模型对第 $i$ 个类别计算得到的 $score$ ,通常在计算损失之前,会用激活函数对 $score$ 加以转换,用 $f(s_i)$ 替代上式的 $s_i$
得到机器学习的交叉熵损失函数
因为对于分类问题,假设模型的输出层上只有2个输出结点,而且是一个二分类单标签问题,如果输出层用符号 $Y$ 表示,那么 $Y$ 服从 $0-1$ 分布(是二项分布的特例,或称伯努利分布,二元分布),即随机变量 $Y$ 的样本空间有两个样本点(分别对应输出层的两个输出结点),每个样本点就是一个类别。我们希望机器学习模型训练出的分布是某个类别的概率为 $1$ ,另一个类别的概率为 $0$ 。推广到多分类单标签问题,那么 $Y$ 服从广义的伯努利分布(是多项式分布的特例,或称 $Category$ 分布,范畴分布,类别分布,$Multinoulli$ 分布(2012年在《Machine Learning - A Probabilistic Perspective》中正式提出))。
最小化交叉熵损失与最大似然推导
先从一个直观的例子感受最小化交叉熵损失与最大似然的关系
去掉 $\frac{1}{N}$ 并不影响函数的单调性,机器学习任务的也可以是最小化下面的交叉熵损失
等价于最大化
这其实就是对伯努利分布求最大似然中的对数似然函数
伯努利分布的最大似然推导
有二元随机变量 $Y \in{0,1}$ ,设 $p(Y=1) = \beta$ ,那么它的概率质量函数(PMF)为
现有 $D=\left{y{1}, y{2}, \ldots, y_{N}\right} $ 来自 $Y$ ,样本容量为 $N$ 的一个样本,似然函数为
在机器学习中,对 $\beta$ 的定义为
其中,$X=\left{x{1}, \ldots, x{N}\right}$ ,$ x_{i} \in X$,$X$ 是 $D$ 中每个样本点对应类别的特征的集合。即给定模型参数 $\theta$ 和随机变量的样本点 $Y=1$ 的属性特征 $x_i$ ( $x_i$ 可以是一个向量),让模型估计出事件 $Y=1$ 的概率(同时也是当前伯努利分布的参数)
故上述的似然函数的参数不再是伯努利分布的 $\beta$,而是模型的参数 $\theta$,有
易得对数似然函数
以下给出最大似然估计与最小化交叉熵损失的转化过程,意在说明在伯努利分布下,最大似然估计与最小化交叉熵损失是同概念的
广义伯努利分布的最大似然推导
单标签多分类任务的类别随机变量只服从多项式分布中试验次数为1的情况,广义伯努利分布( $Category$ 分布)对应的是更常见的单标签多分类任务,以下讨论伯努利分布到广义伯努利分布的过渡以及与最大似然估计的关系
有 $K$ 元类别随机变量 $Y \in{1, \ldots, K} $ ,且 $p(Y=J)=\beta_{j}$,概率质量函数库为
如果 $Y=i$,$I(Y=i) = 1$ ,否则, $I(Y=i)=0$
这个概率质量函数之所以看上去有点奇怪,是因为它出现了 $Identity$ 函数。而符合我们直觉的是维基百科对广义伯努利分布的另一个PMF定义,即 $p(Y=i)=p_i$ ,即直接根据列联表,获得该事件发生的概率。如果想解释上面晦涩难懂的包含 $Identity$ 函数的PMF,可以用严格按照伯努利试验的描述来解释:在进行1次试验中抽到第 $j$ 个类别,其他概率被抽中0次的概率,即
$D=\left{y{1}, y{2}, \ldots, y_{N}\right}$ 是来自 $Y$ 的,样本容量为 $N$,的一个样本,那么似然函数为
同样地,在机器学习模型中,对上述关于对 $\beta$ 的定义做出转变
$X=\left{x{1}, \cdots, x{N}\right}$,$x_i \in X$,$X$ 是 $D$ 中的每个样本点对应特征的集合
同理上述的似然函数的参数不再是广义伯努利分布的 $\beta_1,beta_2,\cdots,\beta_k$,而是模型的参数 $\theta$,所以似然函数有
易得对数似然函数
因为最大化上述式子具有约束条件 $\sum^K_{i=1} \beta_i = 1$,所以最大化上面的对数似然函数是一个条件极值问题,使用拉格朗日乘数法进行求解,得到下面的关于求解广义伯努利分布下的交叉熵的拉格朗日函数
在没有使用机器学习模型的前提下,我们只需对分布的参数和 $\lambda$ 求偏导就能得到参数的估计值
用模型的参数记号 $\hat{\betaj}$ 表示 $p{\theta} (y_i = j | x_i)$,用 one-hot 向量表示 $Identity$ 函数值
得
下面同样给出极大似然估计与最小化广义伯努利分布的交叉熵损失函数的转化过程,意在说明在广义伯努利分布下,最大似然估计与最小化交叉熵损失也是同概念的
小结
最小化交叉熵损失函数与最大似然估计之间的等价并非巧合,同是处理信息的公式,只是应用的方向不同