embedchain / embedchain
- понедельник, 26 июня 2023 г. в 00:00:04
Framework to easily create LLM powered bots over any dataset.
embedchain is a framework to easily create LLM powered bots over any dataset.
It abstracts the entire process of loading a dataset, chunking it, creating embeddings and then storing in a vector database.
You can add a single or multiple dataset using .add
and .add_local
function and then use .query
function to find an answer from the added datasets.
If you want to create a Naval Ravikant bot which has 1 youtube video, 1 book as pdf and 2 of his blog posts, as well as a question and answer pair you supply, all you need to do is add the links to the videos, pdf and blog posts and the QnA pair and embedchain will create a bot for you.
from embedchain import App
naval_chat_bot = App()
# Embed Online Resources
naval_chat_bot.add("youtube_video", "https://www.youtube.com/watch?v=3qHkcs3kG44")
naval_chat_bot.add("pdf_file", "https://navalmanack.s3.amazonaws.com/Eric-Jorgenson_The-Almanack-of-Naval-Ravikant_Final.pdf")
naval_chat_bot.add("web_page", "https://nav.al/feedback")
naval_chat_bot.add("web_page", "https://nav.al/agi")
# Embed Local Resources
naval_chat_bot.add_local("qna_pair", ("Who is Naval Ravikant?", "Naval Ravikant is an Indian-American entrepreneur and investor."))
naval_chat_bot.query("What unique capacity does Naval argue humans possess when it comes to understanding explanations or concepts?")
# answer: Naval argues that humans possess the unique capacity to understand explanations or concepts to the maximum extent possible in this physical reality.
First make sure that you have the package installed. If not, then install it using pip
pip install embedchain
We use OpenAI's embedding model to create embeddings for chunks and ChatGPT API as LLM to get answer given the relevant docs. Make sure that you have an OpenAI account and an API key. If you have dont have an API key, you can create one by visiting this link.
Once you have the API key, set it in an environment variable called OPENAI_API_KEY
import os
os.environ["OPENAI_API_KEY"] = "sk-xxxx"
App
class from embedchain and use .add
function to add any dataset.from embedchain import App
naval_ravikant_chat_bot_app = App()
# Embed Online Resources
naval_chat_bot.add("youtube_video", "https://www.youtube.com/watch?v=3qHkcs3kG44")
naval_chat_bot.add("pdf_file", "https://navalmanack.s3.amazonaws.com/Eric-Jorgenson_The-Almanack-of-Naval-Ravikant_Final.pdf")
naval_chat_bot.add("web_page", "https://nav.al/feedback")
naval_chat_bot.add("web_page", "https://nav.al/agi")
# Embed Local Resources
naval_chat_bot.add_local("qna_pair", ("Who is Naval Ravikant?", "Naval Ravikant is an Indian-American entrepreneur and investor."))
from embedchain import App as EmbedChainApp
# or
from embedchain import App as ECApp
.query
function to get the answer for any query.print(naval_chat_bot.query("What unique capacity does Naval argue humans possess when it comes to understanding explanations or concepts?"))
# answer: Naval argues that humans possess the unique capacity to understand explanations or concepts to the maximum extent possible in this physical reality.
We support the following formats:
To add any youtube video to your app, use the data_type (first argument to .add
) as youtube_video
. Eg:
app.add('youtube_video', 'a_valid_youtube_url_here')
To add any pdf file, use the data_type as pdf_file
. Eg:
app.add('pdf_file', 'a_valid_url_where_pdf_file_can_be_accessed')
Note that we do not support password protected pdfs.
To add any web page, use the data_type as web_page
. Eg:
app.add('web_page', 'a_valid_web_page_url')
To supply your own QnA pair, use the data_type as qna_pair
and enter a tuple. Eg:
app.add_local('qna_pair', ("Question", "Answer"))
Creating a chat bot over any dataset needs the following steps to happen
Whenever a user asks any query, following process happens to find the answer for the query
The process of loading the dataset and then querying involves multiple steps and each steps has nuances of it is own.
These questions may be trivial for some but for a lot of us, it needs research, experimentation and time to find out the accurate answers.
embedchain is a framework which takes care of all these nuances and provides a simple interface to create bots over any dataset.
In the first release, we are making it easier for anyone to get a chatbot over any dataset up and running in less than a minute. All you need to do is create an app instance, add the data sets using .add
function and then use .query
function to get the relevant answer.
embedchain is built on the following stack: