基于项目的协同过滤
最初的基于项目的推荐完全基于用户项目排名(例如,用户给一部电影打了 3 颗星,或者用户“喜欢”了一个视频)。当您计算项目之间的相似度时,除了所有用户的评分历史之外,您不应该知道任何其他内容。因此,项目之间的相似度是基于评分而不是项目内容的元数据来计算的。
让我给你举个例子。假设您只能访问一些评级数据,如下所示:
user 1 likes: movie, cooking
user 2 likes: movie, biking, hiking
user 3 likes: biking, cooking
user 4 likes: hiking
假设现在您想为用户 4 提出建议。
首先,您为项目创建倒排索引,您将获得:
movie: user 1, user 2
cooking: user 1, user 3
biking: user 2, user 3
hiking: user 2, user 4
由于这是一个二元评级(喜欢或不喜欢),我们可以使用类似Jaccard Similarity 之类的相似性度量来计算项目相似性。
|user1|
similarity(movie, cooking) = --------------- = 1/3
|user1,2,3|
在分子中,user1 是电影和烹饪都具有的唯一元素。在分母中,电影和烹饪的联合有 3 个不同的用户(用户 1、2、3)。|.|
这里表示集合的大小。所以我们知道在我们的例子中,电影和烹饪之间的相似度是 1/3。您只需对所有可能的项目对执行相同的操作(i,j)
。
在完成所有对的相似性计算之后,比如说,您需要为用户 4 做出推荐。
- 查看
similarity(hiking, x)
x 是您可能拥有的任何其他标签的相似度得分。
如果您需要为用户 3 进行推荐,您可以汇总其列表中每个项目的相似度得分。例如,
score(movie) = Similarity(biking, movie) + Similarity(cooking, movie)
score(hiking) = Similarity(biking, hiking) + Similarity(cooking, hiking)
基于内容的推荐
基于内容的重点是我们必须知道用户和项目的内容。通常你使用共享属性空间的内容来构建用户配置文件和项目配置文件。例如,对于一部电影,您可以用其中的电影明星和类型来表示它(例如使用二进制编码)。对于用户资料,您可以根据用户喜欢某些电影明星/类型等来做同样的事情。然后可以使用例如余弦相似度来计算用户和项目的相似度。
这是一个具体的例子:
假设这是我们的用户资料(使用二进制编码,0 表示不喜欢,1 表示喜欢),其中包含用户对 5 位电影明星和 5 种电影类型的偏好:
Movie stars 0 - 4 Movie Genres
user 1: 0 0 0 1 1 1 1 1 0 0
user 2: 1 1 0 0 0 0 0 0 1 1
user 3: 0 0 0 1 1 1 1 1 1 0
假设这是我们的电影简介:
Movie stars 0 - 4 Movie Genres
movie1: 0 0 0 0 1 1 1 0 0 0
movie2: 1 1 1 0 0 0 0 1 0 1
movie3: 0 0 1 0 1 1 0 1 0 1
为了计算电影对用户的好坏程度,我们使用余弦相似度:
dot-product(user1, movie1)
similarity(user 1, movie1) = ---------------------------------
||user1|| x ||movie1||
0x0+0x0+0x0+1x0+1x1+1x1+1x1+1x0+0x0+0x0
= -----------------------------------------
sqrt(5) x sqrt(3)
= 3 / (sqrt(5) x sqrt(3)) = 0.77460
相似地:
similarity(user 2, movie2) = 3 / (sqrt(4) x sqrt(5)) = 0.67082
similarity(user 3, movie3) = 3 / (sqrt(6) x sqrt(5)) = 0.54772
如果你想给用户一个推荐,就选择最高的i
电影。j
similarity(i, j)
希望这可以帮助。