
Security News
RubyGems Adds Cooldown Feature to Bundler for Newly Published Gems
RubyGems and Bundler 4.0.13 introduced an opt-in cooldown feature that delays newly published gems during dependency resolution.
lightfm-next
Advanced tools

A Python 3.12+ compatible fork of the original LightFM recommendation library.
| Build status | |
|---|---|
| Linux & macOS (3.8-3.12) |
Note: This is a community-maintained fork that provides Python 3.12+ compatibility by fixing Cython 3.0+ build issues. All credit goes to the original LightFM authors. If you're using Python < 3.12, consider using the original LightFM package.
LightFM is a Python implementation of a number of popular recommendation algorithms for both implicit and explicit feedback, including efficient implementation of BPR and WARP ranking losses. It's easy to use, fast (via multithreaded model estimation), and produces high quality results.
It also makes it possible to incorporate both item and user metadata into the traditional matrix factorization algorithms. It represents each user and item as the sum of the latent representations of their features, thus allowing recommendations to generalise to new items (via item features) and to new users (via user features).
For more details, see the Documentation.
Need help? Contact me via email, Twitter, or Gitter.
Install lightfm-next from PyPI:
pip install lightfm-next
Note: Windows support is not available yet. Use Linux or macOS.
Use the original LightFM package:
pip install lightfm
or Conda:
conda install -c conda-forge lightfm
lightfm-next is a drop-in replacement for the original LightFM. Simply replace your installation:
# Replace this
pip uninstall lightfm
pip install lightfm-next
No code changes required - all imports and APIs remain identical:
from lightfm import LightFM # Works exactly the same
Fitting an implicit feedback model on the MovieLens 100k dataset is very easy:
from lightfm import LightFM
from lightfm.datasets import fetch_movielens
from lightfm.evaluation import precision_at_k
# Load the MovieLens 100k dataset. Only five
# star ratings are treated as positive.
data = fetch_movielens(min_rating=5.0)
# Instantiate and train the model
model = LightFM(loss='warp')
model.fit(data['train'], epochs=30, num_threads=2)
# Evaluate the trained model
test_precision = precision_at_k(model, data['test'], k=5).mean()
Please cite LightFM if it helps your research. You can use the following BibTeX entry:
@inproceedings{DBLP:conf/recsys/Kula15,
author = {Maciej Kula},
editor = {Toine Bogers and
Marijn Koolen},
title = {Metadata Embeddings for User and Item Cold-start Recommendations},
booktitle = {Proceedings of the 2nd Workshop on New Trends on Content-Based Recommender
Systems co-located with 9th {ACM} Conference on Recommender Systems
(RecSys 2015), Vienna, Austria, September 16-20, 2015.},
series = {{CEUR} Workshop Proceedings},
volume = {1448},
pages = {14--21},
publisher = {CEUR-WS.org},
year = {2015},
url = {http://ceur-ws.org/Vol-1448/paper4.pdf},
}
Pull requests are welcome. To install for development:
git clone https://github.com/midodimori/lightfm-next.gitcurl -LsSf https://astral.sh/uv/install.sh | shcd lightfm-next && uv sync --extra dev --extra lintmake test-allAvailable make commands:
make install - Install dependencies and build extensionsmake lint - Run flake8 lintingmake test - Run pytestmake test-basic - Run basic functionality testmake test-all - Run complete test suite (same as CI)When making changes to .pyx extension files, run uv run python setup.py build_ext --inplace to rebuild extensions.
FAQs
LightFM recommendation model - Python 3.12+ compatible fork
We found that lightfm-next demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Security News
RubyGems and Bundler 4.0.13 introduced an opt-in cooldown feature that delays newly published gems during dependency resolution.

Security News
pnpm 11.5 now recognizes npm staged publish approvals in release metadata, preventing those releases from being mistaken for lower-trust package publishes.

Security News
Federal audit finds NIST lacked a plan to clear the NVD backlog, wasted funds on duplicate work, and delayed use of CISA data.