# Federated Learning with Flower

This project sets up a Federated Learning (FL) environment using [Flower (flwr)](https://flower.dev) and PyTorch. Follow the steps below to set up the environment and run an experiment.

## Environment Setup

Create a conda environment from the provided YAML file:

```bash
conda env create --file flwr-pt_env.yaml --name new_env_name
conda activate new_env_name

# install PyTorch
# pip install torch==2.5.1 torchvision==0.20.1 torchaudio==2.5.1 --index-url https://download.pytorch.org/whl/cu121
```

## Project Structure
```bash
FL_OSSL
│
├── flwr-pt_env.yaml               # Conda environment configuration
├── prepare_data.py                # Dataset preparation script
├── data/                          # Processed data
├── saved_models/
└── src/
```

## Prepare Dataset
Before running the simulation, prepare the dataset by executing:
```bash
python prepare_data.py --cfg ./src/experiment/exp1/config.yaml
```

## Run the Experiment
Navigate to the experiment directory and launch the Flower simulation:
```bash
cd ./src/experiment/exp1
PYTHONPATH=../../.. flwr run
```
The `PYTHONPATH=../../..` ensures that Python can locate the root modules properly when running inside a subdirectory.
