Intents

Uma intent categoriza a intenção do usuário final em cada conversa. Em comparação com as intents do ES, as intents do CX foram simplificadas para torná-las um recurso mais reutilizável.

Uma intent contém os seguintes dados:

Termo Definição
Nome de exibição Nome exibido no console para a intent.
Rótulos Rótulos que ajudam a categorizar intents. Por exemplo: intent de head.
Frases de treinamento As frases de treinamento são exemplos de frases que o usuário final pode digitar ou dizer, conhecidas como entradas do usuário final. Quando a entrada do usuário final se assemelhar a uma dessas frases, o Dialogflow corresponderá à intent. Você não precisa definir todos os exemplos possíveis, porque o machine learning integrado do Dialogflow expande sua lista com outras frases semelhantes.
Parâmetros Você define as frases de treinamento para usar parâmetros que extraem valores de partes específicas da entrada do usuário final.
Padrões de DTMF Consulte DTMF para integrações de telefonia.

Correspondência com intents

Quando um usuário final digita uma entrada (texto, fala ou pressionamentos de tecla do telefone), o Dialogflow compara a entrada com frases de treinamento de intent para encontrar a melhor correspondência. Esse processo é chamado de correspondência de intent. A correspondência de intents só pode ocorrer para intents associadas a uma rota de intent (um gerenciador de estado com um requisito de intent) no escopo.

A entrada ao pressionar a tecla é correspondida de acordo com padrões DTMF. No entanto, ao pesquisar uma intent correspondente ao texto, o Dialogflow pontua possíveis correspondências com uma confiança na detecção de intents, também conhecida como pontuação de confiança. Esses valores variam de 0,0 (completamente incerto) a 1,0 (completamente certo). Depois que as intents são pontuadas, há dois resultados possíveis:

  • Se a intent de pontuação mais alta tiver uma pontuação de confiança maior ou igual à configuração de limite de classificação, ela será retornada como uma correspondência.
  • Se nenhuma intent atingir o limite, um evento sem correspondência será invocado.

Os modelos do Dialogflow ML têm um certo nível de diferenciação entre maiúsculas e minúsculas, o que pode resultar em pontuações de correspondência ligeiramente diferentes para entradas do usuário final que diferem apenas em letras maiúsculas. Saiba mais no guia de práticas recomendadas de design de agente.

Frases de treinamento

Frases de treinamento são frases de exemplo que os usuários finais podem digitar ou dizer, conhecidas como entrada do usuário final. Você cria várias frases de treinamento para cada intent. Quando uma entrada de usuário final for parecida com uma dessas frases, o Dialogflow fará a correspondência com a intent.

Por exemplo, a frase de treinamento "Quero pizza" treina seu agente a reconhecer entradas de usuário final semelhantes a essa frase, como "Compre uma pizza" ou "Peça pizza".

Você não precisa definir todos os exemplos possíveis, porque o machine learning integrado do Dialogflow expande sua lista com outras frases semelhantes. Crie pelo menos 10 a 20 frases (dependendo da complexidade da intent) para que o agente reconheça uma variedade de entradas de usuário final. Por exemplo, se você quer que sua intent reconheça a entradas de um usuário final sobre sua cor favorita, defina as seguintes frases de treinamento:

  • “Gosto de vermelho”
  • “Minha cor favorita é amarelo”
  • “preto”
  • "Azul é a minha favorita"
  • ...

Anotar frases de treinamento

Você controla como os dados do usuário final são extraídos anotando partes das frases de treinamento e configurando os parâmetros associados.

Por exemplo, considere uma frase de treinamento como "Qual é a previsão amanhã para Tóquio?" Anote "amanhã" com um parâmetro date e "Tóquio" com um parâmetro location. Quando você anota partes de uma frase de treinamento, o Dialogflow reconhece que essas partes são apenas exemplos de valores reais que serão fornecidos pelos usuários finais no ambiente de execução. Para uma entrada de usuário final, como "Qual é a previsão para Sydney na sexta-feira?", o Dialogflow extrairia o parâmetro date de "Sexta-feira" e o parâmetro location de "Sydney".

É preciso anotar todas as partes da frase de treinamento que precisam ser extraídas como parâmetros. Caso contrário, o Dialogflow não extrairá os valores.

Ao criar um agente com o Console, a maioria das anotações é criada automaticamente quando você adiciona frases de treinamento que contêm partes que podem ser correspondidas a um tipo de entidade atual. Essas partes são destacadas no Console. Edite essas anotações e parâmetros conforme necessário.

Para anotar manualmente uma frase de treinamento com o Console, faça o seguinte:

  1. Selecione a parte da frase de treinamento que você quer anotar.
  2. Selecione o tipo de entidade desejado na lista.
  3. Um parâmetro é criado para você na tabela de parâmetros abaixo.

Ao criar um agente com a API, anote as partes da frase de treinamento manualmente. Veja o tipo TrainingPhrase usado pelo tipo Intent.

Selecione um protocolo e uma versão para a referência de intent:

Protocolo V3 V3beta1
REST Recurso de intent Recurso de intent
RPC Interface da intent Interface da intent
C++ IntentsClient Indisponível
C# IntentsClient Indisponível
Go IntentsClient Indisponível
Java IntentsClient IntentsClient
Node.js IntentsClient IntentsClient
PHP Indisponível Indisponível
Python IntentsClient IntentsClient
Ruby Indisponível Indisponível

Entidades implícitas criadas por frases de treinamento

A maioria das entidades personalizadas é definida explicitamente com a criação de tipos de entidade e a adição de entradas de entidade. No entanto, as entidades personalizadas também podem conter valores implícitos. Isso acontece quando você anota o texto de uma frase de treinamento, em que o texto anotado não é um valor definido pelo tipo de entidade selecionado. O texto anotado se torna um valor de referência de entidade para a entrada de entidade adicionada implicitamente. Se o tipo de entidade for de mapa, o texto também se tornará um sinônimo da entrada da entidade.

Intent de boas-vindas padrão

Quando você cria um agente, uma intent de boas-vindas padrão é criada para você. Para alguns idiomas, a intent tem frases de treinamento simples, como "Oi" ou "Olá", que precisam corresponder à entrada inicial do usuário final. É possível editar essa intent como quiser.

Ao usar a API, é possível referir-se a esse intent com o seguinte código de intent:

00000000-0000-0000-0000-000000000000

Se o agente iniciar a conversa, será possível acionar essa intent usando a API. Use o valor projects/<PROJECT_ID>/locations/<LOCATION_ID>/agents/<AGENT_ID>/intents/00000000-0000-0000-0000-000000000000 no campo QueryInput.intent.intent ao chamar o método detectIntent ou streamingDetectIntent.

Intent negativa padrão

Quando você cria um agente, uma intent de negativa padrão é criada para você. É possível adicionar frases de treinamento a essa intent que funcionam como exemplos negativos. Pode haver casos em que a entrada do usuário final tenha uma pequena semelhança com frases de treinamento em intents normais, mas você não quer que essas entradas correspondam a intents normais.

Por exemplo, um agente de reserva de sala pode ter uma frase de treinamento como "Eu gostaria de reservar uma sala". Se o usuário final quiser comprar um livro sobre o assunto, ele poderá dizer "Eu gostaria de comprar um livro sobre salas". Para que a entrada do usuário final não corresponda à sua intent, adicione essa frase como um exemplo negativo.

Além disso, é preciso adicionar possíveis frases que estejam fora do escopo do agente, de modo que não corresponderão a nenhuma intent. No entanto, evite adicionar uma quantidade muito grande dessas frases. Por exemplo, se você definir 10.000 frases de intent negativa padrão, isso vai afetar negativamente a correspondência de intent normal.

Revise essas frases regularmente, porque algumas delas podem ter ficado originalmente fora do escopo do agente, mas foram adicionadas às intents.

A intenção negativa padrão tem impacto em todas as correspondências de intent. As frases adicionadas podem beneficiar a correspondência para uma intent, mas dano para outra. Por exemplo, é possível adicionar "chamadas internacionais" à intent negativa padrão para evitar a correspondência com uma intent de viagem internacional. No entanto, isso também evita que essa frase corresponda a uma intent de chamada internacional.

Ao usar a API, é possível referir-se a esse intent com o seguinte código de intent:

00000000-0000-0000-0000-000000000001

Cancelar intents

Durante uma conversa, o usuário final pode querer cancelar o tópico da conversa atual. Por exemplo, a página atualmente ativa pode estar pedindo uma data para um novo agendamento, mas o usuário final decidiu não criar um novo compromisso. O usuário final pode dizer algo como "cancelar" ou "Não quero um novo compromisso". Para lidar com essa situação, é possível criar uma ou mais cancelamentos de intent para seu agente. É possível nomear essas intents de cancelamento como quiser, mas é costume incluir "cancelar" no nome. É necessário associar essas intents de cancelamento às rotas de intent que estão no escopo em pontos relevantes da conversa. Essas rotas de intent deverão fazer a transição para uma página adequada para processar o cancelamento.

As frases de treinamento para intents de cancelamento precisam lidar com tentativas genéricas e específicas de tópicos que serão canceladas. Exemplo:

  • Cancelar
  • Parar
  • Mudei de ideia
  • Cancelar
  • Voltar
  • Voltar
  • Não quero um novo compromisso
  • Cancelar novo compromisso
  • Excluir novo compromisso

Como criar uma intent

Para criar um intent:

Console

  1. Abra o Console do Dialogflow CX.
  2. Escolha seu projeto do Google Cloud.
  3. Selecione seu agente.
  4. Selecione a guia Gerenciar.
  5. Clique em Intents.
  6. Clique em Criar.
  7. Digite os dados da intent.
  8. Clique em Salvar.

API

Veja o método create para o tipo Intent.

Selecione um protocolo e uma versão para a referência de intent:

Protocolo V3 V3beta1
REST Recurso de intent Recurso de intent
RPC Interface da intent Interface da intent
C++ IntentsClient Indisponível
C# IntentsClient Indisponível
Go IntentsClient Indisponível
Java IntentsClient IntentsClient
Node.js IntentsClient IntentsClient
PHP Indisponível Indisponível
Python IntentsClient IntentsClient
Ruby Indisponível Indisponível

Excluir uma intent

Para excluir um intent:

Console

  1. Abra o Console do Dialogflow CX.
  2. Escolha seu projeto do Google Cloud.
  3. Selecione seu agente.
  4. Selecione a guia Gerenciar.
  5. Clique em Intents.
  6. Passe o cursor sobre o intent que você quer excluir.
  7. Clique no botão de exclusão .

API

Veja o método delete para o tipo Intent.

Selecione um protocolo e uma versão para a referência de intent:

Protocolo V3 V3beta1
REST Recurso de intent Recurso de intent
RPC Interface da intent Interface da intent
C++ IntentsClient Indisponível
C# IntentsClient Indisponível
Go IntentsClient Indisponível
Java IntentsClient IntentsClient
Node.js IntentsClient IntentsClient
PHP Indisponível Indisponível
Python IntentsClient IntentsClient
Ruby Indisponível Indisponível

Acessar dados da intent

Para acessar os dados do intent:

Console

  1. Abra o Console do Dialogflow CX.
  2. Escolha seu projeto do Google Cloud.
  3. Selecione seu agente.
  4. Selecione a guia Gerenciar.
  5. Clique em Intents.
  6. Clique na intent que você quer acessar.
  7. Visualizar ou atualizar dados de intent.
  8. Clique em Salvar para salvar as alterações.

API

Veja os métodos get e patch/update para o tipo Intent.

Selecione um protocolo e uma versão para a referência de intent:

Protocolo V3 V3beta1
REST Recurso de intent Recurso de intent
RPC Interface da intent Interface da intent
C++ IntentsClient Indisponível
C# IntentsClient Indisponível
Go IntentsClient Indisponível
Java IntentsClient IntentsClient
Node.js IntentsClient IntentsClient
PHP Indisponível Indisponível
Python IntentsClient IntentsClient
Ruby Indisponível Indisponível

Sugestões de intenção

O Dialogflow analisa automaticamente ocorrências sem correspondência durante as conversas e pode sugerir novas intents ou recomendar frases de treinamento adicionais para intents atuais. Aceitar essas sugestões pode ajudar a evitar futuras ocorrências sem correspondência.

Ao usar as sugestões, é possível ajustar o Tamanho do cluster. Valores menores de tamanho de cluster sugerem mais intents com menos frases de treinamento por intent. Valores maiores de tamanho de cluster sugerem menos intents com mais frases de treinamento por intent.

Para aceitar sugestões de intent:

Console

  1. Abra o Console do Dialogflow CX.
  2. Escolha seu projeto do Google Cloud.
  3. Selecione seu agente.
  4. Selecione a guia Gerenciar.
  5. Clique em Intents.
  6. Clique na guia Suggestions.
  7. Ajuste o Tamanho do cluster conforme desejado.
  8. Selecione uma sugestão.
  9. Selecione as frases de treinamento que você quer.
  10. Para a intent de destino, adicione as frases de treinamento a uma intent atual ou nova.
  11. Clique em Salvar ou Criar novo para salvar as alterações. Quando você aceita sugestões de intent, a intent permanece na lista de sugestões.

Intents de divisão

É possível dividir uma intent em duas usando o console. A interface permite selecionar frases de treinamento de uma intent de origem e movê-las para uma nova intent:

Console

  1. Abra o Console do Dialogflow CX.
  2. Escolha o projeto.
  3. Selecione seu agente.
  4. Selecione a guia Gerenciar.
  5. Clique em Intents.
  6. Selecione a intent que você quer dividir.
  7. Clique em Dividir.
  8. Selecionar intents da intent de origem.
  9. Clique em Mover para a direita.
  10. Forneça outros detalhes para a intent de destino.
  11. Clique em Dividir.

Comparar e mesclar intents

É possível comparar ou mesclar duas intents em uma única intent usando o console:

Console

  1. Abra o Console do Dialogflow CX.
  2. Escolha o projeto.
  3. Selecione seu agente.
  4. Selecione a guia Gerenciar.
  5. Clique em Intents.
  6. Selecione as duas intents que você quer comparar ou mesclar.
  7. Clique em Comparar.
  8. As frases de treinamento são mostradas lado a lado para comparação.
  9. Para mesclar as duas intents, clique em Merge.

Exportar e importar intents

É possível exportar e importar intents para compartilhamento entre agentes.

Uma das opções de formato de exportação é CSV, que tem as seguintes colunas:

  • Nome de exibição da intent
  • Idioma
  • Frase

Cada entrada contém o nome de exibição, o idioma e a primeira frase de treinamento ou apenas uma frase de treinamento para a intent declarada anteriormente. O Dialogflow codifica as anotações em frases de treinamento exportadas para que elas sejam restauradas durante a importação. O formato dessa codificação é:

(annotated part)[entity, parameter]

Exemplo:

Intent Display Name,Language,Phrase
Shirt Selection,en,I want a (green)[@sys.color, color] shirt
,,I would like a (yellow)[@sys.color, color] shirt
Store Hours,en,When are you open?
,,What are your hours?

Ao importar intents, pode haver conflitos de mesclagem quando o nome de exibição de uma intent no agente atual corresponder ao de uma intent importada. É possível controlar o comportamento de mesclagem quando os nomes de exibição da intent correspondem selecionando uma das seguintes opções:

  • Substituir intents atuais: uma intent importada substitui qualquer intent de mesmo nome no agente atual.
  • Renomear e importar como novas intents: a intent importada é renomeada anexando "_1" ao nome de exibição.
  • Mesclar com intents atuais: as frases de treinamento de uma intent importada são adicionadas à intent existente. Se as mesmas frases de treinamento existirem, elas não serão duplicadas.
  • Manter as intents originais: a intent existente permanece inalterada, e a intent conflitante é ignorada. Intents não conflitantes são importadas.

Para exportar intents:

Console

  1. Abra o Console do Dialogflow CX.
  2. Escolha seu projeto do Google Cloud.
  3. Selecione seu agente.
  4. Selecione a guia Gerenciar.
  5. Clique em Intents.
  6. Selecione cada intent que você quer exportar.
  7. Clique em Exportar intents selecionadas.
  8. Selecione o formato e o destino desejados.
  9. Clique em Enviar.

Para importar intents:

Console

  1. Abra o Console do Dialogflow CX.
  2. Escolha seu projeto do Google Cloud.
  3. Selecione seu agente.
  4. Selecione a guia Gerenciar.
  5. Clique em Intents.
  6. Clique em Importar.
  7. Selecione a origem.
  8. Se houver conflitos, será mostrada uma caixa de diálogo que permite selecionar o comportamento de mesclagem.
  9. Clique em Enviar.

Exportar e importar frases de treinamento

É possível exportar e importar frases de treinamento para uma intent atual.

O formato do arquivo para importação é CSV sem cabeçalho e com uma única coluna. Exemplo:

"I want a pony"
"I need a pony"
"I must have a pony"

Ao importar frases de treinamento, você pode escolher um dos seguintes modos de importação:

  • Importar como novas frases de treinamento: as frases nos arquivos são adicionadas à lista de frases existentes.
  • Substituir frases de treinamento existentes: as frases de treinamento existentes são excluídas e as frases de treinamento dos arquivos são adicionadas.

Por padrão, as frases de treinamento importadas são anotadas automaticamente. Para desativar esse comportamento, selecione Pular anotação automática.

Para exportar frases de treinamento para uma intent:

Console

  1. Abra o Console do Dialogflow CX.
  2. Escolha seu projeto do Google Cloud.
  3. Selecione seu agente.
  4. Selecione a guia Gerenciar.
  5. Clique em Intents.
  6. Selecione um intent.
  7. Role para baixo até a seção Training phrases.
  8. Selecione as frases de treinamento que você quer exportar.
  9. Clique em Exportar.

Para importar frases de treinamento para uma intent:

Console

  1. Abra o Console do Dialogflow CX.
  2. Escolha seu projeto do Google Cloud.
  3. Selecione seu agente.
  4. Selecione a guia Gerenciar.
  5. Clique em Intents.
  6. Selecione um intent.
  7. Role para baixo até a seção Training phrases.
  8. Se quiser, selecione pular anotação automática.
  9. Clique no botão de importação logo acima da lista de frases de treinamento.
  10. Selecione um arquivo e o modo de importação.
  11. Clique em Enviar.

Ao projetar agentes, pode ser útil pensar nas intents como intents principais ou intents complementares.

Uma intent principal identifica o objetivo principal do usuário final para interagir com um agente. Uma intent suplementar identifica as perguntas subsequentes de um usuário final que estão relacionadas à intent principal. Essas próximas perguntas podem fornecer mais contexto para as necessidades do usuário final ou podem ser perguntas de acompanhamento que ajudam o usuário final a esclarecer ou entender melhor algo.

Uma intent principal geralmente é uma das primeiras intents correspondentes em uma conversa, e as outras perguntas do usuário final correspondem às intents complementares. Exemplo:

Diálogo Explicação
Usuário final: ativar novo smartphone
Agente: Claro, posso ajudar você com isso. Quais são os últimos quatro dígitos do número de telefone que você quer ativar?
A intent principal é correspondida
Usuário final: 1234
Agente: Tudo pronto para ativar seu smartphone agora?
Um parâmetro é definido
Usuário final: Todas as minhas mensagens serão transferidas para meu novo smartphone?
Agente: ...
A intent complementar é correspondida