RankSys

Java 8 Recommender Systems framework for novelty, diversity and much more

Github stars Tracking Chart

RankSys: Java 8 Recommender Systems framework for novelty, diversity and much more

Team, References, Javadoc, Wiki, Twitter

Maven Central
Build Status
GitHub license

Introduction

RankSys is a new framework for the implementation and evaluation of recommendation algorithms and techniques that has resulted from a line of research work that is currently documented in several publications (see here) and a PhD thesis. While it is envisioned as a framework for the generic experimentation of recommendation technologies, it includes substantial support focusing on the evaluation and enhancement of novelty and diversity. RankSys derives its name from explicitly targeting the ranking task problem, rather than rating prediction. This decision is reflected in the design of the different core interfaces and components of the framework.

The framework has been programmed with Java 8, which is the most recent version of the popular programming language. We take advantage of many of the new features of the language, such as the use of lambda functions, Stream's and facilities for automatic parallelization of the code. The code licensed under the MPL 2.0.

The publicly available version of this framework (0.4.3) includes implementations of several collaborative filtering recommendation algorithms as well as a wide variety of novelty and diversity metrics and re-ranking techniques. The modules published to date are the following:

  • RankSys-core: common and auxiliary classes of the framework.
  • RankSys-fast: support for fast and efficient implementation of data structures and algorithms.
  • RankSys-metrics: interfaces and common components for defining metrics.
  • RankSys-rec: support for generating recommendation lists.
  • RankSys-nn: nearest neighbors recommendation algorithms.
  • RankSys-mf: matrix factorization recommendation algorithms.
  • RankSys-fm: factorisation machines for recommendation tasks using JavaFM.
  • RankSys-lda: Latent Dirichlet Allocation for collaborative filtering recommendation algorithms.
  • RankSys-novdiv: common resources for novelty and diversity metrics and enhancement techniques.
  • RankSys-novelty: novelty metrics and enhancement techniques.
  • RankSys-diversity: diversity metrics and enhancement techniques.
  • RankSys-compression: state-of-art compression techniques for in-memory collaborative filtering.
  • RankSys-examples: examples of usage of the previous modules.

Maven

If you want to use the whole framework, include the following dependency:

<dependency>
    <groupId>org.ranksys</groupId>
    <artifactId>RankSys</artifactId>
    <version>0.4.3</version>
</dependency>

Alternatively, include in your project dependencies only the modules of RankSys that you require:

<dependency>
    <groupId>org.ranksys</groupId>
    <artifactId>RankSys-MODULENAME</artifactId>
    <version>0.4.3</version>
</dependency>

where MODULENAME is replaced by core, fast, metrics, rec, etc.

Main metrics

Overview
Name With OwnerRankSys/RankSys
Primary LanguageJava
Program languageJava (Language Count: 2)
Platform
License:Mozilla Public License 2.0
所有者活动
Created At2015-01-17 16:44:39
Pushed At2022-01-21 23:21:58
Last Commit At2021-02-05 14:57:59
Release Count7
Last Release Name0.4.3 (Posted on )
First Release Name0.1 (Posted on )
用户参与
Stargazers Count277
Watchers Count30
Fork Count57
Commits Count458
Has Issues Enabled
Issues Count39
Issue Open Count4
Pull Requests Count18
Pull Requests Open Count1
Pull Requests Close Count6
项目设置
Has Wiki Enabled
Is Archived
Is Fork
Is Locked
Is Mirror
Is Private