In this post, we’re going to use the diagrammatic notation of Bayes nets. However, we use the diagrams a little bit differently than is typical. In practice, such diagrams are usually used to define a distribution - e.g. the stock example diagram

The Slippery Sidewalk Model

... in combination with the five distributions , defines a joint distribution

In this post, we instead take the joint distribution as given, and use the diagrams to concisely state properties of the distribution. For instance, we say that a distribution  “satisfies” the diagram

 

if-and-only-if . (And once we get to approximation, we’ll say that  approximately satisfies the diagram, to within , if-and-only-if .)

The usage we’re interested in looks like:

  • State that some random variables satisfy several different diagrams
  • Derive some new diagrams which they satisfy

In other words, we want to write proofs diagrammatically - i.e. each “step” of the proof combines some diagrams (which the underlying distribution satisfies) to derive a new diagram (which the underlying distribution satisfies).

For this purpose, it’s useful to have a few rules for an “algebra of diagrams”, to avoid always having to write out the underlying factorizations in order to prove anything. We’ll walk through a few rules, give some examples using them, and prove them in the appendix. The rules:

  • Re-Rooting Rule for Markov Chains
  • Joint Independence Rule
  • Frankenstein Rule
  • Factorization Transfer Rule
  • Stitching Rule for A Shared Markov Blanket
  • Bookkeeping Rules

The first couple are relatively-simple rules for “serial” and “parallel” variables, respectively; they’re mostly intended to demonstrate the framework we’re using. The next four rules are more general, and give a useful foundation for application. Finally, the Bookkeeping Rules cover some “obvious” minor rules, which basically say that all the usual things we can deduce from a single Bayes net still apply.

Besides easy-to-read proofs, another big benefit of deriving things via such diagrams is that we can automatically extend our proofs to handle approximation (i.e. cases where the underlying distribution only approximately satisfies the diagrams). We’ll cover approximate versions of the rules along the way.

Finally, we’ll walk through an end-to-end example of a proof which uses the rules.

Re-Rooting Rule for Markov Chains

Suppose we have a distribution over  which satisfies

 

Then the distribution also satisfies all of these diagrams:

 

In fact, we can also go the other way: any one of the above diagrams implies all of the others.

Since this is our first rule, let’s unpack all of that compact notation into its full long-form, in a concrete example. If you want to see the proof, take a look at the appendix.

Verbose Example

For concreteness, let’s say we have a widget being produced on an assembly line. No assembly line is perfect; sometimes errors are introduced at a step, like e.g. a hole isn’t drilled in quite the right spot. Those errors can then cause further errors in subsequent steps, like e.g. the hole isn’t in quite the right spot, a part doesn’t quite fit right. We’ll say that  is the state of the widget after step 1,  is the state after step 2, etc; the variables are random to model the “random” errors sometimes introduced.

Our first diagram

 

says that the probability of an error at step , given all the earlier steps, depends only on the errors accumulated up through step . That means we’re ignoring things like e.g. a day of intermittent electrical outages changing the probability of error in every step in a correlated way. Mathematically, we get that interpretation by first applying the chain rule (which applies to any distribution) to the underlying distribution:

(we can also think of the chain rule as a “universal diagram” satisfied by all distributions; it’s a DAG with an edge between every two variables). We then separately write out the factorization stated by the diagram:

Equating these two (then marginalizing variables different ways and doing some ordinary algebra), we find:

  •  (duh)
  •  (also duh)

… which we can interpret as “probability of an error at step , given all the earlier steps” - i.e. the left-hand side of each of the above - “depends only on the errors accumulated up through step ” - i.e. the right-hand side of each of the above. (Note: many of the proofs for rules in this post start by "breaking things up" this way, using the chain rule.)

So far, we’ve just stated what the starting diagram means. Now let’s look at one of the other diagrams:

 

The factorization stated by this diagram is

Interpretation: we could model the system as though the error-cascade “starts” at step 3, and then errors propagate back through time to steps 2 and 1, and forward to step 4. Obviously this doesn’t match physical causality (i.e. do() operations will give different results on the two diagrams). But for purposes of modeling the underlying distribution , this diagram is equivalent to the first diagram.

What does “equivalent” mean here? It means that any distribution which satisfies the factorization expressed by the first diagram (i.e. ) also satisfies the factorization expressed by the second diagram (i.e. ), and vice versa.

More generally, this is a standard example of what we mean when we say “diagram 1 implies diagram 2”, for any two diagrams: it means that any distribution which satisfies the factorization expressed by diagram 1 also satisfies the factorization expressed by diagram 2. If the two diagrams imply each other, then they are equivalent: they give us the same information about the underlying distribution.

Back to the example: how on earth would one model the widget error-cascade as starting at step 3? Think of it like this: if we want to simulate the error-cascade (i.e. write a program to sample from ), we could do that by:

  • First sampling 
  • … then working backward to the distribution of  given that  value, and sampling  from that distribution
  • … then further back from  to 
  • … and on the other side, sampling  from 

When we frame it that way, it’s not really something physical which is (modeled as) propagating back through time. Rather, we’re just epistemically working backward as a way to “solve for” the system’s behavior. And that’s a totally valid way to “solve for” this system’s behavior (though I wouldn’t personally want to code it that way).

In the context of our widget example, this seems… not very useful. Sure, the underlying distribution can be modeled using some awkward alternative diagram, but the alternative diagram doesn’t really seem better than the more-intuitive starting diagram. More generally, our rule for re-rooting Markov Chains is usually useful as an intermediate in a longer derivation; the real value isn’t in using it as a standalone rule.

Re-Rooting Rule, More Generally

More generally, any diagram of the form

 

is equivalent to any other diagram of the same form (i.e. take any other “root node” ).

For approximation, if the underlying distribution approximately satisfies any diagram of the form

 

to within , then it satisfies all the others to within .

Again, since this is our first rule, let’s unpack that compact notation. The diagram

 

expresses the factorization

We say that the underlying distribution  “approximately satisfies the diagram to within ” if-and-only-if

So, our approximation claim is saying: if  for any , then  for all . Indeed, the proof (in the appendix) shows that those ’s are all equal.

Joint Independence Rule

Suppose I roll three dice . The first roll, , is independent of the second two, . The second roll, , is independent of . And the third roll, X_3, is independent of . Then: all three are independent.

If you’re like “wait, isn’t that just true by definition of independence?”, then you have roughly the right idea! (Some-but-not-all sources define many-variable independence this way.) But if we write out the underlying diagrams/math, it will be more clear that we have a nontrivial (though simple) claim. Our preconditions say:

There are no arrows here, that's the point.

or, in standard notation

Our claim is that these preconditions together imply:

Still no arrows.

or in the usual notation

That’s pretty easy to prove, but the more interesting part is approximation. If our three diagrams hold to within  respectively, then the final diagram holds to within . Writing it out the long way:

(Note that, in the dice example, these ’s are each the mutual information of one die with the others, since  in general.) Together, they imply:

In the context of the dice example: if I think that each die  individually is approximately independent of the others (to within  bits of mutual information), that means the dice are all approximately jointly independent (to within  bits).

More generally, this all extends in the obvious way to more variables. If I have  variables, each of which is individually independent of all the others, then they’re all jointly independent. In the approximate case, if each of variables  has only mutual information  bits with the others, then the variables are jointly independent to within  bits - i.e.

We can also easily extend the rule to conditional independence: if each of the variables  has mutual information at most  with the others conditional on some other variable , then the variables are jointly independent to within  bits conditional on . Diagrammatically:

 

The Frankenstein Rule

Now on to a more general/powerful rule.

Suppose we have an underlying distribution  which satisfies both of these diagrams:

 

Notice that we can order the variables ; with that ordering, there are no arrows from “later” to “earlier” variables in either diagram. (We say that the ordering “respects both diagrams”.) That’s the key precondition we need in order to apply the Frankenstein Rule.

Because we have an ordering which respects both diagrams, we can construct "Frankenstein diagrams", which combine the two original diagrams. For each variable, we can choose which of the two original diagrams to take that variable’s incoming arrows from. For instance, in this case, we could choose:

  • Incoming arrows of  from the left diagram
  • Incoming arrows of  from the right diagram
  • Incoming arrows of  from the left diagram
  • Incoming arrows of  from the left diagram
  • Incoming arrows of  from the left diagram

resulting in this diagram:

 

But we could make other choices instead! We could just as easily choose:

  • Incoming arrows of  from the right diagram
  • Incoming arrows of  from the left diagram
  • Incoming arrows of  from the right diagram
  • Incoming arrows of  from the right diagram
  • Incoming arrows of  from the left diagram

which would yield this diagram:

 

The Frankenstein rule says that, so long as our underlying distribution satisfies both of the original diagrams, it satisfies any Frankenstein of the original diagrams (so long as there exists an order of the variables which respects both original diagrams).

More generally, suppose that:

  • Our underlying distribution  satisfies two different diagrams, and
  • There exists some ordering of the variables  which respects the order of both diagrams simultaneously (i.e. when the variables are in that order, there’s never an arrow from a “later” variable to an “earlier” variable in either diagram).

If those two conditions hold, then we can create an arbitrary “Frankenstein diagram” from the two original diagrams: for each variable, we can take its incoming arrows from either of the two original diagrams. The underlying distribution will satisfy any Frankenstein diagram.

We can also extend the Frankenstein Rule to more than two original diagrams in the obvious way: so long as there exists an ordering of the variables which respects all diagrams, we can construct a Frankenstein which takes the incoming arrows of each variable from any of the original diagrams.

For approximation, we have two options. One approximate Frankenstein rule is simpler but gives mildly looser bounds, the other is a little more complicated but gives mildly tighter bounds (especially as the number of original diagrams increases).

The simpler approximation rule: if the original two diagrams are satisfied to within  and , respectively, then the Frankenstein is satisfied to within . (And this extends in the obvious way to more-than-two original diagrams.)

The more complex approximation rule requires some additional machinery. For any diagram, we can decompose its  into one term for each variable via the chain rule:

If we know how our upper bound  on the diagram’s  decomposes across variables, then we can use that for more fine-grained bounds. Suppose that, for each diagram  and variable , we have an upper bound

Then, we can get a fine-grained bound for the Frankenstein diagram. For each variable , we add only the  from the original diagram  from which we take that variables’ incoming arrows to build the Frankenstein. (Our simple approximation rule earlier added together all the ’s from all of the original diagrams, so it was over-counting.)

Exercise: Using the Frankenstein Rule on the two diagrams at the beginning of this section, show that  is independent of all the other variables (assuming the two diagrams from the beginning of this section hold).

Factorization Transfer Rule

The factorization transfer rule is of interest basically-only in the approximate case; the exact version is quite trivial.

Our previous rules dealt with only one “underlying distribution” , and looked at various properties satisfied by that distribution. Now we’ll introduce a second distribution, . The Transfer Rule says that, if  satisfies some diagram and  approximates  (i.e. ), then  approximately satisfies the diagram (to within ). The factorization (i.e. the diagram) “transfers” from  to .

A simple example: suppose I roll a die a bunch of times. Maybe there’s “really” some weak correlations between rolls, or some weak bias on the die; the “actual” distribution accounting for the correlations/bias is . But I just model the rolls as independent, with all six outcomes equally probable for each roll; that’s .

Under , all the die rolls are independent: . Diagrammatically:

 

So, if , then the die rolls are also approximately independent under . That’s the Transfer Rule.

Stitching Rule for a Markov Blanket

Imagine I have some complicated Bayes net model for the internals of a control system, and another complicated Bayes net model for its environment. Both models include the sensors and actuators, which mediate between the system and environment. Intuitively, it seems like we should be able to “stitch together” the models into one joint model of system and environment combined. That’s what the Stitching Rule is for.

The Stitching Rule is complicated to describe verbally, but relatively easy to see visually. We start with two diagrams over different-but-overlapping variables:

 

In this case, the  variables only appear in the left diagram,  variables only appear in the right diagram, but the  variables appear in both. (Note that the left diagram states a property of  and the right diagram a property of ; we’ll assume that both of those are marginal distributions of the underlying .)

Conceptually, we want to “stitch” the two diagrams together along the variables . But we can’t do that in full generality: there could be all sorts of interactions between  and  in the underlying distribution, and the two diagrams above don’t tell us much about those interactions. So, we’ll add one more diagram:

 

This says that  and  interact only via , i.e.  is a Markov blanket between  and . If this diagram and both diagrams from earlier hold, then we know what the  interactions look like, so in-principle we can stitch the two diagrams together.

In practice, in order for the stitched diagram to have a nice form, we’ll require our diagrams to satisfy two more assumptions:

  • Each of the  may be a child of -variables in the left diagram, or a child of -variables in the right diagram, but not both.
  • Just like the Frankenstein Rule, there must be some ordering of all the variables which respects both of the two diagrams which we wish to stitch.

Short Exercise: verify these two conditions hold for our example above.

Then, the Stitching Rule says we can do something very much like the Frankenstein Rule. We create a stitched-together diagram in which:

  • Each -variable takes its parents from the left diagram
  • Each -variable takes its parents from the right diagram
  • Each -variable with an -parent takes its parents from the left diagram
  • Each -variable with a -parent takes its parents from the right diagram

(A -variable with neither an -parent nor a -parent can take its parents from either diagram.) So, for our example above, we could stitch this diagram:

 

The Stitching Rule says that, if the underlying distribution satisfies both starting diagrams and  is a markov blanket between  and  and the two starting diagrams satisfy our two extra assumptions, then the above diagram holds.

In the approximate case, we have an  for the left diagram, an  for the right diagram, and an  for the diagram . Our final diagram holds to within . As with the Frankenstein rule, that bound is a little loose, and we can tighten it in the same way if we have more fine-grained bounds on  for individual variables in each diagram.

Bookkeeping Rules

If you’ve worked with Bayes nets before, you probably learned all sorts of things implied by a single diagram - e.g. conditional independencies from d-separation, “weaker” diagrams with edges added, that sort of thing. We’ll refer to these as “Bookkeeping Rules”, since they feel pretty minor if you’re already comfortable working with Bayes nets. Some examples:

  • We can always add an arrow to a diagram (assuming it doesn’t introduce a loop), and the approximation will get no worse.
  • We can always “combine nodes”, i.e. combine a node for variable  and a node for variable  into a single node  which inherits all incoming and outgoing arrows from the original nodes, again assuming it doesn’t introduce a loop. The approximation will get no worse.
  • We can always arbitrarily reorder components in a complete subgraph, so long as no loops are introduced, and the approximation will get no worse. [EDIT: This one is wrong; thankyou to Oli for helping hunt down the error (in this thread). It is still correct if the subgraph has no incoming arrows, which suffices for the end-to-end example, but I haven't worked out the most general version.]
  • If  d-separates  and  in a diagram, then the diagram implies , with approximation no worse than the original diagram.

Bookkeeping Rules (including all of the above) can typically be proven via the Factorization Transfer Rule.

Exercise: use the Factorization Transfer Rule to prove the d-separation Bookkeeping Rule above. (Alternative exercise, for those who don’t know/remember how d-separation works and don’t want to look it up: pick two of the other Bookkeeping Rules and use the Factorization Transfer Rule to prove them.)

End-to-End Example

This example is from an upcoming post on our latest work. Indeed, it’s the main application which motivated this post in the first place! We’re not going to give the background context in much depth here, just sketch a claim and its proof, but you should check out the upcoming post on Natural Latents (once it’s out) if you want to see how it fits into a bigger picture.

We’ll start with a bunch of “observable” random variables . In order to model these observables, two different agents learn to use two different latent variables:  and  (capital Greek letters  and ). Altogether, the variables satisfy three diagrams. The first agent chooses  such that all the observables are independent given  (so that it can perform efficient inference leveraging ):

 

The second agent happens to be interested in , because  is very redundantly represented; even if any one observable  is ignored, the remainder give approximately-the-same information about .

 

(Here  denotes all the components of  except for .) Finally, we’ll assume that there’s nothing relating the two agents and their latents to each other besides their shared observables, so

 

(Note: these are kinda-toy motivations of the three diagrams; our actual use-case provides more justification in some places.)

We’re going to show that  mediates between  and X, i.e.

 

Intuitive story: by the first diagram, all interactions between components of  “go through” M. So, any information which is redundant across many components of  must be included in  in particular is redundant across many components of , so it must be included in . That intuitive argument isn’t quite technically watertight, but at a glossy level it’s the right idea, and we’re going to prove it diagrammatically.

From our starting diagrams, a natural first step is to use the Stitching Rule, to combine together the -diagram and the  -diagram across the Markov blanket :

 

Via a couple Bookkeeping steps (add an arrow, reorder complete subgraph) we can rewrite that as

 

Note that we have  diagrams here (one for each ), and the variable ordering  respects that diagram for every , so we can Frankenstein all of those diagrams together.  is the root node,  has only  as parent (all diagrams agree on that), and then we take the parent of each  from the  diagram. That yields:

 

And via one more Bookkeeping operation, we get

 

as desired.

Our full end-to-end proof, presented diagrammatically, looks like this:

 

Besides readability, one major benefit of this diagrammatic proof is that we can immediately derive approximation bounds for it. We assign a bound to each starting diagram, then just propagate through, using the approximate version of the rule at each step:

 

As a teaser: one use-case for this particular theorem is that, insofar as the second agent can express things-it-wants in terms of very redundantly represented latent variables (e.g. ), it will always be able to express those things in terms of the first agent’s latent variables (i.e. ). So, the second agent can express what it wants in terms of the first agent’s internal latent variables. It’s an approach to handling ontological problems, like e.g. The Pointers Problem.

What To Read Next

That concludes our list of rules! This post was written as a prelude to our upcoming post on Natural Latents, which will show a real application of these rules. If you want to build familiarity with the rules, we recommend trying a few exercises in this post, then walking through the proofs in that post (once it’s out), and checking the rules used at each step. There are also several exercises in the appendix of this post, alongside the proofs for the rules.

Appendix: Proofs & Exercises

Re-Rooting Rule for Markov Chains

First, we’ll show that we can move the root node one step to the right.

Note that the same equations (read backwards) imply we can move the root node one step to the left. Then, by induction, we can move the root node as far as we want in either direction (noting that at either end one of the two products becomes an empty product).

Approximation

The previous proof shows that  for all  (for any distribution). So,

As before, the same equations imply that we can move the root node one step to either the left or right. Then, by induction, we can move the root node as far as we want in either direction, without changing the KL-divergence. 

Exercise

Extend the above proofs to re-rooting of arbitrary trees (i.e. the diagram is a tree). We recommend thinking about your notation first; better choices for notation make working with trees much easier.

Joint Independence Rule: Exercise

The Joint Independence Rule can be proven using the Frankenstein Rule. This is left as an exercise. (And we mean that unironically, it is actually a good simple exercise which will highlight one or two subtle points, not a long slog of tedium as the phrase “left as an exercise” often indicates.)

Bonus exercise: also prove the conditional version of the Joint Independence Rule using the Frankenstein Rule.

Frankenstein Rule

We’ll prove the approximate version, then the exact version follows trivially.

Without loss of generality, assume the order of variables which satisfies all original diagrams is . Let  be the factorization expressed by diagram , and let  be the diagram from which the parents of  are taken to form the Frankenstein diagram. (The factorization expressed by the Frankenstein diagram is then .)

The proof starts by applying the chain rule to the  of the Frankenstein diagram:

Then, we add a few more expected KL-divergences (i.e. add some non-negative numbers) to get:

Thus, we have 

Factorization Transfer

Again, we’ll prove the approximate version, and the exact version then follows trivially.

As with the Frankenstein rule, we start by splitting our  into a term for each variable:

Next, we subtract some more ’s (i.e. subtract some non-negative numbers) to get:

Thus, we have

Stitching

We start with the  condition:

At a cost of at most , we can replace  with  in that expression, and likewise for the  term. (You can verify this by writing out the ’s as expected log probabilities.)

Notation:

  •  denotes the components of  whose parents are taken from the -diagram;  denotes the components of  whose parents are taken from the -diagram. (Together, these should include all components of .)
  • All products are implicitly over components of whatever variables they’re indexing - e.g.  (which will appear shortly) is over components of .
  •  denotes the parents of  in the -diagram. Each such parent will be a component of  or , which is why we’re subscripting the pair . Likewise for similar expressions.

Recall that each component of  must have no -parents in the -diagram, and each component of  must have no -parents in the -diagram. Let’s pull those terms out of the products above so we can simplify them:

Those simplified terms in combination with  are themselves a , which we can separate out:

… and that last line is the  for the stitched diagram.

New Comment
31 comments, sorted by Click to highlight new comments since:

I think the parentheses are off here. IIUC you want to express the equality of divergences, not divergences multiplied by probabilities (which wouldn't make sense I think).

Typo:  -> 

Man, that top one was a mess. Fixed now, thank you!

This is one of my favorite posts because it gives me tools that I expect to use.

A little while ago, John described his natural latent result to me. It seemed cool, but I didn't really understand how to use it and didn't take the time to work through it properly. I played around with similar math in the following weeks though; I was after a similar goal, which was better ways to think about abstract variables.

More recently, John worked through the natural latent proof on a whiteboard at a conference. At this point I felt like I got it, including the motivation. A couple of weeks later I tried to prove it as an exercise for myself (with the challenge being that I had to do it from memory, rigorously, and including approximation). This took me two or three days, and the version I ended up with used a slightly different version of the same assumptions, and got weaker approximation results. I used the graphoid axioms, which are the standard (but slow and difficult) way of formally manipulating independence relationships (and I didn't have previous experience using them).

This experience caused me to particularly appreciate this post. It turns lots of work into relatively little work.

  • Re-Rooting Rule for Markov Chains
  • Joint Independence Rule
  • Frankenstein Rule
  • Factorization Transfer Rule
  • Stitching Rule for A Shared Markov Blanket
  • Swap Rule  <=====
  • Bookkeeping Rules

Can't find the "Swap rule" in the post, what was that?


The more complex approximation rule requires some additional machinery. For any diagram, we can decompose its  into one term for each variable via the chain rule:

  <=====

If we know how our upper bound  on the diagram’s  decomposes across variables, then we can use that for more fine-grained bounds. Suppose that, for each diagram  and variable , we have an upper bound

  <=====

I guess here there are missing expectations (indicated in red), otherwise  would remain a free RV. The second expectation is not necessary, although omitting it makes the bound unnecessarily strict.


I have never encountered this topic, and I couldn't find it skimming the Handbook of Graphical Models (2019), did you invent it? If not, could you list references?


Do you perchance have something for conditioning or marginalization? I know that graphical marginalization requires using ADMGs (graphs with double-headed arrows) instead of DAGs, I don't know about conditioning.


Exercise

Extend the above proofs to re-rooting of arbitrary trees (i.e. the diagram is a tree). We recommend thinking about your notation first; better choices for notation make working with trees much easier.

In a tree each node has a single parent. Re-rooting means flipping the arrow from the root to one of its children.

In the factorization I do P(old_root)P(new_root|old_root) = P(old_root|new_root)P(new_root), so the proof is the same.

The fact that notation is not involved makes my suspect I may be missing something. Maybe they mean it's needed to write out in full the factorization expression? I guess the nice notation is using ch(X_i) instead of pa(X_i).


Joint Independence Rule: Exercise

The Joint Independence Rule can be proven using the Frankenstein Rule. This is left as an exercise. (And we mean that unironically, it is actually a good simple exercise which will highlight one or two subtle points, not a long slog of tedium as the phrase “left as an exercise” often indicates.)

Bonus exercise: also prove the conditional version of the Joint Independence Rule using the Frankenstein Rule.

Joint independence starts from the graphs

  X_i        {X_not i}

for all i. The Frankenstein rule can not be applied right away because the graphs are not on the same variables, since all but one appear grouped as a single tuple node.

To change that, I replace the tuple nodes with fully connected subgraphs. This is valid because cliques do not constrain the distribution, as any distribution can be factorized in any order if all variables are kept in the conditionals.

I choose the connection order of the cliques such that they respect a global ordering.

Then I apply Frankenstein, picking, for each node, the graph where that node is isolated.

Is there a way to obtain a narrower bound? Yes: I can pick only  from the i-th graph.

Conditional version: basically the same proof, with the common parent as first node in the global order. Needs more care in justifying replacing a tuple node with a clique: Conditional on the parent, the argument above still goes. The only additional independence property of the graph with the tuple is that the parent d-separates the tuple from the singlet, and that is preserved as well.


Frankenstein Rule

We’ll prove the approximate version, then the exact version follows trivially.

Without loss of generality, assume the order of variables which satisfies all original diagrams is . Let  be the factorization expressed by diagram , and let  be the diagram from which the parents of  are taken to form the Frankenstein diagram. (The factorization expressed by the Frankenstein diagram is then .)

The proof starts by applying the chain rule to the  of the Frankenstein diagram:

   <=====

Then, we add a few more expected KL-divergences (i.e. add some non-negative numbers) to get:

Thus, we have 

   <=====

I guess you meant the green thing (first margin arrow) to appear in place of the red thing (second margin arrow)? The math is right, but I hypothesize the final line was intended to express at once the narrow and the loose bounds.

Can't find the "Swap rule" in the post, what was that?

Oh lol, that was in a draft and I took it out.

I guess here there are missing expectations (indicated in red), otherwise  would remain a free RV.

Good catch, thanks.

Exercise answers look good.

Aaaand about this?

I have never encountered this topic, and I couldn't find it skimming the Handbook of Graphical Models (2019), did you invent it? If not, could you list references?

I wouldn't be surprised if someone else has done this before, but I did not get it from anywhere else and have never seen anyone else do something quite like it.

This is really great!

A few weeks ago I was playing with the Good Regulator and John's Gooder version and incidentally I also found myself pulling out some simple graphical manipulation rules. Your 'Markov re-rooting' came into play, and also various of the 'Bookkeeping' rules. You have various more exciting rules here too, thanks!

I also ended up noticing a kind of 'good regulator motif' as I tried expanded the setting with a few temporal steps and partial observability and so forth. Basically, doing some bookkeeping and coarse-graining, you can often find a simple GR structure within a larger 'regulator-like' structure, and conclude things from that. I might publish it at some point but it's not too exciting yet. I do think the overall move of finding motifs in manipulated graphs is solid, and I have a hunch there's a cool mashup of Bayes-net algebra and Gooder Regulator waiting to be found!

I love the Frankenstein rule. FYI, the orderings you're talking about which are 'consistent' with the graphs are called topological orderings, and every DAG has (at least) one. So you could concisely phrase some of your conditions along the lines of 'shared topological order' or 'mutually-consistent topological ordering'.

BTW causal graphs are usually restricted to be DAGs, right? (i.e., the 'causes' relation is acyclic and antisymmetric.) So in this setting where we are peering at various fragments which are assumed to correspond to some 'overall mega-distribution', it might come in handy to assume the overall distribution has some acyclic presentation - then there's always a(t least one) topo ordering available to be invoked.

Oh yeah, I don't know how common it is, but when manipulating graphs, if there's a topo order, I seem to strongly prefer visualising things with that order respected on the page (vertically or horizontally). So your images committed a few minor crimes according to that aesthetic. I can also imagine that some other aesthetics would strongly prefer writing things the way you did though, e.g. with . (My preference would put and slightly lower, as you did with the , graph.)