This codebase provides a Pytorch implementation for the paper Delving into Out-Of-Distribution Detection with Vision-Language Representations at NeurIPS 2022.
Recognizing out-of-distribution (OOD) samples is critical for machine learning systems deployed in the open world. The vast majority of OOD detection methods are driven by a single modality (e.g., either vision or language), leaving the rich information in multi-modal representations untapped. Inspired by the recent success of vision-language pre-training, this paper enriches the landscape of OOD detection from a single-modal to a multi-modal regime. Particularly, we propose Maximum Concept Matching (MCM), a simple yet effective zero-shot OOD detection method based on aligning visual features with textual concepts. We contribute in-depth analysis and theoretical insights to understand the effectiveness of MCM. Extensive experiments demonstrate that MCM achieves superior performance on a wide variety of real-world tasks. MCM with vision-language features outperforms a common baseline with pure visual features on a hard OOD task with semantically similar classes by 13.1% (AUROC).
Our experiments are conducted on Ubuntu Linux 20.04 with Python 3.8 and Pytorch 1.10. Besides, the following packages are required to be installed:
- transformers
- scipy
- matplotlib
- seaborn
We use the publicly available checkpoints from Hugging Face where the ViT model is pre-trained on ImageNet-21k and fine-tuned on ImageNet-1k. For example, the checkpoint for ViT-B is available here.
For CLIP models, our reported results are based on checkpoints provided by Hugging Face for CLIP-B and CLIP-L. Similar results can be obtained with checkpoints in the codebase by OpenAI.
For complete information, refer to Appendix B in the paper. The default dataset location is ./datasets/
, which can be changed in settings.yaml
.
We consider the following (in-distribution) datasets:
CUB-200
,Standford-Cars
,Food-101
,Oxford-Pet
ImageNet-1k
,ImageNet-10
,ImageNet-20
,ImageNet-100
The ImageNet-1k dataset (ILSVRC-2012) can be downloaded here. ImageNet-10, ImageNet-20, and ImageNet-100 can be generated given the classnames and IDs provided in data/ImageNet10/ImageNet-10-classlist.csv
, data/ImageNet20/ImageNet-20-classlist.csv
, and data/ImageNet100/class_list.txt
respectively. The other datasets will be automatically downloaded.
We use the large-scale OOD datasets iNaturalist, SUN, Places, and Texture curated by Huang et al. 2021. Please follow instruction from the this repository to download the subsampled datasets where semantically overlapped classes with ImageNet-1k are removed.
The overall file structure is as follows:
MCM
|-- datasets
|-- ImageNet
|-- ImageNet10
|-- ImageNet20
|-- ImageNet100
|-- ImageNet_OOD_dataset
|-- iNaturalist
|-- dtd
|-- SUN
|-- Places
...
The main script for evaluating OOD detection performance is eval_ood_detection.py
. Here are the list of arguments:
--name
: A unique ID for the experiment, can be any string--score
: The OOD detection score, which accepts any of the following:MCM
: Maximum Concept Matching scoreenergy
: The Energy scoremax-logit
: Max Logit score (i.e., cosine similarity without softmax)entropy
: Negative entropy of softmax scaled cosine similaritiesvar
: Variance of cosine similarities
--seed
: A random seed for the experiments--gpu
: The index of the GPU to use. For example--gpu=0
--in_dataset
: The in-distribution dataset- Accepts:
ImageNet
,ImageNet10
,ImageNet20
,ImageNet100
,bird200
,car196
,flower102
,food101
,pet37
,
- Accepts:
-b
,--batch_size
: Mini-batch size--CLIP_ckpt
: Specifies the pretrained CLIP encoder to use- Accepts:
ViT-B/32
,ViT-B/16
,ViT-L/14
.
- Accepts:
The OOD detection results will be generated and stored in results/in_dataset/score/CLIP_ckpt/name/
.
We provide bash scripts to help reproduce numerical results of our paper and facilitate future research. For example, to evaluate the performance of MCM score on ImageNet-1k, with an experiment name eval_ood
:
sh scripts/eval_mcm.sh eval_ood ImageNet MCM
If you find our work useful, please consider citing our paper:
@inproceedings{ming2022delving,
title={Delving into Out-of-Distribution Detection with Vision-Language Representations},
author={Ming, Yifei and Cai, Ziyang and Gu, Jiuxiang and Sun, Yiyou and Li, Wei and Li, Yixuan},
booktitle={Advances in Neural Information Processing Systems},
year={2022}
}