当前位置: 首页 > news >正文

网站提升排名单位网站 方案

网站提升排名,单位网站 方案,dw制作网页版面教程视频,wordpress程序出错的原因SVD、SVD、PMF 和 NMF 是几种常见的推荐算法#xff0c;它们主要用于协同过滤和矩阵分解方法来生成个性化推荐。下面是对每种算法的简要介绍#xff1a; 1. SVD#xff08;Singular Value Decomposition#xff09; 用途#xff1a;SVD 是一种矩阵分解技术#xff0c;通…SVD、SVD、PMF 和 NMF 是几种常见的推荐算法它们主要用于协同过滤和矩阵分解方法来生成个性化推荐。下面是对每种算法的简要介绍 1. SVDSingular Value Decomposition 用途SVD 是一种矩阵分解技术通常用于降维和数据压缩。在推荐系统中SVD 用于分解用户-物品评分矩阵从而识别潜在的特征。原理SVD 将评分矩阵分解为三个矩阵的乘积用户矩阵、奇异值矩阵和物品矩阵。通过保留前几个最大的奇异值可以捕捉到用户和物品之间的隐含关系。优势能够处理稀疏数据提取潜在特征生成个性化推荐。缺点对缺失值敏感且需要较大的计算量。 2. SVDSVD Plus Plus 用途SVD 是对 SVD 的扩展考虑了用户对未评分物品的潜在偏好。原理除了使用传统的 SVD 方法外SVD 还引入了隐式反馈如用户浏览、点击等行为将这些信息融入模型中增强了对用户偏好的捕捉能力。优势比传统 SVD 更加准确能够更好地利用隐式反馈信息适应性更强。缺点模型复杂度增加训练时间较长。 3. PMFProbabilistic Matrix Factorization 用途PMF 是一种基于概率的矩阵分解方法用于推荐系统。原理PMF 假设用户和物品的特征遵循正态分布通过最大化似然函数来学习这些特征。与 SVD 不同PMF 通过引入概率模型来捕捉用户和物品之间的关系。优势能够处理缺失值适应性强适用于稀疏数据。缺点计算复杂度较高可能需要较长的训练时间。 4. NMFNon-negative Matrix Factorization 用途NMF 是一种非负矩阵分解方法常用于推荐系统和特征学习。原理NMF 将原始评分矩阵分解为两个非负矩阵的乘积这些非负特征使得模型在解释上更具可解释性。优势生成的特征可以更直观地理解适合处理非负数据如评分、计数等。缺点可能会收敛到局部最优解且在稀疏数据上表现不如 SVD 和 PMF。 各个推荐算法具有的特点是 SVD利用矩阵分解捕捉用户和物品的隐含特征。SVD在 SVD 的基础上引入隐式反馈增强推荐精度。PMF基于概率模型的矩阵分解适应性强。NMF非负矩阵分解生成可解释的特征表示。 安装scikit-surprise pip install pandas scikit-surprise 使用SVD import pandas as pd from surprise import Reader, Dataset, SVD from surprise.model_selection import train_test_split from surprise import accuracy import json# 1. 加载Yelp数据集 # 假设数据文件名为 yelp_academic_dataset_review.json file_path yelp_academic_dataset_review.json# 加载JSON文件到DataFrame with open(file_path, r) as f:data [json.loads(line) for line in f]# 将数据转换为pandas DataFrame df pd.DataFrame(data)# 2. 选择必要的字段user_id, business_id, rating df df[[user_id, business_id, stars]] # 假设评分字段是 stars# 3. 数据预处理将DataFrame转换为适合Surprise库的格式 reader Reader(rating_scale(1, 5)) # 假设评分是1到5 dataset Dataset.load_from_df(df[[user_id, business_id, stars]], reader)# 4. 划分训练集和测试集 trainset, testset train_test_split(dataset, test_size0.2)# 5. 使用SVD训练模型 svd SVD() svd.fit(trainset)# 6. 在测试集上进行预测并评估 predictions svd.test(testset) print(fRMSE: {accuracy.rmse(predictions)})# 7. 获取每个用户的Top-N推荐商家 def get_top_n(predictions, n10):top_n {}for uid, iid, true_r, est, _ in predictions:if uid not in top_n:top_n[uid] []top_n[uid].append((iid, est))# 对每个用户推荐列表按照评分进行排序for uid, user_ratings in top_n.items():user_ratings.sort(keylambda x: x[1], reverseTrue)top_n[uid] user_ratings[:n]return top_n# 获取推荐结果 top_n get_top_n(predictions, n10)# 8. 为特定用户推荐商家 user_id fB3jbHi3m0L2KgGOxBv6uw # 替换为目标用户ID recommended_businesses top_n.get(user_id, []) print(fTop 10 recommended businesses for user {user_id}:) for business_id, rating in recommended_businesses:print(fBusiness ID: {business_id}, Predicted Rating: {rating}) 这个示例假设评分值在1到5之间即rating_scale(1, 5)如果评分范围不同请修改为适合你的数据集的范围。 运行结果 RMSE: 1.2863 RMSE: 1.2862955370267326 Top 10 recommended businesses for user fB3jbHi3m0L2KgGOxBv6uw 使用 SVD import pandas as pd from surprise import Reader, Dataset, SVDpp from surprise.model_selection import train_test_split from surprise import accuracy import json# 1. 加载Yelp数据集 # 假设数据文件名为 yelp_academic_dataset_review.json file_path yelp_academic_dataset_review.json# 加载JSON文件到DataFrame with open(file_path, r) as f:data [json.loads(line) for line in f]# 将数据转换为pandas DataFrame df pd.DataFrame(data)# 2. 选择必要的字段user_id, business_id, rating df df[[user_id, business_id, stars]] # 假设评分字段是 stars# 3. 数据预处理将DataFrame转换为适合Surprise库的格式 reader Reader(rating_scale(1, 5)) # 假设评分是1到5 dataset Dataset.load_from_df(df[[user_id, business_id, stars]], reader)# 4. 划分训练集和测试集 trainset, testset train_test_split(dataset, test_size0.2)# 5. 使用SVD训练模型 svdpp SVDpp() svdpp.fit(trainset)# 6. 在测试集上进行预测并评估 predictions svdpp.test(testset) print(fRMSE: {accuracy.rmse(predictions)})# 7. 获取每个用户的Top-N推荐商家 def get_top_n(predictions, n10):top_n {}for uid, iid, true_r, est, _ in predictions:if uid not in top_n:top_n[uid] []top_n[uid].append((iid, est))# 对每个用户推荐列表按照评分进行排序for uid, user_ratings in top_n.items():user_ratings.sort(keylambda x: x[1], reverseTrue)top_n[uid] user_ratings[:n]return top_n# 获取推荐结果 top_n get_top_n(predictions, n10)# 8. 为特定用户推荐商家 user_id fB3jbHi3m0L2KgGOxBv6uw # 替换为目标用户ID recommended_businesses top_n.get(user_id, []) print(fTop 10 recommended businesses for user {user_id}:) for business_id, rating in recommended_businesses:print(fBusiness ID: {business_id}, Predicted Rating: {rating})数据集的规模 SVD比SVD复杂所以如果数据集非常大可能会需要更长时间进行训练尤其是在计算资源有限的情况下。 运行结果 RMSE: 1.2947 RMSE: 1.2947410246403837 Top 10 recommended businesses for user fB3jbHi3m0L2KgGOxBv6uw: 使用PMF PMF 在 Surprise 中实现为 SVD因此我们可以直接使用 SVD 作为 PMF, 代码参见SVD 使用NMF import pandas as pd from surprise import Reader, Dataset, NMF from surprise.model_selection import train_test_split from surprise import accuracy import json# 1. 加载Yelp数据集 # 假设数据文件名为 yelp_academic_dataset_review.json file_path yelp_academic_dataset_review.json# 加载JSON文件到DataFrame with open(file_path, r) as f:data [json.loads(line) for line in f]# 将数据转换为pandas DataFrame df pd.DataFrame(data)# 2. 选择必要的字段user_id, business_id, rating df df[[user_id, business_id, stars]] # 假设评分字段是 stars# 3. 数据预处理将DataFrame转换为适合Surprise库的格式 reader Reader(rating_scale(1, 5)) # 假设评分是1到5 dataset Dataset.load_from_df(df[[user_id, business_id, stars]], reader)# 4. 划分训练集和测试集 trainset, testset train_test_split(dataset, test_size0.2)# 5. 使用NMFNon-negative Matrix Factorization进行矩阵分解 nmf NMF() nmf.fit(trainset)# 6. 在测试集上进行预测并评估 predictions nmf.test(testset) print(fRMSE: {accuracy.rmse(predictions)})# 7. 获取每个用户的Top-N推荐商家 def get_top_n(predictions, n10):top_n {}for uid, iid, true_r, est, _ in predictions:if uid not in top_n:top_n[uid] []top_n[uid].append((iid, est))# 对每个用户推荐列表按照评分进行排序for uid, user_ratings in top_n.items():user_ratings.sort(keylambda x: x[1], reverseTrue)top_n[uid] user_ratings[:n]return top_n# 获取推荐结果 top_n get_top_n(predictions, n10)# 8. 为特定用户推荐商家 user_id fB3jbHi3m0L2KgGOxBv6uw # 替换为目标用户ID recommended_businesses top_n.get(user_id, []) print(fTop 10 recommended businesses for user {user_id}:) for business_id, rating in recommended_businesses:print(fBusiness ID: {business_id}, Predicted Rating: {rating}) NMF与SVD的区别 NMF非负矩阵分解不同于SVD奇异值分解它强制矩阵的分解结果为非负值。适用于当数据有明显非负约束例如评分数据的情况。如果数据中包含负值NMF可能无法正常工作这时可以考虑使用SVD。性能问题 如果数据集非常大矩阵分解模型可能需要较长时间训练。可以考虑在大规模数据集上进行性能优化例如使用并行计算或使用分布式计算框架。 运行结果 RMSE: 1.4577 RMSE: 1.4577314669222752 Top 10 recommended businesses for user fB3jbHi3m0L2KgGOxBv6uw
http://www.dnsts.com.cn/news/170269.html

相关文章:

  • 网站建站描述撰写网站域名icp备案
  • 织梦网站栏目建设天津正规网站建设调试公司
  • 青岛商务学校网站建设wordpress 全文
  • 张家港百度网站制作企业网站的建立要做的准备
  • 企业网站维护费用常州网站建设电话
  • 网站开发后端书籍搜索服务公司
  • 最好的模板网站沈阳工程建设信息网站
  • 如何建立网站视频wordpress二级目录创建
  • 重庆建筑网站wordpress 爆破脚本
  • 大连市平台网站舆情系统源码
  • 深圳住房和建设局网站首页seog
  • 长沙市网站推广哪家专业wordpress分类二级域名
  • 网站结构优点做网站配置
  • 免费单页网站建设集团网站开发
  • 什么网站可以找人做系统广州金融网站建设
  • 安庆市大观区城乡建设局网站emlog 迁移Wordpress
  • 珠海市建设工程造价协会网站做书网站
  • 企业自己做网站的成本网站的更新与维护
  • 徐州 商城网站建设江北区网络推广技巧
  • 网页qq登录首页乐清seo公司
  • 高明网站设计服务全国知名网站排名
  • 上海智能网站建设公司旅游网站模板库
  • wordpress电源模板青岛做优化网站哪家好
  • 玉环网站制作素材网视频
  • 用地方名字做网站品牌建设典型案例材料
  • 易语言网站建设购买建立网站费怎么做会计凭证
  • 网站开发的开发语言详情页设计模板网站
  • 素材下载网站源码网店运营与管理
  • 俄语网站看摄影作品的网站
  • 物流网站模板友链网站