之前的章节中咱们已知介绍给定因果图关系以后如何分析图中各个因素之间的关系,对撞路径等等。今天这篇文章中咱们主要介绍一下贝叶斯网络的雏形,开启因果推断的核心区域的探索。
条件独立与图
咱们在训练模型的时候经常会说条件变量独立,或者是独立同分布这样的名词,那么条件独立怎么在因果中使用并且怎么给出一个比较客观的定义呢?
令V={V1,V2...}是包含有限个变量的集合。令P(·)是V中变量的联合概率函数,令X、Y、Z表示V中的变量的三个子集。如果
P(x∣y,z)=P(x∣z)
P(y,z)>0,那么在已知Z的情况下X和Y条件独立。换句话说一旦知道了Z, 那么获悉Y的值不会帮助获得X的值有任何额外信息。这就是咱们经常说的条件独立,形式化表达为(X⊥Y∣Z).且独立一般有如下的性质.或者当P满足(X⊥Y∣Z),当且仅当P(X,Y|Z)=P(X|Z)* P(Y|Z).
对称性: (X⊥Y∣Z)⇒(Y⊥Z∣Z)
分解性: (X⊥YW∣Z)⇒(X⊥Y∣Z)
弱联合性:(X⊥YW∣Z)⇒(X⊥Y∣ZW)
收缩性:(X⊥Y∣Z)&(X⊥W∣ZY)⇒(X⊥YW∣Z)
相关性:(X⊥W∣ZY)&(X⊥Y∣ZW⇒(X⊥YW∣Z)
不同路径判断独立
链式结构
对于链式结构而言,
p(a,c∣b)=p(c)p(a,b,c)=p(c)p(a)p(b∣a)p(c∣b)=p(a∣b)p(c∣b)
从而推出a,c关于b独立, A⊥C∣B
叉式结构
p(a,c∣b)=p(b)p(a,b,c)=p(a∣b)p(c∣b)
这种情况存在,A、B不独立,但是关于条件C独立。
对撞结构
如对撞结构可以得出,
p(a,b,c)=p(a)p(c)p(b∣a,c)p(a,b)=p(a)∗p(b)
假设观测到了B,
p(a,c∣b)=p(b)p(a,b,c)=p(c)p(a)p(c)p(b∣a,c)
这种情况下, 一般ac在b的条件下不独立,
贝叶斯网络
顾名思义,接下来咱们就要以图的形式来看你研究的问题的各个因素之间的关系啦。
图分为有向图和无向图。无向图一般称为马尔可夫网络,主要是表示对称的空间关系。而有向图一般称为DAG,用于表示因果关系或是时间关系,这种图就可以称为贝叶斯网络。
- 输入信息的主观属性
- 依赖贝叶斯条件作为信息更新的基础
- 区分推理因果模式和证据模型
DAG给出的基本分解方案如下,给定一个定义了n个离散变量的分布P。我们可以将变量任意排列X1,..,Xn,然后P分解成多个概率的乘积。
P(x1,...,xn)=∏P(xj∣xi,...,xj−1)(1.1)
现在假设某些变量xj的条件概率不是对xj的所有前期变量敏感,而仅仅对其中一小部分敏感。那么将这部分敏感的前驱变量记为paj,那么公式1.1可以写成
P(xj∣xi,...,xj−1)=P(xj∣paj)(1.2)
这样就极大的减少了输入信息。集合paj称为xj的马尔可夫父代变量集合,简称父代。
马尔可夫父代变量集合
令V={X1,...,Xn}是有序集合,令P(V)表示这些变量的联合概率分布。如果PAj使得Xj独立于其他所有的前驱变量的极小前驱变量集合,那么变量集合PAj称为Xj的马尔可夫父代集合。形式化的表示为
P(xj∣paj)=P(xj∣xi,...,xj−1)(1.3)
PAj是满足公式1.3的{X1,...,Xj−1}的子集且PAj的任何子集合均不满足公式1.3.
根据上面的描述,如何构建一个因果贝叶斯网络图呢?首先对(X1,X2)进行检测, 当且仅当着两个变量相关时,就画一个从X1到X2的箭头。继续处理X3,若X3独立于X1,X2,那么不画箭头。否则,检测X2是否使得独立于X1, (X3⊥X1∣X2), 或者X1是否使得X3独立于X2。第一种情形,就画一个从X2到X3的箭头。第二种情况就画一个X1到X3的箭头,如果没有发现条件独立,就从X2和X1都画一个箭头到X3。
d准则分离
首先咱们来看下面三种场景的因果结构。
上图分别是链式结构、叉式结构、对撞结构。
链式结构和叉式结构中的A和C相关都是因为B的存在,因此如果B是确定的某一个值,那么A和C就以B为条件独立了就是 A⊥C∣B, 但是对于对撞结构而言,在对撞结构中A和C是独立的,当B的值确定后,以B为条件,A和C就相关了。
对撞结构的例子
假设A为是否不运动,C为是否吃垃圾食品,B为是否肥胖。
当知道B为肥胖时,如果我们知道A为不运动则可以推断出C为吃垃圾食品,即A和C在条件B下相关。而如果B的答案未知,那么A和C就没有关系,即是否运动和是否吃垃圾食品没有关系。
在因果关系领域,这种判断是否条件独立的方法被称为D-分离。
后门准则
对于上图这种结构,是一种伪相关,消除伪相关的一种方法是采用后门准则,A->C是前门路径, 而A<-B->C是后门路径,后门准则就是将A和C之间的后门路径都阻断,从而得到A和C之间真正的因果关系。是不是感觉被骗啦,这不就是咱们讲过的控制变量B,观察AC之间的因果关系吗?
贝叶斯网络构建的方法
- 选择变量的一个合理顺序:x1,x2,……xn
- 在网络中添加一个节点xi,使之满足p(xi∣parent(xi))=p(xi∣x1,x2,……xi−1)
- 如果不相等则说明它们不独立,可以引出一条线,否则它们之间没有联系。
- 然后增加一点,继续判断,直到结束。
总而言之
形如叉式结构的容易造成伪相关,A<-B->C,A<-B<-D->C这两个结构中A和C之间都存在混杂,结合D-分离方法,第一个结构可以通过以B为条件消除混杂,第二个结构可以以B或D为条件消除混杂。在消除混杂的时候我们需要关注的是对于哪两个变量来说,即从第二个结构来说,如果我们以B为条件可以得到A和B<-D->C,A和C之间的伪相关是可以消除的,但是B和C之间貌似还存在着伪相关。因此伪相关的消除,我们需要关注是去消除哪两个变量之间的伪相关。