Skip to main content

Generating Chessboards With K-Independant Vertex Sets

After looking at Julio Peironcely's poster on generating chemical structures, where he describes using Canonical Path Augmentation (I think due to Brendan McKay) I went looking for more about it. One thing I found was this talk/slideshow by Mathieu Dutour Sikirić - incidentally coauthor of a nice book on Chemical Graphs.

Anyway; that's the context. Now : about chessboards? Well one of the examples given for augmentation (or 'orderly') schemes of independent vertex sets. I'm not sure what made me think of chessboards for this, but I think it's a fairly standard simple toy example. Let me show an example for 3x3 boards:

So, these are all the three by three boards where no two black squares share an edge. In other words, if the board is considered as a grid-shaped graph, then these are the k-independent vertex sets. So the question is : how to generate these?

The simple way, of course, is just to fill in every square and eliminate those boards that have pairs of black squares across an edge. This is the 'brute force' approach, and scales badly : there are 29 boards but we only want 20 of these, or just 3%. For 4x4 boards, this fraction is even smaller - 131 of 216 boards which is only 0.19%. This is 0.0026% for 5x5 boards.

So, the number of boards increases rapidly as the size increases and any way of decreasing this large search space is essential. The approach outlined in Mathieu's talk is quite simple : only try sets (boards) that are the minimal representative in their orbit. Ok, so maybe that doesn't sound so simple :) but look at this:

Here are 3x3 boards, with a numbering (any one will do), the equivalence classes of the cells, and a set of orbits. Lets say we've just generated {0, 4, 6} : how do we check if it is the minimal representative? Well, so long as we have the automorphism group of the board we just apply each permutation in the group to the set of numbers and check to see if any are smaller. In this case, {0, 2, 4} is smaller, so we don't consider {0, 4, 6}.

It's really as simple as that. Of course, we have to check each newly added cell to make sure it is not adjacent, but that can be done without consideration of previously generated boards. This means we don't have to store solutions, which means it can be done in parallel without communication. See how many there are just for 5x5 boards:

I suppose that one last question about all this is : so what? Does this have anything to do with chemistry? Well, actually, it does. Consider the bond order assignment problem : the second image shows all the possible assignments, which you may notice has duplicates (3, 5, 10, and 12 for example). Also consider the line graph approach to double bond systems where again the second image shows a pair of colorings of line graphs. In fact, these are k-independent sets...

Oh, and there is code here

Comments

Anonymous said…
interesting work.

Lemma: When you generate the next solution state, you could ignore previous state.

So this means previous state checks are reduced.

Now the number of solutions are not effected, right?
gilleain said…
Missed this comment, sorry!

Yes, this is exactly right - you can break up the problem into parts, and do each independently.

So, the second post on this topic about graphs should really mention that you can start with a graph on n vertices, and generate all the children on (n+1) vertices.

This can be done for different parents on completely different machines, and you would still get the same number of children.

Popular posts from this blog

Adamantane, Diamantane, Twistane

After cubane, the thought occurred to look at other regular hydrocarbons. If only there was some sort of classification of chemicals that I could use look up similar structures. Oh wate, there is . Anyway, adamantane is not as regular as cubane, but it is highly symmetrical, looking like three cyclohexanes fused together. The vertices fall into two different types when colored by signature: The carbons with three carbon neighbours (degree-3, in the simple graph) have signature (a) and the degree-2 carbons have signature (b). Atoms of one type are only connected to atoms of another - the graph is bipartite . Adamantane connects together to form diamondoids (or, rather, this class have adamantane as a repeating subunit). One such is diamantane , which is no longer bipartite when colored by signature: It has three classes of vertex in the simple graph (a and b), as the set with degree-3 has been split in two. The tree for signature (c) is not shown. The graph is still bipartite accordin

Király's Method for Generating All Graphs from a Degree Sequence

After posting about the Hakimi-Havel  theorem, I received a nice email suggesting various relevant papers. One of these was by Zoltán Király  called " Recognizing Graphic Degree Sequences and Generating All Realizations ". I have now implemented a sketch of the main idea of the paper, which seems to work reasonably well, so I thought I would describe it. See the paper for details, of course. One focus of Király's method is to generate graphs efficiently , by which I mean that it has polynomial delay. In turn, an algorithm with 'polynomial delay' takes a polynomial amount of time between outputs (and to produce the first output). So - roughly - it doesn't take 1s to produce the first graph, 10s for the second, 2s for the third, 300s for the fourth, and so on. Central to the method is the tree that is traversed during the search for graphs that satisfy the input degree sequence. It's a little tricky to draw, but looks something like this: At the top

General Graph Layout : Putting the Parts Together

An essential tool for graph generation is surely the ability to draw graphs. There are, of course, many methods for doing so along with many implementations of them. This post describes one more (or perhaps an existing method - I haven't checked). Firstly, lets divide a graph up into two parts; a) the blocks, also known as ' biconnected components ', and b) trees connecting those blocks. This is illustrated in the following set of examples on 6 vertices: Trees are circled in green, and blocks in red; the vertices in the overlap between two circles are articulation points. Since all trees are planar, a graph need only have planar blocks to be planar overall. The layout then just needs to do a tree layout  on the tree bits and some other layout on the embedding of the blocks. One slight wrinkle is shown by the last example in the image above. There are three parts - two blocks and a tree - just like the one to its left, but sharing a single articulation point. I had