Independent Set |
Maximum set of pairwise non-adjacent vertices in a graph |
data:image/s3,"s3://crabby-images/ffba6/ffba68d4391a53fb0b22cf33149b5edf784d1c78" alt="" |
data:image/s3,"s3://crabby-images/8ff2f/8ff2ffcd720d8d6dfee2d6ad48b97b60359d978f" alt="" |
p = MixedIntegerLinearProgram(maximization = True)
b = p.new_variable(binary = True)
p.set_objective( sum([b[v] for v in g]) )
for u,v in g.edges(labels = False):
p.add_constraint( b[u] + b[v] <= 1 )
p.solve()
b = p.get_values(b)
print [v for v,i in b.items() if i]
# Note: viewed as a boolean, 0 is False and 1.0 is True
|
Dominating Set |
Minimum set of vertices whose neighborhood is the whole graph |
data:image/s3,"s3://crabby-images/8817e/8817e9e36da38ff43ac297b2cc6e7dc662dc05a8" alt="" |
data:image/s3,"s3://crabby-images/81df2/81df2e814304890211d076cedfb2cec625205b60" alt="" |
|
Vertex Cover |
Minimum Set of vertices touching each edge |
data:image/s3,"s3://crabby-images/60b17/60b17a9ff3318cddebddf7d6cabf8b163a3941f9" alt="" |
|
|
Partition |
Partition a set of integers into two sets whose sum is equal |
data:image/s3,"s3://crabby-images/20af9/20af950edee8617b6dabf3b0bfa75959f3d89361" alt="" |
|
|
Bipartite Set |
Partition the graph into two independent sets |
data:image/s3,"s3://crabby-images/98913/98913ef1f64d0e8bbdcb26973f0f7bc6a3af2261" alt="" |
|
|
Subset Sum |
Find a nonempty subset of integers with null sum |
data:image/s3,"s3://crabby-images/1f959/1f9594ccf0a65fc02b9af0dd8f232f660f65a420" alt="" |
|
|
Distances |
Compute the distance from vertex 0 to any other |
data:image/s3,"s3://crabby-images/6152e/6152e91481f7f30a8ac7fde919c0f40ccfcd8f37" alt="" |
|
|
Girth |
Size of the shortest cycle |
data:image/s3,"s3://crabby-images/e73e8/e73e87f0e4b4e93d90f8c0ef8e8101a1c3566814" alt="" |
|
|
Matching |
Maximum number of non-incident edges |
data:image/s3,"s3://crabby-images/9854f/9854f41f3e5b290d86f6eb5277fe0ff6089420b4" alt="" |
|
|
Feedback Arc Set |
Minimum set of arcs hitting all circuits |
data:image/s3,"s3://crabby-images/4cdc7/4cdc7b2599dedcb55751b38d5f6d35e0add4799c" alt="" |
|
|
Feedback Vertex Set |
Minimum set of vertices hitting all circuits |
data:image/s3,"s3://crabby-images/012dd/012ddc94d7207347ace0d72f0f13a711e22bfc0b" alt="" |
|
|
Hamiltonian Cycle |
A cycle going through all vertices |
data:image/s3,"s3://crabby-images/2154a/2154a87f46b3b4d418a22e75ac48c5820c014eab" alt="" |
|
|
3-coloration |
Partition a graph into three independent sets |
data:image/s3,"s3://crabby-images/de722/de722a50c056dab99a744eb7292c6ed1a929b8d0" alt="" |
|
|
GCD |
The gcd of a list of integers |
gcd([12,15,30]) = 3
|
|
|
Sudoku |
Fill an incomplete Sudoku grid |
Get some instances of the Sudoku class and solve them, for example:
sage: S = Sudoku('\
....: 1....7.9.\
....: .3..2...8\
....: ..96..5..\
....: ..53..9..\
....: .1..8...2\
....: 6....4...\
....: 3......1.\
....: .4......7\
....: ..7...3..') ; S
+-----+-----+-----+
|1 | 7| 9 |
| 3 | 2 | 8|
| 9|6 |5 |
+-----+-----+-----+
| 5|3 |9 |
| 1 | 8 | 2|
|6 | 4| |
+-----+-----+-----+
|3 | | 1 |
| 4 | | 7|
| 7| |3 |
+-----+-----+-----+
sage: sudoku_solve_milp(S)
+-----+-----+-----+
|1 6 2|8 5 7|4 9 3|
|5 3 4|1 2 9|6 7 8|
|7 8 9|6 4 3|5 2 1|
+-----+-----+-----+
|4 7 5|3 1 2|9 8 6|
|9 1 3|5 8 6|7 4 2|
|6 2 8|7 9 4|1 3 5|
+-----+-----+-----+
|3 5 6|4 7 8|2 1 9|
|2 4 1|9 3 5|8 6 7|
|8 9 7|2 6 1|3 5 4|
+-----+-----+-----+
|
|
|