RSAlgorithms

RSAlgorithms

集成传统与社交方法的开源推荐系统工具包

RSAlgorithms是一个开源推荐系统工具包,集成了传统和社交推荐算法。该项目提供基于评分数据的传统推荐方法,以及利用社交信息缓解数据稀疏问题的社交推荐方法。同时收录了其他研究者实现的经典算法。RSAlgorithms支持交叉验证,并具有灵活的参数配置功能。

推荐系统协同过滤矩阵分解社交推荐开源工具包Github开源项目

推荐系统工具包:一个开源的推荐系统工具包

该代码库提供了一系列经典的传统推荐方法,这些方法仅使用评分数据进行预测,以及社交推荐方法,这些方法利用信任/社交信息来缓解评分数据的稀疏性问题。此外,我们还收集了一些其他人实现的经典方法,以方便您使用。

传统推荐

  • UserCF[Resnick等人,1994]

Resnick, Paul等人。"GroupLens:协作过滤网络新闻的开放架构"。1994年ACM计算机支持的协作工作会议论文集。ACM,1994。

  • ItemCF[Sarwar等人,2001]

Sarwar, Badrul等人。"基于项目的协作过滤推荐算法"。第10届国际万维网会议论文集。ACM,2001。

  • FunkSVD[Simon Funk,2006]

http://sifter.org/~simon/journal/20061211.html

  • PMF[Salakhutdinov,2008]

Mnih, Andriy和Ruslan R. Salakhutdinov。"概率矩阵分解"。神经信息处理系统进展(2008):1257-1264。

  • IntegSVD[Koren等人,2008]

Koren, Yehuda。"因子化遇上邻域:多面协作过滤模型"。第14届ACM SIGKDD知识发现和数据挖掘国际会议论文集。ACM,2008。

  • BiasSVD[Koren等人,2009]

Koren, Yehuda、Robert Bell和Chris Volinsky。"推荐系统的矩阵分解技术"。计算机42.8(2009)。

  • SVD++[Koren等人,2010]

Koren, Yehuda。"考虑邻居因素:可扩展且准确的协作过滤"。ACM知识发现和数据交易(TKDD)4.1(2010):1。

社交推荐

  • SocialRec[Ma等人,2008]

Ma, Hao等人。"Sorec:使用概率矩阵分解的社交推荐"。第17届ACM信息和知识管理会议论文集。ACM,2008。

  • RSTE[Ma等人,2009]

Ma, Hao、Irwin King和Michael R. Lyu。"学习使用社交信任集成进行推荐"。第32届ACM SIGIR信息检索研究与开发国际会议论文集。ACM,2009。

  • TrustWalker[Jamali和Ester,2009]

Jamali, Mohsen和Martin Ester。"Trustwalker:结合基于信任和基于项目推荐的随机游走模型"。第15届ACM SIGKDD知识发现和数据挖掘国际会议论文集。ACM,2009。

  • SocialMF[Jamali和Ester,2010]

Jamali, Mohsen和Martin Ester。"一种用于社交网络推荐的信任传播矩阵分解技术"。第四届ACM推荐系统会议论文集。ACM,2010。

  • SocialReg[Ma等人,2011]

Ma, Hao等人。"具有社交正则化的推荐系统"。第四届ACM国际网络搜索和数据挖掘会议论文集。ACM,2011。

  • TrustSVD[Guo等人,2015]

Guo, Guibing、Jie Zhang和Neil Yorke-Smith。"TrustSVD:同时考虑用户信任的显式和隐式影响以及项目评分的协作过滤"。AAAI。第15卷。2015。

  • CUNE[Zhang等人,2017]

Chuxu Zhang、Lu Yu、Yan Wang、Chirag Shah、Xiangliang Zhang。"社交推荐系统的协作用户网络嵌入"。SDM,2017。

其他人实现的RSAlgorithms

Sedhain等人。"Autorec:自编码器遇上协作过滤"。WWW,2015。代码

Kim等人。"用于文档上下文感知推荐的卷积矩阵分解"。RecSys,2016。代码

Liang等人。"因子化遇上项目嵌入:使用项目共现正则化矩阵分解"。RecSys,2016。代码

He等人。"用于具有隐式反馈的在线推荐的快速矩阵分解"。SIGIR,2016。代码

Quadrana等人。"使用分层递归神经网络个性化会话推荐"。RecSys,2017。代码

He等人。"神经协作过滤"。WWW,2017。代码

Ebesu等人。"推荐系统的协作记忆网络"。SIGIR,2018。代码

Fan等人。"社交推荐的图神经网络"。WWW,2019。代码

Chong等人。"用于推荐的高效异构协作过滤无需负采样"。AAAI,2020。代码

环境要求

  • numpy==1.14.2
  • scipy==1.0.1
  • pandas==0.22.0
  • matplotlib==2.2.2

代码结构

我们项目的结构以树形式呈现如下:

推荐系统  # 项目根目录
│   README.md
│   __init__.py
│   .gitignore
|
└───configx  # 配置全局参数和超参数
│   │   configx.py   
|   │   
└───data  # 存储评分和社交数据
│   │   ft_ratings.txt
|   │   ft_trust.txt
|   |
│   └───cv  # 交叉验证数据
│       │   ft-0.txt
│       │   ft-1.txt
│       │   ft-2.txt
│       │   ft-3.txt
│       │   ft-4.txt
|       |
└───metrics  # 用于衡量评分预测任务预测准确性的指标
│   │   metric.py
|   |
└───model  # 传统和社交推荐方法集
│   │   bias_svd.py
│   │   funk_svd.py
│   │   pmf.py
│   │   integ_svd.py
|   |   item_cf.py
|   |   item_cf_big.py
|   |   mf.py
|   |   social_mf.py
|   |   social_rec.py
|   |   social_reg.py
|   |   social_rste.py
|   |   svd++.py
|   |   trust_svd.py
|   |   trust_walker.py
|   |   user_cf.py
|   |
└───reader  # 评分和社交数据的数据生成器
│   │   rating.py
│   │   trust.py
|   |
└───utility  # 其他常用工具
    │   cross_validation.py
    │   data_prepro.py
    │   data_statistics.py
    │   draw_figure.py
    │   matrix.py
    │   similarity.py
    │   tools.py
    │   util.py

参数设置

如果您想更改默认超参数,可以在configx.py中进行设置。超参数的含义如下:

数据集参数

dataset_name:数据集的简称,默认值为ft

k_fold_num:交叉验证的折数,默认值为5

rating_path:原始评分数据文件的路径,默认值为../data/ft_ratings.txt

rating_cv_path:评分数据的交叉验证路径,默认值为../data/cv/

trust_path:原始信任数据文件的路径,默认值为../data/ft_trust.txt

sep:三元组中评分和信任数据的分隔符,默认值为

random_state:随机数种子,默认值为0

size:训练集的比例,默认值为0.8

min_val:最小评分值,默认值为0.5

max_val:最大评分值,默认值为4.0

模型超参数

coldUserRating:冷启动用户对项目的评分数量,默认值为5

factor:用户和项目的潜在维度大小,默认值为10

threshold:模型训练的阈值,默认值为1e-4

lr:学习率,默认值为0.01

maxIter:最大迭代次数,默认值为100lambdaP:用户正则化参数,默认值为0.001

lambdaQ:项目正则化参数,默认值为0.001

gamma:动量系数,默认值为0.9

isEarlyStopping:早停标志,默认值为false

输出参数

result_path:结果主目录,默认值为../results/

model_path:训练好的变量目录,默认值为../results/model/

result_log_path:训练模型时的日志目录,默认值为../results/log/

使用方法

接下来,我将以pmf为例介绍如何执行我们的代码。

首先,我们应该将评分数据分割成几个部分用于训练、测试和交叉验证。

from utility.cross_validation import split_5_folds
from configx.configx import ConfigX

if __name__ == "__main__":
    configx = ConfigX()
    configx.k_fold_num = 5 
    configx.rating_path = "../data/ft_ratings.txt"
    configx.rating_cv_path = "../data/cv/"
    
    split_5_folds(configx)

然后,我们打开model文件夹中的pmf.py文件,配置训练的超参数并执行以下代码:

if __name__ == '__main__':

    rmses = []
    maes = []
    bmf = FunkSVDwithR()
    for i in range(bmf.config.k_fold_num):
        bmf.train_model(i)
        rmse, mae = bmf.predict_model()
        print("当前最佳rmse为%0.5f,mae为%0.5f" % (rmse, mae))
        rmses.append(rmse)
        maes.append(mae)
    rmse_avg = sum(rmses) / 5
    mae_avg = sum(maes) / 5
    print("rmse列表为%s" % rmses)
    print("mae列表为%s" % maes)
    print("rmse平均值为%s " % rmse_avg)
    print("mae平均值为%s " % mae_avg)

引用

如果您使用了我们的代码,请引用我们的论文。谢谢!

@inproceedings{pricai2018sotricf,
    title="Social Collaborative Filtering Ensemble",
    author="Zhang, Honglei and Liu, Gangdu and Wu, Jun",
    booktitle="PRICAI",
    pages="1005--1017"
    year="2018",
}

@inproceedings{ijcnn2019MFDGE,
    title={Integrating dual user network embedding with matrix factorization for social recommender systems},
    author={Chen, Liying and Zhang, Honglei and Wu, Jun},
    booktitle={IJCNN},
    pages={1--8},
    year={2019},
}

RSPapers

最近,我们启动了一个开源项目RSPapers,其中包含一些经典的综述传统推荐系统社交推荐系统基于深度学习的推荐系统推荐系统中的冷启动问题POI推荐系统

致谢

特别为您总结了传统和社交推荐系统,如果您有任何问题,请随时联系我。最后,我真诚地期待与您合作,为此做出贡献。

非常感谢@yunzhan2014对此项目的贡献。

我的Gmail:hongleizhang1993@gmail.com

编辑推荐精选

Trae

Trae

字节跳动发布的AI编程神器IDE

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
问小白

问小白

全能AI智能助手,随时解答生活与工作的多样问题

问小白,由元石科技研发的AI智能助手,快速准确地解答各种生活和工作问题,包括但不限于搜索、规划和社交互动,帮助用户在日常生活中提高效率,轻松管理个人事务。

热门AI助手AI对话AI工具聊天机器人
Transly

Transly

实时语音翻译/同声传译工具

Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足你所有需要同传的场景需求,线上线下通用,扫除语言障碍,让全世界的语言交流不再有国界。

讯飞智文

讯飞智文

一键生成PPT和Word,让学习生活更轻松

讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。

AI办公办公工具AI工具讯飞智文AI在线生成PPTAI撰写助手多语种文档生成AI自动配图热门
讯飞星火

讯飞星火

深度推理能力全新升级,全面对标OpenAI o1

科大讯飞的星火大模型,支持语言理解、知识问答和文本创作等多功能,适用于多种文件和业务场景,提升办公和日常生活的效率。讯飞星火是一个提供丰富智能服务的平台,涵盖科技资讯、图像创作、写作辅助、编程解答、科研文献解读等功能,能为不同需求的用户提供便捷高效的帮助,助力用户轻松获取信息、解决问题,满足多样化使用场景。

热门AI开发模型训练AI工具讯飞星火大模型智能问答内容创作多语种支持智慧生活
Spark-TTS

Spark-TTS

一种基于大语言模型的高效单流解耦语音令牌文本到语音合成模型

Spark-TTS 是一个基于 PyTorch 的开源文本到语音合成项目,由多个知名机构联合参与。该项目提供了高效的 LLM(大语言模型)驱动的语音合成方案,支持语音克隆和语音创建功能,可通过命令行界面(CLI)和 Web UI 两种方式使用。用户可以根据需求调整语音的性别、音高、速度等参数,生成高质量的语音。该项目适用于多种场景,如有声读物制作、智能语音助手开发等。

咔片PPT

咔片PPT

AI助力,做PPT更简单!

咔片是一款轻量化在线演示设计工具,借助 AI 技术,实现从内容生成到智能设计的一站式 PPT 制作服务。支持多种文档格式导入生成 PPT,提供海量模板、智能美化、素材替换等功能,适用于销售、教师、学生等各类人群,能高效制作出高品质 PPT,满足不同场景演示需求。

讯飞绘文

讯飞绘文

选题、配图、成文,一站式创作,让内容运营更高效

讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。

热门AI辅助写作AI工具讯飞绘文内容运营AI创作个性化文章多平台分发AI助手
��材料星

材料星

专业的AI公文写作平台,公文写作神器

AI 材料星,专业的 AI 公文写作辅助平台,为体制内工作人员提供高效的公文写作解决方案。拥有海量公文文库、9 大核心 AI 功能,支持 30 + 文稿类型生成,助力快速完成领导讲话、工作总结、述职报告等材料,提升办公效率,是体制打工人的得力写作神器。

openai-agents-python

openai-agents-python

OpenAI Agents SDK,助力开发者便捷使用 OpenAI 相关功能。

openai-agents-python 是 OpenAI 推出的一款强大 Python SDK,它为开发者提供了与 OpenAI 模型交互的高效工具,支持工具调用、结果处理、追踪等功能,涵盖多种应用场景,如研究助手、财务研究等,能显著提升开发效率,让开发者更轻松地利用 OpenAI 的技术优势。

下拉加载更多