# TriGuardFL: Triple-Layer Detection for Byzantine-Robust Federated Learning

[![Python Version](https://img.shields.io/badge/Python-3.9+-blue.svg)](https://www.python.org/)
[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)

TriGuardFL is a research framework for studying Byzantine-robust federated learning. It reproduces classic model-poisoning attacks, implements a layered defense pipeline, and provides tooling to evaluate aggregation strategies under non-IID client data.

## Overview

Federated learning (FL) enables clients to collaborate on training without exposing raw data. The distributed setup, however, makes the system vulnerable to adversaries who submit poisoned model updates. TriGuardFL introduces a three-stage defense:

1. **Cosine-similarity screening** to flag suspicious updates quickly.
2. **Fine-grained validation** on a stratified dataset to disambiguate benign drift from malicious behaviour.
3. **Bayesian reputation tracking** that discounts repeat offenders while preserving benign participation.

The framework supports the following objectives:

- Simulate federated learning rounds with configurable attack capabilities.
- Benchmark layered defenses alongside resilient aggregators such as Krum, Median, and Trimmed Mean.
- Prototype and compare new defensive strategies under controlled experimental settings.

## Technology Stack

- Python 3.9+
- [uv](https://github.com/astral-sh/uv) for environment management
- PyTorch and NumPy for modelling and numerical computation
- `pyproject.toml` for dependency and metadata management

## Getting Started

Use `uv` to create an isolated environment and install dependencies.

```bash
# Clone the repository
git clone <repository-url>
cd Byzantine-robust-FL

# Create and activate the virtual environment
uv venv
source .venv/bin/activate  # adapt for your shell/OS

# Install project dependencies
uv pip install -e .

# (Optional) install development extras
uv pip install ".[dev]"
```

## Running Experiments

The project exposes a CLI entry point named `brfl-run`. All configuration options are available via command-line flags or YAML configuration files.

```bash
# Display available arguments
brfl-run --help
```

### Typical Workflows

- **MNIST baseline without attackers**

  ```bash
  brfl-run --dataset mnist --model mlp --epochs 10 --num_attackers 0
  ```

- **CIFAR-10 with Min-Max attackers and TriGuardFL defense**

  ```bash
  brfl-run \
    --dataset cifar \
    --model cnn \
    --submodel VGG11 \
    --epochs 50 \
    --attack \
    --attackway minmax \
    --num_attackers 5 \
    --detection TriGuardFL
  ```

- **Non-IID training with FLTrust detection**

  ```bash
  brfl-run \
    --dataset cifar \
    --model cnn \
    --epochs 100 \
    --attack \
    --num_attackers 4 \
    --detection FLTrust
  ```

Configuration presets can be supplied with the `--config` flag (e.g., `brfl-run --config configs/demo1.yaml`). Command-line arguments override values from the YAML file.

## Empirical Results

TriGuardFL maintains accuracy close to the no-attack baseline while avoiding false positives on benign but non-IID clients. Competing defences such as DeFL and Multi-Krum show pronounced degradation under full-knowledge adversaries.

![Evolution of test accuracy on CIFAR-10 defenses under various model poisoning attacks.](asset/accuracy_ResNet18_32users_16Chosenusers_4attackers.png)

## Contributing

Contributions are welcome. Please open an issue to discuss substantial changes before submitting a pull request.

1. Fork the repository.
2. Create a feature branch (`git checkout -b feature/my-change`).
3. Commit with clear messages (`git commit -m "Describe change"`).
4. Push the branch and open a pull request.

## License

This project is released under the MIT License. Refer to the `LICENSE` file for the full text.
