### Running hyperparameter sweep

To run the hyperparameter sweep you simply run the command

```bash
./research/flamby/fed_heart_disease/apfl/run_hp_sweep.sh \
   path_to_config.yaml \
   path_to_folder_for_artifacts/ \
   path_to_folder_for_dataset/ \
   path_to_desired_venv/
```

from the top level directory of the repository

An example is something like
``` bash
./research/flamby/fed_heart_disease/apfl/run_hp_sweep.sh \
   research/flamby/fed_heart_disease/apfl/config.yaml \
   research/flamby/fed_heart_disease/apfl/ \
   /Users/jones/Desktop/FLambyDatasets/fed_heart_disease/ \
   /h/djones/repository/fl4health_env/
```

In order to manipulate the grid search being conducted, you need to change the parameters for `alpha` and `lr`, the apfl interpolation value and the learning rate, respectively, in the `run_hp_sweep.sh` script directly.

### Large Model APFL

The default setup for the APFL experiments is "small" models using the Baseline() model implemented by FLamby. This "small" model is simply a logistic regression model with a very small number of trainable parameters. To run experiments with the "large" model, which incorporates an equivalent number of trainable parameters to the FENDA model implementation. To use the large model, one need only replace instances of Baseline() with FedHeartDiseaseLargeApfl(), along with including the proper imports in the experimental code. The large APFL model is here:

```
research/flamby/fed_heart_disease/apfl/apfl_large_model.py
```
