# SPON
Activation Sparsity with Spontaneous Neurons

## 🛠 Installation

### 1. Environment Setup
We recommend using **Python 3.10.0** or higher. You can set up your environment using Conda or a virtual environment:

```bash
# Using Conda (Recommended)
conda create --name spon python=3.10
conda activate spon

# OR using venv
python -m venv spon
source spon/bin/activate
```

### 2. Dependencies
Install the versions of PyTorch that matches your CUDA environment. For CUDA 12.4 and PyTorch v2.6.0, use the following:

```bash
# Install PyTorch
pip install torch==2.6.0 torchvision==0.21.0 torchaudio==2.6.0 --index-url https://download.pytorch.org/whl/cu124
```

### 3. LLM & Utility Packages

```bash
pip install transformers==4.52.4 datasets==3.6.0 accelerate==1.10.1 lm_eval==0.4.9 peft==0.17.1 fire
pip install deepspeed
```

## 🏋️ Training
```bash
bash scripts/run.sh l2
```

## 🧪 Evaluation
To evaluate the model's performance and generate responses via chat completion, use the provided evaluation script:

```bash
bash scripts/eval.sh
```
