5.6 KiB
Arquitetura de Agentes Captain V2: Humanização, Consistência e Sub-Agentes
Data: 06/01/2026 Status: Proposta Arquitetural Contexto: Evolução do Captain para atendimento autônomo de alta fidelidade.
1. Arquitetura Hierárquica (Sub-Agentes)
Atualmente, o Captain opera muito como um "Generalista". Para evitar alucinações e melhorar a consistência, devemos adotar o padrão Orchestrator-Workers (Orquestrador-Trabalhadores).
A Estrutura Proposta
-
O Orquestrador (The Dispatcher/Triagem):
- Função: Não responde ao cliente (exceto saudações simples). A única função dele é analisar a intenção e rotear para o especialista correto.
- Ferramenta:
handoff_to_sales,handoff_to_support,handoff_to_human. - Prompt: Extremamente rígido. "Você é um classificador. Se o cliente quer comprar, chame o agente de vendas. Se tem problema técnico, chame o suporte."
-
Os Especialistas (Sub-Agentes/Scenarios):
- Cada
Captain::Scenariodeve ser tratado como um sub-agente isolado. - Agente de Suporte Técnico: Tem acesso à base de conhecimento (Docs) e ferramentas de debug.
- Agente de Vendas: Tem acesso a tabela de preços e ferramentas de agendamento.
- Agente de Retenção: Especialista em empatia, acionado quando o sentimento é negativo.
- Cada
Benefício Técnico
Ao restringir o escopo de cada agente, reduzimos drasticamente a chance de alucinação. O agente de vendas não sabe inventar soluções técnicas porque ele não tem essa ferramenta.
2. Eliminação de Alucinações (Grounding & RAG)
A alucinação ocorre quando a IA tenta ser prestativa sem ter a informação.
Melhorias Necessárias
-
Strict RAG (RAG Rígido):
- No
SearchDocumentationService, devemos retornar um "score de confiança". - Regra: Se a confiança da busca for menor que 0.7 (exemplo), o Agente NÃO deve tentar responder. Ele deve acionar o
escalate_to_humanou dizer "Preciso confirmar essa informação com um especialista humano".
- No
-
Citação Obrigatória:
- Forçar o modelo a incluir a fonte da resposta no JSON de saída (interno), mas não necessariamente no texto final. Se ele não conseguir citar de onde tirou a informação (ID do artigo), a resposta é descartada.
-
Fact-Checking Step (Passo de Verificação):
- Antes de enviar a resposta ao usuário, um passo intermediário (uma "segunda passada" rápida de LLM) verifica: "A resposta gerada está contida no contexto fornecido? Sim/Não". Se Não, descarta.
3. Humanização e UX (Parecer Humano)
Ser humano não é apenas falar "olá". É sobre timing, memória e adaptação.
Melhorias de Comportamento
-
Latência Variável (Simulação de Digitação):
- Respostas instantâneas (100ms) gritam "SOU UM ROBÔ".
- Implementação: Calcular o tempo de leitura da mensagem do usuário + tempo de "pensamento" + tempo de "digitação" da resposta.
- Exemplo: Uma resposta longa deve demorar 4-6 segundos para aparecer, com o status "digitando..." ativo no Chatwoot.
-
Análise de Sentimento (Gatekeeper):
- Antes de processar a resposta, classificar o sentimento do usuário (Irritado, Feliz, Neutro).
- Regra: Se Sentimento ==
Muito Irritado, bypass da IA. Transfere direto para humano. IA tentando acalmar cliente furioso geralmente piora a situação.
-
Memória de Longo Prazo (User Facts):
- O Captain deve lembrar que o "João" usa "Linux" e prefere ser atendido à tarde.
- Implementação: Um serviço que roda em background pós-conversa (
ConversationSummarizer) para extrair "Fatos" e salvar emContact Custom Attributesou uma tabelaContactMemories. - No próximo chat, esses fatos são injetados no Contexto.
4. Consistência (Style Guides)
Para evitar que o agente seja super formal numa hora e use gírias na outra.
-
Few-Shot Prompting Dinâmico:
- Em vez de apenas instruções ("Seja educado"), injetar 3 exemplos reais de ótimos atendimentos da sua empresa no prompt.
- Prompt: "Aqui estão exemplos de como respondemos nesta empresa: [Exemplo 1], [Exemplo 2]".
-
Playbooks Estruturados:
- Utilizar o campo
playbookdoAssistantnão apenas como texto, mas como uma máquina de estados. - Se o cliente está na fase "Onboarding", o tom é encorajador. Se está em "Cobrança", o tom é firme mas educado.
- Utilizar o campo
5. Plano de Ação (Roadmap Técnico)
-
Fase 1: Estrutura (Imediato)
- Refinar os
System Promptsatuais para incluir a data (Feito) e reforçar a persona. - Configurar os
Scenarioscomo sub-agentes especialistas.
- Refinar os
-
Fase 2: Controle (Curto Prazo)
- Implementar o "Delay de Digitação" no
AgentRunnerService. - Adicionar o "Gatekeeper de Sentimento".
- Implementar o "Delay de Digitação" no
-
Fase 3: Inteligência (Médio Prazo)
- Implementar o "Strict RAG" (só responder se houver documento com alta similaridade).
- Criar o sistema de Memória de Longo Prazo.
Exemplo de Fluxo Ideal (O Sonho)
- Cliente: "Meu sistema caiu e estou perdendo dinheiro!"
- Orquestrador: Detecta sentimento negativo e palavra-chave "caiu".
- Ação: Roteia para Agente de Emergência.
- Agente de Emergência:
- Consulta status do sistema (Tool). Vê que está tudo online.
- Consulta memória: "Cliente usa servidor on-premise".
- Resposta (com delay de 3s): "Oi João. Verifiquei aqui e nossos servidores principais estão online. Como você usa a versão local, pode ser algo na sua rede. Quer que eu chame um técnico dedicado agora?"