朴素贝叶斯法是基于贝叶斯定理与特征条件独立假设的分类方法。对于给定的训练数据集,首先基于特征条件独立假设学习输入输出的联合概率分布,然后基于此模型,对给定的输入 x x x,利用贝叶斯定理求出后验概率最大的输出 y y y,朴素贝叶斯实现简单,学习和预测效率都很高,是一种常用的方法。
本章叙述朴素贝叶斯法,包括朴素贝叶斯的学习与分类,朴素贝叶斯的参数估计算法。
设输入空间 x ⊆ R n x \subseteq R^n x⊆Rn为n维度向量的集合,输出空间为类标记集合 y y y = { c 1 , c 2 , . . . , c k c_1,c_2,...,c_k c1,c2,...,ck}。
输入为特征向量 x ∈ X x \in X x∈X,输出为类标记 y ∈ Y y \in Y y∈Y。
X X X是定义在输入空间 X X X上的随机向量,
Y Y Y是定义在输入空间 y y y上的随机变量,
P ( X , Y ) P(X,Y) P(X,Y)是 X X X和 Y Y Y的联合概率分布,训练数据集为
T T T = { ( x 1 , y 1 ) , ( x 2 , y 2 ) , . . . . , ( x N , y N ) (x_1,y_1),(x_2,y_2),....,(x_N,y_N) (x1,y1),(x2,y2),....,(xN,yN)}
有 P ( X , Y ) P(X,Y) P(X,Y)独立同分布产生。
朴素贝叶斯法通过训练数据集学习联合概率分布 P ( X , Y ) P(X,Y) P(X,Y),具体地,学习以下先验概率分布及条件概率分布,先验概率分布:
P ( Y = c k ) k = 1 , 2 , 3 , . . . . , K P(Y = c_k) k = 1,2,3,....,K P(Y=ck)k=1,2,3,....,K
条件概率分布:
P ( X = x ∣ Y = c k ) = P ( X ( 1 ) = x ( 1 ) , ⋯ , X ( n ) = x ( n ) ∣ Y = c k ) P(X = x|Y = c_k) \\ = P(X^{(1)} = x^{(1)},\cdots,X^{(n)} = x^{(n)}|Y = c_k) P(X=x∣Y=ck)=P(X(1)=x(1),⋯,X(n)=x(n)∣Y=ck)
k = 1 , 2 , 3 , . . . , K k = 1,2,3,...,K k=1,2,3,...,K
于是学习到联合概率分布 P ( X , Y ) P(X,Y) P(X,Y)
条件概率分布:
P ( X = x ∣ Y = c k ) P(X = x|Y = c_k) P(X=x∣Y=ck) 有指数级数量的参数,其估计实际是不可行的,事实上,假设 x ( j ) x^{(j)} x(j)可能取值有 S j S_j Sj个, j = 1 , 2 , 3... , n j = 1,2,3...,n j=1,2,3...,n
Y可能取值有K个,那么总共的参数个数有:
K ∏ j = 1 n S j K \prod^n_{j = 1}S_j Kj=1∏nSj
朴素贝叶斯法对条件概率分布做了条件独立性假设,由于这是一个较强的假设,朴素贝叶斯法也由此得名,具体地,条件独立性假设是:
P ( X = x ∣ Y = c k ) = P ( X ( 1 ) = x ( 1 ) , ⋯ , X ( n ) = x ( n ) ∣ Y = c k ) = ∏ j = 1 n P ( X ( j ) = x ( j ) ∣ Y = c k ) P(X = x|Y = c_k) \\ = P(X^{(1)} = x^{(1)},\cdots,X^{(n)} = x^{(n)}|Y = c_k) \\ = \prod^n_{j = 1}P(X^{(j)} = x^{(j)}|Y = c_k) P(X=x∣Y=ck)=P(X(1)=x(1),⋯,X(n)=x(n)∣Y=ck)=j=1∏nP(X(j)=x(j)∣Y=ck)
朴素贝叶斯法实际上是学习到生成数据的机制,所以属于生成模型,条件独立假设等于是说用于分类的特征在类确定的条件下都是条件独立的,这一假设使朴素贝叶斯法变得简单,但有时会牺牲一定的分类准确率。
朴素贝叶斯份额里时,对给定的输入 x x x,通过学习的模型计算后验概率分布, P ( Y = c k ∣ X = x ) P(Y = c_k|X = x) P(Y=ck∣X=x)
将后验概率最大的类作为 x x x类的输出,后验概率计算根据贝叶斯定理进行:
P ( Y = c k ∣ X = x ) = P ( X = x ∣ Y = c k ) P ( Y = c k ) ∑ k P ( X = x ∣ Y = c k ) P ( Y = c k ) P(Y = c_k|X = x) = \frac{P(X = x|Y = c_k)P(Y = c_k)}{\sum_kP(X = x|Y = c_k)P(Y =c_k)} P(Y=ck∣X=x)=∑kP(X=x∣Y=ck)P(Y=ck)P(X=x∣Y=ck)P(Y=ck)
利用条件独立性假设,该式可以转换为:
P ( Y = c k ∣ X = x ) = P ( Y = c k ) ∏ j P ( X ( j ) = x ( j ) ∣ Y = c k ) ∑ k P ( Y = c k ) ∏ j P ( X ( j ) = x ( j ) ∣ Y = c k ) P(Y = c_k|X = x) = \frac{P(Y =c_k)\prod_jP(X^{(j)} = x^{(j)}| Y = c_k)}{\sum_kP(Y = c_k)\prod_jP(X^{(j)} =x^{(j)} | Y = c_k)} P(Y=ck∣X=x)=∑kP(Y=ck)∏jP(X(j)=x(j)∣Y=ck)P(Y=ck)∏jP(X(j)=x(j)∣Y=ck)
这是朴素贝叶斯算法的基本公式,于是朴素贝叶斯分类器可以表示为:
y = f ( x ) = a r g m a x c k P ( Y = c k ) ∏ j P ( X ( j ) = x ( j ) ∣ Y = c k ) ∑ k P ( Y = c k ) ∏ j P ( X ( j ) = x ( j ) ∣ Y = c k ) y = f(x) = argmax_{c_k}\frac{P(Y =c_k)\prod_jP(X^{(j)} = x^{(j)}| Y = c_k)}{\sum_kP(Y = c_k)\prod_jP(X^{(j)} =x^{(j)} | Y = c_k)} y=f(x)=argmaxck∑kP(Y=ck)∏jP(X(j)=x(j)∣Y=ck)P(Y=ck)∏jP(X(j)=x(j)∣Y=ck)
总之、贝叶斯公式的输出都是后验概率分布,
注意到:
在上式子中,分母对所有的 c k c_k ck都是相同的。
所以:
y = a r g m a x c k P ( Y = c k ) ∏ j P ( X ( j ) = x ( j ) ∣ Y = c k ) y = argmax_{c_k}P(Y = c_k)\prod_jP(X^{(j)} = x^{(j)}|Y = c_k) y=argmaxckP(Y=ck)j∏P(X(j)=x(j)∣Y=ck)
朴素贝叶斯算法将实例分到后验概率最大的类中,这等价于期望风险最小化,假设选择0-1损失函数:
L ( Y , f ( X ) ) = { 1 , Y ≠ f ( X ) 0 , Y = f ( X ) L(Y,f(X))=\left\{\begin{matrix}1,Y \not = f(X)\\0,Y =f(X)\end{matrix}\right. L(Y,f(X))={1,Y=f(X)0,Y=f(X)
其中 f ( X ) f(X) f(X)是分类决策函数,这是期望风险函数为:
R e x p ( f ) = E [ L ( Y , f ( X ) ) ] R_{exp}(f) = E[L(Y,f(X))] Rexp(f)=E[L(Y,f(X))]
期望是对联合分布 P ( X , Y ) P(X,Y) P(X,Y)取的,由此取条件期望:
R e x p ( f ) = E x ∑ k = 1 K [ L ( c k , f ( X ) ) ] P ( c k ∣ X ) R_{exp}(f) = E_x\sum^K_{k = 1}[L(c_k,f(X))]P(c_k|X) Rexp(f)=Exk=1∑K[L(ck,f(X))]P(ck∣X)
为了使得期望风险最小化,只需对$X =x $逐个极小化,由此得到:
f ( x ) = a r g m i n y ∈ y ∑ k = 1 k L ( c k , y ) P ( c k ∣ X = x ) = a r g m i n y ∈ y ∑ k = 1 K P ( y ≠ c k ∣ X = x ) = a r g m i n y ∈ y ( 1 − P ( y = c k ∣ X = x ) ) = a r g m a x y ∈ y P ( y c k ∣ X = x ) f(x) = argmin_{y \in y}\sum^k_{k = 1}L(c_k,y)P(c_k|X = x) \\= argmin_{y \in y}\sum^K_{k = 1}P(y \not=c_k|X = x) \\= argmin_{y \in y} (1 - P(y = c_k|X = x)) \\= argmax_{y\in y}P(y_{c_k}|X = x) f(x)=argminy∈yk=1∑kL(ck,y)P(ck∣X=x)=argminy∈yk=1∑KP(y=ck∣X=x)=argminy∈y(1−P(y=ck∣X=x))=argmaxy∈yP(yck∣X=x)
这样一来,根据期望风险最小化准则就得到了后验概率最大化准则。
f ( x ) = a r g m a x c k P ( c k ∣ X = x ) f(x) = argmax_{c_k}P(c_k|X = x) f(x)=argmaxckP(ck∣X=x)
即朴素贝叶斯法采用的原理为:
关键思想:根据定理求条件概率最大化全部都将其搞定都行啦的样子
在朴素贝叶斯法中,学习意味着估计 P ( Y = c k ) P(Y = c_k) P(Y=ck)和 P ( X ( j ) = x ( j ) ∣ Y = c k ) P(X^{(j)} = x^{(j)} | Y = c_k) P(X(j)=x(j)∣Y=ck).可以应用极大似然估计法去估计相应的概率:
先验概率 P ( Y = c k ) P(Y = c_k) P(Y=ck)的极大似然估计是:
P ( Y = c k ) = ∑ i = 1 N I ( y i = c k ) N k = 1 , 2 , 3... , K P(Y = c_k) = \frac{\sum^N_{i = 1}I(y_i = c_k)}{N} k = 1,2,3...,K P(Y=ck)=N∑i=1NI(yi=ck)k=1,2,3...,K
设第 j j j个特征, x ( j ) x^{(j)} x(j)可能取值集合为{ a j 1 , a j 2 , . . . . , a j S j a_{j1},a_{j2},....,a_{jS_j} aj1,aj2,....,ajSj} 条件概率 P ( X ( j ) = a j l ∣ Y = c k ) P(X^{(j)} = a_{jl} | Y = c_k) P(X(j)=ajl∣Y=ck)的极大似然估计是:
P ( X ( j ) = a j l ∣ Y = c k ) = ∑ i = 1 N I ( x i ( j ) = a j l , y i = c k ) ∑ i = 1 N I ( y i = c k ) j = 1 , 2 , . . . , n ; l = 1 , 2 , . . . . , S j k = 1 , 2 , 3.... , K P(X^{(j)} = a_{jl} | Y = c_k) =\frac{\sum^N_{i = 1}I(x^{(j)}_i =a_{jl},y_i = c_k)}{\sum^N_{i = 1}I(y_i = c_k)} \\ j = 1,2,...,n; l = 1,2,....,S_j k = 1,2,3....,K P(X(j)=ajl∣Y=ck)=∑i=1NI(yi=ck)∑i=1NI(xi(j)=ajl,yi=ck)j=1,2,...,n;l=1,2,....,Sjk=1,2,3....,K
x i j 第 i 个 样 本 和 第 j 个 特 征 , a j l 第 j 个 特 征 可 能 取 第 l 个 值 , I 为 指 示 函 数 x^{j}_i第i个样本和第j个特征,\\ a_{jl} 第j个特征可能取第l个值,I为指示函数 xij第i个样本和第j个特征,ajl第j个特征可能取第l个值,I为指示函数
会自己抽时间把贝叶斯估计也研究以下,全部都将其研究透彻,研究彻底!全部都搞定都行啦的样子与打算。
P ( Y ∣ X ) = P ( X , Y ) P ( X ) P(Y|X) = \frac{P(X,Y)}{P(X)} P(Y∣X)=P(X)P(X,Y)
P ( X , Y ) = P ( X ∣ Y ) ∗ P ( Y ) = P ( x 1 , x 2 , . . . , x n ∣ Y ) ∗ P ( Y ) P(X,Y) = P(X|Y)*P(Y) = P(x_1,x_2,...,x_n|Y)*P(Y) P(X,Y)=P(X∣Y)∗P(Y)=P(x1,x2,...,xn∣Y)∗P(Y)
P ( x 1 , x 2 , . . . . , x n ∣ Y ) = ∏ i = 1 n P ( x i ∣ Y ) P(x_1,x_2,....,x_n|Y) = \prod^n_{i = 1}P(x_i|Y) P(x1,x2,....,xn∣Y)=i=1∏nP(xi∣Y)
会自己将贝叶斯公式定理,机器运用全部将其搞定,并学会迅速变换。全部都搞彻底!