Skip to content

Latest commit

 

History

History
32 lines (25 loc) · 2.26 KB

File metadata and controls

32 lines (25 loc) · 2.26 KB

Collaborative Filtering Recommender Systems

Implementations of matrix factorization and restricted Boltzmann machine based algorithms for collaborative filtering in Python using Numpy, Scipy.

The basics

Matrix factorization models minimize regularized sum of squared errors (equivalent to maximizing log posterior of parameters assuming normal distributions), where rating is predicted as biases plus interaction between user and item passed to an activation function. Interaction is modelled as inner product of learned user and item latent feature vectors.

Weighted model uses weights on latent factors, model idea is described in https://arxiv.org/pdf/1710.00482.pdf.

Friends model uses user's friends network to improve predictions, each user has an additional learned latent feature vector representing his average impact on friends. The idea of implicit feedback, which was used to model friendships is explained in previous article (SVD++).

Restricted Boltzmann machine (RBM) model maximizes log posterior probability of the parameters given the data. The likelihood is approximated with contrastive divergence function (G. Hinton) and its gradient is approximated from collected statistics from Gibbs steps (positive and negative phase) and then used for learning. We try to reconstruct non-missing ratings (not generate new examples of user profiles from the data distribution) thus no sampling is used in training or prediction. The gist of using RBMs in collaborative filtering is explained in https://www.cs.toronto.edu/~rsalakhu/papers/rbmcf.pdf, but we model ratings as real values between 0 and 1.

Using models

Before constructing ratings matrix R, user and item indices are mapped to [0, ..., n_users-1] and [0, ..., n_items-1] respectively. Using matrix factorization models: (example in example_matrix.py)

mm = MatrixModel(*args)
mm = mm.fit(R_train, R_val)
rui_hat = mm.predict(u_new, i_new)

Using RBM model: (example coming soon)

rbm = AERBMModel(*args)
rbm = rbm.fit(R_train, R_val)
R_hat = rbm.predict(R_new)

Example data

Number of times a user plays an artist's song on Last.fm. The data is clipped if it passes a certan threshold and then rescaled to [0,1]. Histogram with 20 bins of preprocessed data: