In this code-base we provide the code for the methods introduced in our paper 'Partial Fusion of Neural Networks: Efficient Tradeoffs Between Ensembles and Weight Aggregation'.



The partial fusion method is implemented in the files in folder neural\_networks/FusionModel/fusion\_methods. The implementation for aligning layers can be found in base_fusion.py with the computation of kernels in partial_fusion.py. The class FusionModel in fusion_model.py handles the combining the block matrices into layers.

The generalized pruning methods are implemented in the files in folder neural\_networks/FusionModel/generalized\_pruning. The files pruning_cnn.py and pruning_mlp.py handle the construction of new models and the clustering algorithms are implemented in the other files.



We also provide code and trained models for our experiments in the folder saved\_compression.

To reproduce the results, please install the packages specified in requirements.txt. Then run the python files in experiments:



* The comparison of different features for partial fusion is in exp\_partial\_fusion.py.
* The comparison of partial Fusion and generalized pruning of ensembles is in cifar\_ensemble\_pruning.py and mnist\_ensemble\_pruning.py.
* Generalized pruning of a single model is in mnist\_seed\_pruning.py and cifar\_seed\_pruning.py.



The code for the experiments in Appendix I is in the folder appendix\_experiments.

