0

0

Python怎么计算余弦相似度_基于余弦夹角距离的超长文本语义相似度计算

P粉602998670

P粉602998670

发布时间:2026-03-16 09:17:03

|

379人浏览过

|

来源于php中文网

原创

cosine_similarity对超长文本报错或不准,因其只处理向量;超长文本直接向量化易致内存爆炸、维度失控或语义失真;应先分句、用sentence-transformers编码、再均值池化并归一化后计算相似度。

python怎么计算余弦相似度_基于余弦夹角距离的超长文本语义相似度计算

为什么 cosine_similarity 对超长文本直接报错或结果不准

因为 cosine_similarity(来自 sklearn.metrics.pairwise)本身不处理文本,它只吃向量;而超长文本若硬塞进 TfidfVectorizerCountVectorizer,会触发内存爆炸、稀疏矩阵维度失控,或者因截断/哈希冲突导致语义失真。

  • 常见错误现象:MemoryErrorValueError: array is too big、相似度值全接近 0 或 1
  • 根本原因不是函数错了,是向量化这步没控住规模:比如 10 万字文档被转成百万维稀疏向量,再求余弦,既慢又偏
  • 真正可用的路径是「降维 + 局部敏感」:先用句粒度切分,再用预训练句向量(如 sentence-transformers)编码,最后批量算 cosine_similarity

怎么用 all-MiniLM-L6-v2 安全计算超长文本相似度

这个模型在 512 token 限制下仍能较好捕获句级语义,且推理快、显存友好,比 BERT 全量微调更适配长文本场景。

  • 不要把整篇超长文本一股脑喂给模型——会截断前 512 token,后半段信息彻底丢失
  • 正确做法:用 spacynltk 按句切分,过滤掉空句和过短句(如 len(sentence) ),再对每句单独 encode
  • 得到句向量矩阵后,用 np.mean(..., axis=0) 得文档级向量(比 max 更稳,抗噪声)
  • 示例关键行:
    from sentence_transformers import SentenceTransformer<br>model = SentenceTransformer('all-MiniLM-L6-v2')<br>sentences = [s.strip() for s in doc.split('。') if len(s.strip()) > 10]<br>embeddings = model.encode(sentences)<br>doc_vec = np.mean(embeddings, axis=0)

cosine_similarity 的输入形状和 dtype 容易踩的坑

它要求输入是二维数组,且必须是 float 类型;很多用户传了 list of list 或 int 型向量,结果返回全 1 或报 ValueError: Expected 2D array

Tweeze
Tweeze

Tweeze.app是一个AI驱动的个性化新闻简报服务,定位为个人互联网AI阅读助手

下载
  • 错误写法:cosine_similarity([vec_a], [vec_b]) —— 这里外层是 list,不是 np.ndarray
  • 正确写法:cosine_similarity(np.array([vec_a]), np.array([vec_b])),注意双层中括号:第一维是样本数,第二维是特征维
  • 如果传的是单个向量对,务必包成 shape=(1, d) 和 (1, d),不能是 (d,) 或 (d, 1)
  • dtype 必须是 float32float64;从 model.encode() 出来的默认是 float32,但手动拼的向量常是 int64,记得加 .astype(np.float32)

超长文本相似度结果不稳定?检查是否漏了归一化

cosine_similarity 内部其实做了 L2 归一化,但前提是输入向量没被意外缩放或混入零向量——而长文本切句后,常有停用句、标点句、编码失败句,它们产出的向量接近零,拉低整体均值向量质量。

立即学习Python免费学习笔记(深入)”;

  • 排查方法:打印 np.linalg.norm(doc_vec),如果不是接近 1.0,说明归一化前就有问题
  • 安全做法:在 np.mean(...) 后显式做一次归一化:doc_vec /= np.linalg.norm(doc_vec) or 1e-8
  • 更鲁棒的做法是剔除低质量句向量:计算每句向量的模长,过滤掉 norm 的(大概率是空句或乱码)
  • 别依赖模型自动归一——sentence-transformers 的 encode 默认不开归一化,得自己加 normalize_embeddings=True 参数
实际跑起来你会发现,瓶颈不在 cosine_similarity 本身,而在句切分是否合理、哪些句该扔、向量要不要裁维。这些细节没控住,再准的余弦公式也救不回语义漂移。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
css中float用法
css中float用法

css中float属性允许元素脱离文档流并沿其父元素边缘排列,用于创建并排列、对齐文本图像、浮动菜单边栏和重叠元素。想了解更多float的相关内容,可以阅读本专题下面的文章。

597

2024.04.28

C++中int、float和double的区别
C++中int、float和double的区别

本专题整合了c++中int和double的区别,阅读专题下面的文章了解更多详细内容。

108

2025.10.23

登录token无效
登录token无效

登录token无效解决方法:1、检查token的有效期限,如果token已经过期,需要重新获取一个新的token;2、检查token的签名,如果签名不正确,需要重新获取一个新的token;3、检查密钥的正确性,如果密钥不正确,需要重新获取一个新的token;4、使用HTTPS协议传输token,建议使用HTTPS协议进行传输 ;5、使用双因素认证,双因素认证可以提高账户的安全性。

6659

2023.09.14

登录token无效怎么办
登录token无效怎么办

登录token无效的解决办法有检查Token是否过期、检查Token是否正确、检查Token是否被篡改、检查Token是否与用户匹配、清除缓存或Cookie、检查网络连接和服务器状态、重新登录或请求新的Token、联系技术支持或开发人员等。本专题为大家提供token相关的文章、下载、课程内容,供大家免费下载体验。

845

2023.09.14

token怎么获取
token怎么获取

获取token值的方法:1、小程序调用“wx.login()”获取 临时登录凭证code,并回传到开发者服务器;2、开发者服务器以code换取,用户唯一标识openid和会话密钥“session_key”。想了解更详细的内容,可以阅读本专题下面的文章。

1092

2023.12.21

token什么意思
token什么意思

token是一种用于表示用户权限、记录交易信息、支付虚拟货币的数字货币。可以用来在特定的网络上进行交易,用来购买或出售特定的虚拟货币,也可以用来支付特定的服务费用。想了解更多token什么意思的相关内容可以访问本专题下面的文章。

2218

2024.03.01

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1071

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

617

2024.08.29

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

69

2026.03.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 5万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号