Skip to content

Latest commit

 

History

History
184 lines (143 loc) · 7.08 KB

README.md

File metadata and controls

184 lines (143 loc) · 7.08 KB

🎁 Gift Generative Recommendation System


banner.jpg


Table of Contents


Technologies Used

Python Streamlit LangChain HuggingFace OpenAI Chroma Pandas NumPy


Description

This project aims to provide gift recommendations using a chatbot interface. The system leverages embeddings and vector stores along with LLMs to process and recommend products from store's catalogue based on user queries.

Objectives

The main goal is to develop a Proof Of Concept that is could be used by a customer.

  1. Load and embed product data from CSV files.
  2. Utilize a pretrained language model (LLM) with Retrieval-Augmented Generation (RAG) for recommendations.
  3. Implement conversation and chat history with the retrieval & answer chain
  4. Create a Streamlit front end for the app.

Dataset

The dataset used, compiled by McAuley Lab in 2023, encompasses a comprehensive collection of Amazon Reviews. It features:

  • User Reviews (ratings, text, helpfulness votes, etc.)
  • Item Metadata (descriptions, price, raw image, etc.)

Important

Disclaimer: The source code as well as the demo currently use free embedidng and llm models provided by TogetherAI. Those models are thus not performant and generally do not offer great recommendations. It is recommended to switch to higher performance models like those from OpenAI, Anthropic... or capable Local models to get better results. An up to date more refined product database would also contribute to getting better results as the database contains rather "random" results

Demo

The app demo is hosted & available on the following link: Demo Link

Streamlit App

  • App Screenshot: image

Notebooks Overview

  1. create_llm_ready_csv.ipynb:
    • Used to preprocess the Amazon Dataset and extract products with rich text features for the demo.

Using Docker

1. Pulling the Docker Image

You can pull the docker image from Docker Hub or Github Packages To pull the Docker image from Docker Hub, run the following command:

# Pull the docker image
$ docker pull medkallel/gift-recommendation-chatbot:latest

2. Building the Docker Image

If you prefer to build the Docker image locally, navigate to the project directory and run:

# Build the docker image
$ docker build -t gift-recommendation-chatbot .

3. Running the Docker Container

To run the Docker container, use the following command:

# Run the docker container
$ docker run -p 8501:8501 -e TOGETHER_API_KEY=<your_api_key_here> gift-recommendation-chatbot

Tip

Do not forget to add your TogetherAI api key You can access the app on another device by following the link: http://<server-ip>:8501



Installation

Important

The project was developed and tested on Python 3.11.6

To run this project locally, follow these steps:

  1. Clone the repository:
$ git clone https://github.com/yourusername/Gift-Recommendation-ChatBot
$ cd Gift-Recommendation-ChatBot
  1. Install requirements:
$ pip install -r requirements.txt
  1. Download the Chroma VecStore & upload it to your Dropbox App: Chroma Store Download Link

Important

Ensure you have the necessary API keys for TogetherAI and Dropbox set up in the secrets.toml file.


Usage

  1. Run the app using:
$ streamlit run src/Gift_Recommendation_Bot.py 
  1. Use the Products Catalogue ⚙️ script to upload and embed product data.
  2. Use the Gift Recommendation Bot script to start the chatbot interface and get gift recommendations.

TIP: The embedding process may take a while depending on the size of the CSV file. Please be patient.


Project structure

📦 Gift-Recommendation-ChatBot/
├── 📁.github/workflows
│   └── 🤖github-docker-cicd.yaml # Used for CI/CD workflows
├── 📁chroma_vectorstore/ # Contains the vector store
├── 📁Data/ # Contains the dataset
├── └── 📓create_llm_ready_csv.ipynb
├── 📁src/
│   ├── 🐍Gift_Recommendation_Bot.py 
│   ├── 📁pages/
│   │   └── 🐍Products Catalogue ⚙️.py
├── 📁tmp/ # Used to store temporary csv file for data embedding
├── 📁.streamlit/
│   └── 🔑secrets.toml # Used to store api Keys for running locally
├── 📄.gitignore
├── 🐋.dockerignore
├── 🐋.Dockerfile
├── 📄README.md
├── 📄LICENCE.md
├── 📄requirements.txt
└── 🖼️banner.png

Collaborators

This project was developed by a collaborative team. Each member played a crucial role in the research, development, and analysis:

  • Mohamed Kallel
  • Jean Christophe Rigoni
  • Simon Pierre Rodner

📫 Contact me

LinkedIn


License

This project is under the CC BY-NC 4.0 License. For more information, refer to the license file.
License: CC BY-NC 4.0