- AI Custom Chatbot Quickstart · Data Pipeline
- Goals
- Architecture Overview
- Prerequisites
- Set up your environment
- Add Data Cleansing
- Add Notion Integration
- Add Links to the AI response
- FAQ
This tutorial shows you how to level-up your data pipeline when building a custom AI chatbot.
We recommend setting up a basic custom chatbot first. This tutorial will build on top of the quicks start you can reference here.
For more resources: check out our page on AI.
- Increase accuracy
- Grow dataset by integrating more disparate data sources
- Earning user trust
- Increase accuracy by implementing multiple data cleansing techniques
- Integrate Notion
- Earn user trust by providing the link to the original data source
- We recommend walking through the steps to build a basic custom chatbot first. This tutorial will build on top of the quickstart you can reference here.
- Clone this repository. Or branch it if you want to make your own edits.
- A Pinecone Vector Database. You can create a free account at Pinecone's website.
- An Open AI API account. You can sign up at Open AI's website.
- You will need to add a payment method to your account here.
- Python (and your favorite IDE). We are using python v3.10.7.
- Your favorite API client tool (our favorite is Postman, or you can use CLI curl)
For more details about how to set up your infrastructure, reference https://github.com/focused-labs/ai-custom-chatbot-quickstart#ingesting-data.
- Install dependencies:
pip install -r requirements.txt
- Start the app:
python3 main.py
- With your favorite API client tool, send a
get
request to the root endpoint (localhost:8000/
)
If you receive the message “Hello World”, you are good to go 🎉
Located in text_cleaner.py
- Remove unnecessary data
- Keep data that adds meaning to the text.
- Remove emojis.
- Add a method to remove emojis. Emojis did not add any new information to the professional-toned documents we were ingesting. So, by removing this duplicate data, we saw an increase in accuracy.
- Ask yourself: “Are emojis adding new meaning to my data?” If yes, explore leaving emojis in the text.
- Remove specific special characters
- Add a method to remove specific special characters.
- DO NOT remove all special characters. Characters such as the period and comma add new information and meaning to the data. Removing these character resulted in a decrease in accuracy.
- Again, ask yourself: “Are these characters adding new meaning to my data?” If yes, explore leaving those characters in the text.
- Replace contractions
- Add a method that replaces common contractions.
- This facilitates better matching of semantic meaning.
In import_service.py
, you’ll see each document is cleaned before being loaded into the database. To trigger this
process,
- Start the app:
python3 main.py
- Send a
POST
**request to the data loading endpoint (ex:/load-website-docs
) with the following body:
{
page_urls: [
""
]
}
Example:
{
page_urls: [
"https://focusedlabs.io",
"https://focusedlabs.io/about",
"https://focusedlabs.io/contact",
"https://focusedlabs.io/case-studies",
"https://focusedlabs.io/case-studies/agile-workflow-enabled-btr-automation",
"https://focusedlabs.io/case-studies/hertz-technology-new-markets",
"https://focusedlabs.io/case-studies/aperture-agile-transformation",
"https://focusedlabs.io/case-studies/automated-core-business-functionality"
]
}
Llama Hub has a collection of open source data loaders you can use. We used the Notion loader, and had fairly good success.
We added a new POST
endpoint that allows us to trigger the ingestion of specified Notion pages
called /load-notion-docs
. The request body requires the ids of the pages you want to upload.
{
page_ids: [
""
]
}
To implement this, you will need to add a Notion API key to your .env
file.
NOTION_API_KEY = "secret notion api key here"
You will also need to make sure the pages you would like to upload have the correct API permissions. Reference the Notion documentation about authorization.
- Ensure that all of your data integrations include the file’s URL in the
metadata
field, as this will be referenced when corresponding vector is queried and selected.- As Llama Hub’s default Notion loader did not come with this feature, we added a method that handles the retrieval of the Notion page URL using Notion’s API.
- In your retriever (ours is located in
focused_labs_q_and_a_tool.py
), set the parameterreturn_source_documents
toTrue
. - In your agent (ours is located in
agent.py
), make sure that you parse the source documents from the primary response. We use a json format for easy integration with the endpoint.
To see this feature, query an agent.
- Start the app:
python3 main.py
- Send a
POST
**request to the endpoint/ask-agent
with the following body:
{
"text": ""
}
Example:
{
"text": "Who is Focused Labs?"
}
Outcome: You’ll receive an answer from the agent with a list of what sources from the database it found to form an answer.
Keep in mind that it will not always return a source if one is not used. For example, if you ask the agent “how are you today?”, that does not require the use of the vector database and thus it won’t include sources in its response.
However, if you ask the agent something related to information in the vector database like “Who is Focused Labs?”, it will pass the source documents that it retrieves.
- If you run into a
Rate Limit Error
, you need to make sure your OpenAI account has credit available. - If you run into a
*PermissionError: [Errno 13] Permission denied:*
then make sure you are running your app with Python3 - If you run into a
*MaxRetryError...Caused by SSLError*
when you are uploading your data to the vector database, wait another 5 minutes for your index to fully initialize and try again.