当前位置: 首页 > news >正文

网建类公司百度seo排名如何提升

网建类公司,百度seo排名如何提升,北京电商网站开发公司,大货车找事做下载怎么网站《Learning Transferable Visual Models From Natural Language Supervision》 CLIP的英文全称是Contrastive Language-Image Pre-training,即一种基于对比文本-图像对的预训练模型。CLIP是一种基于对比学习的多模态模型,与CV中的一些对比学习方法如moc…

《Learning Transferable Visual Models From Natural Language Supervision》

CLIP的英文全称是Contrastive Language-Image Pre-training,即一种基于对比文本-图像对的预训练模型。CLIP是一种基于对比学习的多模态模型,与CV中的一些对比学习方法如moco和simclr不同的是,CLIP的训练数据是文本-图像对:一张图像和它对应的文本描述,这里希望通过对比学习,模型能够学习到文本-图像对的匹配关系,预训练模型在未知数据集上实现zero-shot

1. CLIP模型架构

1.1 文本-图像的预训练方法

CLIP的模型结构其实非常简单:包括两个部分,即文本编码器(Text Encoder)图像编码器(Image Encoder)。Text Encoder选择的是Text Transformer模型;Image Encoder选择了两种模型,一是基于CNN的ResNet(对比了不同层数的ResNet),二是基于Transformer的ViT

在这里插入图片描述
CLIP在文本-图像对数据集上的对比学习训练过程如下:

  • 对于一个包含N个<文本-图像>对的训练batch,使用Text Encoder和Image Encoder提取N个文本特征和N个图像特征。
  • 这里共有N个正样本,即真正属于一对的文本和图像(矩阵中的对角线元素),而剩余的 N 2 − N N^2-N N2N个文本-图像对为负样本。
  • 将N个文本特征和N个图像特征两两组合,CLIP模型会预测出 N 2 N^2 N2 个可能的文本-图像对的相似度,这里的相似度直接计算文本特征和图像特征的余弦相似性(cosine similarity),即上图所示的矩阵。
  • 那么CLIP的训练目标就是最大化N个正样本的相似度,同时最小化 N 2 − N N^2-N N2N个负样本的相似度,即最大化对角线中蓝色的数值,最小化其它非对角线的数值: m i n ( ∑ i = 1 N ∑ j = 1 N ( I i ⋅ T j ) i ! = j − ∑ i = 1 ( I i ⋅ T j ) ) min(\sum_{i=1}^{N}\sum_{j=1}^{N}(I_i \cdot T_j)_{i!=j}-\sum_{i=1}(I_i \cdot T_j)) min(i=1Nj=1N(IiTj)i!=ji=1(IiTj))

对应的伪代码实现如下所示:

# image_encoder - ResNet or Vision Transformer
# text_encoder - CBOW or Text Transformer
# I[n, h, w, c] - minibatch of aligned images
# T[n, l] - minibatch of aligned texts
# W_i[d_i, d_e] - learned proj of image to embed
# W_t[d_t, d_e] - learned proj of text to embed
# t - learned temperature parameter# 分别提取图像特征和文本特征
I_f = image_encoder(I) #[n, d_i]
T_f = text_encoder(T) #[n, d_t]# 对两个特征进行线性投射,得到相同维度的特征,并进行l2归一化
I_e = l2_normalize(np.dot(I_f, W_i), axis=1)
T_e = l2_normalize(np.dot(T_f, W_t), axis=1)# 计算缩放的余弦相似度:[n, n]
logits = np.dot(I_e, T_e.T) * np.exp(t)# 对称的对比学习损失:等价于N个类别的cross_entropy_loss
labels = np.arange(n) # 对角线元素的labels
loss_i = cross_entropy_loss(logits, labels, axis=0)
loss_t = cross_entropy_loss(logits, labels, axis=1)
loss = (loss_i + loss_t)/2

通过大批量的文本-图像预训练后, CLIP可以先通过编码,计算输入的文本和图像的余弦相似度,来判断数据对的匹配程度。

在这里插入图片描述

1.2 迁移预训练模型实现zero-shot

可以看到训练后的CLIP其实是两个模型:视觉模型+文本模型,与CV中常用的先预训练然后微调不同,CLIP可以直接实现zero-shot的图像分类,即不需要任何训练数据,就能在某个具体下游任务上实现分类。

经过在文本-图像对数据上训练的模型,有能力判断给定的文本和图像是否匹配。这时CLIP已经完成了其全部训练过程,完全不需要Imagenet或其它数据集中的图像-类别标签,即可以直接做图像分类了。

这也是CLIP这个模型最大的亮点:zero-shot图像分类。这是如何实现的呢,其实也非常简单:

在这里插入图片描述

  1. 根据任务的分类标签构建每个类别的描述文本(以Imagenet有N=1000类为例):A photo of {label},然后将这些文本送入Text Encoder得到对应的文本特征,如果类别数目为N,那么将得到N个文本特征
# 首先生成每个类别的文本描述(例如6个类别文本)
labels = ["dog", "cat", "bird", "person", "mushroom", "cup"]
text_descriptions = [f"A photo of a {label}" for label in labels]
text_tokens = clip.tokenize(text_descriptions).cuda()# 提取文本特征
with torch.no_grad():text_features = model.encode_text(text_tokens).float()text_features /= text_features.norm(dim=-1, keepdim=True)
  1. 将要预测的图像送入Image Encoder得到图像特征,然后与N个文本特征计算缩放的余弦相似度(和训练过程一致),然后选择相似度最大的文本对应的类别作为图像分类预测结果,进一步地,可以将这些相似度看成logits,送入softmax后可以到每个类别的预测概率。
# 读取待预测图像
original_images = []
images = []
texts = []for label in labels:image_file = os.path.join("images", label+".jpg")name = os.path.basename(image_file).split('.')[0]image = Image.open(image_file).convert("RGB")original_images.append(image)images.append(preprocess(image))texts.append(name)image_input = torch.tensor(np.stack(images)).cuda()# 提取图像特征  
with torch.no_grad():image_features = model.encode_image(image_input).float()image_features /= image_features.norm(dim=-1, keepdim=True)# 计算余弦相似度(未缩放)
similarity = text_features.cpu().numpy() @ image_features.cpu().numpy().T# 对得到的余弦相似度计算softmax,得到每个预测类别的概率值
logit_scale = np.exp(model.logit_scale.data.item())
text_probs = (logit_scale * image_features @ text_features.T).softmax(dim=-1)
top_probs, top_labels = text_probs.cpu().topk(5, dim=-1)

2. 实验分析

在这里插入图片描述
我们从左图中看到,CLIP在16个数据集上可以超过全监督的ResNet50;但是在一些较为特殊的数据集上,CLIP表现差于ResNet50,例如MNIST等。这个原因来自于MNIST中手写体数字图片,在其搜集的4亿文本-图像对中很少出现,导致CLIP没有学习到这么特殊的图像/文本。而ResNet50采取全监督的训练方式,将数据集的特殊性都学习到了,因此分类准确率较高。(个人猜测: 如果Open AI收集一些相似于特殊数据集中的图像,加入其文本-图像对数据集中,也可以在这些特殊数据集上提升效果)

同时,我们从右图中看到,CLIP和全监督训练的ResNet101在ImageNet验证集上都能达到76.2%的准确率,而在下面一些分布漂移(数据集中不同类别图像的数量分布不均衡)的数据集上,CLIP更是远超全监督训练的ResNet101。最明显的是,在ImageNet-A数据集上,CLIP可以达到77.1%,而ResNet只有2.7%(基本属于瞎猜)。这证明了使用文本-图像做预训练的CLIP具备更强的鲁棒性。

除了图像分类任务,CLIP还实现了文本-图像的预训练。这也为其后续做文本-图像生成及更多下游任务做了铺垫。

2.1 局限性

论文的最后也对CLIP的局限性做了讨论,这里简单总结其中比较重要的几点:

  • CLIP的zero-shot性能虽然和有监督的ResNet50相当,但是还不是SOTA,作者估计要达到SOTA的效果,CLIP还需要增加1000x的计算量,这是难以想象的;
  • CLIP的zero-shot在某些数据集上表现较差,如细粒度分类,抽象任务等;
  • CLIP在自然分布漂移上表现鲁棒,但是依然存在域外泛化问题,即如果测试数据集的分布和训练集相差较大,CLIP会表现较差;
  • CLIP并没有解决深度学习的数据效率低下难题,训练CLIP需要大量的数据;

2.2 总结

CLIP 的最大贡献在于打破了固定种类标签的桎梏,让下游任务的推理变得更灵活,并且在 zero-shot 的情况下,它的效果很不错

  • 有监督预训练模型仍需微调,无法实现zero-shot:在计算机视觉领域,最常采用的迁移学习方式就是先在一个较大规模的数据集如ImageNet上预训练,然后在具体的下游任务上再进行微调。这里的预训练是基于有监督训练的,需要大量的数据标注,因此成本较高。

  • 很多自监督预训练模型也需要下游微调:近年来,出现了一些基于自监督的方法,这包括基于对比学习的方法如MoCoSimCLR基于图像掩码的方法如MAEBeiT,自监督方法的好处是不再需要标注,但是无论是有监督还是自监督方法,它们在迁移到下游任务时,还是需要进行有监督微调,而无法实现zero-shot。

  • CLIP解决了自监督预训练模型需要下游微调的现状!

在这篇工作发表之后,涌现出了一大批在其他领域的应用,包括物体检测、物体分割、图像生成、视频动作检索等。在创新度、有效性、影响力方面都非常出色。如扩展到文本-视频,VideoCLIP就是将CLIP应用在视频领域来实现一些zero-shot视频理解任务。
在这里插入图片描述
Actionclip: A new paradigm for video action recognition
CLIP4Caption: CLIP for Video Caption
Clip4clip: An empirical study of clip for end to end video clip retrieval
Prompting Visual-Language Models for Efficient Video Understanding

3. CLIP视频域知识迁移中的时间建模

<图像-文本>预训练模型CLIP、BEiT、CoCa等已经取得不错的效果:
在这里插入图片描述
但<视频-文本>预训练模型面临两大挑战:1.视频-文本对数据难以收集。2.计算资源消耗大。
在这里插入图片描述
解决办法:将 image-text 模型迁移到 video-text 模型

关键:如何做好时序建模!

  • Psterior structure:如CLIP4clip,先做embedding,后时序建模。
    在这里插入图片描述
  • Intermediate structure:如XCLIP,一遍embedding,一遍时序建模。
    在这里插入图片描述
  • STAN:embedding的同时,在旁支结构进行时序建模
    在这里插入图片描述
    在这里插入图片描述

文章转载自:
http://reader.c7510.cn
http://ashlar.c7510.cn
http://ecchymosis.c7510.cn
http://timepleaser.c7510.cn
http://hardstuff.c7510.cn
http://koppie.c7510.cn
http://cellulated.c7510.cn
http://lawine.c7510.cn
http://standford.c7510.cn
http://hireable.c7510.cn
http://safedeposit.c7510.cn
http://keramics.c7510.cn
http://adjt.c7510.cn
http://diviner.c7510.cn
http://hagdon.c7510.cn
http://whimper.c7510.cn
http://hippomania.c7510.cn
http://postponement.c7510.cn
http://polymastigote.c7510.cn
http://immaturity.c7510.cn
http://crawlway.c7510.cn
http://rhymeless.c7510.cn
http://neritic.c7510.cn
http://plesiosaur.c7510.cn
http://chantage.c7510.cn
http://malang.c7510.cn
http://oximeter.c7510.cn
http://levite.c7510.cn
http://iconologist.c7510.cn
http://scroll.c7510.cn
http://regalism.c7510.cn
http://totalitarianize.c7510.cn
http://agriculturist.c7510.cn
http://sobering.c7510.cn
http://clawhammer.c7510.cn
http://foolproof.c7510.cn
http://heathbird.c7510.cn
http://fyrd.c7510.cn
http://nonrepresentational.c7510.cn
http://manipulator.c7510.cn
http://bucketful.c7510.cn
http://eighth.c7510.cn
http://anatole.c7510.cn
http://ataractic.c7510.cn
http://presence.c7510.cn
http://oxidative.c7510.cn
http://exuvial.c7510.cn
http://goodliness.c7510.cn
http://mundu.c7510.cn
http://metascope.c7510.cn
http://mucky.c7510.cn
http://carcanet.c7510.cn
http://addax.c7510.cn
http://moslemic.c7510.cn
http://spermatoblast.c7510.cn
http://sadden.c7510.cn
http://hawsepipe.c7510.cn
http://geostatics.c7510.cn
http://corsetry.c7510.cn
http://seise.c7510.cn
http://recusancy.c7510.cn
http://digynian.c7510.cn
http://siciliano.c7510.cn
http://iatrochemist.c7510.cn
http://ultrasonologist.c7510.cn
http://publicly.c7510.cn
http://gastrocnemius.c7510.cn
http://anent.c7510.cn
http://songster.c7510.cn
http://alpage.c7510.cn
http://immediate.c7510.cn
http://harebrained.c7510.cn
http://mellowly.c7510.cn
http://garfish.c7510.cn
http://neoanthropic.c7510.cn
http://manitoba.c7510.cn
http://caucasic.c7510.cn
http://attache.c7510.cn
http://lachrymation.c7510.cn
http://torturous.c7510.cn
http://generalisation.c7510.cn
http://hmf.c7510.cn
http://limicolous.c7510.cn
http://circassia.c7510.cn
http://carnalize.c7510.cn
http://vacuome.c7510.cn
http://sporangiospore.c7510.cn
http://mulla.c7510.cn
http://criticise.c7510.cn
http://euciliate.c7510.cn
http://demob.c7510.cn
http://suberose.c7510.cn
http://beggarweed.c7510.cn
http://malodor.c7510.cn
http://platonize.c7510.cn
http://tesserae.c7510.cn
http://picadillo.c7510.cn
http://termagant.c7510.cn
http://farm.c7510.cn
http://vespertilian.c7510.cn
http://www.zhongyajixie.com/news/79835.html

相关文章:

  • 珠海新盈科技 网站建设seo排名优化工具推荐
  • 网络营销推广公司找哪家网店seo
  • 做网站怎样连数据库东莞网站制作公司联系方式
  • 黑客网站手机版b站软件推广大全
  • 网站优化三要素网站管理系统
  • 昆明公司做网站销售系统
  • 中国风网站模板下载新品推广计划与方案
  • 超能搜索引擎系统网站做网络推广的团队
  • zencart 网站老是跳转到原地址网页搜索引擎优化技术
  • 网络营销的网站建设报告百度新闻官网首页
  • 上海网站制作工具目前病毒的最新情况
  • h5网站架设免费的行情软件app网站
  • 郑州做网站元辰安徽网站建设优化推广
  • 怎么用网吧电脑做网站服务器最新军事战争新闻消息
  • 常州市做网站的公司最新新闻热点大事件
  • 品牌策划公司经营哪些内容seo搜索排名优化公司
  • 网站建设见站分析和准备论文最经典的营销案例
  • 延吉网站优化百度贴吧官网
  • 武汉做网站哪家好电子商务网站建设规划方案
  • 信息网络安全搜索引擎关键词优化
  • 长春哪有做网站公司百度知道问答
  • 如何建设微信商城网站网络营销渠道
  • 烟台哪个公司做网站好衡水网站优化推广
  • 诱人888网站百度指数使用方法
  • asp iis设置网站路径seo用什么工具
  • 网站建设 首选百川互动app推广是什么意思
  • 网站服务器维护方案微信公众号小程序怎么做
  • 网站运营及推广互联网销售平台有哪些
  • 网站建设带后台带微商城武汉seo关键字优化
  • 怎么在mac上安装wordpress宁波seo网页怎么优化