Skip to content

ProtoFaze/chatbot

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

98 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

💬 RAG chatbot

A simple streamlit app that does RAG

Open in Streamlit

How to run it on your own machine

  1. Setup your environment secrets, refer to .streamlit/secrets.toml.example

  2. Install the dependencies

    $ cd src
    $ pip install -r src/requirements.txt
    
  3. Run the app

    $ streamlit run src/Chat.py
    

How to setup your own remote llm endpoint with ollama and modal labs

Disclaimer: This backend server is strictly for demonstrating a proof-of-concept for running LLMs on modal labs via ollama, you are encouraged to support Modal labs via their payed services for a better experience, support, and system scalability, do check out their pricing page if interested

  1. Setup an account on modal labs
    modal labs sign-up page

  2. Pull this repo and redirect to the project directory using the terminal// command line interface

    $ git clone https://github.com/ProtoFaze/chatbot.git   
    $ cd chatbot
    
  3. Install modal lab's python library using pip.

    $ pip install modal
    
  4. Follow the instructions in your browser to authenticate your device for accessing your modal account

    $ modal setup
    
  5. Change your directory again to the backend codebase and deploy the server

    $ cd ollama_backend
    $ modal deploy ollama_backend.py
    

    Your terminal / command line interface should show a url to access the server

  6. Change the endpoint

    • In your frontend, navigate to the settings page, and fill in the previous url into the ollama endpoint field and submit,
    • or just change the environment variable or secrets that your frontend accesses for ollama endpoints.
      (uses .toml by default, feel free to refactor to use .env)
  7. Try running your own server in the chat page now.

Salesman Chatbot

This is a step by step development of an insurance salesman chatbot proof-of-concept,
The chatbot should be able to access the corpus of data related to a product it is advertising,
The POC is set up using open source and free tier options, no free trials from providers required.

Tech/AI stack

POLM
Python version 3.12
Ollama for edge device language model hosting
LlamaIndex for parsing and ingestion
Modal labs for provisioning computes to develop and test with ASGI web endpoints and llm inference
MongoDB Atlas for data storage
Streamlit for user interface

concepts

Retrieval Augmented Generation (RAG)
Structured LLM output
Few-shot prompting

Further Improvements

  • pdf processing workflow (via notebook)
  • structured data corpus fetch
  • structured outputs via json schema
  • basic chatlog analysis and control
  • sample questions integration via database connection
  • chatbot abuse siteblock
  • timeout message

Acknowledgement

Thanks for sharing these demos and blogs:

Using streamlit with Ollama for prototyping
demo of streamlit with ollama

Using llamaparse with Ollama
the repo
the blog article

Integrating Llamaparse vector indexes with Mongodb
How to Build a RAG System With LlamaIndex, OpenAI, and MongoDB Vector Database

Using Ollama as a freemium backend service
run ollama with modal

Setting up response streaming via fastAPI(compatible with modal labs)
FastAPI Streaming Response: Error: Did not receive done or success response in stream

Using structured outputs on Ollama
Structured outputs

Controling page visibility on Streamlit
Hide/show pages in multipage app based on conditions