-
Notifications
You must be signed in to change notification settings - Fork 824
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
f1bd67b
commit a5c0ede
Showing
8 changed files
with
356 additions
and
24 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,126 @@ | ||
|
||
== Prompts | ||
|
||
Prompts serve as the foundation for language-based inputs that guide an AI model to produce specific outputs. | ||
While this might seem intuitive considering our interactions with ChatGPT, crafting effective prompts involves both an art and a science. | ||
The wording of the language utilized significantly impacts the AI model's responses, and there specific patters and words are recognized by the model to guide responses in the intended direction. | ||
|
||
The importance of this skill has led to the emergence of "Prompt Engineering." | ||
When an effective prompt for a particular use case is identified, it is often shared within the community. | ||
|
||
== Prompt Templates | ||
|
||
Creating effective prompts involves establishing the context of the request and substituting parts of the request with values specific to the user's input. | ||
|
||
This process utilizes traditional text-based Template engines for prompt creation and management. | ||
Spring AI employs the OSS library, StringTemplate, for this purpose. | ||
|
||
For instance, consider the simple prompt template: Tell me a {adjective} joke about {content}. | ||
|
||
In Spring AI, Prompt Templates can be likened to the 'View' in Spring MVC architecture. | ||
A model object, typically a java.util.Map, is provided to populate placeholders within the template. | ||
The 'rendered' string becomes the content of the Prompt supplied to the AI model. | ||
|
||
There is considerable variability in the specific data format of the Prompt sent to the model. | ||
Initially starting as simple strings, prompts have evolved to include multiple messages, where each string in each message represents a distinct role for the model. | ||
|
||
== Tokens | ||
|
||
Tokens serve as the building blocks of how an AI model works. | ||
On input, Models convert words to tokens, and on output, they convert tokens back to words. | ||
|
||
In English, one token roughly corresponds to 75% of a word. For reference, Shakespeare's complete works, totaling around 900,000 words, translates to approximately 1.2 million tokens. | ||
|
||
Perhaps more important is that Tokens = *`$`*. | ||
|
||
In the context of hosted AI models, your charges are determined by the number of tokens utilized. Both input and output contribute to the overall token count. | ||
|
||
Also, models are subject to token limits, which restrict the amount of text processed in a single API call. | ||
This threshold is often referred to as the 'context window'. The model won't process any text exceeding this limit. | ||
|
||
For instance, ChatGPT3 has a 4K token limit, while GPT4 offers varying options, such as 8K, 16K, and 32K. | ||
Anthropic's Claude AI model features a 100K token limit, and Meta's recent research yielded a 1M token limit model. | ||
|
||
To summarize the collected works of Shakespeare with GPT4, you need to devise software engineering strategies to chop up the data and present the data within the model's context window limits. | ||
This is an area that the Spring AI project helps you with. | ||
|
||
== Output Parsing | ||
|
||
The output of AI models traditionally arrives as a `java.util.String`, even if you ask for the reply to be in JSON. | ||
It may be the correct JSON, but it isn't a JSON data structure. It is just a string. | ||
Also, asking "for JSON" as part of the prompt isn't 100% accurate. | ||
|
||
This intricacy has led to the emergence of a specialized field involving the creation of prompts to yield the intended output, followed by parsing the resulting simple string into a usable data structure for application integration. | ||
|
||
Output parsing employs meticulously crafted prompts, often necessitating multiple interactions with the model to achieve the desired formatting. | ||
|
||
This challenge has prompted OpenAI to introduce 'OpenAI Functions' as a means to specify the desired output format from the model precisely. | ||
|
||
== Chaining Calls | ||
|
||
A Chain is the concept that represents a series of calls to a AI model. | ||
It uses the output from one call as the input to another. | ||
|
||
By chaining calls together, you can support complex use-cases by composing pipelines of multiple chains. | ||
|
||
== Customizing Models: Integrating Your Data | ||
|
||
How can you equip the AI model with information it hasn't been trained on? | ||
|
||
It's important to note that the GPT 3.5/4.0 dataset extends only until September 2021. | ||
Consequently, the model will say that it doesn't know the answer for questions that require knowledge beyond that date. | ||
An interesting bit of trivia is that this dataset is around ~650GB. | ||
|
||
Two techniques exist for customizing the AI model to incorporate your data: | ||
|
||
Fine Tuning: This traditional Machine Learning technique involves tailoring the model and changing its internal weighting. | ||
However, it's a challenging process for Machine Learning experts and extremely resource-intensive for models like GPT due to their size. Additionally, some models might not offer this option. | ||
|
||
Prompt Stuffing: A more practical alternative involves embedding your data within the prompt provided to the model. Given a model's token limits, techniques are required to present relevant data within the model's context window. | ||
This approach is colloquially referred to as 'stuffing the prompt'. | ||
|
||
The Spring AI library helps you implement solutions based on the 'stuffing of the prompt' technique. | ||
|
||
|
||
== Retrieval Augmented Generation | ||
|
||
A technique termed Retrieval Augmented Generation has emerged to address the challenge of incorporating relevant data into prompts for accurate AI model responses. | ||
|
||
The approach involves extracting data from your source and segmenting it into smaller units, each within the model's token limit. These pieces are then stored in a database. | ||
When a user's request is received, the most pertinent document fragments are retrieved from the database to enrich the prompt, aiding the AI model's response accuracy. | ||
|
||
Data Loaders play a pivotal role in this process, reading and formatting your data into fragments suitable for database storage. | ||
For optimal retrieval of related documents, a Vector Database is the type of database best suited for this task. | ||
|
||
Data Loaders and Vector Database are the fundamental building blocks for solving use cases such as "Q&A over my documentation". | ||
|
||
|
||
|
||
=== Data Loaders | ||
|
||
TBD | ||
|
||
=== Vector Databases | ||
|
||
== Evaluating AI responses | ||
|
||
Effectively evaluating the output of an AI system in response to user requests is very important to ensuring accuracy and usefulness of the final application. | ||
Several emerging techniques enable the use of the pretrained model itself for this purpose. | ||
|
||
This evaluation process involves analyzing whether the generated response aligns with the user's intent and the context of the query. Metrics such as relevance, coherence, and factual correctness are used to gauge the quality of the AI-generated response. | ||
|
||
One approach involves presenting both the user's request and the AI model's response to the model, querying whether the response aligns with the provided data. | ||
|
||
Furthermore, leveraging the information stored in the Vector Database as supplementary data can enhance the evaluation process, aiding in the determination of response relevance. | ||
|
||
The Spring AI project currenlty provides some very basic examples of how you can evaluate the responses in the form of prompts to include in a JUnit test. | ||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.