Les instructions du playbook définissent le processus à suivre pour atteindre l'objectif du playbook.
Chaque étape contient une instruction en langage naturel qui peut contenir l'un des éléments suivants:
- Instruction de base que le LLM peut comprendre.
- Instruction pour rediriger l'utilisateur vers un autre playbook.
Les playbooks sont référencés sous la forme
${PLAYBOOK: playbook_name}
. - Instruction d'utilisation d'un outil de playbook spécifique.
Les outils sont référencés à l'aide du formulaire
${TOOL: tool_name}
. - Instruction pour rediriger l'utilisateur vers un flux.
Les flux sont référencés à l'aide du formulaire
${FLOW: flow_name}
. - Référence à un paramètre de playbook.
Les paramètres sont référencés à l'aide du formulaire
$parameter_name
. - Instruction permettant d'appeler un bloc de code.
Les blocs de code sont référencés à l'aide du formulaire
`function_name`
.
Chaque description d'étape commence par -
et une étape numérotée facultative. Vous pouvez définir des sous-instructions à l'aide d'une indentation.
Exemple :
- greet the customer and ask them how you can help.
- If the customer wants to book flights, route them to ${PLAYBOOK: flight_booking}.
- If the customer wants to book hotels, route them to ${PLAYBOOK: hotel_booking}.
- If the customer wants to know trending attractions, use the ${TOOL: attraction_tool} to show them the list.
- help the customer to pay for their booking by routing them to ${FLOW: make_payment}.
Étapes d'instruction
Pour structurer vos instructions, vous pouvez éventuellement définir des étapes avec un système de numérotation hiérarchique. Si vous ne fournissez pas de numéros d'étapes et qu'un bloc de code fait référence à une étape spécifique, l'ordre des étapes sera utilisé pour déterminer les valeurs de position des étapes.
Exemple :
- Step 1. Greet the user and ask how you can assist them today.
- Step 2. Collect the user's basic flight information in the following order
from (a) to (f). Do not deviate from this order, and do not proceed until the
user has specified each piece of information. Ask clarifying questions if
necessary, and make sure that the answers the user give make sense.
- Step 2.1 The traveler's $origin city. Do not proceed until the user has
made this clear.
- Step 2.2 The traveler's $destination city. Do not proceed until the user
has made this clear.
- Step 2.3 When the traveler will leave their origin city. If the user
specifies one departure date, collect their $earliest_departure_date. If
the user specifies a range of departure dates, collect their
$earliest_departure_date and $latest_departure_date. Unless otherwise
specified, assume all dates are from 2024 to 2025. If the user provides
a vague departure date, ask them follow-up questions to determine their
precise departure date(s). All dates should be in YYYY-MM-DD format. If
the user does not provide their departure date(s) in YYYY-MM-DD format,
then convert the dates for them.
- Step 2.4 When the traveler will leave from their destination city and
return home. If the user specifies one return date, collect their
$earliest_return_date. If the user specifies a range of return dates,
collect their $earliest_return_date and $latest_return_date. Unless
otherwise specified, assume all dates are from 2024 to 2025. If the user
provides a vague return date or a vague return date range, ask them
follow-up questions to determine their precise return date(s). All dates
should be in YYYY-MM-DD format. If the user does not provide their return
dates in YYYY-MM-DD format, then convert the dates for them.
- Step 2.5 The $num_adult_passengers the user wishes to buy tickets for. All
people 12 years old or older are adult passengers. This value must be a
precise whole number. Do not proceed until the user has provided a valid
number of adult passengers.
- Step 2.6 The $num_child_passengers the user wishes to buy tickets for.
This value must be a precise whole number. Do not proceed until the user
has provided a valid number of child passengers.
- Assume the user is an adult.