# Non-Uniform TropNNC Experiments

This directory contains the implementation used for the non-uniform TropNNC experiments reported in the paper.

The code is based on the CUP repository and has been extended to support non-uniform TropNNC compression. In addition to changes in the source files for the implementation of TropNNC, the experiment notebooks in this directory have also been modified. 

---

## Original CUP Repository

Original repository:

```text
https://github.com/duggalrahul/CUP_Public
```

Please cite the original CUP paper when using this code:

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

---

## Required Pretrained Models

Download the following pretrained models from the original CUP repository resources:

1. `vgg16_cifar10.pth`
2. `resnet18_imagenet_pytorch.pth`

Place the checkpoints in:

```text
checkpoints/
```

---

## Data

Datasets are not included in this repository.

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

ImageNet is required for the ResNet-18 experiments. We downloaded ImageNet through Kaggle's API.

After downloading ImageNet, use:

```bash
python imagenet_format.py
```

to organize the validation images according to their class labels.

---

## Directory Structure

```text
.
├── checkpoints/
├── data/
├── logs/
├── src/
│   ├── cluster_model.py                    # Implementation of non-uniform TropNNC
│   ├── compute_flops.py
│   ├── imagenet_utils.py
│   ├── model.py
│   ├── prune_model.py
│   ├── train_test.py
│   └── utils.py
├── imagenet_format.py
├── Resnet_18_Imagenet.ipynb
├── VGG_16_CIFAR_10.ipynb
└── VGG_16_CIFAR_10_ablation.ipynb
```

---

## Modified Files

The implementation of non-uniform TropNNC is primarily contained in:

```text
src/cluster_model.py
```

The notebooks have also been modified to run the non-uniform TropNNC experiments under our experimental setup:

```text
Resnet_18_Imagenet.ipynb
VGG_16_CIFAR_10.ipynb
VGG_16_CIFAR_10_ablation.ipynb
```

Other files are unchanged or only minimally adapted from the original CUP implementation.

---

## Experiments

### ResNet-18 on ImageNet (Table 2)

Run:

```text
Resnet_18_Imagenet.ipynb
```

### VGG-16 on CIFAR-10 (Table 3)

Run:

```text
VGG_16_CIFAR_10.ipynb
```

### Iterative vs Non-Iterative Comparison (Table 4)

Run:

```text
VGG_16_CIFAR_10_ablation.ipynb
```

Execute the notebooks sequentially to reproduce the reported results.
