For minimizing the BCD over randomly placed physical nodes:

```
python3 BTSP_MSR.py \
--physical_nw_file physical_NWs/n{n}_seed{0-4}_square.npy \
--nw_topology [ring, exponential, one_peer_exp, sparse_exp]
```

  

For minimizing the BCD over the Ebone NW:
```
python3 BTSP_MSR.py \
--physical_nw_file physical_NWs/ebone.gml \
--nw_topology [ring, exponential, one_peer_exp, sparse_exp]
```

  

Optional flags:
```
--milp_opt: Use SCIP-based MILP formulation
--greedy_opt: Use greedy heuristic
--no_opt: Use random permutation as baseline
--seed: Fix random seed (default: 42)
--verbose: Print detailed logs
```
Note: If none of --milp_opt, --greedy_opt, or --no_opt are set, the BTSP-MSR 2-approximation will be used by default.


To run all experiments related to decentralized learning, please execute the following script in `decentralized_learning` directory:
```bash
bash run_all.sh
```