Check out the live project here!
Welcome to the Bollywood Song Recommendation System! This project uses machine learning to recommend Bollywood songs based on user-selected songs.
The Bollywood Song Recommendation System is designed to recommend Bollywood songs to users based on their selected songs. The system preprocesses the song data, trains a model, and provides a web interface for users to get song recommendations.
- Data Preprocessing: Clean and preprocess raw song data.
- Model Training: Train a recommendation model using machine learning techniques.
- Web Interface: A Flask-based web interface for users to select a song and get recommendations for 10 similar songs.
- Dockerized: The project is containerized using Docker for easy deployment.
- AWS Deployment: Deployed on AWS Lambda and API Gateway for scalable and serverless architecture.
├── LICENSE
├── README.md <- The top-level README for developers using this project.
├── data
│ ├── processed <- The final, canonical data sets for modeling.
│ └── raw <- The original, immutable data dump.
├── preprocessor <- The preprocessor model.
├── models <- Trained and serialized models, model predictions, or model summaries.
├── notebooks <- Jupyter notebooks.
├── requirements.txt <- The requirements file for reproducing the analysis environment.
├── src <- Source code for use in this project.
│ ├── __init__.py <- Makes src a Python module.
│ ├── base.py <- Scripts that contain most utility functions.
│ ├── logger.py <- Scripts to log the steps.
│ ├── data_preprocessing.py <- Scripts for data preprocessing.
│ └── model_training.py <- Scripts to train models.
├── static
│ ├── css <- The folder containing CSS files.
│ │ └── style.css <- The file containing CSS classes.
│ ├── favicon.ico <- Favicon for the web app.
│ └── images <- The folder containing images required for the app.
├── templates
│ └── index.html <- The file containing app HTML design.
├── .gitignore <- Gitignore file.
├── .dvc <- DVC configuration file.
├── .dockerignore <- Docker ignore file.
├── app.py <- Flask app.
├── dvc.lock <- DVC lock file.
├── Dockerfile <- Dockerfile for containerizing the app.
├── dvc.yaml <- DVC pipeline configuration.
├── params.yaml <- Parameters file.
├── README.Docker.md <- README for Docker setup.
├── template.yaml <- AWS Lambda and API Gateway template.yaml.
To get a copy of the project up and running on your local machine, follow these steps:
-
Clone the repository:
git clone https://github.com/yourusername/bollywood-song-recommendation-system.git cd bollywood-song-recommendation-system
-
Set up a virtual environment:
conda create --name song-recommendation-system python=3.9 conda activate song-recommendation-system
-
Install the required dependencies:
pip install -r requirements.txt
-
Build and run the Docker container:
docker build -t song-recommendation-system . docker run -p 5000:5000 song-recommendation-system
-
Run the Flask application:
python app.py
-
Open your browser and go to:
http://localhost:5000
-
Select a song from the dropdown and get recommendations for similar songs.
-
Ensure you have AWS CLI installed and configured:
aws configure
-
Build and push the Docker image to Amazon ECR:
aws ecr get-login-password --region us-east-1 | docker login --username AWS --password-stdin <your-account-id>.dkr.ecr.us-east-1.amazonaws.com docker tag song-recommendation-system:latest <your-account-id>.dkr.ecr.us-east-1.amazonaws.com/song-recommendation-system:latest docker push <your-account-id>.dkr.ecr.us-east-1.amazonaws.com/song-recommendation-system:latest
-
Deploy the application using AWS SAM:
sam build --template-file template.yaml sam deploy --guided
-
Follow the prompts to complete the deployment.
MIT License
Copyright (c) 2024 Tarun Singh
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.