#Conversion of sparse Artificial Neural Network to sparse Spiking Neural Network can save up to 99 of energy

**Short description**

This repository contains code to train sparse MLPs/CNNs using Cannistraci-Hebb Training (CHT), and to convert sparse Artificial Neural Networks (ANNs) into sparse Spiking Neural Networks (SNNs) using three conversion methods adapted for sparse models.

---

## Repository structure

* `dst_scheduler/` — module for MLP-like DST scheduler used with CHT
* `CHT/` — Cannistraci-Hebb Training components and sparse convolutional layers
* `Models/` — commonly used model architectures (ResNet, VGG variants, MLPs, etc.)
* `input_mlp/` — training scripts for sparse MLPs using CHT (dense MLP training supported)
* `input_cnn/` — training scripts for sparse CNNs using CHT (dense CNN training supported)
* `QCFS/` — SNN conversion using CS-QCFS (method 1), adapted for sparse models
* `SNM/` — SNN conversion using Signed Neuron with Memory (method 2), adapted for sparse models
* `AEC/` — SNN conversion using At-Most-Two-Spike Exponential Coding (method 3), adapted for sparse models
* `graphs/` — analysis and plotting utilities

---

## Usage — flattened commands (single-line)

> Replace placeholders (ARCH, DATASET, DEVICE, CONV_SPAR, LINEAR_SPAR, LR, BATCH_SIZE, L_STEPS, T_VAL, RESULTS_DIR, FIGURES_DIR) with actual values.

### 1) Train sparse MLP (input_mlp)

```bash
python -u run.py --network_structure ARCH --dataset DATASET --cuda_device DEVICE --learning_rate 0.025 --batch_size 32 --epochs 100 --linearlr --sparsity 0.99 --update_interval 1 --zeta 0.3 --decay_factor 0.9 --adaptive_zeta --init_mode swi --self_correlated_sparse --chain_removal --start_T 1.0 --end_T 3.0 --function linear --sparsity_distribution uniform --remove_method weight_magnitude_soft --regrow_method CH2_L3n_soft --itop --T_decay no_decay --record_anp --dst_scheduler
```

Notes: Dense MLP training is supported — omit sparse-specific flags to run dense experiments.

### 2) Train sparse CNN (input_cnn)

```bash
python trainer.py --conv_sparsity CONV_SPAR --architecture ARCH --dataset DATASET --dropout 0.0 --save --epochs 200 --lr LR --bs BATCH_SIZE --one_fc --device DEVICE --update_interval 1 --linear_sparsity LINEAR_SPAR --zeta 0.3 --adaptive_zeta --chain_removal --linear_remove_method weight_magnitude_soft --linear_regrow_method CH2_L3n_soft
```

### 3) Convert with QCFS (QCFS/)

```bash
python -u main.py --conv_sparsity CONV_SPAR --architecture ARCH --dataset DATASET --save --lr LR --bs BATCH_SIZE --l L_STEPS --t 128 --device cuda:0 --linear_sparsity LINEAR_SPAR --dropout 0.0 --one_fc
```

### 4) Convert with SNM (SNM/)

```bash
python -u main.py --architecture ARCH --dataset DATASET --conv_sparsity CONV_SPAR --linear_sparsity LINEAR_SPAR --device cuda:0 --t 128 --one_fc --bs BATCH_SIZE
```

### 5) Convert with AEC (AEC/)

```bash
python -u main.py --conv_sparsity CONV_SPAR --architecture ARCH --dataset DATASET --save --lr LR --bs BATCH_SIZE --t T_VAL --device DEVICE --linear_sparsity LINEAR_SPAR --dropout 0.0 --one_fc --epochs 200
```

## Tips & conventions

* Replace placeholders like `ARCH`, `DATASET`, `DEVICE`, `CONV_SPAR`, `LINEAR_SPAR`, `LR`, `BATCH_SIZE`, `L_STEPS`, `T_VAL` with concrete values.
* Flags without values (e.g., `--save`, `--one_fc`, `--adaptive_zeta`) are boolean switches — include them to enable a feature.
* To choose a CUDA device, use `--device cuda:0`, `--device cuda:1`, etc.
* For reproducible experiments, set seeds to 0.

---

## References

* Zhang, Y., Cerretti, D., Zhao, J., Wu, W., Liao, Z., Michieli, U., & Cannistraci, C. V. (2025). Brain network science modelling of sparse neural networks enables Transformers and LLMs to perform as fully connected.
*Li, H., Wang, Y., Zhang, Y., & Cannistraci, C. V. (2025). Cannistraci-Hebb Training of Convolutional Neural Networks (No. 2025091904). Preprints. https://doi.org/10.20944/preprints202509.1904.v1
* Yang, H., Yang, S., Zhang, L., Dou, H., Shen, F., & Zhao, J. (2025). CS-QCFS: Bridging the performance gap in ultra-low latency spiking neural networks. Neural Networks.
* Wang, Y., Zhang, M., Chen, Y., & Qu, H. (2022). Signed Neuron with Memory: Towards Simple, Accurate and High-Efficient ANN-SNN Conversion. IJCAI 2022.
* Chen, Y., Feng, R., Xiong, Z., Xiao, J., & Liu, J. K. (2024). High-performance deep spiking neural networks via at-most-two-spike exponential coding. Neural Networks.

---

