Skip to content

A dataset of datasets for learning to learn from few examples

License

Notifications You must be signed in to change notification settings

google-research/meta-dataset

Repository files navigation

This repository contains accompanying code for the article introducing Meta-Dataset, arxiv.org/abs/1903.03096 and the follow-up paper that proposes the VTAB+MD merged benchmark arxiv.org/abs/2104.02638. It also contains accompanying code and checkpoints for CrossTransformers, https://arxiv.org/abs/2007.11498, a follow-up work which improves performance.

This code is provided here in order to give more details on the implementation of the data-providing pipeline, our back-bones and models, as well as the experimental setting.

See below for user instructions, including how to:

  1. install the software,
  2. download and convert the data, and
  3. train implemented models.

See this introduction notebook for a demonstration of how to sample data from the pipeline (episodes or batches).

In order to run the experiments described in the first version of the arXiv article, arxiv.org/abs/1903.03096v1, please use the instructions, code, and configuration files at version arxiv_v1 of this repository.

We are currently working on updating the instructions, code, and configuration files to reproduce the results in the second version of the article, arxiv.org/abs/1903.03096v2. You can follow the progess in branch arxiv_v2_dev of this repository.

This is not an officially supported Google product.

Meta-Dataset: A Dataset of Datasets for Learning to Learn from Few Examples

Eleni Triantafillou, Tyler Zhu, Vincent Dumoulin, Pascal Lamblin, Utku Evci, Kelvin Xu, Ross Goroshin, Carles Gelada, Kevin Swersky, Pierre-Antoine Manzagol, Hugo Larochelle

Few-shot classification refers to learning a classifier for new classes given only a few examples. While a plethora of models have emerged to tackle it, we find the procedure and datasets that are used to assess their progress lacking. To address this limitation, we propose Meta-Dataset: a new benchmark for training and evaluating models that is large-scale, consists of diverse datasets, and presents more realistic tasks. We experiment with popular baselines and meta-learners on Meta-Dataset, along with a competitive method that we propose. We analyze performance as a function of various characteristics of test tasks and examine the models' ability to leverage diverse training sources for improving their generalization. We also propose a new set of baselines for quantifying the benefit of meta-learning in Meta-Dataset. Our extensive experimentation has uncovered important research challenges and we hope to inspire work in these directions.

CrossTransformers: spatially-aware few-shot transfer

Carl Doersch, Ankush Gupta, Andrew Zisserman

This is a Transformer-based neural network architecture which can find coarse spatial correspondence between the query and the support images, and then infer class membership by computing distances between spatially-corresponding features. The paper also introduces SimCLR episodes, which are episodes that require SimCLR-style instance recognition, and therefore encourage features which capture more than just the training-set categories. This algorithm is SOTA on Meta-Dataset (train-on-ILSVRC) as of NeurIPS 2020.

Configuration files for CrossTransformers with and without SimCLR episodes (CTX and CTX+SimCLR Eps from the paper) can be found in learn/gin/default/crosstransformer*. We also have pretrained checkpoints for these two configurations: CTX, and CTX+SimCLR Eps, as well as CTX+SimCLR Eps+BOHB Aug. Note that these were retrained from the versions reported in the paper, but their performance should be on-par. The network structure is the same for all three models, and so they can be loaded using either of the CrossTransformer config files.

Leaderboard (in progress)

The tables below were generated by this notebook.

Adding a new model to the leaderboard

  1. Gather accuracy results and 95% confidence intervals, as well as the number of episodes used for the CI (minimum 600).
  2. If you were affected by #54, make sure the evaluation on Traffic Sign is done on shuffled samples. We encourage you to re-train your best model (or at least perform validation again) as well.
  3. Create an issue, with the name of the model, results, as well as the article to cite or any other relevant information to include, and label it "leaderboard". Alternatively, submit a PR with an update to the notebook.

Training on ImageNet only

Method Avg rank ILSVRC (test) Omniglot Aircraft Birds Textures QuickDraw Fungi VGG Flower Traffic signs MSCOCO
k-NN [1] 9.7 41.03±1.01 (10) 37.07±1.15 (11) 46.81±0.89 (10) 50.13±1.00 (10.5) 66.36±0.75 (8) 32.06±1.08 (11) 36.16±1.02 (8) 83.10±0.68 (8) 44.59±1.19 (10) 30.38±0.99 (10.5)
Finetune [1] 6.15 45.78±1.10 (8) 60.85±1.58 (6.5) 68.69±1.26 (2) 57.31±1.26 (9) 69.05±0.90 (4.5) 42.60±1.17 (8.5) 38.20±1.02 (7) 85.51±0.68 (6) 66.79±1.31 (2) 34.86±0.97 (8)
MatchingNet [1] 8.65 45.00±1.10 (8) 52.27±1.28 (9) 48.97±0.93 (9) 62.21±0.95 (7.5) 64.15±0.85 (10) 42.87±1.09 (8.5) 33.97±1.00 (9) 80.13±0.71 (10) 47.80±1.14 (7.5) 34.99±1.00 (8)
ProtoNet [1] 6.45 50.50±1.08 (4.5) 59.98±1.35 (6.5) 53.10±1.00 (7.5) 68.79±1.01 (5.5) 66.56±0.83 (8) 48.96±1.08 (6) 39.71±1.11 (6) 85.27±0.77 (6) 47.12±1.10 (9) 41.00±1.10 (5.5)
fo-MAML [1] 7.45 45.51±1.11 (8) 55.55±1.54 (8) 56.24±1.11 (5.5) 63.61±1.06 (7.5) 68.04±0.81 (4.5) 43.96±1.29 (8.5) 32.10±1.10 (10) 81.74±0.83 (9) 50.93±1.51 (5.5) 35.30±1.23 (8)
RelationNet [1] 10.55 34.69±1.01 (11) 45.35±1.36 (10) 40.73±0.83 (11) 49.51±1.05 (10.5) 52.97±0.69 (11) 43.30±1.08 (8.5) 30.55±1.04 (11) 68.76±0.83 (11) 33.67±1.05 (11) 29.15±1.01 (10.5)
fo-Proto-MAML [1] 5.2 49.53±1.05 (6) 63.37±1.33 (4.5) 55.95±0.99 (5.5) 68.66±0.96 (5.5) 66.49±0.83 (8) 51.52±1.00 (4.5) 39.96±1.14 (3.5) 87.15±0.69 (3) 48.83±1.09 (7.5) 43.74±1.12 (4)
ALFA+fo-Proto-MAML [3] 3.25 52.80±1.11 (2.5) 61.87±1.51 (4.5) 63.43±1.10 (3) 69.75±1.05 (3.5) 70.78±0.88 (2) 59.17±1.16 (2) 41.49±1.17 (3.5) 85.96±0.77 (6) 60.78±1.29 (3) 48.11±1.14 (2.5)
ProtoNet (large) [4] 3.45 53.69±1.07 (2.5) 68.50±1.27 (2.5) 58.04±0.96 (4) 74.07±0.92 (2) 68.76±0.77 (4.5) 53.30±1.06 (3) 40.73±1.15 (3.5) 86.96±0.73 (3) 58.11±1.05 (4) 41.70±1.08 (5.5)
CTX [4] 1 62.76±0.99 (1) 82.21±1.00 (1) 79.49±0.89 (1) 80.63±0.88 (1) 75.57±0.64 (1) 72.68±0.82 (1) 51.58±1.11 (1) 95.34±0.37 (1) 82.65±0.76 (1) 59.90±1.02 (1)
BOHB [5] 4.15 51.92±1.05 (4.5) 67.57±1.21 (2.5) 54.12±0.90 (7.5) 70.69±0.90 (3.5) 68.34±0.76 (4.5) 50.33±1.04 (4.5) 41.38±1.12 (3.5) 87.34±0.59 (3) 51.80±1.04 (5.5) 48.03±0.99 (2.5)

Training on all datasets

Method Avg rank ILSVRC (test) Omniglot Aircraft Birds Textures QuickDraw Fungi VGG Flower Traffic signs MSCOCO
k-NN [1] 12.85 38.55±0.94 (12.5) 74.60±1.08 (14) 64.98±0.82 (15) 66.35±0.92 (10.5) 63.58±0.79 (11.5) 44.88±1.05 (15) 37.12±1.06 (11.5) 83.47±0.61 (11.5) 40.11±1.10 (14) 29.55±0.96 (13)
Finetune [1] 10.45 43.08±1.08 (10.5) 71.11±1.37 (15) 72.03±1.07 (11.5) 59.82±1.15 (13) 69.14±0.85 (7) 47.05±1.16 (14) 38.16±1.04 (11.5) 85.28±0.69 (10) 66.74±1.23 (1) 35.17±1.08 (11)
MatchingNet [1] 12.4 36.08±1.00 (14) 78.25±1.01 (12.5) 69.17±0.96 (13.5) 56.40±1.00 (14) 61.80±0.74 (13) 60.81±1.03 (11.5) 33.70±1.04 (14) 81.90±0.72 (13) 55.57±1.08 (5.5) 28.79±0.96 (13)
ProtoNet [1] 10.5 44.50±1.05 (10.5) 79.56±1.12 (12.5) 71.14±0.86 (11.5) 67.01±1.02 (10.5) 65.18±0.84 (9.5) 64.88±0.89 (10) 40.26±1.13 (10) 86.85±0.71 (9) 46.48±1.00 (12) 39.87±1.06 (9.5)
fo-MAML [1] 12.25 37.83±1.01 (12.5) 83.92±0.95 (10.5) 76.41±0.69 (9) 62.43±1.08 (12) 64.16±0.83 (11.5) 59.73±1.10 (13) 33.54±1.11 (14) 79.94±0.84 (14) 42.91±1.31 (13) 29.37±1.08 (13)
RelationNet [1] 13.8 30.89±0.93 (15) 86.57±0.79 (9) 69.71±0.83 (13.5) 54.14±0.99 (15) 56.56±0.73 (15) 61.75±0.97 (11.5) 32.56±1.08 (14) 76.08±0.76 (15) 37.48±0.93 (15) 27.41±0.89 (15)
fo-Proto-MAML [1] 8.55 46.52±1.05 (9) 82.69±0.97 (10.5) 75.23±0.76 (10) 69.88±1.02 (8.5) 68.25±0.81 (7) 66.84±0.94 (9) 41.99±1.17 (9) 88.72±0.67 (7) 52.42±1.08 (8.5) 41.74±1.13 (7)
CNAPs [2] 7.5 50.80±1.10 (7.5) 91.70±0.50 (5.5) 83.70±0.60 (5.5) 73.60±0.90 (7) 59.50±0.70 (14) 74.70±0.80 (8) 50.20±1.10 (5.5) 88.90±0.50 (7) 56.50±1.10 (5.5) 39.40±1.00 (9.5)
SUR [6] 5.2 56.10±1.10 (4.5) 93.10±0.50 (3.5) 84.60±0.70 (3.5) 70.60±1.00 (8.5) 71.00±0.80 (4.5) 81.30±0.60 (2) 64.20±1.10 (1.5) 82.80±0.80 (11.5) 53.40±1.00 (8.5) 50.10±1.00 (4)
SUR-pnf [6] 5.65 56.00±1.10 (4.5) 90.00±0.60 (7.5) 79.70±0.80 (7.5) 75.90±0.90 (5) 72.50±0.70 (2.5) 76.70±0.70 (6.5) 49.80±1.10 (5.5) 90.00±0.60 (5) 52.20±0.80 (8.5) 50.20±1.10 (4)
SimpleCNAPS [7] 4.6 56.50±1.10 (1.5) 91.90±0.60 (5.5) 83.80±0.60 (5.5) 76.10±0.90 (5) 70.00±0.80 (4.5) 78.30±0.70 (4.5) 49.10±1.20 (5.5) 91.30±0.60 (4) 59.20±1.00 (3) 42.40±1.10 (7)
TransductiveCNAPS [8] 3.95 57.90±1.10 (1.5) 94.30±0.40 (1.5) 84.70±0.50 (3.5) 78.80±0.70 (1.5) 66.20±0.80 (9.5) 77.90±0.60 (4.5) 48.90±1.20 (5.5) 92.30±0.40 (2) 59.70±1.10 (3) 42.50±1.10 (7)
URT [9] 3.75 55.70±1.00 (4.5) 94.40±0.40 (1.5) 85.80±0.60 (2) 76.30±0.80 (5) 71.80±0.70 (2.5) 82.50±0.60 (1) 63.50±1.00 (1.5) 88.20±0.60 (7) 51.10±1.10 (11) 52.20±1.10 (1.5)
URT-pf [9] 5 55.50±1.10 (4.5) 90.20±0.60 (7.5) 79.80±0.70 (7.5) 77.50±0.80 (3) 73.50±0.70 (1) 75.80±0.70 (6.5) 48.10±0.90 (8) 91.90±0.50 (2) 52.00±1.40 (8.5) 52.10±1.00 (1.5)
FLUTE [10] 3.55 51.80±1.10 (7.5) 93.20±0.50 (3.5) 87.20±0.50 (1) 79.20±0.80 (1.5) 68.80±0.80 (7) 79.50±0.70 (3) 58.10±1.10 (3) 91.60±0.60 (2) 58.40±1.10 (3) 50.00±1.00 (4)

References

[1] Triantafillou et al. (2020)

Eleni Triantafillou, Tyler Zhu, Vincent Dumoulin, Pascal Lamblin, Utku Evci, Kelvin Xu, Ross Goroshin, Carles Gelada, Kevin Swersky, Pierre-Antoine Manzagol, Hugo Larochelle; Meta-Dataset: A Dataset of Datasets for Learning to Learn from Few Examples; ICLR 2020.

[2] Requeima et al. (2019)

James Requeima, Jonathan Gordon, John Bronskill, Sebastian Nowozin, Richard E. Turner; Fast and Flexible Multi-Task Classification Using Conditional Neural Adaptive Processes; NeurIPS 2019.

[3] Baik et al. (2020)

Sungyong Baik, Myungsub Choi, Janghoon Choi, Heewon Kim, Kyoung Mu Lee; Meta-Learning with Adaptive Hyperparameters; NeurIPS 2020.

[4] Doersch et al. (2020)

Carl Doersch, Ankush Gupta, Andrew Zisserman; CrossTransformers: spatially-aware few-shot transfer; NeurIPS 2020.

[5] Saikia et al. (2020)

Tonmoy Saikia, Thomas Brox, Cordelia Schmid; Optimized Generic Feature Learning for Few-shot Classification across Domains; arXiv 2020.

[6] Dvornik et al. (2020)

Nikita Dvornik, Cordelia Schmid, Julien Mairal; Selecting Relevant Features from a Multi-domain Representation for Few-shot Classification; ECCV 2020.

[7] Bateni et al. (2020a)

Peyman Bateni, Raghav Goyal, Vaden Masrani, Frank Wood, Leonid Sigal; Improved Few-Shot Visual Classification; CVPR 2020.

[8] Bateni et al. (2020b)

Peyman Bateni, Jarred Barber, Jan-Willem van de Meent, Frank Wood; Enhancing Few-Shot Image Classification with Unlabelled Examples; arXiv 2020.

[9] Liu et al. (2021)

Lu Liu, William Hamilton, Guodong Long, Jing Jiang, Hugo Larochelle; Universal Representation Transformer Layer for Few-Shot Image Classification; ICLR 2021.

[10] Triantafillou et al. (2021)

Eleni Triantafillou, Hugo Larochelle, Richard Zemel, Vincent Dumoulin; Learning a Universal Template for Few-shot Dataset Generalization; To appear in ICML 2021.

User instructions

Installation

Meta-Dataset is generally compatible with Python 2 and Python 3, but some parts of the code may require Python 3. The code works with TensorFlow 2, although it makes extensive use of tf.compat.v1 internally.

  • We recommend you follow these instructions to install TensorFlow.
  • A list of packages to install is available in requirements.txt, you can install them using pip.
  • Clone the meta-dataset repository. Most command lines start with python -m meta_dataset.<something>, and should be typed from within that clone (where a meta_dataset Python module should be visible).
  • To reproduce the CrossTransformers training, you will need data augmentation code from simclr, which is autimatically downloaded by setup.py.

Downloading and converting datasets

Meta-Dataset uses several established datasets, that are available from different sources. You can find below a summary of these datasets, as well as instructions to download them and convert them into a common format.

For brevity of the command line examples, we assume the following environment variables are defined:

  • $DATASRC: root of where the original data is downloaded and potentially extracted from compressed files. This directory does not need to be available after the data conversion is done.
  • $SPLITS: directory where *_splits.json files will be created, one per dataset. For instance, $SPLITS/fungi_splits.json contains information about which classes are part of the meta-training, meta-validation, and meta-test set. These files are only used during the dataset conversion phase, but can help troubleshooting later. To re-use the canonical splits instead of re-generating them, you can make it point to meta_dataset/dataset_conversion in your checkout.
  • $RECORDS: root directory that will contain the converted datasets (one per sub-directory). This directory needs to be available during training and evaluation.

Dataset summary

Dataset (other names) Number of classes (train/valid/test) Size on disk Conversion time
ilsvrc_2012 (ImageNet, ILSVRC) [instructions] 1000 (712/158/130, hierarchical) ~140 GiB 5 to 13 hours
omniglot [instructions] 1623 (883/81/659, by alphabet: 25/5/20) ~60 MiB few seconds
aircraft (FGVC-Aircraft) [instructions] 100 (70/15/15) ~470 MiB (2.6 GiB download) 5 to 10 minutes
cu_birds (Birds, CUB-200-2011) [instructions] 200 (140/30/30) ~1.1 GiB ~1 minute
dtd (Describable Textures, DTD) [instructions] 47 (33/7/7) ~600 MiB few seconds
quickdraw (Quick, Draw!) [instructions] 345 (241/52/52) ~50 GiB 3 to 4 hours
fungi (FGVCx Fungi) [instructions] 1394 (994/200/200) ~13 GiB 5 to 15 minutes
vgg_flower (VGG Flower) [instructions] 102 (71/15/16) ~330 MiB ~1 minute
traffic_sign (Traffic Signs, German Traffic Sign Recognition Benchmark, GTSRB) [instructions] 43 (0/0/43, test only) ~50 MiB (263 MiB download) ~1 minute
mscoco (Common Objects in Context, COCO) [instructions] 80 (0/40/40, validation and test only) ~5.3 GiB (18 GiB download) 4 hours
Total (All datasets) 4934 (3144/598/1192) ~210 GiB 12 to 24 hours

Meta-Dataset-v2

In order to make the combined benchmark (VTAB+MD) compatible with each other, Meta-Dataset-v2 makes some changes on the existing pipelines. When converting the ImageNet dataset please use ilsvrc\_2012\_v2 (instructions) in order to make it a training only dataset. Also,VGG Flowers is reserved as a VTAB task in VTAB+MD, so there is no need to convert it. For more details check the paper.

In order to run existing meta-learners with the updated training, validation and test classes you can refer to the learn/gin/setups/imagenet_v2.gin learn/gin/setups/all_v2.gin. These files are meant to be drop in replacements for learn/gin/setups/imagenet.gin and learn/gin/setups/all.gin files respectively.

Training

Experiments are defined via gin configuration files, that are under meta_dataset/learn/gin/:

  • setups/ contain generic setups for classes of experiment, for instance which datasets to use (imagenet or all), parameters for sampling the number of ways and shots of episodes.
  • models/ define settings for different meta-learning algorithms (baselines, prototypical networks, MAML...)
  • default/ contains files that each correspond to one experiment, mostly defining a setup and a model, with default values for training hyperparameters.
  • best/ contains files with values for training hyperparameters that achieved the best performance during hyperparameter search.

There are three main architectures, also called "backbones" (or "embedding networks"): four_layer_convnet (sometimes convnet for short), resnet, and wide_resnet. These architectures can be used by all baselines and episodic models. Another backbone, relationnet_convnet (similar to four_layer_convnet but without pooling on the last layer), is only used by RelationNet (and baseline, for pre-training purposes). CrossTransformers use a larger backbone resnet34, which is similar to resnet but with more layers.

Reproducing results

See Reproducing best results for instructions to launch training experiments with the values of hyperparameters that were selected in the paper. The hyperparameters (including the backbone, whether to train from scratch or from pre-trained weights, and the number of training updates) were selected using only the validation classes of the ILSVRC 2012 dataset for all experiments. Even when training on "all" datasets, the validation classes of the other datasets were not used.