Self-labelling via simultaneous clustering and representation learning

Yuki Markus Asano, Christian Rupprecht, Andrea Vedaldi

Introduction

Learning from unlabelled data can dramatically reduce the cost of deploying machine learning algorithms to new applications, thus amplifying their impact in the real world. Self-supervision is an increasingly popular framework for learning without labels. The idea is to define pretext learning tasks that can be constructed from raw data alone, but that still result in neural networks that transfer well to useful applications.

Much of the research in self-supervision has focused on designing new pretext tasks. However, given supervised data such as ImageNet (Deng et al., 2009), the standard classification objective of minimizing the cross-entropy loss still results in better or at least as good pre-training than any of such methods (for a given amount of data and for a given model complexity). This suggests that the task of classification is sufficient for pre-training networks, provided that suitable data labels are available. In this paper, we thus focus on the problem of obtaining the labels automatically by designing a self-labelling algorithm.

Learning a deep neural network together while discovering the data labels can be viewed as simultaneous clustering and representation learning. The latter can be approached by combining cross-entropy minimization with an off-the-shelf clustering algorithm such as KK-means. This is precisely the approach adopted by the recent DeepCluster method (Caron et al., 2018), which achieves excellent results in unsupervised representation learning. However, combining representation learning, which is a discriminative task, with clustering is not at all trivial. In particular, we show that the combination of cross-entropy minimization and KK-means as adopted by DeepCluster cannot be described as the optimization of an overall learning objective; instead, there exist degenerate solutions that the algorithm avoids via particular implementation choices.

In order to address this technical shortcoming, in this paper, we contribute a new principled formulation for simultaneous clustering and representation learning. The starting point is to minimize a single loss, the cross-entropy loss, for learning the deep network and for estimating the data labels. This is often done in semi-supervised learning and multiple instance learning. However, when applied naively to the unsupervised case, it immediately leads to a degenerate solution where all data points are mapped to the same cluster.

We solve this issue by adding the constraint that the labels must induce an equipartition of the data, which we show maximizes the information between data indices and labels. We also show that the resulting label assignment problem is the same as optimal transport, and can therefore be solved in polynomial time by linear programming. However, since we want to scale the algorithm to millions of data points and thousands of labels, standard transport solvers are inadequate. Thus, we also propose to use a fast version of the Sinkhorn-Knopp algorithm for finding an approximate solution to the transport problem efficiently at scale, using fast matrix-vector algebra.

Compared to methods such as DeepCluster, the new formulation is more principled and allows to more easily demonstrate properties of the method such as convergence. Most importantly, via extensive experimentation, we show that our new approach leads to significantly superior results than DeepCluster, achieving the new state of the art for representation learning approaches. In fact, the method’s performance surpasses others that use a single type of supervisory signal for self-supervision, and is on par or better than very recent contributions as well (Tian et al., 2019; He et al., 2019; Misra & van der Maaten, 2019; Oord et al., 2018).

Related Work

Our paper relates to two broad areas of research: (a) self-supervised representation learning, and (b) more specifically, training a deep neural network using pseudo-labels, i.e. the assignment of a label to each image. We discuss closely related works for each.

A wide variety of methods that do not require manual annotations have been proposed for the self-training of deep convolutional neural networks. These methods use various cues and proxy tasks namely, in-painting (Pathak et al., 2016), patch context and jigsaw puzzles (Doersch et al., 2015; Noroozi & Favaro, 2016; Noroozi et al., 2018; Mundhenk et al., 2017), clustering (Caron et al., 2018; Huang et al., 2019; Zhuang et al., 2019; Bautista et al., 2016), noise-as-targets (Bojanowski & Joulin, 2017), colorization (Zhang et al., 2016; Larsson et al., 2017), generation (Jenni & Favaro, 2018; Ren & Lee, 2018; Donahue et al., 2017; Donahue & Simonyan, 2019), geometry (Dosovitskiy et al., 2016), predicting transformations (Gidaris et al., 2018; Zhang et al., 2019) and counting (Noroozi et al., 2017). Most recently, contrastive methods have shown great performance gains, (Oord et al., 2018; Hénaff et al., 2019; Tian et al., 2019; He et al., 2019) by leveraging augmentation and adequate losses. In (Feng et al., 2019), predicting rotation (Gidaris et al., 2018) is combined with instance retrieval (Wu et al., 2018) and multiple tasks are combined in (Doersch & Zisserman, 2017).

In the self-supervised domain, we find a spectrum of methods that either give each data point a unique label (Wu et al., 2018; Dosovitskiy et al., 2016) or train on a flexible number of labels with KK-means (Caron et al., 2018), with mutual information (Ji et al., 2018) or with noise (Bojanowski & Joulin, 2017). In (Noroozi et al., 2018) a large network is trained with a pretext task and a smaller network is trained via knowledge transfer of the clustered data. Finally, (Bach & Harchaoui, 2008; Vo et al., 2019) use convex relaxations to regularized affine-transformation invariant linear clustering, but can not scale to larger datasets.

Our contribution is a simple method that combines a novel pseudo-label extraction procedure from raw data alone and the training of a deep neural network using a standard cross-entropy loss.

Method

We will first derive our self-labelling method, then interpret the method as optimizing labels and targets of a cross-entropy loss and finally analyze similarities and differences with other clustering-based methods.

The model and head parameters are learned by minimizing the average cross-entropy loss

Training with objective (1) requires a labelled dataset. When labels are unavailable, we require a self-labelling mechanism to assign the labels automatically.

In semi-supervised learning, self-labelling is often achieved by jointly optimizing (1) with respect to the model hΦh\circ\Phi and the labels y1,,yNy_{1},\dots,y_{N}. This can work if at least part of the labels are known, thus constraining the optimization. However, in the fully unsupervised case, it leads to a degenerate solution: eq. 1 is trivially minimized by assigning all data points to a single (arbitrary) label.

To address this issue, we first rewrite eq. 1 by encoding the labels as posterior distributions q(yxi)q(y|\bm{x}_{i}):

If we set the posterior distributions q(yxi)=δ(yyi)q(y|\bm{x}_{i})=\delta(y-y_{i}) to be deterministic, the formulations in eqs. 1 and 2 are equivalent, in the sense that E(p,q)=E(py1,,yN)E(p,q)=E(p|y_{1},\dots,y_{N}). In this case, optimizing qq is the same as reassigning the labels, which leads to the degeneracy. To avoid this, we add the constraint that the label assignments must partition the data in equally-sized subsets. Formally, the learning objective objectiveWe assume for simplicity that KK divides NN exactly, but the formulation is easily extended to any NKN\geq K by setting the constraints to either N/K\lfloor N/K\rfloor or N/K+1\lfloor N/K\rfloor+1, in order to assure that there is a feasible solution. is thus:

The constraints mean that each data point xi\bm{x}_{i} is assigned to exactly one label and that, overall, the NN data points are split uniformly among the KK classes.

The objective in eq. 3 is combinatorial in qq and thus may appear very difficult to optimize. However, this is an instance of the optimal transport problem, which can be solved relatively efficiently. In order to see this more clearly, let Pyi=p(yxi)1NP_{yi}=p(y|\bm{x}_{i})\frac{1}{N} be the K×NK\times N matrix of joint probabilities estimated by the model. Likewise, let Qyi=q(yxi)1NQ_{yi}=q(y|\bm{x}_{i})\frac{1}{N} be K×NK\times N matrix of assigned joint probabilities. Using the notation of (Cuturi, 2013), we relax matrix QQ to be an element of the transportation polytope

With this notation, we can rewrite the objective function in eq. 3, up to a constant shift, as

where \langle\cdot\rangle is the Frobenius dot-product between two matrices and log\log is applied element-wise. Hence optimizing eq. 3 with respect to the assignments QQ is equivalent to solving the problem:

This is a linear program, and can thus be solved in polynomial time. Furthermore, solving this problem always leads to an integral solution despite having relaxed QQ to the continuous polytope U(r,c)U(r,c), guaranteeing the exact equivalence to the original problem.

In practice, however, the resulting linear program is large, involving millions of data points and thousands of classes. Traditional algorithms to solve the transport problem scale badly to instances of this size. We address this issue by adopting a fast version (Cuturi, 2013) of the Sinkhorn-Knopp algorithm. This amounts to introducing a regularization term

where KL\operatorname{KL} is the Kullback-Leibler divergence and rcrc^{\top} can be interpreted as a K×NK\times N probability matrix. The advantage of this regularization term is that the minimizer of eq. 7 can be written as:

where exponentiation is meant element-wise and α\alpha and β\beta are two vectors of scaling coefficients chosen so that the resulting matrix QQ is also a probability matrix (see (Cuturi, 2013) for a derivation). The vectors α\alpha and β\beta can be obtained, as shown below, via a simple matrix scaling iteration.

For very large λ\lambda, optimizing eq. 7 is of course equivalent to optimizing eq. 6, but even for moderate values of λ\lambda the two objectives tend to have approximately the same optimizer (Cuturi, 2013). Choosing λ\lambda trades off convergence speed with closeness to the original transport problem. In our case, using a fixed λ\lambda is appropriate as we are ultimately interested in the final clustering and representation learning results, rather than in solving the transport problem exactly.

Given the current label assignments QQ, the model is updated by minimizing eq. 6 with respect to (the parameters of) hΦh\circ\Phi. This is the same as training the model using the common cross-entropy loss for classification.

Given the current model hΦh\circ\Phi, we compute the log probabilities PP. Then, we find QQ using eq. 8 by iterating the updates (Cuturi, 2013)

Each update involves a single matrix-vector multiplication with complexity O(NK)\mathcal{O}(NK), so it is relatively quick even for millions of data points and thousands of labels and so the cost of this method scales linearly with the number of images NN. In practice, convergence is reached within 2 minutes on ImageNet when computed on a GPU. Also, note that the parameters α\alpha and β\beta can be retained between steps, thus allowing a warm start of Step 2.

2 Interpretation

As shown above, the formulation in eq. 2 uses scaled versions of the probabilities. We can interpret these by treating the data index ii as a random variable with uniform distribution p(i)=1/Np(i)=1/N and by rewriting the posteriors p(yxi)=p(yi)p(y|\bm{x}_{i})=p(y|i) and q(yxi)=q(yi)q(y|\bm{x}_{i})=q(y|i) as conditional distributions with respect to the data index ii instead of the feature vector xi\bm{x}_{i}. With these changes, we can rewrite eq. 5 as

which is the cross-entropy between the joint label-index distributions q(y,i)q(y,i) and p(y,i)p(y,i). The minimum of this quantity w.r.t. qq is obtained when p=qp=q, in which case E(q,q)+logNE(q,q)+\log N reduces to the entropy Hq(y,i)H_{q}(y,i) of the random variables yy and ii. Additionally, since we assumed that q(i)=1/Nq(i)=1/N, the marginal entropy Hq(i)=logNH_{q}(i)=\log N is constant and, due to the equipartition condition q(y)=1/Kq(y)=1/K, Hq(y)=logKH_{q}(y)=\log K is also constant. Subtracting these two constants from the entropy yields:

Thus we see that minimizing E(p,q)E(p,q) is the same as maximizing the mutual information between the label yy and the data index ii.

In our formulation, the maximization above is carried out under the equipartition constraint. We can instead relax this constraint and directly maximize the information I(y,i)I(y,i). However, by rewriting information as the difference I(y,i)=H(y)H(yi)I(y,i)=H(y)-H(y|i), we see that the optimal solution is given by H(yi)=0H(y|i)=0, which states each data point ii is associated to only one label deterministically, and by H(y)=lnKH(y)=\ln K, which is another way of stating the equipartition condition.

In other words, our learning formulation can be interpreted as maximizing the information between data indices and labels while explicitly enforcing the equipartition condition, which is implied by maximizing the information in any case. Compared to minimizing the entropy alone, maximizing information avoids degenerate solutions as the latter carry no mutual information between labels yy and indices ii. Similar considerations can be found in (Ji et al., 2018).

3 Relation to simultaneous representation learning and clustering

In the discussion above, self-labelling amounts to assigning discrete labels to data and can thus be interpreted as clustering. Most of the traditional clustering approaches are generative. For example, KK-means takes a dataset x1,,xN\bm{x}_{1},\dots,\bm{x}_{N} of vectors and partitions it into KK classes in order to minimize the reconstruction error

where yi{1,,K}y_{i}\in\{1,\dots,K\} are the data-to-cluster assignments and μy\bm{\mu}_{y} are means approximating the vectors in the corresponding clusters. The KK-means energy can thus be interpreted as the average data reconstruction error.

It is natural to ask whether a clustering method such as KK-means, which is based on approximating the input data, could be combined with representation learning, which uses a discriminative objective. In this setting, the feature vectors x=Φ(I)\bm{x}=\Phi(I) are extracted by the neural network Φ\Phi from the input data II. Unfortunately, optimizing a loss such as eq. 10 with respect to the clustering and representation parameters is meaningless: in fact, the obvious solution is to let the representation send all the data points to the same constant feature vector and setting all the means to coincide with it, in which case the KK-means reconstruction error is zero (and thus minimal).

Nevertheless, DeepCluster (Caron et al., 2018) does successfully combine KK-means with representation learning. DeepCluster can be related to our approach as follows. Step 1 of the algorithm, namely representation learning via cross-entropy minimization, is exactly the same. Step 2, namely self-labelling, differs: where we solve an optimal transport problem to obtain the pseudo-labels, they do so by running KK-means on the feature vectors extracted by the neural network.

DeepCluster does have an obvious degenerate solution: we can assign all data points to the same label and learn a constant representation, achieving simultaneously a minimum of the cross-entropy loss in Step 1 and of the KK-means loss in Step 2. The reason why DeepCluster avoids this pitfall is due to the particular interaction between the two steps. First, during Step 2, the features xi\bm{x}_{i} are fixed so KK-means cannot pull them together. Instead, the means spread to cover the features as they are, resulting in a balanced partitioning. Second, during the classification step, the cluster assignments yiy_{i} are fixed, and optimizing the features xi\bm{x}_{i} with respect to the cross-entropy loss tends to separate them. Lastly, the method in (Caron et al., 2018) also uses other heuristics such as sampling the training data inversely to their associated clusters’ size, leading to further regularization.

However, a downside of DeepCluster is that it does not have a single, well-defined objective to optimize, which means that it is difficult to characterize its convergence properties. By contrast, in our formulation, both Step 1 and Step 2 optimize the same objective, with the advantage that convergence to a (local) optimum is guaranteed.

4 Augmenting self-labelling via data transformations

5 Multiple simultaneous self-labelings

Intuitively, the same data can often be clustered in many equally good ways. For example, visual objects can be clustered by color, size, typology, viewpoint, and many other attributes. Since our main objective is to use clustering to learn a good data representation Φ\Phi, we consider a multi-task setting in which the same representation is shared among several different clustering tasks, which can potentially capture different and complementary clustering axis.

In our formulation, this is easily achieved by considering multiple heads (Ji et al., 2018) h1,,hTh_{1},\dots,h_{T}, one for each of TT clustering tasks (which may also have a different number of labels). Then, we optimize a sum of objective functions of the type eq. 6, one for each task, while sharing the parameters of the feature extractor Φ\Phi among them.

Experiments

In this section, we evaluate the quality of the representations learned by our Self Labelling (SeLa) technique. We first test variants of our method, including ablating its components, in order to find an optimal configuration. Then, we compare our results to the state of the art in self-supervised representation learning, where we find that our method is the best among clustering-based techniques and overall state-of-the-art or at least highly competitive in many benchmarks. In the appendix, we also show qualitatively that the labels identified by our algorithm are usually meaningful and group visually similar concepts in the same clusters, often even capturing whole ImageNet classes.

In order to quantify if a neural network has learned useful feature representations, we follow the standard approach of using linear probes (Zhang et al., 2017). This amounts to solving a difficult task, such as ImageNet classification, by training a linear classifier on top of a pre-trained feature representation, which is kept fixed. Linear classifiers heavily rely on the quality of the representation since their discriminative power is low. We apply linear probes to all intermediate convolutional blocks of representative networks. While linear probes are conceptually straightforward, there are several technical details that can affect the final accuracy, so we follow the standard protocol further outlined in the Appendix.

For training data we consider ImageNet LSVRC-12 (Deng et al., 2009) and other smaller scale datasets. We also test our features by transferring them to MIT Places (Zhou et al., 2014). All of these are standard benchmarks for evaluation in self-supervised learning.

Our base encoder architecture is AlexNet (Krizhevsky et al., 2012), since this is the most frequently used in other self-supervised learning works for the purpose of benchmarking. We inject the probes right after the ReLU layer in each of the five blocks, and denote these entry points conv1 to conv5. Furthermore, since the conv1 and conv2 can be learned effectively from data augmentations alone (YM. et al., 2020), we focus the analysis on the deeper layers conv2 to conv5 which are more sensitive to the quality of the learning algorithm. In addition to AlexNet, we also test ResNet-50 (He et al., 2016) models. Further experimental details are given in the Appendix.

2 Optimal configuration and ablations

In tables 5 and 5, we first validate various modelling and configuration choices. Two key hyper-parameters are the number of clusters KK and the number of clustering heads TT, which we denote in the experiments below with the shorthand “SeLa[K×T][K\times T]”. We run SeLa by alternating steps 1 and 2 as described in section 3.1. Step 1 amounts to standard CE training, which we run for a fixed number of epochs. Step 2 can be interleaved at any point in the optimization; to amortize its cost, we run it at most once per epoch, and usually less, with a schedule described and validated below. For these experiments, we train the representation and the linear probes on ImageNet.

Table 5, compares different values for KK: moving from 1k to 3k improves the results, but larger numbers decrease the quality slightly.

Table 5 shows that increasing the number of heads from T=1T=1 to T=10T=10 yields a large performance gain: +2%+2\% for AlexNet and +10%+10\% for ResNet. The latter more expressive model appears to benefit more from a more diverse training signal.

First, in table 5, we show that self-labelling (step 2) is essential for good performance, as opposed to only relying on the initial random label assignments and the data augmentations. For this, we vary the number of times the self-labelling algorithm (step 2) is run during training (#opts), from zero to once per step 1 epoch. We see that self-labelling is essential, with the best value around 80 (for 160 step 1 epochs in total).

Table 5 compares a smaller variant of AlexNet which uses (64, 192) filters in its first two convolutional layers (Krizhevsky, 2014), to the standard variant with (96, 256) (Krizhevsky et al., 2012), all the way to a ResNet-50. SeLa works well in all cases, for large models such as ResNet but also smaller ones such as AlexNet, for which methods such as BigBiGAN (Donahue & Simonyan, 2019) or CPC (Hénaff et al., 2019) are unsuitable.

3 Label transfer

An appealing property of SeLa is that the label it assigns to the images can be used to train another model from scratch, using standard supervised training. For instance, table 5 shows that, given the labels assigned by applying SeLa to AlexNet, we can re-train AlexNet from scratch using a shorter 90-epochs schedule with achieving the same final accuracy. This shows that the quality of the learned representation depends only the final label assignment, not on the fact that the representation is learned jointly with the labels. More interestingly, we can transfer labels between different architectures. For example, the labels obtained by applying SeLa [3k×13\text{k}\times 1] and SeLa [3k×103\text{k}\times 10] to ResNet-50 can be used to train a better AlexNet model than applying SeLa to the latter directly. For this reason, we publish on our website the self-labels for the ImageNet dataset in addition to the code and trained models.

4 Small-scale Datasets

Here, we evaluate our method on relatively simple and small datasets, namely CIFAR-10/100 (Krizhevsky et al., 2009) and SVHN (Netzer et al., 2011). For this, we follow the experimental and evaluation protocol from the current state of the art in self-supervised learning in these datasets, AND (Huang et al., 2019). In table 7, we compare our method with the settings [128×10128\times 10] for CIFAR-10, [512×10512\times 10] for CIFAR-100 and [128×1128\times 1] for SVHN to other published methods; details on the evaluation method are provided in the appendix. We observe that our proposed method outperforms the best previous method by 5.8%5.8\% for CIFAR-10, by 9.5%9.5\% for CIFAR-100 and by 0.8%0.8\% for SVHN when training a linear classifier on top of the frozen network. The relatively minor gains on SVHN can be explained by the fact that the gap between the supervised baseline and the self-supervised results is already very small (< ⁣3%<\!3\%). We also evaluate our method using weighted kNN using an embedding of size 128128. We find that the proposed method consistently outperforms the previous state of the art by around 2%2\% across these datasets, even though AND is based on explicitly learning local neighbourhoods.

5 Imbalanced Data Experiments

In order to understand if our equipartition regularization is affected by the underlying class distribution of a dataset, we perform multiple ablation experiments on artificially imbalanced datasets in table 8. We consider three training datasets based on CIFAR-10. The first is the original dataset with 50005000 images for each class (full in table 8). Second, we remove 50%50\% of the images of one class (truck) while the rest remains untouched (light imbalance) and finally we remove 10%10\% of one class, 20%20\% of the second class and so on (heavy imbalance). On each of the three datasets we compare the performance of our method “ours (SK)” with a baseline that replaces our Sinkhorn-Knopp optimization with KK-means clustering “ours (KK-means)”. We also compare the performance to training a network under full supervision. The evaluation follows Huang et al. (2019) and is based on linear probing and kNN classification — both on CIFAR-10 and, to understand feature generalization, on CIFAR-100.

To our surprise, we find that our method generalizes better to CIFAR-100 than the supervised baseline during kNN evaluation, potentially due to overfitting when training with labels. We also find that using SK optmization for obtaining pseudo-labels is always better than KK-means on all metrics and datasets. When comparing the imbalance settings, we find that under the light imbalance scenario, the methods’ performances are ranked the same and no method is strongly affected by the imbalance. Under the heavy imbalance scenario, all methods drop in performance. However, compared to full data and light imbalance, the gap between supervised and self-supervised even decreases slightly for both KK-means and our method, indicating stronger robustness of self-supervised methods compared to a supervised one.

In conclusion, our proposed method does not rely on the data to contain the same number of images for every class and outperforms a KK-means baseline even in very strong imbalance settings. This confirms the intuition that the equipartioning constraint acts as a regularizer and does not exploit the class distribution of the dataset.

6 Large Scale Benchmarks

To compare to the state of the art and concurrent work, we evaluate several architectures using linear probes on public benchmark datasets.

Training better models than AlexNets is not yet standardized in the feature learning community. In Table 10 we compare a ResNet-50 trained with our method to other works. With top-1 accuracy of 61.561.5, we outperform than all other methods including Local Aggregation, CPCv1 and MoCo that use the same level of data augmentation. We even outperform larger architectures such as BigBiGAN’s RevNet-50x4 and reach close to the performance of models using AutoAugment-style transformations.

7 Fine-tuning: Classification, object detection and semantic segmentation

Finally, since pre-training is usually aimed at improving down-stream tasks, we evaluate the quality of the learned features by fine-tuning the model for three distinct tasks on the PASCAL VOC benchmark. In Table 7 we compare results with regard to multi-label classification, object detection and semantic segmentation on PASCAL VOC (Everingham et al., 2010).

As in the linear probe experiments, we find our method better than the current state of the art in detection and classification with both fine-tuning only the last fully connected layers and when fine-tuning the whole network (“all”. Notably, our fine-tuned AlexNet outperforms its supervised ImageNet baseline on the VOC detection task. Also for segmentation the method is very close (0.2%0.2\%) to the best performing method. This shows that our trained network does not only learn useful feature representations but is also able to perform well when fine-tuned on actual down-stream tasks.

Conclusion

We present a self-supervised feature learning method that is based on clustering. In contrast to other methods, ours optimizes the same objective during feature learning and during clustering. This becomes possible through a weak assumption that the number of samples should be equal across clusters. This constraint is explicitly encoded in the label assignment step and can be solved for efficiently using a modified Sinkhorn-Knopp algorithm. Our method outperforms all other feature learning approaches and achieves SOTA on SVHN, CIFAR-10/100 and ImageNet for AlexNet and ResNet-50. By virtue of the method, the resulting self-labels can be used to quickly learn features for new architectures using simple cross-entropy training.

Yuki Asano gratefully acknowledges support from the EPSRC Centre for Doctoral Training in Autonomous Intelligent Machines & Systems (EP/L015897/1). We are also grateful to ERC IDIU-638009, AWS Machine Learning Research Awards (MLRA) and the use of the University of Oxford Advanced Research Computing (ARC).

References

Appendix A Appendix

Unless otherwise noted, we train all our self-supervised models with SGD and intial learning rate 0.05 for 400 epochs with two learning rate drops where we divide the rate by ten at 150 and 300 and 350 epochs. We spread our pseudo-label optimizations throughout the whole training process in a logarithmic distribution. We optimize the label assignment at ti=(iM1)2,i{1,,M}t_{i}=\left(\frac{i}{M-1}\right)^{2},i\in\{1,\ldots,M\}, where MM is the user-defined number of optimizations and tit_{i} is expressed as a fraction of total training epochs. For the Sinkhorn-Knopp optimization we set λ=25\lambda=25 as in (Cuturi, 2013). We use standard data augmentations during training that consist of randomly resized crops, horizontal flipping and adding noise, as in (Wu et al., 2018).

Unfortunately, prior work has used several slightly different setups, so that comparing results between different publications must be done with caution.

In our ImageNet implementation, we follow the original proposal (Zhang et al., 2017) in pooling each representation to a vector with 9600,9216,9600,9600,92169600,9216,9600,9600,9216 dimensions for conv1-5 using adaptive max-pooling, and absorb the batch normalization weights into the preceding convolutions. For evaluation on ImageNet we follow RotNet to train linear probes: images are resized such that the shorter edge has a length of 256256 pixels, random crops of 224 ⁣× ⁣224224\!\times\!224 are computed and flipped horizontally with 50%50\% probability. Learning lasts for 3636 epochs and the learning rate schedule starts from 0.010.01 and is divided by five at epochs 55, 1515 and 2525. The top-1 accuracy of the linear classifier is then measured on the ImageNet validation subset by optionally extracting 1010 crops for each validation image (four at the corners and one at the center along with their horizontal flips) and averaging the prediction scores before the accuracy is computed or just taking the a centred crop. For CIFAR-10/100 and SVHN we train AlexNet architectures on the resized images with batchsize 128128, learning rate 0.030.03 and also the same image augmentations (random resized crops, color jitter and random grayscale) as is used in prior work (Huang et al., 2019). We use the same linear probing protocol as for our ImageNet experiments but without using 1010 crops. For the weighted kNN experiments we use k=50,σ=0.1k=50,\sigma=0.1 and we use an embedding of size 128128 as done in previous works.

In Table 9, when retraining an AlexNet using ResNet generated labels, we can apply heavier augmentation strategies as the labels are kept constant. Hence for the experiments denoted by "+ more aug.", in addition to the usual augmentations, we further randomly apply one of equalize, autoconstrast and sharpening. We find that this raises the performance for ImageNet but lowers the performance on Places by a small amount, hence illuminating the need to always also report performance on both datasets.

A.2 Further details

In fig. A.1 we find that most learning takes place in the early epochs, and we reach a final NMI value of around 66%. Similarly, we find that due to the updating of the pseudo-labels at regular intervals and our data augmentation, the pseudo-label accuracies keep continuously rising without overfitting to these labels.

In table A.1, we report standard clustering metrics (see (Vinh et al., 2010) for detailed definitions) of our trained models with regards to the ImageNet validation set ground-truth labels. These metrics include chance-corrected metrics which are the adjusted normalized mutual information (NMI) and the adjusted Rand-Index, as well as the default NMI, also reported in DeepCluster (Caron et al., 2018).

In fig. A.3 we show the first convolutional filters of two of our trained models. We can find the typical Gabor-like edge detectors as well as color blops and dot-detectors.

A.3 Complete tables

In the following, we report the unabridged tables with all related work.

A.4 Low Entropy Pseudoclasses

A.5 Random Pseudoclasses