基于自监督学习的高效句子嵌入模型
采用自监督对比学习技术,all-MiniLM-L12-v2模型专注于高效编码句子和短段落,利用超过11亿句对进行训练,加强语义搜索和信息检索性能。结合TPU与JAX/Flax技术优化,模型方便集成在sentence-transformers或HuggingFace Transformers中,适合多种文本处理应用。
all-MiniLM-L12-v2 是一个句子嵌入模型,隶属于SENTENCE-TRANSFORMERS 库。该模型的主要功能是将句子和段落映射到384维度的稠密向量空间,从而可以用于聚类或语义搜索等任务。
该项目的目标是利用大规模句子级数据集,通过自监督对比学习目标训练句子嵌入模型。我们采用了预训练的microsoft/MiniLM-L12-H384-uncased
模型,并在十亿级别的句子对数据集上进行了微调。项目使用了 Hugging Face 组织的使用 JAX/Flax 的 NLP & CV 社区周中开发,得到了 Google Flax、JAX 和云团队的硬件支持。
此模型主要用于对句子和短段落进行编码。给定一个输入文本,模型输出一个捕捉语义信息的向量,可用于信息检索、聚类或句子相似性任务。在默认配置下,超过256个词片段的输入文本会被截断。
要使用该模型,可以通过以下命令安装sentence-transformers
库:
pip install -U sentence-transformers
然后,可以如下使用模型:
from sentence_transformers import SentenceTransformer sentences = ["This is an example sentence", "Each sentence is converted"] model = SentenceTransformer('sentence-transformers/all-MiniLM-L12-v2') embeddings = model.encode(sentences) print(embeddings)
不通过sentence-transformers
,可以通过以下方式使用模型:
from transformers import AutoTokenizer, AutoModel import torch import torch.nn.functional as F def mean_pooling(model_output, attention_mask): token_embeddings = model_output[0] input_mask_expanded = attention_mask.unsqueeze(-1).expand(token_embeddings.size()).float() return torch.sum(token_embeddings * input_mask_expanded, 1) / torch.clamp(input_mask_expanded.sum(1), min=1e-9) sentences = ['This is an example sentence', 'Each sentence is converted'] tokenizer = AutoTokenizer.from_pretrained('sentence-transformers/all-MiniLM-L12-v2') model = AutoModel.from_pretrained('sentence-transformers/all-MiniLM-L12-v2') encoded_input = tokenizer(sentences, padding=True, truncation=True, return_tensors='pt') with torch.no_grad(): model_output = model(**encoded_input) sentence_embeddings = mean_pooling(model_output, encoded_input['attention_mask']) sentence_embeddings = F.normalize(sentence_embeddings, p=2, dim=1) print("Sentence embeddings:") print(sentence_embeddings)
我们使用预训练模型microsoft/MiniLM-L12-H384-uncased
。有关更详细的预训练过程,请参阅模型卡。
通过对比学习目标微调模型。此过程中计算每个可能句子对的余弦相似性,并通过交叉熵损失与真实配对进行比较。
train_script.py
中可访问。模型微调使用了多个数据集的合并,总句子对数量超过十亿。每个数据集的采样权重配置详见data_config.json
文件。
数据集 | 论文 | 训练元组数量 |
---|---|---|
Reddit comments | 论文链接 | 726,484,430 |
S2ORC Abstracts | 论文链接 | 116,288,806 |
WikiAnswers | 论文链接 | 77,427,422 |
PAQ | 论文链接 | 64,371,441 |
S2ORC Titles | 论文链接 | 52,603,982 |
Stack Exchange (Title, Body) | - | 25,316,456 |
更多数据集... | - | ... |
总训练样本数量超过一十七亿条。
有关该模型的自动化评估,请参见句子嵌入基准测试。
一键生成PPT和Word,让学习生活更轻松
讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。
深度推理能力全新升级,全面对标OpenAI o1
科大讯飞的星火大模型,支持语言理解、知识问答和文本创作等多功能,适用于多种文件和业务场景,提升办公和日常生活的效率。讯飞星火是一个提供丰富智能服务的平台,涵盖科技资讯、图像创作、写作辅助、编程解答、科研文献解读等功能,能为不同需求的用户提供便捷高效的帮助,助力用户轻松获取信息、解决问题,满足多样化使用场景。