LibRec 是一个基于java 1.7以GPL-3.0协议发布的开源推荐系统. LibRec内包含大量推荐算法并可以通过这些算法快速解决rating和ranking问题. 目前LibRec已被RecSys wiki收录.
与1.4相比, 2.0版本重新程序的整体结构, 接口更加合理, 可扩展性更强. 对于已经实现的程序, 可以使用命令行和参数或者配置文件来执行. 开发新推荐算法可以通过继承相应的抽象类来实现.
因Librec中系统结构发生变化, 对于1.4中实现的算法, 需要做以下调整来适配LibRec 2.0:
Linux And MAC:
bash librec rec -exec -conf ../core/src/mian/resources/rec/baseline/usercluster-test.properties
Windows:
librec.sh [CATEGORY] -exec [OPTIONS] where CATEGORY is one of: data: rec: OPTIONS: -load -save -D|-jobconf: -conf -libjars
Librec通过properties格式来定义配置文件. 数据的读取以及数据集划分算法等可以直接在driver.classes.props进行定义 不同推荐系统的个性化推荐算法可以通过配置项定义之后, 可以使用-conf来进行加载
librec保存在
稀疏矩阵保存时同时以CSR与CSC的格式保存
读取数据的类为Convertor, 通过readData方法来进行数据的读取,相关的配置文件示例如下:
目前项目中分别实现了通过ratio进行数据分割, K折交叉验证, leave-one-out, 与GivenN四种分割方式. 配置文件实例如下:
目前有基于矩阵分解等推荐算法共六十余种,
librec对于rating的算法实现了MAE, MPE, MSE, RMSE四种评估算法 对ranking算法实现了AUE, AveragePrecision等十种评估算法
librec通过property配置项来读取并生成相应的类
在librec中, 推荐算法的的原理被分为以下几类, 基于矩阵分解, 基于因子分解, 基于概率图模型, 基于张量. 实现的推荐算法可以根据相应类别继承自相应抽象类, 也可以直接继承AbstractRecommender抽象类.