Presentation is loading. Please wait.

Presentation is loading. Please wait.

Exact Inference Continued

Similar presentations


Presentation on theme: "Exact Inference Continued"— Presentation transcript:

1 Exact Inference Continued
.

2 A Graph-Theoretic View
Eliminating vertex v from an undirected graph G – the process of making NG(v) a clique and removing v and its incident edges from G. NG(v) is the set of vertices that are adjacent to v in G. Elimination sequence of G – an order of all vertices.

3 Treewidth The width w of an elimination sequence s is the size of
the largest clique (minus 1) being formed in the elimination process, namely, ws = maximumv|NG(v)|. The treewidth tw of a graph G is the minimum width among all elimination sequences, namely, tw=minimums ws Examples. All trees have tw = 1, All graphs with isolated cycles have tw = 2, cliques of size n have tw=n-1.

4 Another Example Order 1: “Corners first” Largest clique size 4 Width=3
Order 2: x2, x5,… Largest clique size 5 Width=4 x1 x4 x2 x5 x3 x6 x7 x8 x9 Exercise: Build clique trees.

5 Observations Theorem. Computing a posteriori probability in a Markov graph G (or a BN for which G is the moral graph) has complexity |V|· kw where w is the width of the elimination sequence used and k is the largest domain size. Theorem. Computing a posteriori probability in chordal graphs is polynomial in the size of the input (namely, the largest clique). Justification: Chordal graphs have tw equal to the size of their largest clique (minus 1).

6 Observations Theorem. Finding an elimination sequence that produces the treewidth or more precisely just finding if tw = c is NP-hard. Simple heuristic. At each step eliminate a vertex v that produces the smallest clique, namely, minimizes |NG(v)|.

7 Results about treewidth
Theorem(s). There are several algorithms that produce treewidth tw with a small constant factor error  at time complexity of Poly(n)ctw. where c is a constant and n is the number of vertices. Main idea. Find a vertex minimum (A,B) cutset S (error by some factor). Make S a clique. Solve recursively G[A,S] and G[B,S], namely, make them chordal. The union graph is chordal. Observation. The above theorem is “practical” if the constants  and c are low enough because computing posterior belief also requires complexity of at most Poly(n)ktw where k is the size of the largest variable domain.

8 Elimination Sequence with Weights
There is a need for cost functions for optimizing time complexity that take the number of states into account. Elimination sequence of a weighted graph G – an order of the vertices of G, written as Xα= (Xα(1) ,…,Xα(n) ), where α is a permutation on {1,…,n}. The cost of eliminating vertex v from a graph Gi is the product of weights of the vertices in NGi(v).

9 Elimination Sequence with Weights
The residual graph Gi is the graph obtained from Gi-1 by eliminating vertex Xα(i-1). (G1≡G). The cost of an elimination sequence Xα is the sum of costs of eliminating Xα(i) from Gi, for all i.

10 Example Weights of vertices (#of states): yellow nodes: w = 2
Original Bayes network. V S T L A B D X Weights of vertices (#of states): yellow nodes: w = 2 blue nodes: w = 4 V S T L A B D X Undirected graph Representation, called the moral graph. I-map of the original

11 Example Suppose the elimination sequence is Xα=(V,B,S,…): G1 G2 G3 V S
D X G2 S T L A B D X G3 S T L A D X

12 Finding Good Elimination Order
Optimal elimination sequence: one with minimal cost. NP-complete. Repeat until the graph becomes empty Compute the elimination cost of each variable in the current graph. Choose a vertex v among the k lowest “at random” (flip a coin according to their current elimination costs). 3. Eliminate vertex v from the graph (make its neighbors a clique) Repeat these steps until using 5% of the estimated time needed to solve the inference problem with the elimination order found so far (estimated by the sum of state space size of all cliques).

13 Global conditioning Fixing value of A & B a a b b A B C D C D E E I J
K K L L M M This transformation yields an I-map of Prob(a,b,C,D…) for fixed values of A and B. Fixing values in the beginning of the summation can decrease tables formed by variable elimination. This way space is traded with time. Special case: choose to fix a set of nodes that “break all loops”. This method is called cutset-conditioning.

14 Cuteset conditioning Fixing value of A & B & L breaks all loops. We remain with solving a tree. But can we choose less variables to break all loops ? Are there better variables to choose than others ? A L C I D J B E K M This optimization question translates to the well known WVFS problem: Choose a set of variables of least weight that lie on every cycle of a given weighted undirected graph G.

15 Optimization The weight w of a node v is defined by:
L C I D J B E K M The weight w of a node v is defined by: w(v)= Log(|Dom(V)|). The problem is to minimize the sum of w(v) of all v in the selected cutset. Solution idea (Factor 2). Remove a vertex with minimum w(v)/d(v). Update neighboring weights by w(u)-w(u)/d(u). Repeat until all cycles are gone. Make the set minimal.

16 Summary Variable elimination: find an order that minimizes the width. The optimal is called treewidth. Complexity of inference grows exponentially in tw. Treewith is smallest in trees and maximal in cliques. Cutset conditioning: find an order that minimizes the cutset size/weight. Complexity of inference grows exponentially in cutset size. Cutset is smallest in trees and maximal in cliques. Example: Small loops connected in a chain. Inference is exponential using the second method but polynomial using the first method.

17 The Loop Cutset Problem
Each vertex that is not a sink with respect to a loop Γ is called an allowed vertex with respect to Γ. A loop cutset of a directed graph D is a set of vertices that contain at least one allowed vertex with respect to each loop in D. A minimum loop cutset of a weighted directed graph D is one for which the weight is minimum. A B C I D E K J L Example: L is a sink with respect to the loop with I and J; and L is an allowed vertex with respect to loop JLMJ. M

18 Reduction from LC to WVFS
Given a weighted directed graph (D,w), produce the weighted undirected graph Ds as follows: Split each vertex v in D into two vertices vin and vout in Ds , connect vin and vout . All incoming edges to v become undirected incident edges with vin . All outcoming edges from v become undirected incident edges with vout . Set ws(vin)=∞ and ws(vout)=w(v). C1 W(v) Γ1 W(v) V Vin Vout W(v) V Vin Vout Γ2 C2

19 Algorithm LoopCutset Algorithm LC Input: A Bayesian network D.
Output: A loop cutset of D. Construct the graph Ds with weight function ws . Find a vertex feedback set F for (Ds , ws). Output Ψ(F). Ψ(X) is a set obtained by replacing each vertex vin or vout in X by the respective source vertex v in D One-to-one and onto correspondence between loops in D and cycles in Ds 2-approximation for WVFS yields 2-approximation for LC

20 Approximate Inference
Loopy belief propagation Gibbs sampling Bounded conditioning Likelihood Weighting Variational methods

21 Extra Slides If time allows

22 The Noisy Or-Gate Model

23 Belief Update in Poly-Trees

24 Belief Update in Poly-Trees


Download ppt "Exact Inference Continued"

Similar presentations


Ads by Google