RePlay 是一个先进的框架,旨在促进推荐系统的开发和评估。它提供了一套强大的工具,涵盖了推荐系统管道的整个生命周期:
<a name="toc"></a>
<a name="installation"></a>
默认推荐通过 pip 包管理器进行安装:
pip install replay-rec
这种情况下,将安装不包含 PySpark 和 PyTorch 依赖的 core 包。
同时 experimental 子模块也不会被安装。
要安装 experimental 子模块,请指定带有 rc0 后缀的版本。
例如:
pip install replay-rec==XX.YY.ZZrc0
除了核心包之外,还提供了几个附加功能,包括:
[spark]:安装 PySpark 功能[torch]:安装 PyTorch 和 Lightning 功能[all]:[spark] [torch]示例:
# 安装带有 PySpark 依赖的核心包 pip install replay-rec[spark] # 安装带有实验子模块和 PySpark 依赖的包 pip install replay-rec[spark]==XX.YY.ZZrc0
要从源代码构建 RePlay,请使用此说明。
如果在安装 RePlay 过程中遇到错误,请查看故障排除指南。
<a name="quickstart"></a>
from rs_datasets import MovieLens from replay.data import Dataset, FeatureHint, FeatureInfo, FeatureSchema, FeatureType from replay.data.dataset_utils import DatasetLabelEncoder from replay.metrics import HitRate, NDCG, Experiment from replay.models import ItemKNN from replay.utils.spark_utils import convert2spark from replay.utils.session_handler import State from replay.splitters import RatioSplitter spark = State().session ml_1m = MovieLens("1m") K=10 # 数据预处理 interactions = convert2spark(ml_1m.ratings) # 数据拆分 splitter = RatioSplitter( test_size=0.3, divide_column="user_id", query_column="user_id", item_column="item_id", timestamp_column="timestamp", drop_cold_items=True, drop_cold_users=True, ) train, test = splitter.split(interactions) # 数据集创建 feature_schema = FeatureSchema( [ FeatureInfo( column="user_id", feature_type=FeatureType.CATEGORICAL, feature_hint=FeatureHint.QUERY_ID, ), FeatureInfo( column="item_id", feature_type=FeatureType.CATEGORICAL, feature_hint=FeatureHint.ITEM_ID, ), FeatureInfo( column="rating", feature_type=FeatureType.NUMERICAL, feature_hint=FeatureHint.RATING, ), FeatureInfo( column="timestamp", feature_type=FeatureType.NUMERICAL, feature_hint=FeatureHint.TIMESTAMP, ), ] ) train_dataset = Dataset( feature_schema=feature_schema, interactions=train, ) test_dataset = Dataset( feature_schema=feature_schema, interactions=test, ) # 数据编码 encoder = DatasetLabelEncoder() train_dataset = encoder.fit_transform(train_dataset) test_dataset = encoder.transform(test_dataset) # 模型训练 model = ItemKNN() model.fit(train_dataset) # 模型推理 encoded_recs = model.predict( dataset=train_dataset, k=K, queries=test_dataset.query_ids, filter_seen_items=True, ) recs = encoder.query_and_item_id_encoder.inverse_transform(encoded_recs) # 模型评估 metrics = Experiment( [NDCG(K), HitRate(K)], test, query_column="user_id", item_column="item_id", rating_column="rating", ) metrics.add_result("ItemKNN", recs) print(metrics.results)
<a name="examples"></a>
视频指南:
研究论文:
<a name="contributing"></a>
我们欢迎社区贡献。详情请查看我们的贡献指南。


AI一键生成PPT,就用博思AIPPT!
博思AIPPT,新一代的AI生成PPT平台,支持智能生成PPT、AI美化PPT、文本&链接生成PPT、导入Word/PDF/Markdown文档生成PPT等,内置海量精美PPT模板,涵盖商务、教育、科技等不同风格,同时针对每个页面提供多种版式,一键自适应切换,完美适配各种办公场景。


AI赋能电商视觉 革命,一站式智能商拍平台
潮际好麦深耕服装行业,是国内AI试衣效果最好的软件。使用先进AIGC能力为电商卖家批量提供优质的、低成本的商拍图。合作品牌有Shein、Lazada、安踏、百丽等65个国内外头部品牌,以及国内10万+淘宝、天猫、京东等主流平台的品牌商家,为卖家节省将近85%的出图成本,提升约3倍出图效率,让品牌能够快速上架。


企业专属的AI法律顾问
iTerms是法大大集团旗下法律子品牌,基于最先进的大语言模型(LLM)、专业的法律知识库和强大的智能体架构,帮助企业扫清合规障碍,筑牢风控防线,成为您企业专属的AI法律顾问。


稳定高效的流量提升解决方案,助力品牌曝光
稳定高效的流量提升解决方案,助力品牌曝光

