Question/Answering Assistant that generates answers from user questions about the official state gazette of Spain: BoletĂn Oficial del Estado (BOE).
TL;DR: All BOE articles are embedded in vectors and stored in a vector database. When a question is asked, the question is embedded in the same latent space and the most relevant text is retrieved from the vector database by performing a query using the embedded question. The retrieved pieces of text are then sent to the LLM to construct an answer.
At this moment we are running a user-free service: Justicio
You can test it without charge! Please, give us your feedback if you have!
- All BOE articles are embedded as embeddings and stored in an embedding database. This process is run at startup and every day.
- The user writes (using natural language) any question related to the BOE as input to the system.
- The backend service processes the input request (user question), transforms the question into an embedding, and sends the generated embedding as a query to the embedding database.
- The embedding database returns documents that most closely match the query.
- The most similar documents returned by the embedding database are added to the input query as context. Then a request with all the information is sent to the LLM API model.
- The LLM API model returns a natural language answer to the user's question.
- The user receives an AI-generated response output.
It is the web service, and it is a central component for the whole system, doing most of the tasks:
- Process the input requests from the user.
- Transform the input text into embeddings.
- Send requests to the embeddings database to get the most similar embeddings.
- Send requests to the LLM API model to generate the response.
- Save the traces.
- Handle input/output exceptions.
We download the BOE documents and break them into small chunks of text (e.g. 1200 characters). Each text chunk is transformed into an embedding (e.g. a numerically dense vector of 768 sizes). Some additional metadata is also stored with the vectors so that we can pre- or post-filter the search results. Check the code
The BOE is updated every day, so we need to run an ETL job every day to retrieve the new documents, transform them into embeddings, link the metadata, and store them in the embedding database. Check the code
It implements APIs to transform the input question into a vector, and to perform ANN (Approximate Nearest Neighbour) against all the vectors in the database. Check the code
There are different types of search (semantic search, keyword search, or hybrid search).
There are different types of ANNs (cosine similarity, Euclidean distance, or dot product).
The text in BOE is written in Spanish, so we need a sentence transformer model that is fine-tuned using Spanish datasets. We are experimenting with these models.
More info: https://www.newsletter.swirlai.com/p/sai-notes-07-what-is-a-vector-database
It is a Large Language Model (LLM) which generates answers for the user questions based on the context, which is the most similar documents returned by the embedding database.
- Langchain
- FastAPI
- Qdrant
- OpenAI API (gpt-4-1106-preview)
- Fine tuned Spanish SBert model
- BeautifulSoup
Check deployment_guide.md
file
- Summarize ELI5
- From QA to chat conversation (using memory)
- Add other regional and/or provincial gazettes https://www.boe.es/legislacion/otros_diarios_oficiales.php
- Generate smart questions from an article
- Use OpenAI Moderation API to filter wrong behaviours from users: https://platform.openai.com/docs/guides/moderation
- Create an OpenAI plugin
- Create a Justicio GPT on OpenAI
You are welcome! Please, contact us to see how you can help.
- @bukosabino
- @adantart