两矩阵行向量余弦相似度计算向量化操作

余弦相似度计算:

1 ```math
2 \cos(\bf{v_1}, \bf{v_2}) = \frac{\left(
3 v_1 \times v_2 \right)}{||v_1|| * ||v_2|| }
4 
5 ```

 

 1 ### 矩阵矢量化操作
 2 ### 按行计算余弦相似度
 3 ### 两矩阵计算相似度向量应为同维度
 4 ### 返回值RES为A矩阵每行对B矩阵每行向量余弦值
 5 ### RES[i,j] 表示A矩阵第i行向量与B矩阵第j行向量余弦相似度
 6 
 7 def cosine_Matrix(_matrixA, _matrixB):
 8   import numpy
 9   _matrixA_matrixB = _matrixA * _matrixB.transpose()
10   ### 按行求和,生成一个列向量
11   ### 即各行向量的模
12   _matrixA_norm = numpy.sqrt(numpy.multiply(_matrixA,_matrixA).sum(axis=1))
13   _matrixB_norm = numpy.sqrt(numpy.multiply(_matrixB,_matrixB).sum(axis=1))
14   return numpy.divide(_matrixA_matrixB, _matrixA_norm * _matrixB_norm.transpose())
15 
16 ### 向量计算余弦相似度
17 ### 计算两向量余弦相似度
18 ### 返回_vec1和_vec2余弦相似度
19 ### 此处用于计算向量余弦相似度,验证矩阵相似度计算结果
20 
21 def cosine(_vec1, _vec2):
22   import numpy
23   return float(numpy.sum(_vec1*_vec2))/(numpy.linalg.norm(_vec1)*numpy.linalg.norm(_vec2))

 

转载于:https://www.cnblogs.com/suanec/p/9121082.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值