Skip to content

pong1013/ArticleMind-Chat-LangChain

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

16 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

ArticleMind ChatBot

Introduction:

In this project, we utilize the API provided by LangChain to leverage large language models offered by companies like OpenAI and Google. With this setup, our chatbot can read documents provided by the user and answer professional questions from within them. One noteworthy aspect is that our bot can retain memory of previous questions, allowing users to seek answers more conveniently.

plot

The chatbot is presented as a web application, consisting of a frontend directory and a backend program directory.

plot

Step 1: OpenAI ChatGPT Configuration:

In chatbot-server/ directory, create docs folder and .env file:

  • docs
    cd chatbot-server
    mkdir docs
    
    Move the documentation that you want the chatbot to learn into the docs folder.
  • .env
    OPENAI_API_KEY = '<YOUR_KEY>'
    OPENAI_MODEL=gpt-4
    EMBEDDING_MODEL=text-embedding-ada-002
    MONGO_URI = '<YOUR_MONGO_URI>'
    DATABASE_NAME = ChatBotDB
    

Step 2: Install python package:

First, navigate to the "chatbot-server" directory and install Python packages listed in requirements.txt. Python version 3.8 or higher is required.

pip install -r requirements.txt

Step 3: Activate Backend Server

After completing the configuration, start the backend service, including the conversation chain:

python3 main.py

Step 4: Activate Frontend GUI

Once the backend is running, enable the frontend GUI. Navigate to the "chatbot-gui" directory:

pnpm install
pnpm start

How to use the api to config chatbot

  1. Merge Docs
    curl -X POST "http://localhost:3035/documents/merge-docs"
    
    Merge all documentation in docs folder into one md file.
  2. Create Embeddings
    curl -X POST "http://localhost:3035/embedding/create-embeddings"
    
    Create embeddings to serve as the chatbot's knowledge base.

Architecture

  • Frontend
    .
    └── chatbot-gui/
        ├── public/
        │   └── ...
        └── src/
            ├── Apps/
            │   ├── App.css
            │   ├── App.js
            │   └── App.test.js
            ├── animations/
            │   └── loading.json
            ├── components/
            │   ├── AnswerSection/
            │   │   └── AnswerSection.jsx
            │   ├── FormSection/
            │   │   └── FormSection.jsx
            │   ├── TopicButtons/
            │   │   ├── TopicButtons.jsx
            │   │   └── TopicButtons.module.css
            │   └── styles/
            │       └── scrollbar.css
            ├── data/
            │   └── topics.js
            ├── index.css
            ├── index.js
            ├── reportWebVitals.js
            ├── setupTests.js
            └── .env
    
    
  • Backend
    .
    └── chatbot-server/
        ├── config/
        │   ├── mongo_db.py
        │   └── open_ai.py
        ├── controllers/
        │   ├── document_controller.py
        │   ├── embedding_controller.py
        │   └── qa_controller.py
        ├── models/
        │   └── qa_model.py
        ├── routers/
        │   └── routers.py
        ├── services/
        │   ├── qa_service.py
        │   └── vector_store_service.py
        ├── main.py
        ├── requirements.txt
        └── .env