# New Part

Install the requirements from the `shell.nix` file, that is primarily METIS and the python packages from `requirements.txt`

```
usage: main.py [-h] [--algos ALGOS [ALGOS ...]] [--bisectalgos BISECTALGOS [BISECTALGOS ...]] [--ks KS [KS ...]] [--num_itr NUM_ITR] [--n_processors N_PROCESSORS]
               graph

positional arguments:
  graph                 Path to graph file

options:
  -h, --help            show this help message and exit
  --algos ALGOS [ALGOS ...]
                        Algorithms to run
  --bisectalgos BISECTALGOS [BISECTALGOS ...]
                        Bisection algorithms
  --ks KS [KS ...]      Values of k
  --num_itr NUM_ITR     Number of iterations
  --n_processors N_PROCESSORS
                        Number of processors
```

- `num_itr` is the number of iterations for non-deterministic algorithms
- `algos` is a subset of `["ours", "cb", "gb", "ca"]`
- `bisectalgos` only has effect if `ours in algos`. Subset of `["spectral", "spectralbalanced_10", "spectralbalanced_1", "metismulti_1", "metismulti_10", "metismulti_100"]`.
- `n_processors` isn't implemented at the moment. Default is 32.

Running `main.py` will write results as many text files to `results/`. Then, run `results_to_json.py` to convert them to a json. Then, the json can be visualized with `visualize.py`.

