This repository contains the implementation of the C2P recommendation system, which aims to provide personalized movie recommendations by combining community ratings with individual user preferences. The C2P architecture addresses the challenge of making accurate recommendations for users who have rated too few items or are new to the system.
With the continuous development in the field of recommendation systems, providing personalized product recommendations tailored to individual users’ preferences has become increasingly accurate. However, limitations arise when users rate too few items or are new users. To overcome this issue, we propose the C2P (From Community to Personality Recommendation System) architecture.
C2P comprises two main stages:
- Community Model: Aggregating the average ratings of all users to create a Community Model through fine-tuning.
- Personality Model: Parallel fine-tuning for each user using their labeled ratings from previously rated items to uncover their unique personality traits.
The architecture of the proposed recommendation system involves utilizing Hugging Face’s models for a regression task trained on the Community dataset to establish the Community model. Then, this model is fine-tuned to create the Personality model. Predicted ratings are generated by passing combined features of the movie to the user’s personality model.
Features representing a movie are created by combining multiple factors such as budget, genres, production company, production country, runtime, casts, and movie overview.
The datasets used in this study are:
- Community Dataset: Used to pre-train the Community model.
- Personality Dataset: Used for fine-tuning the Personality model for each user.
You can reproduce this code by only change num_cluster in config, if num_cluster = num_users, that mean this architecture are more personality.
Our architecture surpasses several existing models, achieving the best results with:
- MSE = 0.897
- RMSE = 0.947
The detailed results and comparisons are provided in the paper.
We welcome contributions from the community. Please follow these steps to contribute:
- Fork the repository.
- Create a new branch (
git checkout -b feature-branch
). - Commit your changes (
git commit -am 'Add new feature'
). - Push to the branch (
git push origin feature-branch
). - Create a new Pull Request.
This project is licensed under the MIT License - see the LICENSE file for details.
For more details, please refer to the paper or contact the authors at [email protected]