As instruções do playbook definem o processo que precisa ser realizado para alcançar a meta do playbook.
Cada etapa contém uma instrução em linguagem natural que pode conter qualquer um dos seguintes:
- Uma instrução básica que o LLM pode entender.
- Uma instrução para encaminhar o usuário a outro playbook.
Os playbooks são referenciados usando o formulário
${PLAYBOOK: playbook_name}
. - Uma instrução para usar uma ferramenta de manual de instruções específica.
As ferramentas são referenciadas usando o formulário
${TOOL: tool_name}
. - Uma instrução para encaminhar o usuário a um
fluxo.
Os fluxos são referenciados usando o formulário
${FLOW: flow_name}
. - Uma referência a um parâmetro de playbook.
Os parâmetros são referenciados usando o formulário
$parameter_name
. - Uma instrução para chamar um
bloco de código.
Os blocos de código são referenciados usando o formulário
`function_name`
.
Cada descrição de etapa começa com -
e uma etapa numerada opcional.
Você pode definir subinstruções usando recuo.
Exemplo:
- 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}.
Etapas das instruções
Para adicionar estrutura às suas instruções, você pode definir etapas com um sistema de numeração hierárquica. Se você não fornecer números de etapas e um bloco de código fizer referência a uma etapa específica, a ordem das etapas será usada para determinar os valores de posição das etapas.
Exemplo:
- 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.