This repo is to help you build a powerful question answering system that can accurately answer questions by combining Langchain and large language models (LLMs) including OpenAI's GPT3 models.
The image shows the architechture of the system and you can change the code based on your needs. The main components of this code:
-
Backend: It has been written in Python using FastAPI framework and does the following:
- handles all the requests coming from client side.
- creates the data processing pipeline. It converts PDF documents to text and split them to smaller chuncks. You can use it for other document types, thanks to langchain for providng the
data loaders
. Backend also handles the embedding part. It initializes the embedding model. I have usedSentenceTransformers
to make it faster and free of cost. You can use OpenAI embeddings or other ones. I have used Qdrant cloud (free tier) to host my embeddings and textual documents for fast search and retrieval. It can be replaced by other vector-based databases such as Pinecone, Weaviate, Elasticsearch, etc., either on the cloud or mostly locally hosted, depending on the vendor.
-
Frontend: I developed it using React/Typescript.
qa_demo.mp4
If you are going to use Qdrant Cloud, then you need to sign up and get your API_KEY
and HOST_URL
. Otherwise you can run Qdrant locally. You can check out the documentation here. You also need OpenAI api key.
After getting your keys, you have to create a .env
file in backend/app
directory with the following information:
QDRANT_HOST=
QDRANT_API_KEY=
OPENAI_API_KEY=
Clone the repo:
git clone https://github.com/mallahyari/drqa.git
Running the frontend is very straightforward. You simply go to the frontend
directory and run:
npm install
npm start
For running the backend, first create a virtual environment and then from backend/app
directory run:
pip install -r requirements.txt
python main.py
This repo can be used as a general guide line for how to combine your own data with LLMs with other frameworks like Langchain, LlamaIndex. Also, since it only uses OpenAI for final response generation, it reduces the API call cost significantly.
- Streaming feature: The client will get the stream of response as soon as it becomes available.
- Cache: Adding cache could make the system much more efficient. For similar or repeatitive questions, you don't need to generate response/call API as they are stored in the cache
- UI: Rewriting the UI for better user experience
- Adding different types of documents for question-answering. Currently, you can only use it for PDF files.
- Adding memory for long conversations and summarization
- and many more!
If you have any comment or feedback, please don't hesitate to use the Discussions
section and open a new topic. You can also reach out directly via Linkedin or Twitter