# Federated Recommendation Framework

This repository provides a federated recommendation framework for training and evaluating models on public datasets using FedNCF, FedMF, LightGCN, and other variants. The framework supports flexible configuration via YAML files.

---

## Datasets

- Public datasets used in the paper:
  - **Amazon**: [https://nijianmo.github.io/amazon/index.html](https://nijianmo.github.io/amazon/index.html)
  - **MovieLens-1M**: [https://grouplens.org/datasets/movielens/1m/](https://grouplens.org/datasets/movielens/1m/)
  - **MovieLens-100k**: [https://grouplens.org/datasets/movielens/100k/](https://grouplens.org/datasets/movielens/100k/)
- Dataset configurations are set in `config/data_config.yaml`.

---

## Model

- Model configurations are set in `config/model_config.yaml`.
- Available models can be found in the `zoo/` directory.
- Examples include:
  - FedMF_FLRL
  - FedLightGCN_FLRL
  - FedNCF_FLRL

---

## Running Experiments

You can run a model with the following command:

```bash
python main.py --expid {expid in model_config.yaml} --gpu {-1 for CPU, otherwise specify CUDA device}
````

### Example:

```bash
python main.py --expid FedMF_ml1m_triple_101 --gpu 0
```

---

## Requirements

This code requires the following Python packages:

* PyYAML
* pandas
* scikit-learn
* numpy
* h5py
* tqdm

You can also see a complete list of dependencies in `requirements.txt`.

---

## Acknowledgement

* This code framework is based on [FuxiCTR](https://github.com/reczoo/FuxiCTR).

---

## Notes

* Make sure to download and place datasets according to the paths specified in `data_config.yaml`.
* Adjust `model_config.yaml` to configure your experiments, including dataset, model, training parameters, and evaluation metrics.
