# FedSSM

Federated Learning with State Space Models for proactive client selection.

## Overview

FedSSM introduces a decision-aware state space model to predict training dynamics and enable counterfactual client selection in federated learning.

**Key Components:**
- **State Space Model**: Action-conditioned SSM with HiPPO initialization
- **Counterfactual Selector**: Adaptive budget + explore-exploit tradeoff
- **Trust Aggregator**: Surprise-based uncertainty calibration

## Structure

```
fedssm/
├── models/
│   ├── __init__.py
│   └── ssm.py              # State Space Model
├── core/
│   ├── __init__.py
│   ├── selector.py         # Client Selection
│   ├── aggregator.py       # Trust-weighted Aggregation
│   └── server.py           # FedSSM Server
├── utils/
│   └── __init__.py
├── configs/
│   └── default.yaml
├── main.py                 # Training entry
└── README.md
```

## Usage

```bash
# Default config
python main.py --config configs/default.yaml

# Custom settings
python main.py --config configs/default.yaml --num_clients 20 --num_rounds 10
```

## Algorithm

```
For each round t:
    1. Compute observation x_t = [loss, grad_norm, grad_var, progress]
    2. SSM prediction: h_t, x_hat_t = SSM(h_{t-1}, x_{t-1}, a_{t-1})
    3. Compute surprise: S_t = (x_t - x_hat_t)^T Σ^{-1} (x_t - x_hat_t)
    4. Adaptive budget: N_t = N_min + sigmoid(κ(S_t - θ_S)) * (N_max - N_min)
    5. Select clients with explore-exploit balance
    6. Local training on selected clients
    7. Trust-weighted aggregation based on surprise
```

## Key Equations

**State Transition:**
```
h_t = A(a) @ h_{t-1} + B(a) @ x_{t-1}
x_hat_t = C @ h_t
```

**Participation Budget:**
```
N_t = N_min + sigmoid(κ(S_{t-1} - θ_S)) * (N_max - N_min)
```

**Selection Probability:**
```
p_i ∝ (1 - ρ) * w_explore + ρ * w_exploit
ρ = sigmoid(τ(θ_S - S_t))
```

**Trust Coefficient:**
```
τ_i = exp(-S_t * η * |L_i - L_bar| / std(L))
```

## Configuration

Key parameters in `configs/default.yaml`:

| Parameter | Description | Default |
|-----------|-------------|---------|
| `state_dim` | SSM hidden state dimension | 32 |
| `n_min` | Minimum participation budget | 4 |
| `n_max` | Maximum participation budget | 8 |
| `kappa` | Budget sigmoid steepness | 2.0 |
| `tau` | Explore-exploit switch steepness | 2.0 |
| `trust_eta` | Trust penalty coefficient | 1.0 |


