机器学习系列 | 03:从朴素贝叶斯和HMM说起

本文涉及的产品
实时计算 Flink 版,5000CU*H 3个月
检索分析服务 Elasticsearch 版,2核4GB开发者规格 1个月
大数据开发治理平台 DataWorks,不限时长
简介: 本系列博文尝试系统化地梳理概率图模型。本文以朴素贝叶斯和HMM为切入点尝试窥探概率图模型一二。

0. 背景

本系列博文尝试系统化地梳理概率图模型。本文以朴素贝叶斯和HMM为切入点尝试窥探概率图模型一二。

【更多、更及时内容欢迎留意微信公众号: 小窗幽记机器学习

1. 预备知识

在介绍朴素贝叶斯之前,需要先简单介绍下概率论中的基础知识:条件概率、贝叶斯公式和全概率公式。

1.1 条件概率

给定条件发生变化后,会导致事件发生的可能性发生变化。比如:背对着一个人,让你猜猜背后这个人是 男/女的概率是多少? 在没有其他先验信息的情况下,只能猜测50%。但是如果有了先验信息,比如你从旁边玻璃的反光中看到 ta 头发是长的,那么在知晓这个信息的前提下,你猜测此人性别的概率是会发生变化的,是不是? 其实这其中隐藏着信息论的真理,用信息来消除不确定性。

我们先来看表示事件 B 发生后事件 A 发生的概率(即条件概率)$P(A | B)$在数学表达式上的定义:
$$ P(A | B)=\frac{P(A \cap B)}{P(B)} $$
解释为"A在B发生的条件下发生的概率"。由定义引申得到:
$$ P(A \cap B) = P(A|B) P(B) $$
其中$P(A\cap B)$也记为$P(A,B)$是联合概率,表示两个事件共同发生的概率。

image.png

我们对上述公式从两个角度进行理解。因为$P(A,B)$可以站在A的角度去看B,也可以站在B的角度去看A,看到的事实应该是一致。
在空间$\Omega$中有2个集合A、B,具体如下所示:

image.png

从B的角度去看A,此时的$P(A,B)$解释如下:

image.png

从A的角度去看B,此时的$P(A,B)$解释如下:

image.png

可以看出,不管是从公式还是从结果上来看,二者结果是一致的。

1.2 贝叶斯公式

由上述条件概率得到$P(A \cap B) = P(A|B) P(B)=P(B|A) P(A)$,进而可以得到常规的贝叶斯公式:
$$ P(A | B)=\frac{P(B | A) P(A)}{P(B)} $$

(1) $P(A)$称为$A$的先验概率(或者边缘概率),之所以称为"先验"是因为它不考虑任何$B$方面的因素;
(2) $P(B)$称为$B$的先验概率;
(3) $P(A | B)$是已知$B$发生后,发生$A$的条件概率。从A的角度,这就意味着我们认为B是果,A是因。
由于得自$B$的取值而被称作$A$的后验概率;此时的$P(B|A)$就是似然。
(4) 同理$P(B|A)$是已知$A$发生后,$B$的条件概率。从B的角度,此时,A是果,B是因。也由于得自$A$的取值而被称作$B$的后验概率。所以,后验概率是相对的。

单从上述贝叶斯公式来讲,因为这个公式的潜在语义是,B是观测结果,我们希望获得A这个原因,即参数。$P(A |B)$ 叫做后验概率,$P(B|A)$称为似然,其他称为先验概率。如果替换成$P(Y |X)$理解上应该更直观些。

1.3 全概率公式

若事件$B1,B2 ……,Bn$是样本空间Ω中的一个划分,则:
$$ P(A)=\sum_{i=1}^{n} P\left(A \cap B_{i}\right) $$
可以从条件概率进一步得到:
$$ P(A)=\sum_{i=1}^{n} P\left(A \cap B_{i}\right)=\sum_{i=1}^{n} P\left(A | B_{i}\right) \bullet P\left(B_{i}\right) $$
全概率公式的意义在于,当某一事件的概率难以求得时,可转化为在一系列条件下发生概率的和。
全概率公式和贝叶斯公式的合体形式,即将贝叶斯公式分母这一先验概率以全概率公式展开而已:
$$ P(A | B)=\frac{P(B | A) \bullet P(A)}{P(B)}=\frac{P(B | A) \bullet P(A)}{\sum_{i=1}^{n} P\left(B | A_{i}\right) \cdot P\left(A_{i}\right)} $$

2. 朴素贝叶斯

上面我们已经介绍过了贝叶斯公式:
$$ P(A | B)=\frac{P(B | A) P(A)}{P(B)} $$
那么现在我们将以垃圾邮件分类为例,详细阐述如何在贝叶斯公式的基础上引入朴素贝叶斯方法处理垃圾邮件分类这一任务。

我们将A、B分别替换成Y和X:
$$ P(Y | X)=\frac{P(X | Y) P(Y)}{P(X)} $$
对分类任务来说,
$$ P(属于某类|具体某特征)=\frac{P(具体某特征|属于某类) P(属于某类)}{P(具体某特征)} $$
通过上述贝叶斯公式,将$P(属于某类|具体某特征)$的计算转为求$P(具体某特征|属于某类)$

这里我们再强调下或者说再啰嗦一下下下:

  • P(“属于某类”|“具有某特征”)=在已知某样本“具有某特征”的条件下,该样本“属于某类”的概率。所以叫做『后验概率』。
  • P(“具有某特征”|“属于某类”)=在已知某样本“属于某类”的条件下,该样本“具有某特征”的概率。
  • P(“属于某类”)=(在未知某样本具有该“具有某特征”的条件下,)该样本“属于某类”的概率。所以叫做『先验概率』。
  • P(“具有某特征”)=(在未知某样本“属于某类”的条件下,)该样本“具有某特征”的概率。

只需要找到一些包含已知特征标签的样本,即可进行训练。而样本的类别标签都是明确的。

整个句子作为特征

具体到这里的垃圾邮件分类任务上,观测值$X$是邮件的内容,需要比较$P(是垃圾邮件|X)$ 和 $P(是正常邮件|X)$的大小。
$$ P(是垃圾邮件|X)=\frac{P(X|是垃圾邮件)P(是垃圾邮件)}{P(X)}=\frac{P(X,是垃圾邮件)}{P(X)} $$

$$ P(是正常邮件|X)=\frac{P(X|是正常邮件)P(是正常邮件)}{P(X)}=\frac{P(X,是正常邮件)}{P(X)} $$

假设此时的邮件内容$X$="我们拥有300多名来自全国各地各行业的博士、工程师、行业专家、副教授水平以上的兼职写作人员,倾心为你代写各类原创的高水平的论文"

$$ P(是垃圾邮件|X)=\frac{垃圾邮件中出现这句话的次数}{垃圾邮件中出现这句话的次数+正常邮件中出现这句话的次数} $$
同理可以统计得到$P(是正常邮件|X)$,最后进行比较即可。当然,由于我们这里只有2个类别,只需计算$P(是垃圾邮件|X)$的概率,如果大于0.5即可判断是垃圾邮件。

分词

但是,由于训练集有限,而句子的可能性则是无限的。所以覆盖所有句子可能性的训练集是不存在的。虽然句子的可能性无限,但是词语就那么些!!汉语常用字2500个,常用词语也就56000个。按人们的经验理解,两句话意思相近并不强求非得每个字、词语都一样。且同一个意思的句子存在多样化的表达方式。

于是,可以不拿句子作为特征,而是拿句子里面的词语(组合)作为特征去考虑。所以,这里就用到了分词!所谓的分词就是把一整句话拆分成更细粒度的词语来进行表示。另外,分词之后去除标点符号、数字甚至无关成分(停用词)是特征预处理中的一项技术。

我们对原始的邮件进行分词,结果$X_{seg}$是:

我们 / 拥有 / 300 / 多名 / 来自 / 全国 / 各地 / 各 / 行业 / 的 / 博士 / 、 / 工程师 / 、 / 行业 / 专家 / 、 / 副教授 / 水平 / 以上 / 的 / 兼职 / 写作 / 人员 / , / 倾心 / 为 / 你 / 代写 / 各类 / 原创 / 的 / 高水平 / 的 / 论文 / 。

那么此时的贝叶斯公式就可以写成:
$$ P(是垃圾邮件|(我们,拥有,……,论文))=\frac{P((我们,拥有,……,论文)|是垃圾邮件)P(是垃圾邮件)}{P((我们,拥有,……,论文))} $$

$$ P(是正常邮件|(我们,拥有,……,论文))=\frac{P((我们,拥有,……,论文)|是正常邮件)P(是正常邮件)}{P((我们,拥有,……,论文))} $$

此时分子部分的$P((我们,拥有,……,论文)|是垃圾邮件)P(是垃圾邮件)$,仍旧不好计算,为此引入一个很朴素的近似:

假设所有特征都彼此独立!

那么上述分子就可以等价于:
$$ P((我们,拥有,……,论文)|是垃圾邮件)=P(我们|是垃圾邮件) \cdot P(拥有|是垃圾邮件) \cdot …… \cdot P(论文|是垃圾邮件) $$
同理可以得到:
$$ P((我们,拥有,……,论文)|是正常邮件)=P(我们|是正常邮件) \cdot P(拥有|是正常邮件) \cdot …… \cdot P(论文|是正常邮件) $$

最终只需要比较:
$$ P((我们,拥有,……,论文)|是垃圾邮件) \cdot P(是垃圾邮件)=P(我们|是垃圾邮件) \cdot P(拥有|是垃圾邮件) \cdot …… \cdot P(论文|是垃圾邮件) \cdot P(是垃圾邮件) $$

$$ P((我们,拥有,……,论文)|是正常邮件) \cdot P(是正常邮件)=P(我们|是正常邮件) \cdot P(拥有|是正常邮件) \cdot …… \cdot P(论文|是正常邮件) \cdot P(是正常邮件) $$
这两者的概率大小即可。
在假设特征条件独立之后,每一项就很好计算了,比如“代写”这个词:
$$ P(代写|是垃圾邮件)=\frac{垃圾邮件中出现“代写”的次数}{垃圾邮件中所有词的次数} $$

统计次数非常方便,而且样本数量足够大,算出来的概率比较接近真实。于是垃圾邮件识别的问题就可解了。

从图模型的角度看朴素贝叶斯:

image.png

每个特征都在一定的条件下,这里是指定类别,比如是垃圾邮件(Y),特征之间(X)是相互独立的!

3. 概率图模型(PGM)

上面既然提到了图模型,那么我们这里就先较为宏观地介绍下概率图模型的概貌。

概率图模型(Probabilistic GraphicalModel,PGM),简称图模型(Graphical Model,GM)是指一种用图结构来描述多元随机变量之间条件独立关系的概率模型,从而给研究高维空间中的概率模型带来了很大的便捷性。其中涉及两个概念:
(1)节点:表示变量
(2)节点之间的边:表示变量之间的概率关系

概率图模型根据边是否有向分为:

  • 有向图模型或贝叶斯网(Bayesian network)
  • 无向图模型或马尔可夫网(Markov network)

概率图模型的体系如下图所示:

image.png

image.png

这里就先不就此体系展开说明了,仅先给一个概貌,后续再逐个娓娓道来。

4. 马尔科夫链

在介绍隐马尔可夫之前,我们需要先介绍下马尔科夫链。
马尔可夫链(Markov chain), 又称离散时间马尔可夫链(discrete-time Markov chain,缩写为DTMC)。因俄国数学家安德烈·马尔可夫得名,为状态空间中经过从一个状态到另一个状态的转换的随机过程。

image.png

该过程要求具备“无记忆”的性质:
下一状态的概率分布只能由当前状态决定,在时间序列中它前面的历史事件均与之无关。这种特定类型的“无记忆性”称作马尔可夫性质。换一句话说,历史是应该被遗忘的,当前决定了未来。

数据表达式:
$$ P\left(x_{t+1} | \cdots, x_{t-2}, x_{t-1}, x_{t}\right)=P\left(x_{t+1} | x_{t}\right) $$

马尔科夫链的三要素:
1.状态 S:能够被观测到的可能结果
2.初始向量$\pi$:定义系统在时间为0,即初始时刻的状态概率
3.状态转移矩阵 A:每种状态之间的转换概率

假设天气有两种状态 晴、阴,即S=晴、阴

image.png

状态转移矩阵:

image.png

那么在很多天之后,比如n天之后,
$$ \begin{array}{c}{q=\lim _{n \rightarrow \infty}(1 \quad 0) P^{n}=(0.8330 .167)} \\ {p^{\infty}=\left(\begin{array}{cc}{0.833} & {0.167} \\ {0.833} & {0.167}\end{array}\right)}\end{array} $$
不管今天晴还是阴,很多天之后的晴阴分布收敛到一个固定分布,这个固定分布叫做稳态分布。上述例子说明,未来每一天天气都是q=(0.833,0.167)的一个样本点。

但是,实现中有的状态是无法观测到的,即隐状态,这时候对应的模型就是隐马尔科夫HMM。

5. 隐马尔可夫链

5.1 HMM的概念

隐马尔科夫模型也同样有三要素:

  1. 初始状态概率分布$\pi$
  2. 状态转移矩阵 A
  3. 观测概率矩阵 B
    则隐马尔可夫模型可以用以下表示:
    $$ \lambda = (A,B,\pi) $$

HMM两个基本假设:

  • 齐次马尔科夫假设:
    t 时刻状态仅取决于前一时刻 (t-1)的状态,与其他状态和观测无关,也与时刻 t 无关

  • 观测独立性假设:
    任意时刻的观测只依赖于该时刻的状态,与其他观测和状态无关

5.2 HMM示例

示例1:分词
我们以序列标注中的分词为例:
观测序列: 南京市长江大桥欢迎您
隐状态序列1: 南京市 / 长江大桥 / 欢迎您
隐状态序列2: 南京市长 / 江大桥 / 欢迎您

此时的停顿位置就是隐状态!

示例2:股市
再以股市为例,如果只是观测市场,我们只能知道当天的价格、交易量等信息,但是并不知道当前股市处于什么状态(牛市、熊市、震荡、反弹等)。此时,我们就有2个状态集合:

  • 可以观测到的状态集合,包括股市成交价格、成交量等
  • 另一个隐藏的状态集合,即股市的状态,是牛市还是熊市等
    观测状态序列与隐藏的状态序列是概率相关的。

image.png

5.3 HMM的3个基本问题

估计:

已知模型$\lambda = (A,B,\pi)$和 观测序列$O=(o_1,o_2,……,o_T)$。估计在该模型下观测序列$O$出现的概率,即$P(O|\lambda)$

学习:
已知观测序列$O=(o_1,o_2,……,o_T)$,求模型$\lambda = (A,B,\pi)$的参数,使得在该模型下观测序列概率最大,即$\operatorname{argmax}P(O|\lambda)$

预测(解码):
已知模型$\lambda = (A,B,\pi)$和观测序列$O=(o_1,o_2,……,o_T)$,
求给定观测序列条件概率$P(I|O)$最大的状态序列$I=(i_1,i_2,……,i_T)$
即,给定观测序列,求最有可能的状态序列。

【更多、更及时内容欢迎留意微信公众号: 小窗幽记机器学习 】

相关文章
|
5月前
|
机器学习/深度学习 算法 Python
07 机器学习 - 朴素贝叶斯分类算法(案例二)
07 机器学习 - 朴素贝叶斯分类算法(案例二)
46 0
|
5月前
|
机器学习/深度学习 自然语言处理 算法
05 机器学习 - 朴素贝叶斯分类算法原理
05 机器学习 - 朴素贝叶斯分类算法原理
38 0
|
4月前
|
机器学习/深度学习 算法 Python
【Python机器学习】朴素贝叶斯分类的讲解及预测决策实战(图文解释 附源码)
【Python机器学习】朴素贝叶斯分类的讲解及预测决策实战(图文解释 附源码)
53 0
|
5天前
|
机器学习/深度学习 算法 数据挖掘
PYTHON银行机器学习:回归、随机森林、KNN近邻、决策树、高斯朴素贝叶斯、支持向量机SVM分析营销活动数据|数据分享-2
PYTHON银行机器学习:回归、随机森林、KNN近邻、决策树、高斯朴素贝叶斯、支持向量机SVM分析营销活动数据|数据分享
28 1
|
4月前
|
机器学习/深度学习 自然语言处理 算法
机器学习——朴素贝叶斯
机器学习——朴素贝叶斯
|
5月前
|
机器学习/深度学习 算法 Python
06 机器学习 - 朴素贝叶斯分类算法(案例一)
06 机器学习 - 朴素贝叶斯分类算法(案例一)
50 0
|
8月前
|
机器学习/深度学习 自然语言处理 算法
【机器学习】十大算法之一 “朴素贝叶斯”
朴素贝叶斯算法是一种监督学习的算法,通过计算条件概率来预测或分类数据。它的核心思想是贝叶斯定理,即后验概率等于先验概率与似然函数的乘积除以证据因子。在文本分类的应用中,假设我们有一个文档和一个文档分类,我们想要判断这个文档属于哪个分类。我们可以将文档中的每个词都看作一个特征,每个特征的值为 0 或 1,0 表示该词不在文档中,1 表示该词在文档中。这样,我们就可以将每个文档表示为一个特征向量。然后,我们可以使用朴素贝叶斯算法来计算每个分类的条件概率,并选择条件概率最大的分类作为文档所属的分类。
233 0
【机器学习】十大算法之一 “朴素贝叶斯”
|
8月前
|
机器学习/深度学习 算法 搜索推荐
【机器学习实战项目】10分钟学会Python怎么用朴素贝叶斯Bayes进行分类预测(二)
【机器学习实战项目】10分钟学会Python怎么用朴素贝叶斯Bayes进行分类预测(二)
203 0
|
11月前
|
机器学习/深度学习 算法
瞎聊机器学习——朴素贝叶斯以及拉普拉斯平滑
瞎聊机器学习——朴素贝叶斯以及拉普拉斯平滑
|
机器学习/深度学习 算法 前端开发
python机器学习——朴素贝叶斯算法笔记详细记录
朴素贝叶斯法是基于贝叶斯定理与特征条件独立假设的分类方法。最为广泛的两种分类模型是决策树模型(Decision Tree Model)和朴素贝叶斯模型(Naive Bayesian Model,NBM)。和决策树模型相比,朴素贝叶斯分类器(Naive Bayes Classifier 或 NBC)发源于古典数学理论,有着坚实的数学基础,以及稳定的分类效率。同时,NBC模型所需估计的参数很少,对缺失数据不太敏感,算法也比较简单。
185 0