Skip to content

Latest commit

 

History

History
105 lines (81 loc) · 4.77 KB

README.org

File metadata and controls

105 lines (81 loc) · 4.77 KB

graphsat – a python package for graph satisfiability

graphsat

https://zenodo.org/badge/doi/10.5281/zenodo.4662169.svg

A Python package brought to you by Vaibhav Karve and Anil N. Hirani, Department of Mathematics, University of Illinois at Urbana-Champaign.

We introduce a Python package that recognizes clauses, Cnfs, graphs, hypergraphs, and multi-hypergraphs. The package implements local graph-rewriting, graph-satchecking, calculation of graph disjunctions, as well as checking of new reduction rules.

This package is written in Python v3.10, and is publicly available under an the GNU-GPL-v3.0 license. It is set to be released on the Python Packaging Index as an open-source scientific package written in the literate programming style. We specifically chose to write this package as a literate program, despite the verbosity of this style, with the goal to create reproducible computational research.

Installation and usage

To get started running the code in this package, you will need 3 things –

  1. A copy of this repository downloaded from GitHub.
  2. Python 3.10 or higher.
  3. An installation of just from GitHub:casey/just.

Algorithms

Currently, graphsat implements the following algorithms –

  • For formulae in conjunctive normal forms (CNFs), it implements variables, literals, clauses, Boolean formulae, and truth-assignments. It includes an API for reading, parsing and defining new instances.
  • For graph theory, the package includes graphs with self-loops, edge-multiplicities, hyperedges, and multi-hyperedges. It includes an API for reading, parsing and defining new instances.
  • For satisfiability of CNFs and graphs, it contains a bruteforce algorithm, an implementation that uses the open-source sat-solver PySAT, and an implementation using the MiniSAT solver.
  • Additionally, for graph theory, the library also implements vertex maps, vertex degree, homeomorphisms, homomorphisms, subgraphs, and isomorphisms. This allows us to encode local rewriting rules as well as parallelized grid-based searching for forbidden structures.
  • Finally, graphsat has a tree-based recursive reduction algorithm that uses known local-rewrite rules as well as algorithms for checking satisfiability invariance of proposed reduction rules.

Principles

graphsat has been written in the functional-programming style with the following principles in mind –

  • Avoid classes as much as possible. Prefer defining functions instead.
  • Write small functions and then compose/map/filter them to create more complex functions (using the functools library).
  • Use lazy evaluation strategy whenever possible (using the itertools library).
  • Add type hints wherever possible (checked using the mypy static type-checker).
  • Add unit-tests for each function (checked using the pytest framework). Firther, add property-based testing wherever possible (using the hypothesis framework.

Overview of the package

The package consists of several different modules.

  1. Modules that act only on Cnfs –
    cnf.py
    Constructors and functions for sentences in conjunctive normal form (Cnf).
    cnf_simplify.py
    Functions for simplifying Cnfs, particularly (a∨b∨c) ∧ (a∨b∨¬ c) ⇝ (a ∨ b).
    prop.py
    Functions for propositional calculus – conjunction, disjunction and negation.
  2. Modules that act only on graphs –
    graph.py
    Constructors and functions for simple graphs.
    mhgraph.py
    Constructors and functions for Loopless-Multi-Hyper-Graphs
    morphism.py
    Constructors and functions for Graph and MHGraph morphisms.
  3. Modules concerning SAT and GraphSAT –
    sat.py
    Functions for sat-checking Cnfs, Graphs, MHGraphs.
    sxpr.py
    Functions for working with s-expressions.
    operations.py
    Functions for working with graph-satisfiability and various graph parts.
  4. Modules that implement and compute local graph rewriting, rule reduction etc.
    graph_collapse.py
    Functions for collapsing a set of Cnfs into compact graphs representation.
    graph_rewrite.py
    An implementation of the Local graph rewriting algorithm.
  5. Finally, the test suite for each module is located in the test/ folder.