Os geradores usam os modelos de linguagem grandes generativos (LLMs) mais recentes do Google e os comandos fornecidos por você para gerar o comportamento e as respostas do agente no momento da execução. Os modelos disponíveis são fornecidos pela Vertex AI.
Um gerador permite fazer uma chamada para um LLM de forma nativa de agentes de conversa (Dialogflow CX) sem precisar criar seu próprio webhook externo. É possível configurar o gerador para fazer tudo o que você normalmente pediria a um LLM.
Os geradores são ótimos para tarefas como resumo, extração de parâmetros, transformações de dados e assim por diante. Confira os exemplos abaixo.
Limitações
Esse recurso está disponível para agentes em qualquer idioma do Dialogflow, embora os modelos disponíveis possam ter limitações de idioma mais restritivas. Consulte a Vertex AI para mais informações.
Entender os conceitos do gerador
A documentação da Vertex AI contém informações importantes para entender ao criar geradores para o Dialogflow:
- Modelos (modelos de fundação do Google e versões e ciclo de vida do modelo)
- Comandos
- Controles (chamados de "valores de parâmetro" na Vertex AI)
Definir um gerador
Para criar um gerador:
- Acesse o console do Dialogflow CX.
- Selecione seu projeto do Google Cloud.
- Selecione o agente.
- Clique na guia Gerenciar.
- Clique em Geradores.
- Clique em Criar novo.
- Insira um nome de exibição descritivo para o gerador.
- Insira o comando de texto, o modelo e os controles, conforme descrito em conceitos.
- Clique em Salvar.
O comando de texto é enviado ao modelo generativo durante a execução. Ela precisa ser uma pergunta ou solicitação clara para que o modelo gere uma resposta satisfatória.
Você pode tornar o comando contextual marcando palavras como marcadores de posição, adicionando um
$
antes da palavra. É possível associar esses marcadores de posição de solicitação
do gerador a parâmetros de sessão no fulfillment. Eles são substituídos pelos
valores do parâmetro de sessão durante a execução.
Há marcadores de posição de comando do gerador especiais que não precisam ser associados aos parâmetros de sessão. Esses marcadores de posição de comando integrado do gerador são
Termo | Definição |
---|---|
$conversation |
A conversa entre o agente e o usuário, excluindo a última declaração do usuário e as declarações do agente depois disso. |
$last-user-utterance |
A última declaração do usuário. |
Usar um gerador no fulfillment
É possível usar geradores durante o fulfillment (em Rotas, Manipuladores de eventos, Parâmetros e muito mais).
Acesse a seção Geradores do painel Fulfillment e expanda. Em seguida, clique em Adicionar gerador. Agora você pode selecionar um gerador predefinido ou definir um novo gerador no local.
Depois de selecionar um gerador, é necessário associar os marcadores de posição do comando do gerador ao comando com os parâmetros da sessão. Além disso, é necessário definir o parâmetro de saída que vai conter o resultado do gerador após a execução.
É possível adicionar vários geradores em uma fulfillment, que são executados em paralelo.
O parâmetro de saída pode ser usado mais tarde, por exemplo, na resposta do agente.
Testar um gerador
O recurso gerador pode ser testado diretamente no simulador.
Exemplos
Esta seção apresenta exemplos de casos de uso para geradores. Como os geradores são uma tecnologia generativa baseada em modelos de linguagem grandes (LLMs), seus resultados individuais com o uso dos exemplos de comandos abaixo podem ser diferentes da saída documentada aqui. Todos os resultados de comando retornados pelo Google são o melhor esforço.
Resumo do conteúdo
Este exemplo mostra como resumir o conteúdo.
Comando:
Your goal is to summarize a given text.
Text:
$text
A concise summary of the text in 1 or 2 sentences is:
Resumo da conversa
Este exemplo mostra como fornecer um resumo da conversa.
Comando:
You are an expert at summarizing conversations between a User and an Agent.
When providing the summary, always start with "Dear $email_address, the conversation summary is as follows:"
Provide a summary in a few bullet points.
Try to be as brief as possible with each bullet point,
only noting the key points of the conversation.
Output the summary in markdown format.
Conversation:
$conversation
Summary:
Prompt resolvido:
Como exemplo de conversa, a instrução resolvida enviada ao modelo generativo pode ser:
You are an expert at summarizing conversations between a User and an Agent.
When providing the summary, always start with "Dear joe@example.com conversation summary is as follows:"
Provide a summary in a few bullet points.
Try to be as brief as possible with each bullet point,
only noting the key points of the conversation.
Output the summary in markdown format.
Conversation:
Agent: Good day! What can I do for you today?
User: Hi, which models can I use in Conversational Agents (Dialogflow CX)'s generators?
Agent: You can use all models that Vertex AI provides!
User: Thanks, thats amazing!
Summary:
Formatação Markdown
Este exemplo mostra como formatar texto em Markdown.
# Instructions
You are presented with a text and your goal is to apply markdown formatting to text.
**NOTE:** Do not change the meaning of the text, only the formatting.
# Example
## Text
Generators allow you to use Googles latest generative models to format text,
or to create a summaries, or even to write code. What an amazing feature.
## Text in Markdown
*Generators* allow you to use Google's latest generative models to
* format text
* create a summaries
* write code
What an amazing feature.
# Your current task
## Text
$text
## Text in Markdown
Respostas a perguntas
Esta série de exemplos mostra como usar geradores para responder a perguntas.
Primeiro, você pode simplesmente confiar no conhecimento interno do modelo generativo para responder à pergunta. No entanto, o modelo simplesmente fornece uma resposta com base nas informações que faziam parte dos dados de treinamento. Não há garantia de que a resposta seja verdadeira ou atualizada.
Solicitar respostas a perguntas com autoconhecimento
Your goal is to politely reply to a human with an answer to their question.
The human asked:
$last-user-utterance
You answer:
Solicitar respostas a perguntas com as informações fornecidas
No entanto, se você quiser que o modelo responda com base nas informações fornecidas, basta adicioná-las ao comando. Isso funciona se você não quiser fornecer muitas informações, por exemplo, um pequeno cardápio de restaurante ou os dados de contato da sua empresa.
# Instructions
Your goal is to politely answer questions about the restaurant menu.
If you cannot answer the question because it's not related to the restaurant
menu or because relevant information is missing from the menu, you politely
decline to answer.
# Restaurant menu:
## Starters
Salat 5$
## Main dishes
Pizza 10$
## Deserts
Ice cream 2$
# Examples
Question: How much is the pizza?
Answer: The pizza is 10$.
Question: I want to order the ice cream.
Answer: We do have ice cream! However, I can only answer questions about the menu.
Question: Do you have spaghetti?
Answer: I'm sorry, we do not have spaghetti on the menu.
# Your current task
Question: $last-user-utterance
Answer:
Pedir respostas a perguntas com informações fornecidas de forma dinâmica
Muitas vezes, as informações que você quer que o modelo use para responder são muitas para ser simplesmente coladas no comando. Nesse caso, é possível conectar o gerador a um sistema de recuperação de informações, como um banco de dados ou um mecanismo de pesquisa, para recuperar dinamicamente as informações com base em uma consulta. Basta salvar a saída desse sistema em um parâmetro e conectá-lo a um marcador de posição no prompt.
# Instructions
Your goal is to politely answer questions based on the provided information.
If you can't answer the question given the provided information, you politely
decline to answer.
# Provided information:
$information
Question: $last-user-utterance
Answer:
Geração de códigos
Este exemplo mostra como usar um gerador para escrever código. Aqui, faz sentido usar um modelo generativo que foi treinado especificamente para gerar código.
Comando
# Instructions:
Your goal is to write code in a given programming language solving a given problem.
Problem to solve:
$problem
Programming language:
$programming-language
# Solution:
Encaminhar para um agente humano
Este exemplo mostra como lidar com a transferência para um agente humano. As duas últimas instruções no comando impedem que o modelo seja muito detalhado.
Comando:
# Instructions:
You are a polite customer service agent that handles requests
from users to speak with an operator.
Based on the $last-user-utterance,
respond to the user appropriately about their request to speak with an operator.
Always be polite and assure the user that you
will do your best to help their situation.
Do not ask the user any questions.
Do not ask the user if there is anything you can do to help them.
# Answer:
Geração de consultas de pesquisa
Este exemplo mostra como otimizar uma consulta da Pesquisa Google fornecida pelo usuário.
Comando:
# Instructions:
You are an expert at Google Search and using "Google Fu"
to build concise search terms that provide the highest quality results.
A user will provide an example query,
and you will attempt to optimize this to be the best Google Search query possible.
# Example:
User: when was covid-19 first started and where did it originated from?
Agent: covid-19 start origin
# Your task:
User: $text
Agent:
Recuperação de informações do cliente
Este exemplo mostra como realizar a recuperação de informações e pesquisar dados fornecidos em formato de string ou JSON. Esses formatos são usados com frequência pelos parâmetros de sessão do Dialogflow.
Comando:
You are a database engineer and specialize in extracting information
from both structured and unstructured data formats like CSV, SQL, JSON,
and also plain text.
Given a $user_db, extract the information requested
by the user from the $last-user-utterance
EXAMPLE:
user_db: {'customer_name': 'Patrick', 'balance': '100'}
User: What is my current account balance?
Agent: Your current balance is 100.
Begin!
user_db: $user_db
User: $last-user-utterance
Agent:
Como atualizar um objeto JSON
Este exemplo mostra como aceitar um objeto JSON de entrada do usuário (ou webhook) e manipular o objeto com base na solicitação do usuário.
Comando:
You are an expert Software Engineer
that specializes in the JSON object data structure.
Given some user $update_request and existing $json_object,
you will modify the $json_object based on the user's $update_request.
EXAMPLE:
json_object = { "a": 1, "b": 123 }
User: Add a new key/value pair to my JSON
Agent: What do you want to add?
User: c: cat
Agent: { "a": 1, "b": 123, "c": "cat"}
json_object = {"accounts": [{"username": "user1", "account_number": 12345}, {"username": "user2", "account_number": 98765}], "timestamp": "2023-05-25", "version":"1.0"}
User: Add a new value for user1
Agent: What do you want to add?
User: birthday, 12/05/1982
Agent: {"accounts": [{"username": "user1", "account_number": 12345, "birthday": "12/05/1982"}, {"username": "user2", "account_number": 98765}], "timestamp": "2023-05-25", "version":"1.0"}
json_object = $json_object
User: Add a new key value to my db
Agent: What do you want to add?
User: $last-user-utterance
Agent:
Codelab
Consulte também o Codelab de geradores.
Solução de problemas
Se você quiser depurar o recurso, inspecione a solicitação de entrada do modelo de linguagem grande (LLM) resolvido no simulador do console do Dialogflow:
Clique no botão resposta original:
Localize o campo "Generators LLM Inputs". Leia esses campos como texto simples e verifique se a entrada do LLM faz sentido. Se alguma frase contiver
$
, examine a entrada do simulador e esclareça se o$
nos comandos é intencional. Por exemplo,$
emprice is $10
provavelmente é intencional, enquantovisit $city
provavelmente não é e pode implicar uso indevido ou um bug.Se o campo "Entradas LLM generativas" não aparecer, entre em contato com o suporte.