Welcome to MARS, the Movie Automated Recommender System, your personalized, AI-powered movie recommendation engine. Imagine having the ability to type in a single movie title, genre, or keyword, and MARS will scan the universe of films, offering you the best recommendations based on their synopses!
Whether you're hunting for the perfect sci-fi thriller or looking for an underrated gem, MARS has you covered. In this readme, we'll take you through the journey of how this simple yet powerful app works, broken down step-by-step to give you an in-depth understanding.
- The Story Behind MARS
- Tech Stack
- How it Works
- Running the Application
- Contributing
- Future Enhancements
Imagine you're sitting on your couch, flipping through Netflix, and you just can't decide what to watch. You've seen all the classics, you’re tired of the trending films, and you're craving something different. That's where MARS comes to the rescue!
Instead of endlessly scrolling through platforms, MARS harnesses the power of Google’s advanced AI and suggests movies based on synopsis similarity, using deep learning to find you the perfect movie match. Think of it as a personal movie critic who never runs out of recommendations!
MARS is built with a few essential tools that allow it to work its magic:
- Streamlit - For the clean and responsive web interface.
- Langchain - To create seamless workflows between the input and AI models.
- Google Generative AI - To generate movie recommendations based on movie titles, genres, or keywords.
- Dotenv - To securely manage API keys for the model configuration.
Let’s break down how MARS works behind the scenes.
Before MARS can start making any recommendations, the environment must be set up to handle API calls to Google’s AI services. This is done using dotenv
, which loads environment variables securely.
import os
from dotenv import load_dotenv
load_dotenv() # Activate the local environment
With this, we load the necessary API key for the Google Generative AI model:
genai.configure(api_key=os.getenv('GOOGLE-API-KEY'))
To make the user experience easy and fun, MARS uses Streamlit to provide a clean, user-friendly interface. Users can enter a movie title, genre, or keyword of their choice.
st.title("MARS (Automated Movie Recommender System) ✅")
movie_input = st.text_input('Enter the Movie title, genre or keyword 🎞️')
The input from the user is captured and used to generate tailored movie recommendations based on the similarity of film synopses.
At the core of MARS is Langchain, which helps structure our input and output into a flow that interacts with Google’s powerful Generative AI model. The prompt that drives the recommendations is wrapped in a PromptTemplate
, designed to use the user’s input dynamically.
demo_template = '''Based on {movie_input}, give me the best 5 movie recommendations by their similarity of the synopsis of the film'''
template = PromptTemplate(input_variables=[movie_input], template=demo_template)
We then initialize Google’s ChatGoogleGenerativeAI model:
llm = ChatGoogleGenerativeAI(model='gemini-pro', api_key=os.getenv('GOOGLE-API-KEY'))
Once the user enters their movie-related query, MARS runs the model and returns five movie recommendations based on the input.
llm_chain = LLMChain(prompt=template, llm=llm)
recommendations = llm.predict(text=prompt)
st.write(f'Recommendations for you:\n {recommendations}')
- Python 3.7+
- A valid Google API key (configured in your
.env
file)
- Clone the repository:
git clone https://github.com/your-repo/MARS.git
- Navigate into the project folder:
cd MARS
- Install the required dependencies:
pip install -r requirements.txt
- Run the application:
streamlit run app.py
Now, open the URL generated by Streamlit in your browser and start getting movie recommendations!
Want to make MARS even better? We welcome contributions! Feel free to submit pull requests, suggest features, or report bugs.
To contribute:
- Fork the repository.
- Create a new branch (
git checkout -b feature/new-feature
). - Commit your changes (
git commit -m 'Add new feature'
). - Push to the branch (
git push origin feature/new-feature
). - Open a Pull Request.
While MARS is already a cool tool for movie recommendations, there's always room for growth! Here are a few ideas for future development:
- Add more filters: Incorporate filters based on user preferences like runtime, language, etc.
- User ratings: Allow users to rate the recommendations and improve results.
- TV shows: Expand beyond movies to include TV show recommendations.
And that’s a wrap! 🎬 With MARS, movie discovery becomes easier, faster, and more enjoyable. Happy watching!