Project Icon

SupContrast

监督对比学习框架增强视觉表征

SupContrast是一个开源的监督对比学习框架,致力于提升视觉表征学习效果。该项目实现了监督对比学习和SimCLR算法,在CIFAR数据集上展现出色性能。它提供简洁的损失函数实现,支持自定义数据集,并附有详细运行指南和可视化结果。在ImageNet上,SupContrast实现了79%以上的Top-1准确率。这一工具为计算机视觉领域的研究和应用提供了重要支持。

SupContrast: 监督对比学习

本仓库包含了以下论文在PyTorch中的参考实现,使用CIFAR作为说明性示例: (1) 监督对比学习。论文 (2) 视觉表示对比学习的简单框架。论文

更新

${\color{red}注意}$:如果您发现本仓库中的supcon损失实现难以解析,我们已经为您准备好了。Supcon损失本质上只是一个交叉熵损失(参见StableRep论文中的等式4)。因此,我们在这里提供了一个更清晰简洁的实现。希望这能帮到您。

ImageNet模型(使用动量编码器技巧的小批量大小)已在此处发布。它达到了超过79%的top-1准确率。

损失函数

losses.py中的损失函数SupConLoss接受特征(L2归一化)和标签作为输入,并返回损失。如果标签None或未传递给它,则退化为SimCLR。

用法:

from losses import SupConLoss

# 定义具有温度参数`temp`的损失
criterion = SupConLoss(temperature=temp)

# features: [bsz, n_views, f_dim]
# `n_views`是每张图像的裁剪数量
# 最好在f_dim维度上进行L2归一化
features = ...
# labels: [bsz]
labels = ...

# SupContrast
loss = criterion(features, labels)
# 或 SimCLR
loss = criterion(features)
...

比较

CIFAR-10的结果:

架构设置损失准确率(%)
SupCrossEntropyResNet50监督交叉熵95.0
SupContrastResNet50监督对比96.0
SimCLRResNet50无监督对比93.6

CIFAR-100的结果:

架构设置损失准确率(%)
SupCrossEntropyResNet50监督交叉熵75.3
SupContrastResNet50监督对比76.5
SimCLRResNet50无监督对比70.7

ImageNet的结果(敬请期待):

架构设置损失准确率(%)
SupCrossEntropyResNet50监督交叉熵-
SupContrastResNet50监督对比79.1 (MoCo技巧)
SimCLRResNet50无监督对比-

运行

您可以使用CUDA_VISIBLE_DEVICES设置适当数量的GPU,和/或通过--dataset cifar100切换到CIFAR100。 (1) 标准交叉熵

python main_ce.py --batch_size 1024 \
  --learning_rate 0.8 \
  --cosine --syncBN \

(2) 监督对比学习 预训练阶段:

python main_supcon.py --batch_size 1024 \
  --learning_rate 0.5 \
  --temp 0.1 \
  --cosine

您也可以指定--syncBN,但我发现它对SupContrast并不关键(syncBN 95.9% vs BN 96.0%)。

警告:目前,--syncBN没有效果,因为代码使用的是DataParallel而不是DistributedDataParaleel

线性评估阶段:

python main_linear.py --batch_size 512 \
  --learning_rate 5 \
  --ckpt /path/to/model.pth

(3) SimCLR 预训练阶段:

python main_supcon.py --batch_size 1024 \
  --learning_rate 0.5 \
  --temp 0.5 \
  --cosine --syncBN \
  --method SimCLR

--method SimCLR标志只是阻止将标签传递给SupConLoss准则。 线性评估阶段:

python main_linear.py --batch_size 512 \
  --learning_rate 1 \
  --ckpt /path/to/model.pth

在自定义数据集上:

python main_supcon.py --batch_size 1024 \
  --learning_rate 0.5  \ 
  --temp 0.1 --cosine \
  --dataset path \
  --data_folder ./path \
  --mean "(0.4914, 0.4822, 0.4465)" \
  --std "(0.2675, 0.2565, 0.2761)" \
  --method SimCLR

--data_folder必须采用./path/label/xxx.png的形式,遵循https://pytorch.org/docs/stable/torchvision/datasets.html#torchvision.datasets.ImageFolder 约定。

t-SNE可视化

(1) 标准交叉熵

(2) 监督对比学习

(3) SimCLR

参考文献

@Article{khosla2020supervised,
    title   = {Supervised Contrastive Learning},
    author  = {Prannay Khosla and Piotr Teterwak and Chen Wang and Aaron Sarna and Yonglong Tian and Phillip Isola and Aaron Maschinot and Ce Liu and Dilip Krishnan},
    journal = {arXiv preprint arXiv:2004.11362},
    year    = {2020},
}
项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

SubCat字幕猫

SubCat字幕猫APP是一款创新的视频播放器,它将改变您观看视频的方式!SubCat结合了先进的人工智能技术,为您提供即时视频字幕翻译,无论是本地视频还是网络流媒体,让您轻松享受各种语言的内容。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号