java实现推荐算法实例_从技术角度分析推荐系统案例

我们在使用各类型的软件的时候,总是能在各大app中获取到推荐信息的数据,而且会发现推荐的信息数据还比较适合个人的口味,例如说某些共同兴趣爱好的好友推荐,某些好听的音乐推荐等等。

在进行推荐系统的核心算法介绍之前,我们需要先来回顾一下以前所学过的数学知识内容。

欧几里得距离

二维的欧几里得距离:

例如下图所示,在这样的一个简单的二维空间图里面,根据对于a点的坐标和b点的坐标进行二维空间距离的计算,假设p为点a到点b的欧式距离,那么可以根据勾股定理来计算出两点之间的向量距离为:

cd5e28e69d56e52d140ef68b6d2f6a1a.png

4261dfacc99866f82f85467fdb7c4173.png

三维空间的欧几里得距离:

除了常见的二维空间之外,常用于的计算场景还有可能是基于三维空间运算的。

7054eeda3579cff0904f5647d3935dc1.png

在这种场景下,假设计算A点和B点之间的距离为p,那么计算可以得出p的值为:

0a71a1e64f4d1fac188ce08cc3ce0871.png

在了解了这些基本的知识点之后,我们再结合实际的应用场景来展开应用。

例如说一个电影影评网站,需要加入一个推荐喜欢观看同类电影的好友功能。

首先模拟出一个具体的数据场景:

296f0b43cdae480202cb09fac71976d3.png

1对该电影进行过评价,0没有对该电影进行过评价

有了这样的一个数据统计场景之后,我们可以根据对电影是否有共同评价进行共同兴趣爱好的匹配推荐。但是这种场景下也有一定的缺陷,那就是对于电影的评价有好有坏,需要将共同喜爱同一类电影的用户进行匹配推荐,将不喜欢同一类电影的用户进行匹配推荐就属于推荐失误的场景了。

改进点

在用户评论里面加入对于电影的打分功能,我们将打分等级也进行一个分类

674006906ce2b94b0e6ffc134c1bb7a2.png

那么我们将这里的打分等级和上述的电影评价相互结合之后便可得出下表:

58f3c544434ee2d92dd9a475067f92b8.png

根据上述的这张表,我们再回顾到本文开始时候所说的二维和三维空间里面的欧几里得距离计算。

假设A点的坐标为A(a1,a2…),B点坐标为B(b1,b2…)

二维空间距离计算:

6f44e9217897848eed3ac4f903e9983b.png

三维空间距离计算:

1e308681a65ce6a3172051d5d46a07e7.png

类比一维、二维、三维的表示方法,n 维空间中的某个位置,我们可以写作(X1X1,X2X2,X3X3,…,XKXK)。这种表示方法我们称之为向量。

n维空间的距离计算:

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值