Geradores

Os geradores usam os modelos generativos de linguagem grande (LLMs) mais recentes do Google e as solicitações que você fornece para gerar comportamento e respostas do agente no momento da execução. Os modelos disponíveis são fornecidos pela Vertex AI.

Um gerador permite fazer chamadas para um LLM de maneira nativa a partir do 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 em tarefas como resumo, extração de parâmetros, transformações de dados e assim por diante. Confira os exemplos abaixo.

Limitações

No momento, esse recurso está disponível para agentes em qualquer idioma do Dialogflow. Observe que os modelos disponíveis podem ter limitações de linguagem mais restritivas. Consulte Vertex AI para saber mais.

Entender os conceitos do gerador

A documentação da Vertex AI contém informações importantes sobre a criação de geradores para o Dialogflow:

Definir um gerador

Para criar um gerador:

  1. Acesse o Console do Dialogflow CX.
  2. Selecione seu projeto do Google Cloud.
  3. Selecione o agente.
  4. Clique na guia Gerenciar.
  5. Clique em Geradores.
  6. Selecione Criar novo.
  7. Insira um nome de exibição descritivo para o gerador.
  8. Insira o comando de texto, o modelo e os controles, conforme descrito em Conceitos.
  9. Clique em Save.

O comando de texto é enviado ao modelo generativo durante o fulfillment no momento da execução. Ela precisa ser uma pergunta ou uma solicitação clara para que o modelo gere uma resposta satisfatória.

Para tornar o comando contextual, marque palavras como marcadores adicionando um $ antes da palavra. Mais tarde, é possível associar esses marcadores de solicitação do gerador a parâmetros de sessão no fulfillment, e eles serão substituídos pelos valores de parâmetro da sessão durante a execução.

Definir um gerador
Definir um gerador

marcadores de solicitação do gerador especiais que não precisam ser associados a parâmetros de sessão. Estes marcadores de solicitação do gerador integrado são

Termo Definição
$conversation A conversa entre o agente e o usuário, excluindo o último enunciado do usuário.
$last-user-utterance A última fala 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).

Abra a seção Generators (Geradores) do painel Fulfillment e expanda-o. Em seguida, clique em Adicionar gerador. Agora é possível selecionar um gerador predefinido ou definir um novo.

Depois de selecionar um gerador, é preciso associar os marcadores de solicitação do gerador aos parâmetros de sessão. Além disso, é preciso definir o parâmetro de saída que vai conter o resultado do gerador após a execução.

Usar um gerador
Usar o gerador no fulfillment

É possível adicionar vários geradores em um fulfillment, que são executados em paralelo.

O parâmetro de saída pode ser usado mais tarde, por exemplo, na resposta do agente.

Usar a saída do gerador
Usar a saída do gerador

Testar um gerador

O recurso gerador pode ser testado diretamente no simulador.

Gerador de teste no simulador
Teste o gerador no simulador

Examples

Nesta seção, mostramos exemplos de casos de uso para geradores.

Resumo de 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 de conversas

Este exemplo mostra como fornecer um resumo de conversa. Observe como podemos especificar explicitamente os prefixos das viradas da conversa no histórico de conversa e adicionar a expressão $last-user-utterance, porque ela não está incluída em $conversation.

Comando:

Your goal is to summarize a given conversation between a Human and an AI.

Conversation:
${conversation USER:"Human:" AGENT:"AI:"}Human: $last-user-utterance

A concise summary of the conversation in 1 or 2 sentences is:

Comando resolvido:

Para um exemplo de conversa, o comando resolvido que é enviado ao modelo generativo pode ser:

Your goal is to summarize a given conversation between a Human and an AI.

Conversation:
AI: Good day! What can I do for you today?
Human: Hi, which models can I use in Dialogflow's generators?
AI: You can use all models that Vertex AI provides!
Human: Thanks, thats amazing!

A concise summary of the conversation in 1 or 2 sentences is:

Formatação do Markdown

Este exemplo mostra como formatar o texto com 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, basta confiar no conhecimento interno do modelo generativo para responder à pergunta. No entanto, observe que o modelo simplesmente fornecerá uma resposta com base nas informações que fizeram 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:

Prompt para responder perguntas com informações fornecidas

No entanto, se você quiser que o modelo responda com base nas informações fornecidas, basta adicioná-lo ao comando. Isso funciona se não houver muitas informações que você quer fornecer (por exemplo, um pequeno cardápio de restaurante ou 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 is 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:

Solicitação de respostas com informações dinâmicas

Muitas vezes, as informações em que você quer que o modelo baseie a resposta são muito grandes para serem 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á-la a um marcador no comando.

# Instructions

Your goal is to politely answer questions based on the provided information.
If you cannot answer the question given the provided information, you plitely
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. Observe que, aqui, faz sentido usar um modelo generativo 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:

Encaminhamento para um agente humano

Neste exemplo, mostramos como lidar com o encaminhamento para um agente humano. As duas instruções finais no prompt evitam 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

Neste exemplo, mostramos como executar a recuperação de informações e pesquisar dados fornecidos no formato string ou JSON. Esses formatos são comumente usados 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

Neste exemplo, mostramos 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.