IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> 【推荐系统的离线评估方法】 -> 正文阅读

[人工智能]【推荐系统的离线评估方法】

声明

内容摘自:项亮,《推荐系统实战》。侵删。

推荐效果的离线评估

现阶段有三类评估推荐效果的方法:离线实验、用户调查、在线实验。本文主要是基于离线实验阐述一些具体的方法。

记R(u)为对用户u推荐的N个物品,记T(u)为用户喜爱/点击了的物品,那么做推荐系统的精度为。

召回率:

R e c a l l = ∑ N ∣ R ( u ) ∩ T ( u ) ∣ ∑ N ∣ T ( u ) ∣ Recall= \frac{\sum_{N}|R(u) \cap T(u)|}{\sum_{N}|T(u)|} Recall=N?T(u)N?R(u)T(u)?

准确率:

P r e c i s i o n = ∑ N ∣ R ( u ) ∩ T ( u ) ∣ ∑ N ∣ R ( u ) ∣ Precision= \frac{\sum_{N}|R(u) \cap T(u)|}{\sum_{N}|R(u)|} Precision=N?R(u)N?R(u)T(u)?

根据公式,召回率描述的是有多少比例的用户—物品评分记录包含在最终的推荐列表中,而准确率描述的是最终的推荐列表中有多少比例是发生过的用户—物品评分记录。
下面给出两种评测方法的代码(python):

# 召回率
def Recall(train, test, N):     
	hit = 0     
	all = 0     
	for user in train.keys():         
		tu = test[user]         
		rank = GetRecommendation(user, N)         
		for item, pui in rank:             
			if item in tu:                 
				hit += 1            
		all += len(tu)     # 区别在这行
	return hit / (all * 1.0)

# 准确率
def Precision(train, test, N):     
	hit = 0     
	all = 0     
	for user in train.keys():         
		tu = test[user]         
		rank = GetRecommendation(user, N)         
		for item, pui in rank:             
			if item in tu:                 
			hit    +=    1            
		all += N      # 区别在这行  
	return hit / (all * 1.0)

覆盖率

除了评测推荐算法的精度,很多推荐系统还会计算算法的覆盖率(反映了推荐算法发掘长尾的能力),覆盖率越高,说明推荐算法越能够将长尾中的物品推荐给用户。
C o v e r a g e = ∣ U u ∈ U R ( u ) ∣ ∣ I ∣ Coverage= \frac{|U_{u \in U}R(u) |}{|I|} Coverage=IUuU?R(u)?
如果所有的物品都被推荐给至少一个用户,那么覆盖率就是100%。
下面给出代码(python):

# 覆盖率
def Coverage(train, test, N):     
	recommend_items = set()     
	all_items = set()     
	for user in train.keys():         
		for item in train[user].keys():
			all_items.add(item)            
		rank = GetRecommendation(user, N)         
		for item, pui in rank:
			recommend_items.add(item)        
	return len(recommend_items) / (len(all_items) * 1.0) 
  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2022-03-16 22:21:38  更:2022-03-16 22:22:01 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/9 16:00:48-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码