Momentum-transfer cross section: Difference between revisions

From formulasearchengine
Jump to navigation Jump to search
en>Monkbot
en>DentonW
Added relation to the phase shifts
 
Line 1: Line 1:
The '''generalized distributive law (GDL)''' is a general [[message passing]] algorithm devised by Srinivas M. Aji and [[Robert McEliece|Robert J. McEliece]]. It is a synthesis of the work of many authors in the [[information theory]], [[digital communications]], [[signal processing]], [[statistics]], and [[artificial intelligence]] communities.<ref name=GenDistLaw>{{cite journal|last=Aji|first=S.M.|coauthors=McEliece, R.J.|title=The generalized distributive law|journal=Information Theory, IEEE Transactions on|date=Mar 2000|volume=46|issue=2|pages=325–343|doi=10.1109/18.825794|url=http://ieeexplore.ieee.org/stamp/stamp.jsp?tp=&arnumber=825794&isnumber=17872}}</ref>  This article is based on a semi-tutorial by Srinivas M. Aji and [[Robert McEliece|Robert J. McEliece]] with the same title.<ref name=GenDistLaw />
== Nike Free 5.0  es vermeiden ==


==Introduction==
Dies könnte eine islamisch orientierte Gesetzgebung, mit dem Geist der Scharia infundiert werden demokratisiert oder es könnte ein Gericht die Ausübung islamischer gerichtliche Überprüfung zu gestalten und Einfluss Gesetze in seinem Schatten vergangen sein. '. die Frage, wie viele Juden lebten in der Familie Schtetl, Plunge, an der Ostsee, vor dem Krieg, Simonas Telefone Mordechai.<br><br>Aber für [http://www.maennerchor-therwil.ch/images/gelterkinden/deco/banner.asp?f=196-Nike-Free-5.0 Nike Free 5.0] einige Menschen, auch mit Medikamenten, bleiben die Symptome. Das Spiel war nicht unvergesslich; die Erinnerung an die Bedingungen aushält .. Es hängt von der Art des Problems und Schädlinge haben Sie in Ihrem Haus und entwickeln Sie einen Plan, um diese Insekten zu töten. Die Dynamik kann weiter für die Demokraten noch [http://www.riccicabanas.com/includes/client.asp?k=22-Oakley-Sonnenbrillen-Schweiz Oakley Sonnenbrillen Schweiz] verschärft werden, weil sie in diesem Jahr vor einer Wettbewerbsprimär Schlacht, während Präsident Bush ist einstimmig für die Nominierung.<br><br>Com die grenzenlose Potenzial der Sie Lebensmittel Ernährung Kochtipps protzen Vitamine ergänzt Rezepte myplate Menschen lesen die 20 besten Lebensmittel in Ihrem Supermarkt der Kunst und Wissenschaft der Cheat Mahlzeiten die Passform Kühlschrank: 10 Lebensmittel, die Sie gesünder machen Fitness loslegen Gang Übung [http://www.relax-limousinen.ch/images/umbau/banner.asp?m=77-Michael-Kors-Tasche-Online Michael Kors Tasche Online] Workouts Fitness Tipps Sport Menschen lesen die Kontroverse hinter Quer passen einen genaueren Blick auf Kettlebells 5 am meisten überbewertete Übungen gesund gesundheit Lebensbedingungen Zentren myplate myplate d Menschen lesen, wie Kaffee könnte Ihre Gesundheit verbessern Sie Ihren Schlaf zu sabotieren? Wird kontaktieren Sport töten Ihr Gehirn? Gewichtsverlust loslegen gesunde Ernährung Diätpläne myplate Kalorienbilanz [http://www.leu-ruesi.ch/pages/inc/Guest.asp?n=81-Jordan-Schweiz Jordan Schweiz] mobilen Menschen lesen die Frist Ernährung warum Sie nicht über den Körper, wie viele Kalorien sollte ich essen? Lifestyle Stil Geld Freizeit Beziehungen myplate Menschen gelesen werden.<br><br>Nicht Herren über diejenigen, die euch anvertraut, aber als Vorbilder der Herde. Im Jahr 1996 hatte Alan Sokal ein Papier in akzeptiert. Wir müssen klare Protokolle, um Computer bezogenen Pathologie behandeln zu entwickeln .. Ich habe Essays geschrieben und getan anderen universitären Arbeit am 3GS, als es war alles, was ich hatte so meine Anwendungsfälle sind vielleicht nur eine kleine Nische ..<br><br>Basierend auf diesen Informationen, gibt es wenig oder keine Möglichkeit, es vermeiden, die Oberschenkel beim Laufen. Einige Eistees enthalten auch Minze, die zusätzliche Antioxidantien und fügt fügt Geschmack ohne Zusatz von Zucker, die zu Fragen der Gesundheit beiträgt .. Die Fähigkeit, in der Lage, Kompromisse einzugehen ist wichtig in der Zusammenarbeit als Team.<ul>
 
    
''"The distributive law in mathematics is the law relating the operations of multiplication and addition, stated symbolically, <math> a*(b + c) = a*b + a*c</math>; that is, the monomial factor <math>a</math> is distributed, or separately applied, to each term of the binomial factor <math> b + c </math>, resulting in the product <math> a*b + a*c </math>"'' -  Britannica<ref name=Britannica>{{cite web|title=distributive law|url=http://www.britannica.com/EBchecked/topic/166204/distributive-law|work=Encyclopædia Britannica. Encyclopædia Britannica Online|publisher=Encyclopædia Britannica Inc|accessdate=1 May 2012}}</ref>
  <li>[http://www.haojiyou1069.com/forum.php?mod=viewthread&tid=4897988&fromuid=63025 http://www.haojiyou1069.com/forum.php?mod=viewthread&tid=4897988&fromuid=63025]</li>
 
 
As it can be observed from the definition, application of distributive law to an arithmetic expression reduces the number of operations in it. In the previous example the total number of operations reduced from three (two multiplications and an addition in <math> a*b + a*c </math>) to two (one multiplication and one addition in <math> a*(b + c) </math>). Generalization of distributive law leads to a large family of [[fast algorithms]]. This includes the [[Fast Fourier transform|FFT]] and [[Viterbi algorithm]].  
  <li>[http://verdamilio.net/tonio/spip.php?article1/ http://verdamilio.net/tonio/spip.php?article1/]</li>
 
 
This is explained in a more formal way in the example below:
  <li>[http://42.121.2.33:100/bbs/viewthread.php?tid=9603007&extra= http://42.121.2.33:100/bbs/viewthread.php?tid=9603007&extra=]</li>
 
 
<math>\alpha(a,\, b) \stackrel{\mathrm{def}}{=} \displaystyle\sum \limits_{c,d,e \in A} f(a, \, c, \, b) \, g(a, \, d, \, e) </math> where <math>f(\cdot)</math> and <math>g(\cdot)</math> are real-valued functions, <math>a,b,c,d,e \in A</math> and <math>|A|=q</math> (say)
  <li>[http://bxl.indymedia.org/spip.php?article1671&lang=nl/ http://bxl.indymedia.org/spip.php?article1671&lang=nl/]</li>
 
 
Here we are "marginalizing out" the independent variables (<math>c</math>, <math>d</math>, and <math>e</math>) to obtain the result. When we are calculating the computational complexity, we can see that for each <math>q^{2}</math> pairs of <math>(a,b)</math>, there are <math>q^{3}</math> terms due to the triplet <math>(c,d,e)</math> which needs to take part in the evaluation of <math>\alpha(a,\, b)</math> with each step having one addition and one multiplication. Therefore the total number of computations needed is <math>2\cdot q^2 \cdot q^3 = 2q^5</math>. Hence the asymptotic complexity of the above function is <math>O(n^5)</math>. 
  <li>[http://www.clen.cn/bbs/forum.php?mod=viewthread&tid=744261 http://www.clen.cn/bbs/forum.php?mod=viewthread&tid=744261]</li>
 
 
If we apply the distributive law to the RHS of the equation, we get the following:
</ul>
 
: <math>\alpha(a, \, b) \stackrel{\mathrm{def}}{=}  \displaystyle\sum\limits_{c \in A} f(a, \, c, \, b ) \cdot \sum _{d,\,e \in A} g(a,\,d,\,e) </math>
 
This implies that <math>\alpha(a, \, b)</math> can be described as a product <math>\alpha_{1}(a,\, b) \cdot \alpha_{2}(a)</math> where <math> \alpha_{1}(a,b) \stackrel{\mathrm{def}}{=} \displaystyle\sum\limits_{c \in A} f(a, \, c, \, b )</math> and <math>\alpha_{2}(a) \stackrel{\mathrm{def}}{=} \displaystyle\sum\limits_{d,\,e \in A} g(a,\, d, \,e )</math>
 
Now, when we are calculating the computational complexity, we can see that there are <math>q^{3}</math> additions in <math>\alpha_{1}(a,\, b)</math> and <math>\alpha_{2}(a)</math> each and there are <math>q^2</math> multiplications when we are using the product <math>\alpha_{1}(a,\, b) \cdot \alpha_{2}(a)</math> to evaluate <math>\alpha(a, \, b)</math>. Therefore the total number of computations needed is <math>q^3 + q^3 + q^2 = 2q^3 + q^2</math>. Hence the asymptotic complexity of calculating <math>\alpha(a,b)</math> reduces to <math>O(n^{3})</math> from <math>O(n^{5})</math>. This shows by an example that applying distributive law reduces the computational complexity which is one of the good features of a "fast algorithm".
 
==History==
 
Some of the problems that used distributive law to solve can be grouped as follows
 
1. Decoding algorithms<br>
A GDL like algorithm was used by Gallager's for decoding low density parity-check codes. Based on Gallager's work Tanner introduced the [[Tanner graph]] and expressed Gallagers work in message passing form. The tanners graph also helped explain the  [[Viterbi algorithm]].
 
It is observed by Forney that Viterbi's maximum likelihood decoding of [[convolutional codes]] also used algorithms of GDL-like generality. 
 
2. [[Forward-backward algorithm]]<br>
The forward backward algorithm helped as an algorithm for tracking the states in the [[markov chain]]. And this also was used the algorithm of GDL like generality
 
3. [[Artificial intelligence]]<br>
The notion of [[junction tree]]s has been used to solve many problems in AI. Also the concept of [[bucket elimination]] used many of the concepts.
 
==The MPF problem==
 
'''MPF or mariginalize a product function''' is a general computational problem which as special case includes many classical problems such as computation of discrete [[Hadamard transform]], [[maximum likelihood decoding]] of a [[linear code]] over a memory-less [[Channel (communications)|channel]], and [[matrix chain multiplication]]. The power of the GDL lies in the fact that it applies to situations in which additions and multiplications are generalized.
A [[commutative semiring]] is a good framework for explaining this behavior. It is defined over a set <math>K</math> with operators "<math>+</math>" and "<math>.</math>" where <math>(K,\, +)</math> and <math>(K,\, .)</math> are a [[commutative monoid]]s and the distributive law holds.
 
Let <math>p_1, \ldots, p_n</math> be variables such that <math>p_1 \in A_1, \ldots, p_n \in A_{n}</math> where <math>A </math> is a finite set and <math>|A_i| = q_i</math>. Here <math>i = 1,\ldots, n</math>. If <math>S = \{i_{1}, \ldots, i_{r}\}</math> and <math>S \, \subset \{1,\ldots, n\}</math>, let
<math> A_{S}  = A_{i_1} \times \cdots \times A_{i_r} </math>,
<math> p_{S} = (p_{i_1},\ldots, p_{i_r})</math>, 
<math> q_{S} = |A_{S}|</math>,
<math>\mathbf A  = A_{1} \times \cdots \times A_{1} </math>, and
<math>\mathbf p = \{p_{1}, \ldots, p_{n}\}</math>
 
Let <math>S = \{S_{j}\}_{j=1}^M </math> where <math>S_{j} \subset \{1, ...\,,n\}</math>. Suppose a function is defined as <math>\alpha_{i}: A_{S_{i}} \rightarrow R</math>, where <math>R</math> is a [[commutative semiring]]. Also, <math> p_{S_{i}}</math> are named the ''local domains'' and <math>\alpha_{i}</math> as the ''local kernels''.
 
Now the global kernel <math>\beta : \mathbf A \rightarrow R</math> is defined as :
<math> \beta(p_{1}, ...\,, p_{n}) = \prod_{i=1}^M \alpha(p_{S_{i}})</math>
 
''Definition of MPF problem'': For one or more indices <math>i = 1, ...\,, M</math>, compute a table of the values of <math>S_{i}</math>-''marginalization'' of the global kernel <math>\beta</math>, which is the function <math>\beta_{i}:A_{S_{i}} \rightarrow R</math> defined as <math>\beta_{i}(p_{S_{i}}) \, = \displaystyle\sum\limits_{p_{S_{i}^c} \in A_{S_{i}^c}} \beta(p)</math>
 
Here <math>S_{i}^c</math> is the complement of <math>S_{i}</math> with respect to <math>\mathbf \{1,...\,,n\}</math> and the <math>\beta_i(p_{S_i})</math> is called the <math>i^{th}</math> ''objective function'', or the ''objective function'' at <math>S_i</math>. It can observed that the computation of the <math>i^{th}</math> objective function in the obvious way needs <math>Mq_1 q_2 q_3\cdots q_{n}</math> operations. This is because there are <math>q_1 q_2\cdots q_n</math> additions and <math>(M-1)q_1 q_2...q_n</math> multiplications needed in the computation of the <math>i^\text{th}</math> objective function. The GDL algorithm which is explained in the next section can reduce this computational complexity.
 
The following is an example of the MPF problem.
Let <math>p_{1},\,p_{2},\,p_{3},\,p_{4},</math> and <math>p_{5}</math> be variables such that <math>p_{1} \in A_{1}, p_{2} \in A_{2}, p_{3} \in A_{3}, p_{4} \in A_{4}, </math> and <math>p_{5} \in A_{5}</math>. Here <math>M=4</math> and <math>S = \{\{1,2,5\},\{2,4\},\{1,4\}, \{2\}\}</math>. The given functions using these variables are <math>f(p_{1},p_{2},p_{5})</math> and <math>g(p_{3},p_{4})</math> and we need to calculate <math>\alpha(p_{1}, \, p_{4})</math> and <math>\beta(p_{2})</math> defined as:
 
: <math> \alpha(p_1, \, p_4) =  \displaystyle\sum\limits_{p_2 \in A_2,\, p_3 \in A_3, \, p_5 \in A_5 } f(p_1,\, p_2,\, p_5 ) \cdot g(p_2, \, p_4)</math>
 
: <math> \beta(p_{2}) = \sum\limits_{p_1 \in A_1,\, p_3 \in A_3,\, p_4 \in A_4, \, p_5 \in A_5 } f(p_1, \, p_2, \, p_5) \cdot g(p_2, \, p_4) </math>
 
Here local domains and local kernels are defined as follows:
{|
|-
! local domains !! local kernels
|-
| <math>\{p_{1}, p_{2}, p_{5}\}</math> || <math>(f(p_{1}, p_{2}, p_{5})</math>
|-
| <math>\{ p_{2}, p_{4}\}</math> || <math>g(p_{2}, p_{4})</math>
|-
| <math>\{p_{1}, p_{4}\}</math> || <math>1</math>
|-
| <math>\{p_{2}\}</math> || <math>1</math>
|}
 
where <math>\alpha(p_{1}, p_{4})</math> is the <math>3^{rd}</math> objective function and <math>\beta(p_{2})</math> is the <math>4^{th}</math> objective function.  
 
Let us consider another example where <math>p_{1},p_{2},p_{3},p_{4},r_{1},r_{2},r_{3},r_{4} \in \{0,1\}</math> and <math>f(r_{1},r_{2},r_{3},r_{4})</math> is a real valued function. Now, we shall consider the MPF problem where the commutative semiring is defined as the set of real numbers with ordinary addition and multiplication and the local domains and local kernels are defined as follows:
 
{|
|-
! local domains !! local kernels
|-
| <math>\{r_1, r_2, r_3,r_4\}</math> || <math>f(r_1, r_2, r_3,r_4)</math>
|-
| <math>\{ p_1, r_1\}</math> || <math>(-1)^{p_1 r_1}</math>
|-
| <math>\{p_2, r_2\}</math> || <math>(-1)^{p_2 r_2}</math>
|-
| <math>\{p_3, r_3\}</math> || <math>(-1)^{p_3 r_3}</math>
|-
| <math>\{p_4, r_4\}</math> || <math>(-1)^{p_4 r_4}</math>
|-
| <math>\{p_1,p_2, p_3, p_4\}</math> || <math>1</math>
|}
 
Now since the global kernel is defined as the product of the local kernels, it is
 
: <math>F(p_1, p_2, p_3,p_4, r_1, r_2, r_3,r_4) = f(p_1,p_2,p_3,p_4)\cdot(-1)^{p_1r_1 + p_2r_2 + p_3r_3 + p_4r_4}</math>
 
and the objective function at the local domain <math>p_1, p_2, p_3,p_4</math> is
 
: <math>F(p_1, p_2, p_3,p_4) = \displaystyle\sum \limits_{r_1,r_2,r_3,r_4} f(r_1,r_2,r_3,r_4) \cdot(-1)^{p_1r_1 + p_2r_2 + p_3r_3 + p_4r_4}.</math>
 
This is the [[Hadamard transform]] of the function <math>f(\cdot)</math>. Hence we can see that the computation of [[Hadamard transform]] is a special case of the MPF problem. More examples can be demonstrated to prove that the MPF problem forms special cases of many classical problem as explained above whose details can be found at<ref name=GenDistLaw />
 
== GDL: an algorithm for solving the MPF problem ==
 
If one can find a relationship among the elements of a given set <math>S</math>, then one can solve the MPF problem basing on the notion of [[belief propagation]] which is a special use of "message passing" technique. The required relationship is that the given set of local domains can be organised into a [[junction tree]]. In other words, we create a graph theoretic tree with the elements of <math>S</math> as the vertices of the [[Tree (graph theory)|tree]] <math>T</math>, such that for any two arbitrary vertices say <math>v_{i}</math> and <math>v_{j}</math> where <math>i \neq j</math> and there exists an edge between these two vertices, then the intersection of corresponding labels, viz <math>S_{i}\cap S_{j}</math>, is a subset of the label on each vertex on the unique path from <math>v_{i}</math> to <math>v_{j}</math>.  
 
For example,
 
Example 1: Consider the following nine local domains:
 
# <math>\{p_2\}</math>
# <math>\{p_3,p_2\}</math>
# <math>\{p_2,p_1\}</math>
# <math>\{p_3,p_4\}</math>
# <math>\{p_3\}</math>
# <math>\{p_1,p_4\}</math>
# <math>\{p_1\}</math>
# <math>\{p_4\}</math>
# <math>\{p_2,p_4\}</math>
 
For the above given set of local domains, one can organize them into a junction tree as shown below:
 
[[File:An example of a junction tree on a given set.png|center|An example of a junction of tree]]
 
Similarly If another set like the following is given
 
Example 2: Consider the following four local domains:
 
# <math>\{p_1,p_2\}</math>
# <math>\{p_2,p_3\}</math>
# <math>\{p_3,p_4\}</math>
# <math>\{p_1,p_4\}</math>
 
Then constructing the tree only with these local domains is not possible since this set of values has no common domains which can be placed between any two values of the above set. But however if add the two dummy domains as shown below then organizing the updated set into a junction tree would be possible and easy too.
 
5.<math>\{p_{1},p_{2}</math>,<math>p_{4}\}</math><br />
6.<math>\{p_{2},p_{3}</math>,<math>p_{4}\}</math>
 
Similarly for these set of domains, the junction tree looks like shown below:
[[File:Example of junction tree.png|center|Another example of a junction tree]]
 
===Generalized distributive law (GDL) algorithm===
Input: A set of local domains.<br />
Output: For the given set of domains, possible minimum number of operations that is required to solve the problem is computed. <br />
So, if <math>v_{i}</math>and<math>v_{j}</math> are connected by an edge in the junction tree, then a message from <math>v_{i}</math> to <math>v_{j}</math> is a set/table of values given by a function: <math>\mu_{i,j}</math>:<math>A_{S_{i}\cap S_{j}} \rightarrow R</math>. To begin with all the functions i.e. for all combinations of <math>i</math>and <math>j</math> in the given tree, <math>\mu_{i,j}</math> is defined to be identically <math>1</math> and when a particular message is update, it follows the equation given below.
 
: <math>\mu_{i,j}(p_{S_{i}\cap S_{j}})</math> = <math>\sum_{p_{S_{i}\setminus S_{j}}\in A_{S_{i} \setminus S_{j}}} \alpha _{i} (p_{S_{i}}) \prod_{{v_k \operatorname{adj} v_i},{k \neq j}} \mu_{k,j}(p_{S_k\cap S_i})(1)
</math>
   
where <math>v_k \operatorname{adj} v_i</math> means that <math>v_{k}</math> is an adjacent vertex to <math>v_{i}</math> in tree.
 
Similarly each vertex has a state which is defined as a table containing the values from the function <math>\sigma_{i}: A_{S_{i}} \rightarrow R </math>, Just like how messages initialize to 1 identically, state of <math>v_{i}</math> is defined to be local kernel <math>\alpha(p_{S_{i}})</math>, but whenever <math>\sigma_{i}</math> gets updated, it follows the following equation:
 
: <math>\sigma(p_{S_i})  =   \alpha_i(p_{S_i}) \prod_{v_k \operatorname{adj} v_i}  \mu_{k,j}(p_{S_k\cap S_i})(2).</math>
 
===Basic working of the algorithm===
For the given set of local domains as input, we find out if we can create a junction tree, either by using the set directly or by adding dummy domains to the set first and then creating the junction tree, if construction junction is not possible then algorithm output that there is no way to reduce the number of steps to compute the given equation problem, but once we have junction tree, algorithm will have to schedule messages and compute states, by doing these we can know where steps can be reduced, hence will be discusses this below.
 
== Scheduling of the message passing and the state computation ==
 
There are two special cases we are going to talk about here namely ''Single Vertex Problem'' in which the objective function is computed at only one vertex <math>v_{0}</math>  and the second one is ''All Vertices Problem'' where the goal is to compute the objective function at all vertices.
 
Lets begin with the '''single-vertex problem''', GDL will start by directing each edge towards the targeted vertex <math>v_0</math>. Here messages are sent only in the direction towards the targeted vertex. Note that all the directed messages are sent only once. The messages are started from the leaf nodes(where the degree is 1) go up towards the target vertex <math>v_0</math>. The message travels from the leaves to its parents and then from there to their parents and so on until it reaches the target vertex <math>v_0</math>. The target vertex <math>v_0</math> will compute its state only when it receives all messages from all its neighbors. Once we have the state, We have got the answer and hence the algorithm terminates.
 
For Example, Lets consider a junction tree constructed from the set of local domains given above i.e. the set from example 1, <br />Now the Scheduling table for these domains is (where the target vertex is <math>p_2</math>).
 
<math>\text{Round                      Message or State Computation} </math><br />
<math>1.\mu_{8,4}(p_{4}) = \alpha_{8}(p_{4}) </math><br />
<math>2.\mu_{8,4}(p_{4}) = \Sigma_{p_{2}} \alpha_{9}(p_{2},p_{4}) </math><br />
<math>3.\mu_{5,2}(p_{3}) = \alpha_{5}(p_{3}) </math><br />
<math>4.\mu_{6,3}(p_{1}) = \Sigma_{p_{4}} \alpha_{6}(p_{1},p_{4}) </math><br />
<math>5.\mu_{7,3}(p_{1}) = \alpha_{7}(p_{1}) </math><br />
<math>6.\mu_{4,2}(p_{3}) = \Sigma_{p_{4}} \alpha_{4}(p_{3},p_{4}).\mu_{8,4}(p_{4}).\mu_{9,4}(p_{4}) </math><br />
<math>7.\mu_{3,1}(p_{2}) = \Sigma_{p_{1}} \alpha_{3}(p_{2},p_{1}).\mu_{6,3}(p_{1}).\mu_{7,3}(p_{1}) </math><br />
<math>8.\mu_{2,1}(p_{2}) = \Sigma_{p_{3}} \alpha_{2}(p_{3},p_{2}).\mu_{4,2}(p_{3}).\mu_{5,2}(p_{3}) </math><br />
<math>9.\sigma_{1}(p_{2}) = \alpha_{1}(p_{2}).\mu_{2,1}(p_{2}).\mu_{3,1}(p_{2})</math>
 
Thus the complexity for Single Vertex GDL can be shown as
 
<math>\Sigma_{v} d(v)|A_{S_{(v)}}| </math>  arithmetic operations<br />
Where (Note: The explanation for the above equation is explained later in the article )<br />
<math>S(v)</math> is the label of <math>v</math>.<br />
<math>d(v)</math> is the [[Degree (graph theory)|degree]] of <math>v</math> (i.e. number of vertices adjacent to v).
 
To solve the '''All-Vertices''' problem, we can schedule GDL in several ways, some of them are parallel implementation where in each round, every state is updated and every message is computed and transmitted at the same time. In this type of implementation the states and messages will stabilizes after number of rounds that is at most equal to the diameter of the tree. At this point all the all states of the vertices will be equal to the desired objective function.
 
Another way to schedule GDL for this problem is serial implementation where its similar to the  Single vertex problem except that we don't stop the algorithm until all the vertices of a required set have not got all the messages from all their neighbors and have compute their state. <br />
Thus the number of arithmetic this implementation requires is at most <math>\Sigma_{v \in V} d(v)|A_{S_{(v)}}| </math> arithmetic operations.
 
==Constructing a junction tree==
 
The key to constructing a junction tree lies in the local domain graph <math>G_{LD}</math>, which is a weighted complete graph with <math>M</math> vertices <math>v_1,v_2,v_3,\ldots ,v_M</math> i.e. one for each local domain, having the weight of the edge  <math>e_{i,j} : v_i \leftrightarrow v_j</math> defined by<br />
<math>\omega_{i,j} = |S_{i} \cap S_{j}|</math>.<br />
if <math>x_{k} \in S_{i} \cap S_{j}</math>, then we say <math>x_{k}</math> is contained in<math>e_{i,j}</math>. Denoted by <math>\omega_{max}</math> (the weight of a maximal-weight spanning tree of <math>G_{LD}</math>), which is defined by
 
: <math>\omega^{*} = \Sigma ^M_{i=1}|S_{i}| - n</math>
 
where ''n'' is the number of elements in that set. For more clarity and details, please refer to these.<ref>http://ai.stanford.edu/~paskin/gm-short-course/lec3.pdf The Junction Tree Algorithms</ref><ref>http://www-anw.cs.umass.edu/~cs691t/SS02/lectures/week7.PDF The Junction Tree Algorithm</ref>
 
==Scheduling theorem==
 
Let <math>'T'</math> be a junction tree with vertex set <math>'V'</math> and edge set <math>'E'</math>. In this algorithm, the messages are sent in both the direction on any edge, so we can say/regard the edge set E as set of ordered pairs of vertices. For example from Figure 1 <math>'E'</math> can be defined as follows
 
: <math>E = \{(1,2),(2,1),(1,3),(3,1),(4,2),(2,4),(5,2),(2,5),(6,3),(3,6),(7,3),(3,7),(8,4),(4,8),(9,4),(4,9)\}</math>
 
NOTE:<math>E</math> above gives you all the possible directions that a message can travel in the tree.
 
The schedule for the GDL is defined as a finite sequence of subsets of<math>E</math>. Which is generally represented by
<math>\mathcal{E} =</math>{<math>E_{1},E_{2},E_{3},\ldots, E_{N}</math>}, Where <math>E_{N}</math> is the set of messages updated during the <math>N^{th}</math> round of running the algorithm.
 
Having defined/seen some notations, we will see want the theorem says,
When we are given a schedule <math>\mathcal{E} =\{ E_1,E_2,E_3,\ldots, E_N\}</math>, the corresponding [[Trellis (graph)|message trellis]] as a finite directed graph with Vertex set of  <math>V \times \{0,1,2,3,\ldots, N\}</math>, in which a typical element is denoted by <math>v_{i}(t)</math> for  <math>t \in \{0,1,2,3,\ldots,N\}</math>, Then after completion of the message passing, state at  vertex <math>v_{j}</math> will be the <math>j^\text{th}</math> objective defined in
 
: <math>\sigma(p_{S_i}) = \alpha_i(p_{S_i}) \prod_{v_k \operatorname{adj} v_i}  \mu_{k,j}(p_{S_{k}\cap S_{i}})</math>
 
and <nowiki>iff</nowiki> there is a path from <math>v_i(0)</math> to <math>v_j(N)</math>
 
== Computational complexity ==
 
Here we try to explain the complexity of solving the MPF problem in terms of the number of mathematical operations required for the calculation. i.e. We compare the number of operations required when calculated using the normal method (Here by normal method we mean by methods that do not use message passing or junction trees in short methods that do not use the concepts of GDL)and the number of operations using the generalized distributive law.
 
Example: Let us consider the simplest case where we need to compute the following expression <math>ab+ac</math>.
 
To evaluate this expression naively requires two multiplications and one addition. The expression when expressed using the distributive law can be written as <math>a(b+c)</math> a simple optimization that reduces the number of operations to one addition and one multiplication.
 
Similar to the above explained example we will be expressing the equations in different forms to perform as few operation as possible by applying the GDL.
 
As explained in the previous sections we solve the problem by using the concept of the junction trees. The optimization obtained by the use of these trees is comparable to the optimization obtained by solving a semi group problem on trees. For example to find the minimum of a group of numbers we can observe that if we have a tree and the elements are all at the bottom of the tree, then we can compare the minimum of two items in parallel and the resultant minimum will be written to the parent. When this process is propagated up the tree the minimum of the group of elements will be found at the root.
 
The following is the complexity for solving the junction tree using message passing
 
We rewrite the formula used earlier to the following form. This is the eqn for a message to be sent from vertex ''v'' to ''w''
 
: <math>\mu _{v,w} (p_{v \cap w}) = \sum _{p _{v \setminus w} \in A _{S(v) \setminus S(w)}} \alpha _{v} (p _{v})  \prod _{u adj v _{u \neq v}} \mu _{u,v} (p _{u \cap v})</math>            ----message equation
Similarly we rewrite the equation for calculating the state of vertex v as follows
 
: <math>\sigma_v(p_v) =  \alpha_v (p_v) \prod_{u \operatorname{adj} v} \mu _{v,w} (p _{v \cap w}) </math>
 
We first will analyze for the single-vertex problem and assume the target vertex is <math>v_0</math> and hence we have one edge from <math>v</math> to <math>v _{0}</math>.  
Suppose we have an edge <math>(v,w)</math> we calculate the message using the message equation. To calculate <math>p _{u \cap v}</math> requires
 
: <math> q _{v \setminus w} -1 </math>
 
additions and
 
: <math> q _{v \setminus w} (d(v)-1)</math>
 
multiplications.
 
(We represent the <math>|A _{S(v) \ S(w)}|</math> as <math>q _{v \setminus w}</math>.)
 
But there will be many possibilities for <math>x _{v \cap w}</math> hence <br />
<math> q _{v \cap w} \stackrel{\mathrm{def}}{=} | A _{S(v) \cap S(w)}|</math> possibilities for <math>p _{v \cap w}</math>.
Thus the entire message will need
 
: <math> (q _{v \cap w})(q _{v \setminus w} -1)  = q _{v} - q _{v \cap w}</math>
 
additions and
 
: <math> (q _{v \cap w}) q _{v \setminus w}. (d(v) -1) = (d(v) -1) q _v</math>
multiplications
 
The total number of arithmetic operations required to send a message towards <math>v_0 </math>along the edges of tree will be
 
: <math>\sum _{ v \neq v0} (q_v - q _{v \cap w})</math>
 
additions and
 
: <math> \sum _{ v \neq v0}  (d(v) - 1) q_v</math>
 
multiplications.
 
Once all the messages have been transmitted the algorithm terminates with the computation of state at <math>v_0</math>  The state computation requires <math>d(v_0) q _0</math> more multiplications.
Thus number of calculations required to calculate the state is given as below
 
: <math> \sum _{v \neq v _{0}} (q _{v} - q _{v \cap w}) </math>
 
additions and
 
: <math> \sum _{v \neq v _{0}} (d(v) -1) q _{v} + d(v _{0})q _{v _{0}}</math>
 
multiplications
 
Thus the grand total of the number of calculations is
 
: <math> \chi (T) = \sum _{v \in V} d(v)q _{v} - \sum _{e \in E} q _{e}</math> ----<math>(1)</math>
 
where <math>e = (v,w)</math> is an edge and its size is defined by <math>q _{v \cap w}</math>
 
The formula above gives us the upper bound.
 
If we define the complexity of the edge <math>e = (v,w)</math> as
 
: <math> \chi (e) = q _{v} + q _{w} - q _{v \cap w} </math>
 
Therefore <math>(1)</math> can be written as
 
: <math> \chi(T) = \sum _{e \in E} \chi (e)</math>
 
We now calculate the edge complexity for the problem defined in Figure 1 as follows
 
: <math> \chi(1,2) = q_2 + q_2 q_3 - q_2</math>
: <math> \chi(2,4) = q_3 q_4 + q_2 q_3 - q_3</math>
: <math> \chi(2,5) = q_3 + q_2 q_3 - q_3</math>
: <math> \chi(4,8) = q_4 + q_3 q_4 - q_4</math>
: <math> \chi(4,9) = q_2 q_4 + q_3 q_4 - q_4</math>
: <math> \chi(1,3) = q _2 + q_2 q_1 - q_2</math>
: <math> \chi(3,7) = q_1 + q_1 q_2 - q_1</math>
: <math> \chi(3,6) = q_1 q _4 + q _1 q_2 - q _1</math>
 
The total complexity will be <math> 3 q _{2}q _{3} + 3q _{3}q _{4}+ 3 q _{1}q _{2}+q _{2}q _{4} + q _{1}q _{4} - q _{1} - q _{3} - q _{4}</math> which is considerably low compared to the direct method. (Here by direct method we mean by methods that do not use message passing. The time taken using the direct method will be the equivalent to calculating message at each node and time to calculate the state of each of the nodes.)
 
Now we consider the all-vertex problem where the message will have to be sent in both the directions and state must be computed at both the vertexes. This would take <math> O( \sum _{v} d(v) d(v) q _{v}) </math> but by precomputing we can reduce the number of multiplications to <math>3(d-2)</math>. Here <math>d</math> is the degree of the vertex. Ex : If there is a set <math>(a _{1}, \ldots ,a _{d})</math> with <math> d </math> numbers. It is possible to compute all the d products of <math>d-1</math> of the <math> a _{i}</math> with at most <math>3(d-2)</math> multiplications rather than the obvious <math> d(d-2) </math>.  
We do this by precomputing the quantities
<math>b_1 = a_1, b_2= b_1 \cdot a_2 = a_1 \cdot a _2, b _{d-1} = b _{d-2} \cdot a_{d-1} = a_1 a_2 \cdots a_{d-1}</math> and <math>c_d = a_d, c_{d-1} = a_{d-1} c_d = a _{d-1} \cdot a_d, \ldots , c_2 = a _2 \cdot c_3 = a _2 a_3 \cdots a_d</math> this takes <math> 2 (d-2)</math> multiplications. Then if <math> m_j</math> denotes the product of all <math> a_i</math> except for <math> a_j</math> we have <math> m_1 = c_2, m_2 = b_1 \cdot c_3</math> and so on will need another <math>d-2</math> multiplications making the total <math> 3 (d-2)</math>
 
There is not much we can do when it comes to the construction of the junction tree except that we may have many maximal weight spanning tree and we should choose the spanning tree with the least <math>\chi(T)</math> and sometimes this might mean adding a local domain to lower the junction tree complexity.
 
It may seem that GDL is correct only when the local domains can be expressed as a junction tree. But even in cases where there are cycles and a number of iterations the messages will approximately be equal to the objective function. The experiments on Gallager–Tanner–Wiberg algorithm for low density parity-check codes were supportive of this claim.
 
{{more footnotes|date=June 2012}}
{{refimprove|date=June 2012}}
 
==References==
<references/>
 
[[Category:Information theory]]
[[Category:Algorithms]]
[[Category:Graphical models]]
[[Category:Artificial intelligence]]
[[Category:Digital signal processing]]

Latest revision as of 21:28, 26 September 2014

Nike Free 5.0 es vermeiden

Dies könnte eine islamisch orientierte Gesetzgebung, mit dem Geist der Scharia infundiert werden demokratisiert oder es könnte ein Gericht die Ausübung islamischer gerichtliche Überprüfung zu gestalten und Einfluss Gesetze in seinem Schatten vergangen sein. '. die Frage, wie viele Juden lebten in der Familie Schtetl, Plunge, an der Ostsee, vor dem Krieg, Simonas Telefone Mordechai.

Aber für Nike Free 5.0 einige Menschen, auch mit Medikamenten, bleiben die Symptome. Das Spiel war nicht unvergesslich; die Erinnerung an die Bedingungen aushält .. Es hängt von der Art des Problems und Schädlinge haben Sie in Ihrem Haus und entwickeln Sie einen Plan, um diese Insekten zu töten. Die Dynamik kann weiter für die Demokraten noch Oakley Sonnenbrillen Schweiz verschärft werden, weil sie in diesem Jahr vor einer Wettbewerbsprimär Schlacht, während Präsident Bush ist einstimmig für die Nominierung.

Com die grenzenlose Potenzial der Sie Lebensmittel Ernährung Kochtipps protzen Vitamine ergänzt Rezepte myplate Menschen lesen die 20 besten Lebensmittel in Ihrem Supermarkt der Kunst und Wissenschaft der Cheat Mahlzeiten die Passform Kühlschrank: 10 Lebensmittel, die Sie gesünder machen Fitness loslegen Gang Übung Michael Kors Tasche Online Workouts Fitness Tipps Sport Menschen lesen die Kontroverse hinter Quer passen einen genaueren Blick auf Kettlebells 5 am meisten überbewertete Übungen gesund gesundheit Lebensbedingungen Zentren myplate myplate d Menschen lesen, wie Kaffee könnte Ihre Gesundheit verbessern Sie Ihren Schlaf zu sabotieren? Wird kontaktieren Sport töten Ihr Gehirn? Gewichtsverlust loslegen gesunde Ernährung Diätpläne myplate Kalorienbilanz Jordan Schweiz mobilen Menschen lesen die Frist Ernährung warum Sie nicht über den Körper, wie viele Kalorien sollte ich essen? Lifestyle Stil Geld Freizeit Beziehungen myplate Menschen gelesen werden.

Nicht Herren über diejenigen, die euch anvertraut, aber als Vorbilder der Herde. Im Jahr 1996 hatte Alan Sokal ein Papier in akzeptiert. Wir müssen klare Protokolle, um Computer bezogenen Pathologie behandeln zu entwickeln .. Ich habe Essays geschrieben und getan anderen universitären Arbeit am 3GS, als es war alles, was ich hatte so meine Anwendungsfälle sind vielleicht nur eine kleine Nische ..

Basierend auf diesen Informationen, gibt es wenig oder keine Möglichkeit, es vermeiden, die Oberschenkel beim Laufen. Einige Eistees enthalten auch Minze, die zusätzliche Antioxidantien und fügt fügt Geschmack ohne Zusatz von Zucker, die zu Fragen der Gesundheit beiträgt .. Die Fähigkeit, in der Lage, Kompromisse einzugehen ist wichtig in der Zusammenarbeit als Team.