# Algorithms for the preorder problem

This repository contains implementations of the algorithm described in the paper **The Preordering Problem: A Hybrid of Corrleation Clustering and Partial Ordering**.

![image](ego-network-preorder-example.png)


## Requirements

The python packages listed in the `requirement.txt` file are required.
In order to solve the ILPs with gurobi a license is required.
Free academic licenses can be obtained [here](https://www.gurobi.com/academia/academic-program-and-licenses/).

## Installation

pip install -r requirements.txt

## Usage Example

```python
import numpy as np
import matplotlib.pyplot as plt
from preordering_problem.ilp_solver import Preorder
from preordering_problem.drawing import PreorderPlot

# create a value function
values = np.array([
    [ 0,  2,  0,  0,  0, -1],
    [ 3,  0, -2,  0,  0,  4],
    [ 0,  5,  0, -1,  1,  0],
    [ 0,  0, -2,  0,  2, -1],
    [ 0, -3,  0, -2,  0,  3],
    [-3,  0,  0,  0, -1,  0]
])
# create an instance of the preordering problem
preorder = Preorder(values, binary=True)
# solve ILP
preorder.solve()

# plot results
plotter = PreorderPlot(preorder.get_variable_values(), values)
plotter.plot()
plt.show()
```

## Experiments

To reproduce the experiments from the article, download the data from

- https://snap.stanford.edu/data/congress-twitter.html
- https://snap.stanford.edu/data/ego-Twitter.html
- https://snap.stanford.edu/data/ego-Gplus.html

and run the scripts from the `experiments` directory:

```
cd experiments
python congress.py
python ego_networks.py
```

You may want to modfy the `main` function in the scripts to run only some of the experiments.