chatwoot-develop/progresso/arquitetura_captain_v2.md

110 lines
5.6 KiB
Markdown

# 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
1. **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."
2. **Os Especialistas (Sub-Agentes/Scenarios):**
* Cada `Captain::Scenario` deve 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.
### 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
1. **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_human` ou dizer "Preciso confirmar essa informação com um especialista humano".
2. **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.
3. **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
1. **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.
2. **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.
3. **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 em `Contact Custom Attributes` ou uma tabela `ContactMemories`.
* 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.
1. **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]".
2. **Playbooks Estruturados:**
* Utilizar o campo `playbook` do `Assistant` nã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.
---
## 5. Plano de Ação (Roadmap Técnico)
1. **Fase 1: Estrutura (Imediato)**
* Refinar os `System Prompts` atuais para incluir a data (Feito) e reforçar a persona.
* Configurar os `Scenarios` como sub-agentes especialistas.
2. **Fase 2: Controle (Curto Prazo)**
* Implementar o "Delay de Digitação" no `AgentRunnerService`.
* Adicionar o "Gatekeeper de Sentimento".
3. **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)
1. **Cliente:** "Meu sistema caiu e estou perdendo dinheiro!"
2. **Orquestrador:** Detecta sentimento negativo e palavra-chave "caiu".
* *Ação:* Roteia para **Agente de Emergência**.
3. **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?"