# TropNNC: Structured Neural Network Compression Using Tropical Geometry

Official implementation of the paper:

**TropNNC: Structured Neural Network Compression Using Tropical Geometry**  
Accepted at *Transactions on Machine Learning Research (TMLR)*.

TropNNC is a framework for compressing neural networks with linear and convolutional layers and ReLU-type activations using tropical geometry. The method reduces the tropical polynomials associated with network layers to identify redundant neurons. Unlike previous geometric approaches, TropNNC adaptively selects the weights of retained neurons, leading to improved approximations. The framework is data-free, requiring access only to network weights and no training data.

---

## Repository Structure

```text
.
├── src/
│   ├── algorithms.py                   # Compression algorithms implementation
│   ├── dataloading.py                  # Pytorch custom dataloaders
│   ├── experiment_*.py                 # Code for each of the experiments
│   ├── models.py                       # Model definitions
│   ├── pruning.py                      # Network pruning class and methods
│   ├── report.py                       # Writes tables or plots in src/plots/
│   ├── training.py                     # Training functions
│   ├── requirements.txt
│   ├── environment.yml
│   ├── data/
│   ├── models/
│   ├── plots/                          # Contains generated plots and tables
│   ├── fonts/
│   ├── results_*                       # Files where results are written
│   └── non_uniform_tropnnc/            # Experiments of non-uniform TropNNC
│       ├── README.md
│       ├── checkpoints/
│       ├── data/
│       ├── src/
│       └── notebooks
├── LICENSE
└── README.md
```

The top-level `src/` directory contains the implementation used for the main TropNNC experiments.

The `src/non_uniform_tropnnc/` directory contains the implementation of the non-uniform TropNNC experiments. This directory is based on the CUP repository and includes our modifications to implement and evaluate non-uniform TropNNC.

---

## Installation

Clone the repository:

```bash
git clone https://github.com/kostfoto/TropNNC.git
cd TropNNC/src
```

The experiments were conducted using Python 3.8.18 with CUDA toolkit 11.1.

For reproduction of the experimental environment, create the Conda environment:

```bash
conda env create -f environment.yml
conda activate myenv
```

Alternatively, a convenience `requirements.txt` is also provided:

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

The Conda environment is recommended for reproducing the reported results, while `requirements.txt` is intended for users who only wish to install the project dependencies without recreating the exact experimental environment.

---

## Data

The repository does not include datasets.

The `data/` directories are included as placeholders and as default locations where datasets may be downloaded or stored by the code. If a `data/` directory is missing, create it manually before running the corresponding experiments.

The experiments use standard vision datasets, including:

- MNIST
- Fashion-MNIST
- CIFAR-10
- ImageNet

ImageNet must be downloaded separately. Additional ImageNet setup instructions are provided in `src/non_uniform_tropnnc/README.md`.

---

## Running Experiments

All commands below assume the current working directory is `src/`. Run all experiments and generate the corresponding tables and figures:

```bash
make
```

Run only the experiments:

```bash
make -s experiments
```

Generate reports from existing result files:

```bash
make -s report
```

Generated plots and tables are written to:

```text
src/plots/
```

## Mapping to Paper Results

| Paper result | Command(s) |
|---|---|
| Table 1 | `python experiment_2.py --dataset MNIST --model CNN2D --image_size 28`<br>`python experiment_2.py --dataset FASHION_MNIST --model CNN2D --image_size 28` |
| Figure 4(a,b) | `python experiment_2.py --dataset MNIST --model deepNN --image_size 28`<br>`python experiment_2.py --dataset FASHION_MNIST --model deepNN --image_size 28` |
| Figure 4(c,d) | `python experiment_4.py --dataset MNIST --model deepCNN2D --image_size 28`<br>`python experiment_4.py --dataset FASHION_MNIST --model deepCNN2D --image_size 28` |
| Figure 5(a,b) | `python experiment_3.py --model AlexNet --dataset CIFAR10 --image_size 128`<br>`python experiment_3.py --model AlexNet --dataset CIFAR100 --image_size 128` |
| Figure 5(c,d) | `python experiment_5.py --model ConvCIFAR-VGG --dataset CIFAR10 --image_size 32`<br>`python experiment_5.py --model ConvCIFAR-VGG --dataset CIFAR100 --image_size 32` |

`experiment_1.py` contains additional exploratory experiments and was not included in the final paper.

---

## Important Note

Results are appended to existing `results_*` files.

Before re-running experiments, delete existing result files to avoid mixing outputs from different runs.

---

## Compute Requirements

All experiments were executed on:

- NVIDIA GeForce RTX 2080 Ti with 12 GB memory
- NVIDIA GeForce RTX 3060 with 12 GB memory

A single GPU with approximately 12 GB of memory is sufficient to reproduce the results.

Running the complete experimental suite may require up to three days depending on hardware and system load.

---

## Citation

If you use this code, please cite:

```bibtex
@article{fotopoulos2026tropnnc,
  title   = {Trop{NNC}: Structured Neural Network Compression Using Tropical Geometry},
  author  = {Fotopoulos, Konstantinos and Maragos, Petros and Misiakos, Panagiotis},
  journal = {Transactions on Machine Learning Research},
  year    = {2026}
}
```

---

## Acknowledgments

The non-uniform TropNNC experiments build upon the CUP repository:

Duggal, R., Xiao, C., Vuduc, R., Chau, D. H., and Sun, J.  
*CUP: Cluster Pruning for Compressing Deep Neural Networks*.  
IEEE International Conference on Big Data, 2021.
