# Hi-SAFE


Implementation of our ICLR 2026 paper: [Hi-SAFE: Hierarchical Secure Aggregation for Lightweight Federated Learning]

**Abstract:**  
Federated learning (FL) faces challenges in ensuring both privacy and communication efficiency, particularly in resource-constrained environments such as Internet of Things (IoT) and edge networks. While sign-based methods, such as sign stochastic gradient descent with majority voting (signSGD-MV), offer substantial bandwidth savings, they remain vulnerable to inference attacks due to exposure of gradient signs. Existing secure aggregation techniques are either incompatible with sign-based methods or incur prohibitive overhead. 
To address these limitations, we propose *Hi-SAFE*, a lightweight and cryptographically secure aggregation framework for sign-based FL. Our core contribution is the construction of efficient majority vote polynomials for signSGD-MV, derived from Fermat’s Little Theorem. This formulation represents the majority vote as a low-degree polynomial over a finite field, enabling secure evaluation that hides intermediate values and reveals only the final result. We further introduce a hierarchical subgrouping strategy that ensures constant multiplicative depth and bounded per-user complexity, independent of the number of users $n$. 
Hi-SAFE reduces per-user communication by over 94% when $n \geq 24$, and total cost by up to 52% at $n = 24$, while preserving model accuracy. Experiments on benchmark datasets confirm the scalability, robustness, and practicality of Hi-SAFE in bandwidth-constrained FL deployments.
---

## Requirements

This code was tested on the following environments:

* Python 3.9.12
* PyTorch 1.12.1 with CUDA 11.3
* Ubuntu 22.04 

You can install all necessary packages from requirements.txt

* Python3
* Pytorch
* Torchvision

```bash
pip install -r requirements.txt
```
## Experiments

Experiments are conducted on three image classification datasets: MNIST, FMNIST, and CIFAR-10 (automatically downloaded via torchvision).

### How to Run

* To run it on Python:

```
python Hi-SAFE_main.py --lr 0.001 --epoch 2 --lrdecay 3 --local_bs 100 --dataset fmnist --frac 0.24 --iid 1  --seed 2025 
```
* Or to run it on Ubuntu: 
* ```cd``` to ```scripts/```

```bash
bash Hi-SAFE.sh
```
* All parameters required for the experiment are described in ```options.py```. Please see the python file for a detailed description of the parameters.



## Acknowledgment

This project includes code originally developed by Ashwin R Jadhav at https://github.com/AshwinRJ/Federated-Learning-PyTorch
