created |
---|
2024-10-23 |
Some basic but useful instructions. (Last synced 2024-10-23)
![[assets/Pasted image 20241023211050.png]]
How to give clear and effective instructions to OpenAI models
Updated over a week ago
Due to the way OpenAI models are trained, there are specific prompt formats that work particularly well and lead to more useful model outputs.
The official prompt engineering guide by OpenAI is usually the best place to start for prompting tips.Below we present a number of prompt formats we find work well, but feel free to explore different formats, which may fit your task better.
Note: the "{text input here}" is a placeholder for actual text/context
For best results, we generally recommend using the latest, most capable models. Newer models tend to be easier to prompt engineer.
2. Put instructions at the beginning of the prompt and use ### or """ to separate the instruction and context
Less effective ❌:
Summarize the text below as a bullet point list of the most important points.
{text input here}
Better ✅:
Summarize the text below as a bullet point list of the most important points.
Text: """
{text input here}
"""3. Be specific, descriptive and as detailed as possible about the desired context, outcome, length, format, style, etc
Be specific about the context, outcome, length, format, style, etc
Less effective ❌:
Write a poem about OpenAI.
Better ✅:
Write a short inspiring poem about OpenAI, focusing on the recent DALL-E product launch (DALL-E is a text to image ML model) in the style of a {famous poet}
Less effective ❌:
Extract the entities mentioned in the text below. Extract the following 4 entity types: company names, people names, specific topics and themes.
Text: {text}
Show, and tell - the models respond better when shown specific format requirements. This also makes it easier to programmatically parse out multiple outputs reliably.
Better ✅:
Extract the important entities mentioned in the text below. First extract all company names, then extract all people names, then extract specific topics which fit the content and finally extract general overarching themes
Desired format:
Company names: <comma_separated_list_of_company_names>
People names: -||-
Specific topics: -||-
General themes: -||-Text: {text}
✅ Zero-shot
Extract keywords from the below text.
Text: {text}
Keywords:
✅ Few-shot - provide a couple of examples
Extract keywords from the corresponding texts below.
Text 1: Stripe provides APIs that web developers can use to integrate payment processing into their websites and mobile applications.
Keywords 1: Stripe, payment processing, APIs, web developers, websites, mobile applicationsText 2: OpenAI has trained cutting-edge language models that are very good at understanding and generating text. Our API provides access to these models and can be used to solve virtually any task that involves processing language.
Keywords 2: OpenAI, language models, text processing, API.Text 3: {text}
Keywords 3:✅Fine-tune: see fine-tune best practices here.
Less effective ❌:
The description for this product should be fairly short, a few sentences only, and not too much more.
Better ✅:
Use a 3 to 5 sentence paragraph to describe this product.
Less effective ❌:
The following is a conversation between an Agent and a Customer. DO NOT ASK USERNAME OR PASSWORD. DO NOT REPEAT.
Customer: I can’t log in to my account.
Agent:Better ✅:
The following is a conversation between an Agent and a Customer. The agent will attempt to diagnose the problem and suggest a solution, whilst refraining from asking any questions related to PII. Instead of asking for PII, such as username or password, refer the user to the help article www.samplewebsite.com/help/faq
Customer: I can’t log in to my account.
Agent:Less effective ❌:
In this code example below, adding “import” hints to the model that it should start writing in Python. (Similarly “SELECT” is a good hint for the start of a SQL statement.)
Better ✅:
import
Developers can use the 'Generate Anything' feature to describe a task or expected natural language output and receive a tailored prompt.
Learn more about using the 'Generate Anything' feature.
Generally, we find that
model
andtemperature
are the most commonly used parameters to alter the model output.
model
- Higher performance models are generally more expensive and may have higher latency.
temperature
- A measure of how often the model outputs a less likely token. The higher thetemperature
, the more random (and usually creative) the output. This, however, is not the same as “truthfulness”. For most factual use cases such as data extraction, and truthful Q&A, thetemperature
of 0 is best.
max_tokens
(maximum length) - Does not control the length of the output, but a hard cutoff limit for token generation. Ideally you won’t hit this limit often, as your model will stop either when it thinks it’s finished, or when it hits a stop sequence you defined.
stop
(stop sequences) - A set of characters (tokens) that, when generated, will cause the text generation to stop.For other parameter descriptions see the API reference.