Awesome
KingdraCluster - Deep Learning Clustering Implementation
Official implementation of ICLR 2020 paper Unsupervised Clustering using Pseudo-semi-supervised Learning
Link to the blog post : https://divamgupta.com/unsupervised-learning/2020/10/31/pseudo-semi-supervised-learning-for-unsupervised-clustering.html
Project webpage | Link to the paper
This repository contains the code for "Unsupervised Clustering using Pseudo-semi-supervised Learning" paper (ICLR 2020) by Divam Gupta, Ramachandran Ramjee, Nipun Kwatra, Muthian Sivathanu
Bibtex:
@inproceedings{gupta2019unsupervised,
title={Unsupervised Clustering using Pseudo-semi-supervised Learning},
author={Gupta, Divam and Ramjee, Ramachandran and Kwatra, Nipun and Sivathanu, Muthian},
booktitle={International Conference on Learning Representations},
year={2019}
}
Abstract
In this paper, we propose a framework that leverages semi-supervised models to improve unsupervised clustering performance. To leverage semi-supervised models, we first need to automatically generate labels, called pseudo-labels. We find that prior approaches for generating pseudo-labels hurt clustering performance because of their low accuracy. Instead, we use an ensemble of deep networks to construct a similarity graph, from which we extract high accuracy pseudo-labels. The approach of finding high quality pseudo-labels using ensembles and training the semi-supervised model is iterated, yielding continued improvement. We show that our approach outperforms state of the art clustering results for multiple image and text datasets. For example, we achieve 54.6% accuracy for CIFAR-10 and 43.9% for 20news, outperforming state of the art by 8-12% in absolute terms.
Usage
Dependencies
- Python 2/3
- Keras 2.1.4
- Tensorflow 1.15.0
- Sklearn 0.20.4
Note that due to changes in Sklearn, version > 0.20.4 will result in wrong calculation of clustering accuracy.
Training
from kingdra_cluster.kingdra_cluster import KingdraCluster
model = KingdraCluster()
model.fit( X )
# API documentation coming soon
Evaluating
from kingdra_cluster.unsup_metrics import ACC
preds = model.predict( X )
ACC( gt , preds )
Reproducing paper results :
# Download the datasets
wget https://github.com/divamgupta/datasets/releases/download/clustering_datasets/ens_cluster_datasets.zip
unzip ens_cluster_datasets.zip
# train and evaluate on the datasets
python run_exp.py configs/kingdra_ladder_im_mnist.json
python run_exp.py configs/kingdra_ladder_im_20news.json
python run_exp.py configs/kingdra_ladder_im_cifar10.json
python run_exp.py configs/kingdra_ladder_im_reuters.json
python run_exp.py configs/kingdra_ladder_im_stl10.json