Skip to content
/ blossalg Public

Construct a maximum matching on a graph using the blossom algorithm.

License

Notifications You must be signed in to change notification settings

nenb/blossalg

Repository files navigation

Logo

blossalg

CI Status Test Coverage Code style: black

blossalg is a Python implementation of the Edmonds algorithm for constructing maximum matchings on graphs. For more information on how the Edmonds algorithm works see the Wikipedia page.

Installation

You can install blossalg from PyPI:

pip install blossalg

blossalg is supported on Python 2.7 and Python 3.8.

Usage

You can run blossalg as follows:

blossalg infile.csv [outfile.txt]

The input file infile.csv contains information on the number of nodes and the neighbours of each node. This information is stored using a series of comma-delimited binary-valued strings. Nodes are identified by different rows and columns and a value of 1 indicates a node neighbour. By convention a node cannot be a neighbour with itself.

For example, the input file of a three node graph where both node 0 and node 2 are neighbours of node 1 would look as follows:

0,1,0
1,0,1
0,1,0

Given an input file, blossalg will compute the maximum matching using the Edmonds blossom algorithm. The total number of matched nodes will then be output to screen.

If an output file outfile.txt is supplied the matched pairs from the maximal matching will be saved to the file. The format of the output is as follows. Each node and its matched node will be stored as node_number: matched_node_number. The node number will correspond to the node number from the input file (e.g. row 1 in the input file will represent node 0 in the output file). Each matched pair in the output file will be separated by a newline. By convention, unmatched nodes are not included in the outfile.

About

Construct a maximum matching on a graph using the blossom algorithm.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages