# Decentralized Stochastic Bilevel Optimization

Our code is implemented in python with mpi4py. Here we provide instructions on how to run our code. In each experiment we set the number of total agents equal to 8.

## Prerequisites

+ python=3.8.12
+ pytorch=1.11.0
+ mpi4py=3.1.3
+ numpy=1.21.5

## Main args

+ `--alg`: Algorithms (SUN-SE, SUN-GT)
+ `--o_steps`: Total number of iterations
+ `--num_of_nodes`: The total number of agents
+ `--network_weight`: The weight parameter used in the ring network

## Logistic regression on synthetic heterogeneous data

+ ### DSBO with batch size 100 and noise rate 0.1

```python
mpiexec -np 8 python synthetic_logistic_regression.py --alg SUN-SE --batch_size 100 --noise_rate 0.1
```

## Hyperparameter optimization on real-world data

+ ### Hyperparameter optimization on MNIST dataset

```python
mpiexec -np 8 python l2reg_on_mnist.py --alg SUN-SE
```