With the rise of powerful pre-trained vision-language models like CLIP, it becomes essential to investigate ways to adapt these models to downstream datasets. A recently proposed method named Context Optimization (CoOp) introduces the concept of prompt learning -- a recent trend in NLP -- to the vision domain for adapting pre-trained vision-language models. Specifically, CoOp turns context words in a prompt into a set of learnable vectors and, with only a few labeled images for learning, can achieve huge improvements over intensively-tuned manual prompts. In our study we identify a critical problem of CoOp: the learned context is not generalizable to wider unseen classes within the same dataset, suggesting that CoOp overfits base classes observed during training. To address the problem, we propose Conditional Context Optimization (CoCoOp), which extends CoOp by further learning a lightweight neural network to generate for each image an input-conditional token (vector). Compared to CoOp's static prompts, our dynamic prompts adapt to each instance and are thus less sensitive to class shift. Extensive experiments show that CoCoOp generalizes much better than CoOp to unseen classes, even showing promising transferability beyond a single dataset; and yields stronger domain generalization performance as well. Code is available at https://github.com/KaiyangZhou/CoOp.
| Task | Dataset | Metric | Value | Model |
|---|---|---|---|---|
| Prompt Engineering | ImageNet-R | Top-1 accuracy % | 76.18 | CoCoOP |
| Prompt Engineering | Stanford Cars | Harmonic mean | 72.01 | CoCoOp |
| Prompt Engineering | Oxford 102 Flower | Harmonic mean | 81.71 | CoCoOp |
| Prompt Engineering | EuroSAT | Harmonic mean | 71.21 | CoCoOp |
| Prompt Engineering | Oxford-IIIT Pet Dataset | Harmonic mean | 96.43 | CoCoOp |
| Prompt Engineering | ImageNet-S | Top-1 accuracy % | 48.75 | CoCoOp |
| Prompt Engineering | DTD | Harmonic mean | 64.85 | CoCoOp |
| Prompt Engineering | UCF101 | Harmonic mean | 77.64 | CoCoOp |
| Prompt Engineering | Food-101 | Harmonic mean | 90.99 | CoCoOp |
| Prompt Engineering | Caltech-101 | Harmonic mean | 95.84 | CoCoOp |
| Prompt Engineering | ImageNet | Harmonic mean | 73.1 | CoCoOp |
| Prompt Engineering | FGVC-Aircraft | Harmonic mean | 27.74 | CoCoOp |
| Prompt Engineering | SUN397 | Harmonic mean | 78.27 | CoCoOp |
| Prompt Engineering | ImageNet-A | Top-1 accuracy % | 50.63 | CoCoOp |
| Prompt Engineering | ImageNet V2 | Top-1 accuracy % | 64.07 | CoCoOp |