An implementation of flag algebras.
Flag algebras is a framework used to produce computer-assisted proofs of some inequalities in combinatorics, relying on Semi-Definite Programming.
```rust // Proving that in any graph, at least 1/4 of the triples // are triangles or independent sets. extern crate flag_algebra;
use flagalgebra::*; use flagalgebra::flags::Graph; use sdp::Problem;
pub fn main() { // Work on the graphs of size 3. let basis = Basis::new(3);
// Define useful flags. let k3 = flag(&Graph::new(3, &[(0, 1), (1, 2), (2, 0)])); // Triangle let e3 = flag(&Graph::new(3, &[])); // Independent set of size 3
// Definition of the optimization problem.
let pb = Problem::
// Write the correspondind SDP program in "goodman.sdpa". // This program can then be solved by CSDP. The answer would be 0.25. pb.write_sdpa("goodman").unwrap(); } ```
License: GPL-3.0