Awesome
recmetrics
A python library of evalulation metrics and diagnostic tools for recommender systems.
**This library is actively maintained. My goal is to continue to develop this as the main source of recommender metrics in python. Please submit issues, bug reports, feature requests or contribute directly through a pull request. If I do not respond you can ping me directly at longoclaire@gmail.com **
Description | Command |
---|---|
Installation | pip install recmetrics |
Notebook Demo | make run_demo |
Test | make test |
Full documentation coming soon.... In the interim, the python notebook in this repo, example.ipynb
, contains examples of these plots and metrics in action using the MovieLens 20M Dataset. You can also view my Medium Article.
<i>This library is an open source project. The goal is to create a go-to source for metrics related to recommender systems. I have begun by adding metrics and plots I found useful during my career as a Data Scientist at a retail company, and encourage the community to contribute. If you would like to see a new metric in this package, or find a bug, or have suggestions for improvement, please contribute! </i>
<p align="center"> <img src="https://media.giphy.com/media/YAnpMSHcurJVS/giphy.gif" width=200> </p>Long Tail Plot
recmetrics.long_tail_plot()
The Long Tail plot is used to explore popularity patterns in user-item interaction data. Typically, a small number of items will make up most of the volume of interactions and this is referred to as the "head". The "long tail" typically consists of most products, but make up a small percent of interaction volume.
<p align="center"> <img src="images/long_tail_plot.png" alt="Long Tail Plot" width=600> </p>The items in the "long tail" usually do not have enough interactions to accurately be recommended using user-based recommender systems like collaborative filtering due to inherent popularity bias in these models and data sparsity. Many recommender systems require a certain level of sparsity to train. A good recommender must balance sparsity requirements with popularity bias.
Mar@K and Map@K
recmetrics.mark()
recmetrics.mark_plot()
recmetrics.mapk_plot()
Mean Average Recall at K (Mar@k) measures the recall at the kth recommendations. Mar@k considers the order of recommendations, and penalizes correct recommendations based on the order of the recommendations. Map@k and Mar@k are ideal for evaluating an ordered list of recommendations. .
<p align="center"> <img src="images/mark_plot.png" alt="Mar@k" width=600> </p>Map@k and Mar@k metrics suffer from popularity bias. If a model works well on popular items, the majority of recommendations will be correct, and Mar@k and Map@k can appear to be high while the model may not be making useful or personalized recommendations.
Coverage
recmetrics.prediction_coverage()
recmetrics.catalog_coverage()
recmetrics.coverage_plot()
Coverage is the percent of items that the recommender is able to recommend. It is depicted by this formula.
<p align="center"> <img src="images/coverage_equation.gif" alt="Coverage Equation" width=200> </p>Where 'I' is the number of unique items the model recommends in the test data, and 'N' is the total number of unique items in the training data. The catalog coverage is the rate of distinct items recommended over a period of time to the user. For this purpose the catalog coverage function take also as parameter 'k' the number of observed recommendation lists. In essence, both of metrics quantify the proportion of items that the system is able to work with.
<p align="center"> <img src="images/coverage_plot.png" alt="Coverage Plot" width=400> </p>Novelty
recmetrics.novelty()
Novelty measures the capacity of a recommender system to propose novel and unexpected items which a user is unlikely to know about already. It uses the self-information of the recommended item and it calculates the mean self-information per top-N recommended list and averages them over all users.
<p align="center"> <img src="images/novelty.gif" alt="Coverage Equation" width=200> </p>Where the absolute U is the number of users, count(i) is the number of users consumed the specific item and N is the length of recommended list.
Personalization
recmetrics.personalization()
Personalization is the dissimilarity between user's lists of recommendations. A high score indicates user's recommendations are different). A low personalization score indicates user's recommendations are very similar.
For example, if two users have recommendations lists [A,B,C,D] and [A,B,C,Y], the personalization can be calculated as:
<p align="center"> <img src="images/personalization_code.png" alt="Coverage Plot" width=400> </p>Intra-list Similarity
recmetrics.intra_list_similarity()
Intra-list similarity uses a feature matrix to calculate the cosine similarity between the items in a list of recommendations. The feature matrix is indexed by the item id and includes one-hot-encoded features. If a recommender system is recommending lists of very similar items, the intra-list similarity will be high.
<p align="center"> <img src="images/ils_matrix.png" alt="Coverage Plot" width=400> </p> <p align="center"> <img src="images/ils_code.png" alt="Coverage Plot" width=400> </p>MSE and RMSE
recmetrics.mse()
recmetrics.rmse()
Mean Squared Error (MSE) and Root Mean Squared Error (RMSE) are used to evaluate the accuracy of predicted values that such as ratings compared to the true value, y. These can also be used to evalaute the reconstruction of a ratings matrix.
<p align="center"> <img src="images/mse.gif" alt="MSE Equation" width=200> </p> <p align="center"> <img src="images/rmse.gif" alt="RMSE Equation" width=200> </p>Predicted Class Probability Distribution Plots
recmetrics.class_separation_plot()
This is a plot of the distribution of the predicted class probabilities from a classification model. The plot is typically used to visualize how well a model is able to distinguish between two classes, and can assist a Data Scientist in picking the optimal decision threshold to classify observations to class 1 (0.5 is usually the default threshold for this method). The color of the distribution plots represent true class 0 and 1, and everything to the right of the decision threshold is classified as class 0.
<p align="center"> <img src="images/class_probs.png" alt="binary class probs" width=400> </p>This plot can also be used to visualize the recommendation scores in two ways.
In this example, and item is considered class 1 if it is rated more than 3 stars, and class 0 if it is not. This example shows the performance of a model that recommends an item when the predicted 5-star rating is greater than 3 (plotted as a vertical decision threshold line). This plot shows that the recommender model will perform better if items with a predicted rating of 3.5 stars or greater is recommended.
<p align="center"> <img src="images/rec_scores.png" alt="ratings scores" width=500> </p>The raw predicted 5 star rating for all recommended movies could be visualized with this plot to see the optimal predicted rating score to threshold into a prediction of that movie. This plot also visualizes how well the model is able to distinguish between each rating value.
<p align="center"> <img src="images/ratings_distribution.png" alt="ratings distributions" width=500> </p>ROC and AUC
recmetrics.roc_plot()
The Receiver Operating Characteristic (ROC) plot is used to visualize the trade-off between true positives and false positives for binary classification. The Area Under the Curve (AUC) is sometimes used as an evaluation metrics.
<p align="center"> <img src="images/ROC.png" alt="ROC" width=600> </p>Recommender Precision and Recall
recmetrics.recommender_precision()
recmetrics.recommender_recall()
Recommender precision and recall uses all recommended items over all users to calculate traditional precision and recall. A recommended item that was actually interacted with in the test data is considered an accurate prediction, and a recommended item that is not interacted with, or received a poor interaction value, can be considered an inaccurate recommendation. The user can assign these values based on their judgment.
Precision and Recall Curve
recmetrics.precision_recall_plot()
The Precision and Recall plot is used to visualize the trade-off between precision and recall for one class in a classification.
<p align="center"> <img src="images/PrecisionRecallCurve.png" alt="PandRcurve" width=400> </p>Confusion Matrix
recmetrics.make_confusion_matrix()
Traditional confusion matrix used to evaluate false positive and false negative trade-offs.
<p align="center"> <img src="images/confusion_matrix.png" alt="PandRcurve" width=400> </p>