Skip to content

Latest commit

 

History

History
91 lines (63 loc) · 2.77 KB

README.md

File metadata and controls

91 lines (63 loc) · 2.77 KB

ChatDoc+

This repository contains an app that allows users to ask questions about a provided document or engage in a question-answering chatbot conversation. The app is built with Streamlit, Llama-Index, LangChain, Llama-cpp-python, and is powered by the LLM NeuralBeagle14-7B-GGUF by Maxime Labonne.

  • No OpenAI API key required.
  • Runs locally on Macs (Tested on Apple Silicon Mac with macOS Ventura 13.5.1).
  • You can turn off your internet connection.

Requirements

  • Python3.11 or above (should work with Python3.10)
  • pip (Python’s package installer)

Installation

Follow these steps to install and set up the app:

  1. Clone the Repository and Navigate to the Directory:

    git clone https://github.com/hbacard/chatdoc-plus.git && cd chatdoc-plus
    
  2. Create a Python Virtual Environment:

    python3 -m venv .venv
    
  3. Activate the Environment:

    • On Unix-based systems:
      source .venv/bin/activate
      
  4. Install Dependencies:

    pip install -r requirements.txt
    
  • Note: On Linux there might be an error with the installation of llama-cpp-python. You can try these steps:

    • sudo apt-get install build-essential
    • pip install -r requirements.txt
  1. Download the gguf file for NeuralBeagle14-7B-GGUF:

    python3 download_model.py
    
  2. Enable GPU with llama-cpp-python:

    • On Apple Silicon (METAL):
      CMAKE_ARGS="-DLLAMA_METAL=on" FORCE_CMAKE=1 pip install --force-reinstall llama-cpp-python==0.1.83 --no-cache-dir
      
    • On Linux:
      CMAKE_ARGS="-DLLAMA_CUBLAS=on" FORCE_CMAKE=1 pip install --force-reinstall llama-cpp-python==0.1.83 --no-cache-dir
      
  3. Run the App:

    streamlit run app.py
    

Open your browser and navigate to http://localhost:8501 to interact with the app.

  • Note: If the app doesn't start you can try these steps:

    • Deactivate the virtual environment with deactivate
    • Reactivate it with source .venv/bin/activate
    • Then run streamlit run app.py

Usage

The app provides two modes of operation:

  1. Q&A Chat Bot: When no document is provided, engage in a question-answering conversation with the AI assistant.
  2. Document Query Mode: Upload a document and ask questions about its content. The AI assistant will process queries using the document as context.

Contributing

We welcome contributions to improve this app. If you have suggestions or encounter issues, please open an issue or submit a pull request on GitHub.

License

This project is licensed under the MIT License.