É possível influenciar os resultados da pesquisa recuperados das ferramentas de repositório de dados dos agentes de conversa (Dialogflow CX) ao configurar especificações de reforço e filtro. Isso permite interações mais personalizadas e contextuais quando o agente usa um repositório de dados para encontrar informações.
Se quiser, inclua expressões dinâmicas para refinar os resultados com base no contexto da conversa. Por exemplo, o agente capturou informações indicando que o usuário final tem um "smartphone". Você pode configurar a ferramenta de repositório de dados para impulsionar documentos relacionados a smartphones ao responder a uma consulta geral mais tarde na conversa, como "Como faço para verificar minha caixa postal?".
É possível configurar os resultados da pesquisa no repositório de dados usando o console, a API ou a integração do Messenger do Dialogflow CX.
Entradas de condição de pesquisa
Os resultados da pesquisa são configurados usando os campos
especificação de reforço (BoostSpec)
e especificação de filtro (FilterSpec)
em um objeto SearchConfig. Essas configurações são aplicadas por repositório de dados na ferramenta, oferecendo controle granular sobre o comportamento de cada repositório conectado.
É possível configurar condições de pesquisa de duas maneiras: usando o console ou enviando uma chamada de API direta. Há distinções importantes entre os dois.
Chamada de API:
BoostSpeceFilterSpecsão enviados em umSearchConfigusando uma chamada de APIDetectIntent. Um objetoSearchConfigcompleto precisa ser fornecido na solicitação. UmSearchConfigenviado por uma chamada direta de API sempre substitui umSearchConfigenviado usando o console. Expressões dinâmicas e referências de parâmetros não são compatíveis.Console: suas configurações de
BoostSpeceFilterSpecsão usadas para construir um objetoSearchConfigque é enviado com a solicitação de pesquisa. Como opção, inclua referências de parâmetros e expressões dinâmicas para personalizar os resultados de acordo com os dados de contexto gravados na conversa. Você só precisa fornecer objetosConditionBoostSpece uma lista de strings de filtro para construirFilterSpecs, em vez de um objetoSearchConfigcompleto.
As informações do usuário final são fornecidas como JSON. Não há um esquema esperado, então você pode definir as propriedades do objeto.
Otimizar especificações (especificações de otimização)
Com as especificações de otimização, é possível mudar a classificação dos resultados da pesquisa aplicando um valor de otimização a documentos específicos. É possível adicionar várias especificações de reforço a um único repositório de dados.
Cada especificação de reforço é inserida como uma string JSON. Essa string JSON precisa representar
um único objeto ConditionBoostSpec.
Campos-chave:
condition: (string) uma expressão que especifica quando o reforço deve ser aplicado. Isso usa a sintaxe de expressão de filtro padrão. Você pode usar expressões do Dialogflow para tornar os resultados dinâmicos, como$session.params.YOUR_PARAM_NAMEou$request.end-user-metadata.YOUR_KEY.boost: (número) um valor entre -1,0 e 1,0 que determina a intensidade da otimização.- Um valor positivo promove documentos correspondentes. Um valor de
1.0oferece uma promoção forte. - Um valor negativo diminui a classificação dos documentos correspondentes. Um valor de
-1.0resulta em uma redução significativa. - Um valor de
0.0não aplica reforço e não é permitido.
- Um valor positivo promove documentos correspondentes. Um valor de
boostControlSpec: oferece mais controles para uma classificação personalizada do que a combinação básica de condição e reforço. Para mais informações sobre como configurar esse campo, consulte a documentação de referência.
Exemplo de entrada do console:
Se você estiver configurando o agente no console, forneça uma lista de
ConditionBoostSpecs
no seguinte formato.
Neste exemplo, os documentos com um URI que corresponda ao valor do parâmetro de sessão $session.params.doc_id serão promovidos com uma intensidade de 0,5. JSON desse formato
{
"condition": "uri: ANY(\"http://www.example.com/docs/$session.params.doc_id\")",
"boost": 0.5
}
Exemplo de entrada da API:
Se você estiver chamando a API diretamente, forneça ConditionBoostSpecs em um
objeto SearchConfig
completo.A configuração de pesquisa a seguir descreve uma especificação de reforço:
"searchConfig": {
"boostSpecs": [
{
"dataStores": [ "DATASTORE_ID" ],
"spec": [
{
"conditionBoostSpecs": {
"condition": "CONDITION",
"boost": "1.0"
}
}
]
}
]
}
Especificações de filtro
As especificações de filtro restringem os resultados da pesquisa para incluir apenas documentos que correspondam aos critérios definidos. É possível adicionar várias especificações de filtro a um único repositório de dados.
Cada especificação de filtro precisa ser inserida como uma expressão de string. A string precisa estar em conformidade com a sintaxe de expressão de filtro padrão.
Você pode usar expressões do Dialogflow nessa string para tornar os resultados dinâmicos, como $session.params.YOUR_PARAM_NAME ou $request.end-user-metadata.YOUR_KEY.
Exemplo de string de especificação de filtro do console:
Se você configurar o agente usando o console, forneça uma lista de strings
filter para formar um objeto
FilterSpec.
Neste exemplo, o filtro retorna apenas documentos com numeric_field maior ou igual ao valor de $session.params.min_value E em que stock_availability é "IN_STOCK".
"numeric_field >= $session.params.min_value AND stock_availability: ANY(\"IN_STOCK\")"
Exemplo de configuração de filtro de API:
Se você estiver chamando a API diretamente, forneça strings filter em um objeto SearchConfig completo:
"searchConfig": {
"filterSpecs": [
{
"dataStores": [ "DATASTORE_ID" ],
"filter": "CONDITION"
}
]
}
Expressões dinâmicas do Dialogflow
As condições BoostSpec e as strings FilterSpec podem incorporar expressões do Dialogflow para torná-las dinâmicas. Isso permite personalizar o comportamento de pesquisa com base em dados contextuais recuperados de uma conversa em andamento.
As expressões dinâmicas não são compatíveis com chamadas diretas de API e só podem ser usadas
se você estiver configurando usando o console.
É possível acessar os dados de contexto da conversa de duas maneiras:
- Parâmetros de sessão:valores coletados durante a conversa usando
$session.params.YOUR_PARAMETER_ID. - Metadados do usuário final:metadados sobre o usuário final transmitidos no
DetectIntentRequestusando$request.end-user-metadata.YOUR_KEY. Para que essa opção esteja disponível, verifique seend_user_metadataestá incluído noQueryParametersdas suas chamadasDetectIntent. Para mais informações, consulte endUserMetadata.
Para mais detalhes sobre as funções do sistema disponíveis e a sintaxe de expressão, consulte a referência de condições e funções do sistema.
Condições de pesquisa aplicadas no ambiente de execução
Quando a ferramenta de repositório de dados executa uma pesquisa:
- As strings JSON fornecidas para as especificações de reforço são avaliadas. Cada string JSON válida é convertida em um objeto
ConditionBoostSpec. Em seguida, eles são agrupados em um objetoBoostSpecspara a conexão específica do repositório de dados, que é adicionado aoSearchConfiggeral. - As strings fornecidas para especificações de filtro são avaliadas como expressões do Dialogflow. Cada string de filtro resultante é usada para
criar um objeto
FilterSpecspara o repositório de dados, que também é adicionado aoSearchConfig. - Esse
SearchConfigconstruído dinamicamente é incluído noQueryParametersda solicitação de pesquisa enviada ao repositório de dados.
Configurar condições de pesquisa
Antes de configurar as condições de pesquisa, verifique se você tem:
- Um agente de conversação (Dialogflow CX) já criado.
- Uma ferramenta de repositório de dados configurada para seu agente com um ou mais repositórios de dados ativados.
Configuração do console
- Abra o console dos Agentes de conversação e escolha um projeto do Google Cloud.
- Selecione um agente no menu suspenso.
- No menu à esquerda, clique em Ferramentas. Selecione a ferramenta de repositório de dados que você quer configurar.
- Na página de edição da ferramenta, acesse a seção Repositórios de dados. Clique no ícone Configurações (⚙️) ao lado do repositório de dados que você quer modificar.
- O menu Configurar repositório de dados vai aparecer. Aqui, você pode adicionar especificações de otimização e filtro para modificar os resultados da pesquisa.
- Para uma especificação de reforço, forneça um objeto JSON que defina um
ConditionBoostSpec. Consulte Especificações de impulso para mais detalhes. - Para uma especificação de filtro, forneça uma string que defina os critérios de filtro. Consulte Especificações de filtro para mais detalhes.
- Para uma especificação de reforço, forneça um objeto JSON que defina um
- Depois de adicionar e configurar as especificações, clique em Confirmar na parte de baixo do painel lateral.
- Clique em Salvar na página de edição da ferramenta de repositório de dados para salvar as mudanças.
Configuração da API
É possível fornecer dados de configuração de pesquisa aos agentes de conversação (Dialogflow CX) ao enviar solicitações de detecção de intenção. Essas informações precisam ser fornecidas em todas as solicitações de detecção de intenção, porque não são mantidas na sessão.
Forneça essas informações no campo queryParams.searchConfig do método Sessions.detectIntent.
Selecione um protocolo e uma versão para a referência de sessão:
| Protocolo | V3 | V3beta1 |
|---|---|---|
| REST | Recurso da sessão | Recurso da sessão |
| RPC (remote procedure call) | Interface da sessão | Interface da sessão |
| C++ | SessionsClient | Indisponível |
| C# | SessionsClient | Indisponível |
| Go | SessionsClient | Indisponível |
| Java | SessionsClient | SessionsClient |
| Node.js | SessionsClient | SessionsClient |
| PHP | Indisponível | Indisponível |
| Python | SessionsClient | SessionsClient |
| Ruby | Indisponível | Indisponível |
Configuração do Dialogflow CX Messenger
É possível fornecer dados de configuração de pesquisa para a integração do Dialogflow CX Messenger. Consulte o método setContext para mais informações.
Para aplicar uma especificação ou configuração de pesquisa, o snippet a seguir precisa ser adicionado ao código do Dialogflow CX Messenger ao incorporá-lo em um site:
<script>
document.addEventListener('df-messenger-loaded', () => {
const dfMessenger = document.querySelector('df-messenger');
const searchConfig = { ... }
dfMessenger.setQueryParameters(searchConfig);
});
</script>
Consulte o método setQueryParameters.
Solução de problemas
Esta seção descreve as soluções para alguns problemas comuns encontrados durante a configuração. Sempre teste suas configurações simulando conversas que acionam diferentes parâmetros de sessão e valores de metadados do usuário final.
Expressões inválidas
Se uma condição de especificação de reforço ou uma string de especificação de filtro contiver uma expressão inválida de
agentes de conversa (Dialogflow CX), por exemplo, sintaxe incorreta ou referência a um
parâmetro inexistente, a compilação da expressão vai falhar. Erros relacionados à
compilação de expressões geralmente são retornados no DetectIntentResponse
dentro do campo diagnostic_info
como SystemFunctionResults.
JSON ConditionBoostSpec inválido
O console de agentes de conversa realiza algumas validações na string JSON ConditionBoostSpec ao salvá-la. Isso é para verificar se é um JSON válido e se a estrutura dele pode ser mapeada para um objeto ConditionBoostSpec. Se o JSON for válido, mas resultar em um SearchConfig inválido de acordo com o serviço de pesquisa subjacente (por exemplo, uma string de condição inválida após a substituição de parâmetros), o serviço de pesquisa vai retornar um erro.
Erros de substituição de tempo de execução
Se uma string JSON ConditionBoostSpec for válida e analisável, mas ocorrer um erro
durante a substituição em tempo de execução de expressões do Dialogflow nos
campos (como a string de condição), esses erros serão informados em
diagnostic_info
como SystemFunctionResults.
Analise o SearchConfig compilado
O SearchConfig aplicado quando a consulta é executada está disponível em search_signals na resposta. A análise do SearchConfig pode fornecer insights sobre outros problemas não descritos aqui.
A seguir
- Para mais informações sobre a estrutura do
SearchConfige os componentes dele, consulte a documentação dosearch_config. - Para mais informações sobre a sintaxe de expressões, consulte a referência de condições e funções do sistema do Dialogflow.
- Para mais informações sobre a sintaxe de expressão de filtro para pesquisa, consulte Filtrar e ordenar resultados.