A realtime recommendation system supporting online updates
Project description
rtrec: Realtime Recommendation Library in Python
A realtime recommendation system supporting online updates.
Highlights
- ❇️ Supporting online updates.
- ⚡️ Fast implementation (>=190k samples/sec training on laptop).
- ◍ efficient sparse data support.
- 🕑 decaying weights of user-item interactions based on recency.
experimental Rust implementation
Supported Recommendation Algorithims
- Sparse SLIM with time-weighted interactions.
- Factorization Machines using LightFM
Installation
pip install rtrec
Usage
Find usages in notebooks/examples.
Examples using Raw-level APIs
# Dataset consists of user, item, tstamp, rating
import time
current_unixtime = time.time()
interactions = [('user_1', 'item_1', current_unixtime, 5.0),
('user_2', 'item_2', current_unixtime, -2.0),
('user_2', 'item_1', current_unixtime, 3.0),
('user_2', 'item_4', current_unixtime, 3.0),
('user_1', 'item_3', current_unixtime, 4.0)]
# Fit SLIM model
from rtrec.models import SLIM
model = SLIM()
model.fit(interactions)
# can fit from streams using yield as follows:
def yield_interactions():
for interaction in interactions:
yield interaction
model.fit(yield_interactions())
# Recommend top-5 items for a user
recommendations = model.recommend('user_1', top_k=5)
assert recommendations == ["item_4", "item_2"]
Examples using high level DataFrame APIs
# load dataset
from rtrec.experiments.datasets import load_dataset
df = load_dataset(name='movielens_1m')
# Split data set by temporal user split
from rtrec.experiments.split import temporal_user_split
train_df, test_df = temporal_user_split(df)
# Initialize SLIM model with custom options
from rtrec.recommender import Recommender
from rtrec.models import SLIM
model = SLIM(min_value=0, max_value=15, decay_in_days=180, nn_feature_selection=50)
recommender = Recommender(model)
# Bulk fit
recommender.bulk_fit(train_df)
# Partial fit
from rtrec.experiments.split import temporal_split
test_df1, test_df2 = temporal_split(test_df, test_frac=0.5)
recommender.fit(test_df1, update_interaction=True, parallel=True)
# Evaluation
metrics = recommender.evaluate(test_df2, recommend_size=10, filter_interacted=True)
print(metrics)
# User to Item Recommendation
recommended = recommender.recommend(user=10, top_k=10, filter_interacted=True)
assert len(recommended) == 10
# Item to Item recommendation
similar_items = recommender.similar_items(query_items=[3,10], top_k=5)
assert len(similar_items) == 2
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
rtrec-0.1.9.tar.gz
(67.6 kB
view details)
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
rtrec-0.1.9-py3-none-any.whl
(57.5 kB
view details)
File details
Details for the file rtrec-0.1.9.tar.gz.
File metadata
- Download URL: rtrec-0.1.9.tar.gz
- Upload date:
- Size: 67.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.6.17
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
600f5750382f51f1b02f797e8bd3e00a2eb484a3d6b4fad23caeedd0b9e17692
|
|
| MD5 |
9bf69a63544ea48ea69648ae2f1eaa32
|
|
| BLAKE2b-256 |
3e3803a7917ce092c7d57e2d6f4f685eca79a537b341eccc22400f54fcc74d80
|
File details
Details for the file rtrec-0.1.9-py3-none-any.whl.
File metadata
- Download URL: rtrec-0.1.9-py3-none-any.whl
- Upload date:
- Size: 57.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.6.17
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2922f8765bb82b945dedcd887e1c8655c31653a46aa67b74bfbc6bed7024798e
|
|
| MD5 |
23458c279232d8fdee4928328e06a4de
|
|
| BLAKE2b-256 |
fd496e0adeaf43243b44c3ac95269444ba1ca71a317beca3c29509b56748083a
|