机器学习 —— 概率图模型(Homework: MCMC)

  除了精确推理之外,我们还有非精确推理的手段来对概率图单个变量的分布进行求解。在很多情况下,概率图无法简化成团树,或者简化成团树后单个团中随机变量数目较多,会导致团树标定的效率低下。以图像分割为例,如果每个像素的label都是随机变量,则图中会有30W个随机变量(30W像素的小型相机)。且这30W个随机变量相互之间耦合严重(4邻接,多回环),采用团树算法无法高效的获得单个像素label的可能值。所以,在精确推理之外,我们使用非精确推理的手段对节点的概率分布进行估计。

1、Loopy 置信传播

  BP是精确推理中的概念,我们从root向leaf发射一次MESSAGE,再接受一次MESSAGE则可完成团树的标定,这个过程称为置信传播。但是在多回环的团树,BP非常难执行,由于环的存在会导致某个节点一直无法出于可发射MESSAGE的状态(此时的团树不叫团树,应该称为“聚类图”)。然而理论证明,如果我们预先给定一套消息传递的顺序,保证节点i -> j 传播且仅传播一次消息,那么消息最终会收敛到某个定值。一旦消息收敛到某个定值,则代表节点之间就某变量达成一致,我们获得概率图可行的分布。此时对聚类图中的变量进行边缘化,即可获得有效的单变量分布。

  Loopy置信传播有3项极其重要的工作:

  1、保证节点之间仅传播一次的传播顺序(此顺序显然不是唯一的)

  2、获取每次传播后更新的消息

  3、判断消息最终收敛

  

 1     List = [];
 2     edges_ = P.edges;
 3   for i = 1:length(P.clusterList)     
 4       j =  find(edges_(i,:),8);
 5       List = [List; j' linspace(i,i,length(j))'];
 6   end
 7   length_list = length(List);
 8   array_      = mod(m,length_list)+1;
 9   ij          = List(array_,:);
10   i = ij(1);
11   j = ij(2);
View Code
 1     length_c = length(P.clusterList);
 2     for m = 1:length_c
 3         if m ~= j&&P.edges(m,i)==1
 4             Belief(i) = FactorProduct(Belief(i), lastMESSAGES(m, i));
 5         end
 6     end
 7     Belief(i).val = Belief(i).val/sum(Belief(i).val);
 8     MESSAGES(i,j) = FactorMarginalization(Belief(i),setdiff(Belief(i).var,...
 9                                                             MESSAGES(i,j).var));
10     MESSAGES(i,j).val = MESSAGES(i,j).val/sum(MESSAGES(i,j).val);
View Code
 1 converged = true;
 2 thresh = 1.0e-6;
 3 %converged should be 1 if converged, 0 otherwise.
 4 
 5 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
 6 % YOUR CODE HERE
 7 % 
 8 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
 9 [a_,b_] = size(mNew);
10 length_m = a_*b_;
11 m_New_array = reshape(mNew,length_m,1);
12 m_Old_array = reshape(mOld,length_m,1);
13 for i = 1:length_m
14     diff = m_New_array(i).val - m_Old_array(i).val;
15     if max(abs(diff)) > thresh
16         converged = false;
17         return
18     end
19 end
View Code

  如果消息收敛,则我们可以得到聚类图中各个Cluster的联合分布,每个Cluster可能仅对应1~2个随机变量,很容易就能求到所有随机变量的分布。

2、MCMC

  MCMC是马尔科夫蒙特卡罗的缩写。马尔科夫指的是马尔科夫链,蒙特卡罗指的是基于频率的随机变量分布推测方法。这里值得注意的是虽然马尔科夫链与马尔科夫场里面都有马尔科夫,这两样东西却是完全不同的。马尔科夫链是描述采样过程的一种模型,马尔科夫场是概率图模型。研究马尔科夫场可以帮助我们对随机变量进行建模,研究马尔科夫链可以帮助我们更好的求解马尔科夫场。对于马尔科夫链而言,我们可以从任意一个状态出发(一个状态就是所有var的一个assignment),转移到另一个状态。而转移到另一个状态的概率由MRF决定。最终,各种状态出现的次数则代表了assignment 对应的val.

2.1 吉布斯采样

  吉布斯采样使用了非常朴素的概念,对于一个给定的assignment,如果此时更换var1的取值,则是转向下一个状态了。而var1本身的分布可能知道,但是与var1相关概率的联合分布是由Cluster决定的。只要总结MRF中var1所有的信息,并将上一个assignment作为”后验“,那么就可以求得var1”此时“的边缘分布了。依据此边缘分布决定一个var1的取值并更新assignment,就完成了采样。

  所以Gibbs采样中有3个重要的地方:

  1、求取与var1有关的分布

  2、求取var1在先前assignment条件下的后验分布

  3、依据结果分布更新var1的值

 1 var_array = 1:length(A);
 2 EVDCE = [var_array' A'];
 3 factorLists = G.var2factors(V);
 4 for j = 1:length(factorLists)
 5     factorList = factorLists{j};
 6     Distribution_= F(factorList(1));
 7     length_fList = length(factorList);
 8     if length_fList>1
 9         for i = 2:length_fList
10             Distribution_ = FactorProduct(Distribution_,F(factorList(i)));
11         end
12     end
13 end
14 
15 EVDCE_var = setdiff(Distribution_.var,V);
16 EVDCE = EVDCE(EVDCE_var,:);
17 target_var = ObserveEvidence(Distribution_,EVDCE);
18 target_var = FactorMarginalization(target_var,setdiff(Distribution_.var,V));
19 LogBS = target_var.val;
20 LogBS = log(LogBS);
View Code
randSample();
View Code

2.2 Metropolis Hasting采样

  在吉布斯采样中,存在陷入某个局部采样循环的风险。简而言之,如果var1,var2,var3具有很强的相关性,那么在给定var2,var3的条件下,var1很难取到其他值。并且,初始条件很容易将Gibbs采样陷入某个MC回环中,使得其无法遍历整个状态空间。最终导致错误的结果。MH采样与Gibbs采样不同,MH一次对所有var的assignment进行更新,同样是状态转移,显然MH会转移的更远。关于MC,其要达到稳态,必须满足稳态性质,定性而言:如果某个状态发生的概率越高,则其转移向其他概率的可能性必须很小,以保证很高的自转移概率。

  如果有两个状态s1,s2,如果我们强制从s1 --> s2,那么必须决定从s1 --> s2的概率是多少。定性而言,如果s1 很难发生s2很容易发生,则这个转移发生的概率应该比较高。如果两者都很容易/很难发生,这个转移发生的概率应该一般容易发生。如果s1很容易发生,则转移会很难出现。依赖转移稳定公式建模,则有此转移发生的概率为:

 

  式中:Q是计划转移的概率,pi是assignment发生的概率。A是接受概率。A的作用是对于任意Q,强制转移符合稳定性质。这里有两样东西是未知的:1、Q,2、A。相反pi是已知的。由于基于采样的算法是被用于图像分割等领域,var很多,card却很小,和ORC正好相反。card小的好处是我们可以直接求取联合分布,在依据联合分布进行查询,就可以获得pi了。

  ***********************************************           Q的设计据说是一份值60W刀年薪的job,不敢妄议。这里我们假设Q是给定的(uniform/SW)              **********************************************

  MH采样的流程如下:

  1、给定Assignment,依据F求pi(Assignment)

  2、根据上面的公式计算接受概率A

  3、决定是否接受,完成采样更新Assignment

3.总结

  基于团树的精确推理算法可以很好的完成树状结构聚类图的推理,并且运行速度很快。对于多环的结构我们可以选择LBP算法以及基于采样的算法。LBP算法的弱点是MESSAGE难以收敛,会耗费较长时间,但是其可以保证所有的Assignment都能被遍历到。基于采样的算法同样也会耗费一定的时间,但是这个时间是可控的,其决定于我们需要的迭代次数,对某些任务可以牺牲精度来换取迭代次数的减少。

  至此,我们完成了所有推理相关工作的作业。然而这并不是完整的概率图,在之前的学习中,我们都假设factor的val是已知的,这个val难道来自秋名山的神秘车牌?显然不是的。它来自机器学习。

  由于Coursera Honor Code,不再公布源码。

 

 

原文地址:https://www.cnblogs.com/ironstark/p/5428097.html