Visual Prompt Tuning

摘要

当前将预训练模型适用于下游任务的实现方法涉及更新全部 Backbone 参数,例如 Full Fine-tuning。提出了  Visual Prompt Tuning (VPT) 作为一种快捷有效的方法来完整微调大规模 Transformer 模型。受益于高效调优 LLMs 的最新进展,VPT 在保持模型主干冻结的同时,仅引入少量 (不到模型参数的1%) 可训练参数。通过广泛的实验,在各种下游识别任务中,与其他方法相比,VPT实现了显着的性能提升,甚至在多种模型和数据规模下优于完全微调,同时降低了每个任务的存储成本。代码可从 github.com/kmnp/vpt 获得。

Intro.

Fig.1 VPT vs. 迁移学习方法。(a) 目前的迁移学习是根据调整范围分组的:完全微调,面向 Head 和面向 Backbone 的方法。(b) VPT 在输入空间中增加了额外的参数。(c) 采用预训练的 ViT-B 主干在广泛的下游分类任务上的不同方法的表现,并附有平均值和标准差注释。在使用不到1%参数的情况下,在24个场景中有20个优于完全微调

Related Work

Transformer

Transfer Learning

Prompting

Approach

### Prompt Tuning 的概念及其在大模型中的应用 Prompt tuning 是一种轻量级的大规模语言模型微调方法,它通过引入可学习的连续向量(称为 prompts 或 prefix vectors),而不是更新整个模型权重来适应新任务。这种方法显著减少了参数数量,同时保持了良好的性能表现[^1]。 --- #### **Prompt Tuning 的核心原理** Prompt tuning 的基本思想是在输入序列前附加一组可训练的 token embeddings(prompts)。这些 prompts 被视为额外的上下文信息,指导预训练模型更好地理解和生成目标输出。相比于传统的全参数微调,prompt tuning 只需优化少量新增加的参数,因此具有更高的效率和更低的计算成本[^3]。 ```python import torch from transformers import BertModel, BertTokenizer class PromptTuningModel(torch.nn.Module): def __init__(self, model_name, num_prompts=10): super(PromptTuningModel, self).__init__() self.bert = BertModel.from_pretrained(model_name) self.tokenizer = BertTokenizer.from_pretrained(model_name) self.prompts = torch.nn.Parameter(torch.randn(num_prompts, self.bert.config.hidden_size)) def forward(self, input_ids, attention_mask=None): batch_size = input_ids.shape[0] prompt_embeddings = self.prompts.unsqueeze(0).expand(batch_size, -1, -1) inputs_embeds = self.bert.embeddings(input_ids=input_ids) combined_inputs = torch.cat([prompt_embeddings, inputs_embeds], dim=1) if attention_mask is not None: extended_attention_mask = torch.cat( [torch.ones((batch_size, prompt_embeddings.size(1)), dtype=torch.long)], dim=-1 ) attention_mask = torch.cat([extended_attention_mask, attention_mask], dim=-1) outputs = self.bert(inputs_embeds=combined_inputs, attention_mask=attention_mask) return outputs.last_hidden_state[:, :len(prompt_embeddings)] ``` 上述代码展示了一个简单的 prompt tuning 实现框架,其中 `num_prompts` 表示要插入的提示长度,而 `self.prompts` 则是需要训练的部分。 --- #### **Prompt Tuning 在美团业务场景的应用** ##### **1. 商品描述优化** 在电商领域,商品描述通常需要简洁明了且吸引消费者注意。通过 prompt tuning 方法,可以将原始的商品标题或其他元数据作为条件输入,并生成高质量的营销文案。例如,给定一段关于食品成分的文字说明,经过适当设计的 prompts,可以让模型专注于提取关键卖点并重新表述为更易懂的形式[^3]。 --- ##### **2. 客服对话系统改进** 对于在线订餐平台而言,高效的客户支持至关重要。采用基于 prompt tuning 构建的服务机器人不仅可以降低运营成本,还能提升响应速度和服务质量。具体来说,当接收到用户的提问时,先由固定的 templates 提供初步意图识别线索,随后依靠 finetuned LLM 进一步细化答案内容[^5]。 --- ##### **3. 推荐系统中的冷启动问题缓解** 面对新人或新品缺乏足够历史交互记录的情况,传统协同过滤算法往往显得乏力。此时如果结合 NLP 技术,则有可能从文本角度挖掘潜在关联性。比如利用带有特定 domain knowledge encoded into its parameters via prompting mechanism 的 transformer architecture 来预测某类用户可能会喜欢哪一类餐厅风格[^4]。 --- #### **总结与展望** 尽管目前仍处于发展阶段,但随着研究深入和技术成熟度不断提高,相信 future work will continue exploring how to better leverage these techniques across diverse real-world applications including but not limited those mentioned above within Meituan ecosystem. ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值