Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/benfred/implicit
Fast Python Collaborative Filtering for Implicit Feedback Datasets
https://github.com/benfred/implicit
collaborative-filtering machine-learning matrix-factorization recommendation recommendation-system recommender-system
Last synced: about 4 hours ago
JSON representation
Fast Python Collaborative Filtering for Implicit Feedback Datasets
- Host: GitHub
- URL: https://github.com/benfred/implicit
- Owner: benfred
- License: mit
- Created: 2016-04-17T03:45:23.000Z (almost 9 years ago)
- Default Branch: main
- Last Pushed: 2024-07-11T17:58:17.000Z (6 months ago)
- Last Synced: 2025-01-20T03:35:56.061Z (1 day ago)
- Topics: collaborative-filtering, machine-learning, matrix-factorization, recommendation, recommendation-system, recommender-system
- Language: Python
- Homepage: https://benfred.github.io/implicit/
- Size: 7.51 MB
- Stars: 3,608
- Watchers: 77
- Forks: 612
- Open Issues: 99
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome-list - Implicit - Fast Python Collaborative Filtering for Implicit Feedback Datasets. (Recommendation, Advertisement & Ranking / Others)
- awesome-python-machine-learning-resources - GitHub - 16% open · ⏱️ 21.08.2022): (推荐系统)
- awesome-production-machine-learning - Implicit - Implicit provides fast Python implementations of several different popular recommendation algorithms for implicit feedback datasets (Industry Strength RecSys)
README
Implicit
=======[![Build
Status](https://github.com/benfred/implicit/workflows/Build/badge.svg)](https://github.com/benfred/implicit/actions?query=workflow%3ABuild+branch%3Amain)
[![Documentation](https://img.shields.io/badge/documentation-blue.svg)](https://benfred.github.io/implicit/)Fast Python Collaborative Filtering for Implicit Datasets.
This project provides fast Python implementations of several different popular recommendation algorithms for
implicit feedback datasets:* Alternating Least Squares as described in the papers [Collaborative Filtering for Implicit Feedback Datasets](http://yifanhu.net/PUB/cf.pdf) and [Applications of the Conjugate Gradient Method for Implicit
Feedback Collaborative Filtering](https://pdfs.semanticscholar.org/bfdf/7af6cf7fd7bb5e6b6db5bbd91be11597eaf0.pdf).* [Bayesian Personalized Ranking](https://arxiv.org/pdf/1205.2618.pdf).
* [Logistic Matrix Factorization](https://web.stanford.edu/~rezab/nips2014workshop/submits/logmat.pdf)
* Item-Item Nearest Neighbour models using Cosine, TFIDF or BM25 as a distance metric.
All models have multi-threaded training routines, using Cython and OpenMP to fit the models in
parallel among all available CPU cores. In addition, the ALS and BPR models both have custom CUDA
kernels - enabling fitting on compatible GPU's. Approximate nearest neighbours libraries such as [Annoy](https://github.com/spotify/annoy), [NMSLIB](https://github.com/searchivarius/nmslib)
and [Faiss](https://github.com/facebookresearch/faiss) can also be used by Implicit to [speed up
making recommendations](https://www.benfrederickson.com/approximate-nearest-neighbours-for-recommender-systems/).#### Installation
Implicit can be installed from pypi with:
```
pip install implicit
```Installing with pip will use prebuilt binary wheels on x86_64 Linux, Windows
and OSX. These wheels include GPU support on Linux.Implicit can also be installed with conda:
```
# CPU only package
conda install -c conda-forge implicit# CPU+GPU package
conda install -c conda-forge implicit implicit-proc=*=gpu
```#### Basic Usage
```python
import implicit# initialize a model
model = implicit.als.AlternatingLeastSquares(factors=50)# train the model on a sparse matrix of user/item/confidence weights
model.fit(user_item_data)# recommend items for a user
recommendations = model.recommend(userid, user_item_data[userid])# find related items
related = model.similar_items(itemid)
```The examples folder has a program showing how to use this to [compute similar artists on the
last.fm dataset](https://github.com/benfred/implicit/blob/master/examples/lastfm.py).For more information see the [documentation](https://benfred.github.io/implicit/).
#### Articles about Implicit
These blog posts describe the algorithms that power this library:
* [Finding Similar Music with Matrix Factorization](https://www.benfrederickson.com/matrix-factorization/)
* [Faster Implicit Matrix Factorization](https://www.benfrederickson.com/fast-implicit-matrix-factorization/)
* [Implicit Matrix Factorization on the GPU](https://www.benfrederickson.com/implicit-matrix-factorization-on-the-gpu/)
* [Approximate Nearest Neighbours for Recommender Systems](https://www.benfrederickson.com/approximate-nearest-neighbours-for-recommender-systems/)
* [Distance Metrics for Fun and Profit](https://www.benfrederickson.com/distance-metrics/)There are also several other articles about using Implicit to build recommendation systems:
* [H&M Personalized Fashion Recommendations Kaggle Competition](https://www.kaggle.com/competitions/h-and-m-personalized-fashion-recommendations/discussion/324129)
* [Yandex Cup 2022: Like Prediction](https://github.com/greenwolf-nsk/yandex-cup-2022-recsys)
* [Recommending GitHub Repositories with Google BigQuery and the implicit library](https://medium.com/@jbochi/recommending-github-repositories-with-google-bigquery-and-the-implicit-library-e6cce666c77)
* [Intro to Implicit Matrix Factorization: Classic ALS with Sketchfab Models](http://blog.ethanrosenthal.com/2016/10/19/implicit-mf-part-1/)
* [A Gentle Introduction to Recommender Systems with Implicit Feedback](https://jessesw.com/Rec-System/).#### Requirements
This library requires SciPy version 0.16 or later and Python version 3.6 or later.
GPU Support requires at least version 11 of the [NVidia CUDA Toolkit](https://developer.nvidia.com/cuda-downloads).
This library is tested with Python 3.7, 3.8, 3.9, 3.10 and 3.11 on Ubuntu, OSX and Windows.
#### Benchmarks
Simple benchmarks comparing the ALS fitting time versus [Spark can be found here](https://github.com/benfred/implicit/tree/master/benchmarks).
#### Optimal Configuration
I'd recommend configuring SciPy to use Intel's MKL matrix libraries. One easy way of doing this is by installing the Anaconda Python distribution.
For systems using OpenBLAS, I highly recommend setting 'export OPENBLAS_NUM_THREADS=1'. This
disables its internal multithreading ability, which leads to substantial speedups for this
package. Likewise for Intel MKL, setting 'export MKL_NUM_THREADS=1' should also be set.Released under the MIT License