With the rise of personalized music streaming services, there is a growing need for systems that can recommend music based on usersβ emotional states. Realizing this need, Moodify is being developed by Son Nguyen in 2024 to provide personalized music recommendations based on usersβ detected emotions.
The Moodify project is an integrated emotion-based music recommendation system that combines frontend, backend, AI/ML models, and data analytics to provide personalized music recommendations based on user emotions. The application analyzes text, speech, or facial expressions and suggests music that aligns with the detected emotions.
Supporting both desktop and mobile platforms, Moodify offers a seamless user experience with real-time emotion detection and music recommendations. The project leverages React for the frontend, Django for the backend, and three advanced, self-trained AI/ML models for emotion detection. Data analytics scripts are used to visualize emotion trends and model performance.
Moodify provides personalized music recommendations based on usersβ emotional states detected through text, speech, and facial expressions. It interacts with a Django-based backend, AI/ML models for emotion detection, and utilizes data analytics for visual insights into emotion trends and model performance.
The project has a comprehensive file structure combining frontend, backend, AI/ML models, and data analytics components:
Moodify/
βββ frontend/ # React frontend for the web application
β βββ public/
β β βββ index.html # Main HTML file
β β βββ manifest.json # Web app manifest
β β βββ favicon.ico # Favicon for the app
β β
β βββ src/
β β βββ components/ # Contains all React components
β β βββ pages/ # Contains main pages of the app
β β βββ styles/ # Contains global styles and themes
β β βββ App.js # Main App component
β β βββ index.js # Entry point for React
β β βββ theme.js # Material UI theme configuration
β β
β βββ .gitignore # Git ignore file
β βββ package.json # NPM dependencies and scripts
β βββ README.md # Project documentation
β
βββ backend/ # Django backend for API services and database management
β βββ manage.py # Django's command-line utility
β βββ requirements.txt # Backend dependencies
β βββ backend/
β β βββ settings.py # Django settings for the project
β β βββ urls.py # URL declarations for the project
β β βββ users/ # User management components
β β βββ api/ # Emotion detection and recommendation APIs
β β
β βββ db.sqlite3 # SQLite database (if used)
β
βββ ai_ml/ # AI/ML models for emotion detection
β βββ data/ # Datasets for training and testing
β βββ models/ # Trained models for emotion detection
β βββ src/ # Source files for emotion detection and recommendation
β β βββ api/ # API scripts for running emotion detection services
β β βββ recommendation/ # Music recommendation logic
β β βββ data_processing/ # Data preprocessing scripts
β β
β βββ README.md # AI/ML documentation
β
βββ data_analytics/ # Data analytics scripts and visualizations
β βββ emotion_distribution.py # Script for visualizing emotion distribution
β βββ training_visualization.py # Script for visualizing training and validation metrics
β βββ predictions_analysis.py # Script for analyzing model predictions
β βββ recommendation_analysis.py # Script for visualizing music recommendations
β βββ spark-hadoop/ # Spark and Hadoop integration scripts
β βββ visualizations/ # Generated visualizations
β
βββ mobile/ # React Native mobile application
β βββ App.js # Main entry point for React Native app
β βββ index.js # App registry for React Native
β βββ package.json # NPM dependencies and scripts
β βββ babel.config.js # Babel configuration for React Native
β βββ
β βββ components/ # React Native components
β β βββ Footer.js # Footer component
β β βββ Navbar.js # Header component
β β βββ Auth/ # Authentication components (e.g., Login, Register)
β β βββ Profile/ # Profile-related components
β β
β βββ pages/ # Main pages of the app
β β βββ HomePage.js # Home page component
β β βββ ProfilePage.js # Profile page component
β β βββ ResultsPage.js # Results page component
β β βββ NotFoundPage.js # 404 page component
β β
β βββ assets/ # Images, fonts, and other assets
β βββ styles/ # Styling files (similar to CSS for web)
β βββ .gitignore # Git ignore file
β βββ package.json # Dependencies and scripts
β βββ README.md # Mobile app documentation
β
βββ images/ # Images used in the README documentation
βββ README.md # Comprehensive README file for the entire project
venv
)Start with setting up and training the AI/ML models, as they will be required for the backend to function properly.
git clone https://github.com/hoangsonww/Moodify-Emotion-Music-App.git
cd Moodify-Emotion-Music-App/ai_ml
python -m venv venv
source venv/bin/activate # For macOS/Linux
.\venv\Scripts\activate # For Windows
pip install -r requirements.txt
src/config.py
file:
src/config.py
file and update the configurations as needed, especially your Spotify API keys and configure ALL the paths.src/models
directory and update the paths to the datasets and output paths as needed.python src/models/train_text_emotion.py
Repeat similar commands for other models as needed (e.g., facial and speech emotion models).
Ensure all trained models are placed in the models
directory, and that you have trained all necessary models before moving to the next step!
src/models/test_emotion_models.py
script to test the trained models.Once the AI/ML models are ready, proceed with setting up the backend.
cd ../backend
python -m venv venv
source venv/bin/activate # For macOS/Linux
.\venv\Scripts\activate # For Windows
pip install -r requirements.txt
Configure your secrets and environment:
.env
file in the backend
directory..env
file:
SECRET_KEY=your_secret_key
DEBUG=True
ALLOWED_HOSTS=<your_hosts>
MONGODB_URI=<your_mongodb_uri>
backend/settings.py
and add SECRET_KEY
& set DEBUG
to True
.python manage.py migrate
python manage.py runserver
The backend server will be running at http://127.0.0.1:8000/
.
Finally, set up the frontend to interact with the backend.
cd ../frontend
npm install
npm start
The frontend will start at http://localhost:3000
.
Note: If you encounter any problems or need my .env
file, feel free to contact me.
HTTP Method | Endpoint | Description |
---|---|---|
POST |
/users/register/ |
Register a new user |
POST |
/users/login/ |
Login a user and obtain a JWT token |
GET |
/users/user/profile/ |
Retrieve the authenticated userβs profile |
PUT |
/users/user/profile/update/ |
Update the authenticated userβs profile |
DELETE |
/users/user/profile/delete/ |
Delete the authenticated userβs profile |
POST |
/users/recommendations/ |
Save recommendations for a user |
GET |
/users/recommendations/<str:username>/ |
Retrieve recommendations for a user by username |
DELETE |
/users/recommendations/<str:username>/<str:recommendation_id>/ |
Delete a specific recommendation for a user |
DELETE |
/users/recommendations/<str:username>/ |
Delete all recommendations for a user |
POST |
/users/mood_history/<str:user_id>/ |
Add a mood to the userβs mood history |
GET |
/users/mood_history/<str:user_id>/ |
Retrieve mood history for a user |
DELETE |
/users/mood_history/<str:user_id>/ |
Delete a specific mood from the userβs history |
POST |
/users/listening_history/<str:user_id>/ |
Add a track to the userβs listening history |
GET |
/users/listening_history/<str:user_id>/ |
Retrieve listening history for a user |
DELETE |
/users/listening_history/<str:user_id>/ |
Delete a specific track from the userβs history |
POST |
/users/user_recommendations/<str:user_id>/ |
Save a userβs recommendations |
GET |
/users/user_recommendations/<str:user_id>/ |
Retrieve a userβs recommendations |
DELETE |
/users/user_recommendations/<str:user_id>/ |
Delete all recommendations for a user |
HTTP Method | Endpoint | Description |
---|---|---|
POST |
/api/text_emotion/ |
Analyze text for emotional content |
POST |
/api/speech_emotion/ |
Analyze speech for emotional content |
POST |
/api/facial_emotion/ |
Analyze facial expressions for emotions |
POST |
/api/music_recommendation/ |
Get music recommendations based on emotion |
HTTP Method | Endpoint | Description |
---|---|---|
GET |
/admin/ |
Access the Django Admin interface |
python manage.py createsuperuser
Access the admin panel at http://127.0.0.1:8000/admin/
Our backend APIs are all well-documented using Swagger UI and Redoc. You can access the API documentation at the following endpoints:
http://127.0.0.1:8000/swagger
.http://127.0.0.1:8000/redoc
.If you have set up the backend correctly, you should see the following API documentation:
Swagger UI:
Redoc:
The AI/ML models are built using PyTorch, TensorFlow, Keras, and HuggingFace Transformers. These models are trained on various datasets to detect emotions from text, speech, and facial expressions.
The emotion detection models are used to analyze user inputs and provide real-time music recommendations based on the detected emotions. The models are trained on various datasets to capture the nuances of human emotions and provide accurate predictions.
The models are integrated into the backend API services to provide real-time emotion detection and music recommendations for users.
Note: The models must be trained first before using them in the backend services. Ensure that the models are trained and placed in the models
directory before running the backend server. Refer to the (Getting Started)[#getting-started] section for more details.
Examples of training the text emotion model.
There is also a mobile version of the Moodify app built using React Native and Expo. You can find the mobile app in the mobile
directory.
cd ../mobile
yarn install
yarn start
If successful, you should see the following home screen:
Feel free to explore the mobile app and test its functionalities!
The data_analytics
folder provides data analysis and visualization scripts to gain insights into the emotion detection modelβs performance.
python data_analytics/main.py
View generated visualizations in the visualizations
folder.
Emotion Distribution Visualization
Training Loss Curve Visualization
The project can be containerized using Docker for easy deployment and scaling. You can create Docker images for the frontend, backend, and AI/ML models.
docker compose up --build
docker images
If you encounter any errors, try to rebuild your image without using the cache since Dockerβs cache may cause issues.
docker-compose build --no-cache
Contributions are welcome! Feel free to fork the repository and submit a pull request.
Note that this project is still under active development, and any contributions are appreciated.
If you have any suggestions, feature requests, or bug reports, feel free to open an issue here.
Happy Coding and Analyzing! πΆ
Created with β€οΈ by Son Nguyen in 2024.