(Clique na imagem acima para assistir ao vídeo desta lição)
Bem-vindo à lição sobre metacognição em agentes de IA! Este capítulo foi projetado para iniciantes que têm curiosidade sobre como agentes de IA podem pensar sobre seus próprios processos de pensamento. Ao final desta lição, você entenderá os conceitos-chave e estará equipado com exemplos práticos para aplicar a metacognição no design de agentes de IA.
Após concluir esta lição, você será capaz de:
- Compreender as implicações dos ciclos de raciocínio nas definições de agentes.
- Usar técnicas de planejamento e avaliação para ajudar agentes autoajustáveis.
- Criar seus próprios agentes capazes de manipular código para realizar tarefas.
Metacognição refere-se aos processos cognitivos de ordem superior que envolvem pensar sobre o próprio pensamento. Para agentes de IA, isso significa ser capaz de avaliar e ajustar suas ações com base na autoconsciência e em experiências passadas. Metacognição, ou "pensar sobre o pensamento", é um conceito importante no desenvolvimento de sistemas de IA agentes. Envolve sistemas de IA estarem cientes de seus próprios processos internos e serem capazes de monitorar, regular e adaptar seu comportamento de forma correspondente. Muito parecido com o que fazemos ao "ler a sala" ou analisar um problema. Essa autoconsciência pode ajudar sistemas de IA a tomar decisões melhores, identificar erros e melhorar seu desempenho ao longo do tempo — relacionando-se novamente ao teste de Turing e ao debate sobre se a IA vai dominar.
No contexto de sistemas de IA agentes, a metacognição pode ajudar a enfrentar vários desafios, tais como:
- Transparência: Garantir que sistemas de IA possam explicar seu raciocínio e decisões.
- Raciocínio: Aumentar a capacidade de sistemas de IA de sintetizar informações e tomar decisões sólidas.
- Adaptação: Permitir que sistemas de IA se ajustem a novos ambientes e condições mutáveis.
- Percepção: Melhorar a precisão dos sistemas de IA em reconhecer e interpretar dados do ambiente.
Metacognição, ou "pensar sobre o pensamento", é um processo cognitivo de ordem superior que envolve autoconsciência e autorregulação dos próprios processos cognitivos. No domínio da IA, a metacognição capacita agentes a avaliar e adaptar suas estratégias e ações, levando a melhorias na resolução de problemas e nas capacidades de tomada de decisão. Ao entender a metacognição, você poderá projetar agentes de IA que sejam não apenas mais inteligentes, mas também mais adaptáveis e eficientes. Na metacognição verdadeira, você veria a IA raciocinando explicitamente sobre seu próprio raciocínio.
Exemplo: “Eu priorizei voos mais baratos porque... posso estar deixando de lado voos diretos, então vou verificar novamente.”
Acompanhando como ou por que escolheu determinada rota.
- Notar que cometeu erros porque confiou demais nas preferências do usuário da última vez, então modifica sua estratégia de tomada de decisão, não apenas a recomendação final.
- Diagnosticar padrões como: “Sempre que vejo o usuário mencionar ‘muito cheio’, não devo apenas remover certas atrações, mas também refletir que meu método de escolher ‘principais atrações’ é falho se eu sempre classifico pela popularidade.”
A metacognição desempenha um papel crucial no design de agentes de IA por várias razões:
- Autorreflexão: Agentes podem avaliar seu próprio desempenho e identificar áreas para melhoria.
- Adaptabilidade: Agentes podem modificar suas estratégias com base em experiências passadas e ambientes em mudança.
- Correção de Erros: Agentes podem detectar e corrigir erros autonomamente, levando a resultados mais precisos.
- Gestão de Recursos: Agentes podem otimizar o uso de recursos, como tempo e poder computacional, planejando e avaliando suas ações.
Antes de mergulhar nos processos metacognitivos, é essencial entender os componentes básicos de um agente de IA. Um agente de IA normalmente consiste em:
- Persona: A personalidade e características do agente, que definem como ele interage com os usuários.
- Ferramentas: As capacidades e funções que o agente pode executar.
- Habilidades: O conhecimento e expertise que o agente possui.
Esses componentes trabalham juntos para criar uma "unidade de expertise" capaz de realizar tarefas específicas.
Exemplo:
Considere um agente de viagens, um serviço de agentes que não só planeja suas férias, mas também ajusta seu trajeto com base em dados em tempo real e experiências anteriores dos clientes.
Imagine que você está projetando um serviço de agente de viagens movido a IA. Este agente, "Agente de Viagem", auxilia os usuários a planejar suas férias. Para incorporar a metacognição, o Agente de Viagem precisa avaliar e ajustar suas ações com base em autoconsciência e experiências passadas. Veja como a metacognição pode desempenhar um papel:
A tarefa atual é ajudar um usuário a planejar uma viagem para Paris.
- Coletar Preferências do Usuário: Perguntar ao usuário sobre datas de viagem, orçamento, interesses (ex.: museus, gastronomia, compras) e quaisquer exigências específicas.
- Recuperar Informações: Pesquisar opções de voos, acomodações, atrações e restaurantes que correspondam às preferências do usuário.
- Gerar Recomendações: Fornecer um itinerário personalizado com detalhes de voos, reservas de hotéis e atividades sugeridas.
- Ajustar com Base no Feedback: Solicitar retorno do usuário sobre as recomendações e fazer ajustes necessários.
- Acesso a bancos de dados de voos e reservas de hotéis.
- Informações sobre atrações e restaurantes em Paris.
- Dados de feedback de usuários de interações anteriores.
O Agente de Viagem usa metacognição para avaliar seu desempenho e aprender com experiências anteriores. Por exemplo:
- Analisar Feedback do Usuário: O Agente de Viagem revisa o feedback para determinar quais recomendações foram bem recebidas e quais não foram, ajustando sugestões futuras conforme.
- Adaptabilidade: Se um usuário mencionou anteriormente aversão a lugares lotados, o Agente evitará recomendar pontos turísticos populares nos horários de pico futuramente.
- Correção de Erros: Se cometeu um erro em uma reserva passada, como sugerir um hotel lotado, o Agente aprende a checar a disponibilidade de forma mais rigorosa antes de recomendar.
Aqui está um exemplo simplificado de como o código do Agente de Viagem pode ser ao incorporar metacognição:
class Travel_Agent:
def __init__(self):
self.user_preferences = {}
self.experience_data = []
def gather_preferences(self, preferences):
self.user_preferences = preferences
def retrieve_information(self):
# Pesquise voos, hotéis e atrações com base nas preferências
flights = search_flights(self.user_preferences)
hotels = search_hotels(self.user_preferences)
attractions = search_attractions(self.user_preferences)
return flights, hotels, attractions
def generate_recommendations(self):
flights, hotels, attractions = self.retrieve_information()
itinerary = create_itinerary(flights, hotels, attractions)
return itinerary
def adjust_based_on_feedback(self, feedback):
self.experience_data.append(feedback)
# Analise o feedback e ajuste recomendações futuras
self.user_preferences = adjust_preferences(self.user_preferences, feedback)
# Exemplo de uso
travel_agent = Travel_Agent()
preferences = {
"destination": "Paris",
"dates": "2025-04-01 to 2025-04-10",
"budget": "moderate",
"interests": ["museums", "cuisine"]
}
travel_agent.gather_preferences(preferences)
itinerary = travel_agent.generate_recommendations()
print("Suggested Itinerary:", itinerary)
feedback = {"liked": ["Louvre Museum"], "disliked": ["Eiffel Tower (too crowded)"]}
travel_agent.adjust_based_on_feedback(feedback)- Autorreflexão: Agentes podem analisar seu desempenho e identificar áreas para melhoria.
- Adaptabilidade: Agentes podem modificar estratégias com base no feedback e em condições mutáveis.
- Correção de Erros: Agentes podem detectar e corrigir erros autonomamente.
- Gestão de Recursos: Agentes podem otimizar o uso de recursos, como tempo e poder computacional.
Incorporando a metacognição, o Agente de Viagem pode fornecer recomendações de viagem mais personalizadas e precisas, melhorando a experiência geral do usuário.
O planejamento é um componente crítico do comportamento de um agente de IA. Envolve delinear os passos necessários para alcançar um objetivo, considerando o estado atual, recursos e possíveis obstáculos.
- Tarefa Atual: Definir claramente a tarefa.
- Passos para Completar a Tarefa: Dividir a tarefa em etapas gerenciáveis.
- Recursos Necessários: Identificar os recursos necessários.
- Experiência: Utilizar experiências passadas para informar o planejamento.
Exemplo:
Aqui estão os passos que o Agente de Viagem precisa realizar para ajudar um usuário a planejar sua viagem efetivamente:
-
Coletar Preferências do Usuário
- Perguntar ao usuário detalhes sobre datas de viagem, orçamento, interesses e quaisquer requisitos específicos.
- Exemplos: "Quando você pretende viajar?" "Qual é a faixa do seu orçamento?" "Que atividades você gosta durante as férias?"
-
Recuperar Informações
- Pesquisar opções de viagem relevantes com base nas preferências do usuário.
- Voos: Procurar voos disponíveis dentro do orçamento e datas preferidas.
- Acomodações: Encontrar hotéis ou propriedades para aluguel que correspondam às preferências de localização, preço e comodidades.
- Atrações e Restaurantes: Identificar atrações populares, atividades e opções gastronômicas alinhadas aos interesses do usuário.
-
Gerar Recomendações
- Compilar as informações recuperadas em um itinerário personalizado.
- Fornecer detalhes como opções de voo, reservas de hotel e atividades sugeridas, garantindo que as recomendações sejam adaptadas às preferências do usuário.
-
Apresentar o Itinerário ao Usuário
- Compartilhar o itinerário proposto com o usuário para revisão.
- Exemplo: "Aqui está um itinerário sugerido para sua viagem a Paris. Inclui detalhes de voos, reservas de hotel e uma lista de atividades e restaurantes recomendados. Me avise o que acha!"
-
Coletar Feedback
- Pedir ao usuário seu feedback sobre o itinerário proposto.
- Exemplos: "Você gostou das opções de voo?" "O hotel atende suas necessidades?" "Gostaria de adicionar ou remover alguma atividade?"
-
Ajustar Baseado no Feedback
- Modificar o itinerário conforme o feedback do usuário.
- Fazer as mudanças necessárias nas recomendações de voos, acomodações e atividades para melhor atender às preferências.
-
Confirmação Final
- Apresentar o itinerário atualizado para confirmação final do usuário.
- Exemplo: "Fiz os ajustes baseados no seu feedback. Aqui está o itinerário atualizado. Está tudo certo para você?"
-
Reservar e Confirmar
- Após aprovação do usuário, proceder com as reservas de voos, acomodações e atividades pré-planejadas.
- Enviar detalhes de confirmação ao usuário.
-
Fornecer Suporte Contínuo
- Permanecer disponível para ajudar o usuário com alterações ou solicitações adicionais antes e durante a viagem.
- Exemplo: "Se precisar de mais alguma coisa durante sua viagem, fique à vontade para me chamar a qualquer momento!"
class Travel_Agent:
def __init__(self):
self.user_preferences = {}
self.experience_data = []
def gather_preferences(self, preferences):
self.user_preferences = preferences
def retrieve_information(self):
flights = search_flights(self.user_preferences)
hotels = search_hotels(self.user_preferences)
attractions = search_attractions(self.user_preferences)
return flights, hotels, attractions
def generate_recommendations(self):
flights, hotels, attractions = self.retrieve_information()
itinerary = create_itinerary(flights, hotels, attractions)
return itinerary
def adjust_based_on_feedback(self, feedback):
self.experience_data.append(feedback)
self.user_preferences = adjust_preferences(self.user_preferences, feedback)
# Exemplo de uso dentro de uma solicitação de reserva
travel_agent = Travel_Agent()
preferences = {
"destination": "Paris",
"dates": "2025-04-01 to 2025-04-10",
"budget": "moderate",
"interests": ["museums", "cuisine"]
}
travel_agent.gather_preferences(preferences)
itinerary = travel_agent.generate_recommendations()
print("Suggested Itinerary:", itinerary)
feedback = {"liked": ["Louvre Museum"], "disliked": ["Eiffel Tower (too crowded)"]}
travel_agent.adjust_based_on_feedback(feedback)Primeiro vamos entender a diferença entre Ferramenta RAG e Carregamento de Contexto Preemptivo
RAG combina um sistema de recuperação com um modelo generativo. Quando uma consulta é feita, o sistema de recuperação busca documentos ou dados relevantes de uma fonte externa, e essas informações recuperadas são usadas para aumentar a entrada do modelo generativo. Isso ajuda o modelo a gerar respostas mais precisas e contextualmente relevantes.
Em um sistema RAG, o agente recupera informações relevantes de uma base de conhecimento e as usa para gerar respostas ou ações apropriadas.
A abordagem Corretiva RAG foca no uso das técnicas RAG para corrigir erros e melhorar a precisão dos agentes de IA. Isso envolve:
- Técnica de Prompting: Usar prompts específicos para orientar o agente na recuperação da informação relevante.
- Ferramenta: Implementar algoritmos e mecanismos que permitem ao agente avaliar a relevância das informações recuperadas e gerar respostas precisas.
- Avaliação: Avaliar continuamente o desempenho do agente e fazer ajustes para melhorar sua precisão e eficiência.
Considere um agente de busca que recupera informações da web para responder às consultas dos usuários. A abordagem Corretiva RAG pode envolver:
- Técnica de Prompting: Formular consultas de busca baseadas na entrada do usuário.
- Ferramenta: Usar processamento de linguagem natural e algoritmos de aprendizado de máquina para ranquear e filtrar os resultados da busca.
- Avaliação: Analisar o feedback do usuário para identificar e corrigir imprecisões nas informações recuperadas.
O RAG Corretivo (Geração Aumentada por Recuperação) aprimora a capacidade da IA de recuperar e gerar informações enquanto corrige quaisquer imprecisões. Vamos ver como o Agente de Viagem pode usar esta abordagem para fornecer recomendações de viagem mais precisas e relevantes.
Isso envolve:
- Técnica de Prompting: Usar prompts específicos para guiar o agente na recuperação de informações relevantes.
- Ferramenta: Implementar algoritmos e mecanismos que permitam ao agente avaliar a relevância das informações recuperadas e gerar respostas precisas.
- Avaliação: Avaliar continuamente o desempenho do agente e fazer ajustes para melhorar sua precisão e eficiência.
-
Interação Inicial com o Usuário
-
O Agente de Viagem coleta as preferências iniciais do usuário, como destino, datas de viagem, orçamento e interesses.
-
Exemplo:
preferences = { "destination": "Paris", "dates": "2025-04-01 to 2025-04-10", "budget": "moderate", "interests": ["museums", "cuisine"] }
-
-
Recuperação de Informações
-
O Agente de Viagem recupera informações sobre voos, acomodações, atrações e restaurantes conforme as preferências do usuário.
-
Exemplo:
flights = search_flights(preferences) hotels = search_hotels(preferences) attractions = search_attractions(preferences)
-
-
Geração de Recomendações Iniciais
-
O Agente de Viagem usa as informações recuperadas para gerar um itinerário personalizado.
-
Exemplo:
itinerary = create_itinerary(flights, hotels, attractions) print("Suggested Itinerary:", itinerary)
-
-
Coleta de Feedback do Usuário
-
O Agente de Viagem solicita o feedback do usuário sobre as recomendações iniciais.
-
Exemplo:
feedback = { "liked": ["Louvre Museum"], "disliked": ["Eiffel Tower (too crowded)"] }
-
-
Processo RAG Corretivo
-
Técnica de Prompting: O Agente de Viagem formula novas consultas de busca baseadas no feedback do usuário.
-
Exemplo:
if "disliked" in feedback: preferences["avoid"] = feedback["disliked"]
-
-
Ferramenta: O Agente de Viagem usa algoritmos para ranquear e filtrar novos resultados de busca, enfatizando a relevância baseada no feedback do usuário.
-
Exemplo:
new_attractions = search_attractions(preferences) new_itinerary = create_itinerary(flights, hotels, new_attractions) print("Updated Itinerary:", new_itinerary)
-
-
Avaliação: O Agente de Viagem avalia continuamente a relevância e precisão de suas recomendações ao analisar o feedback do usuário e fazer os ajustes necessários.
-
Exemplo:
def adjust_preferences(preferences, feedback): if "liked" in feedback: preferences["favorites"] = feedback["liked"] if "disliked" in feedback: preferences["avoid"] = feedback["disliked"] return preferences preferences = adjust_preferences(preferences, feedback)
-
-
Aqui está um exemplo simplificado em Python incorporando a abordagem RAG Corretiva no Agente de Viagem:
class Travel_Agent:
def __init__(self):
self.user_preferences = {}
self.experience_data = []
def gather_preferences(self, preferences):
self.user_preferences = preferences
def retrieve_information(self):
flights = search_flights(self.user_preferences)
hotels = search_hotels(self.user_preferences)
attractions = search_attractions(self.user_preferences)
return flights, hotels, attractions
def generate_recommendations(self):
flights, hotels, attractions = self.retrieve_information()
itinerary = create_itinerary(flights, hotels, attractions)
return itinerary
def adjust_based_on_feedback(self, feedback):
self.experience_data.append(feedback)
self.user_preferences = adjust_preferences(self.user_preferences, feedback)
new_itinerary = self.generate_recommendations()
return new_itinerary
# Exemplo de uso
travel_agent = Travel_Agent()
preferences = {
"destination": "Paris",
"dates": "2025-04-01 to 2025-04-10",
"budget": "moderate",
"interests": ["museums", "cuisine"]
}
travel_agent.gather_preferences(preferences)
itinerary = travel_agent.generate_recommendations()
print("Suggested Itinerary:", itinerary)
feedback = {"liked": ["Louvre Museum"], "disliked": ["Eiffel Tower (too crowded)"]}
new_itinerary = travel_agent.adjust_based_on_feedback(feedback)
print("Updated Itinerary:", new_itinerary)O Carregamento de Contexto Preemptivo envolve carregar o contexto relevante ou informações de fundo no modelo antes de processar uma consulta. Isso significa que o modelo tem acesso a essa informação desde o início, o que pode ajudá-lo a gerar respostas mais informadas sem precisar recuperar dados adicionais durante o processo.
Aqui está um exemplo simplificado de como um carregamento de contexto preemptivo pode parecer para um aplicativo de agente de viagens em Python:
class TravelAgent:
def __init__(self):
# Pré-carregar destinos populares e suas informações
self.context = {
"Paris": {"country": "France", "currency": "Euro", "language": "French", "attractions": ["Eiffel Tower", "Louvre Museum"]},
"Tokyo": {"country": "Japan", "currency": "Yen", "language": "Japanese", "attractions": ["Tokyo Tower", "Shibuya Crossing"]},
"New York": {"country": "USA", "currency": "Dollar", "language": "English", "attractions": ["Statue of Liberty", "Times Square"]},
"Sydney": {"country": "Australia", "currency": "Dollar", "language": "English", "attractions": ["Sydney Opera House", "Bondi Beach"]}
}
def get_destination_info(self, destination):
# Buscar informações do destino a partir do contexto pré-carregado
info = self.context.get(destination)
if info:
return f"{destination}:\nCountry: {info['country']}\nCurrency: {info['currency']}\nLanguage: {info['language']}\nAttractions: {', '.join(info['attractions'])}"
else:
return f"Sorry, we don't have information on {destination}."
# Exemplo de uso
travel_agent = TravelAgent()
print(travel_agent.get_destination_info("Paris"))
print(travel_agent.get_destination_info("Tokyo"))-
Inicialização (método
__init__): A classeTravelAgentpré-carrega um dicionário contendo informações sobre destinos populares como Paris, Tóquio, Nova York e Sydney. Este dicionário inclui detalhes como país, moeda, idioma e principais atrações para cada destino. -
Recuperando Informações (método
get_destination_info): Quando um usuário consulta sobre um destino específico, o métodoget_destination_infobusca as informações relevantes a partir do dicionário de contexto pré-carregado.
Ao pré-carregar o contexto, o aplicativo agente de viagens pode responder rapidamente às consultas dos usuários sem precisar recuperar essas informações de uma fonte externa em tempo real. Isso torna o aplicativo mais eficiente e responsivo.
Iniciar um plano com um objetivo envolve começar com uma meta clara ou resultado desejado em mente. Ao definir esse objetivo antecipadamente, o modelo pode usá-lo como um princípio orientador ao longo do processo iterativo. Isso ajuda a garantir que cada iteração se aproxime de alcançar o resultado desejado, tornando o processo mais eficiente e focado.
Aqui está um exemplo de como você pode iniciar um plano de viagem com um objetivo antes de iterar para um agente de viagens em Python:
Um agente de viagens quer planejar férias personalizadas para um cliente. O objetivo é criar um roteiro de viagem que maximize a satisfação do cliente com base em suas preferências e orçamento.
- Definir as preferências e o orçamento do cliente.
- Iniciar o plano inicial com base nessas preferências.
- Iterar para refinar o plano, otimizando a satisfação do cliente.
class TravelAgent:
def __init__(self, destinations):
self.destinations = destinations
def bootstrap_plan(self, preferences, budget):
plan = []
total_cost = 0
for destination in self.destinations:
if total_cost + destination['cost'] <= budget and self.match_preferences(destination, preferences):
plan.append(destination)
total_cost += destination['cost']
return plan
def match_preferences(self, destination, preferences):
for key, value in preferences.items():
if destination.get(key) != value:
return False
return True
def iterate_plan(self, plan, preferences, budget):
for i in range(len(plan)):
for destination in self.destinations:
if destination not in plan and self.match_preferences(destination, preferences) and self.calculate_cost(plan, destination) <= budget:
plan[i] = destination
break
return plan
def calculate_cost(self, plan, new_destination):
return sum(destination['cost'] for destination in plan) + new_destination['cost']
# Exemplo de uso
destinations = [
{"name": "Paris", "cost": 1000, "activity": "sightseeing"},
{"name": "Tokyo", "cost": 1200, "activity": "shopping"},
{"name": "New York", "cost": 900, "activity": "sightseeing"},
{"name": "Sydney", "cost": 1100, "activity": "beach"},
]
preferences = {"activity": "sightseeing"}
budget = 2000
travel_agent = TravelAgent(destinations)
initial_plan = travel_agent.bootstrap_plan(preferences, budget)
print("Initial Plan:", initial_plan)
refined_plan = travel_agent.iterate_plan(initial_plan, preferences, budget)
print("Refined Plan:", refined_plan)-
Inicialização (método
__init__): A classeTravelAgenté inicializada com uma lista de destinos potenciais, cada um com atributos como nome, custo e tipo de atividade. -
Iniciando o Plano (método
bootstrap_plan): Este método cria um plano inicial baseado nas preferências do cliente e no orçamento. Ele itera pela lista de destinos e os adiciona ao plano se eles corresponderem às preferências do cliente e estiverem dentro do orçamento. -
Correspondência de Preferências (método
match_preferences): Este método verifica se um destino corresponde às preferências do cliente. -
Iterando o Plano (método
iterate_plan): Este método refina o plano inicial tentando substituir cada destino do plano por uma combinação melhor, considerando as preferências e as restrições de orçamento do cliente. -
Calculando o Custo (método
calculate_cost): Este método calcula o custo total do plano atual, incluindo um possível novo destino.
- Plano Inicial: O agente de viagens cria um plano inicial baseado nas preferências do cliente por passeios turísticos e um orçamento de $2000.
- Plano Refinado: O agente de viagens itera o plano, otimizando para as preferências e orçamento do cliente.
Ao iniciar o plano com um objetivo claro (por exemplo, maximizar a satisfação do cliente) e iterar para refinar o plano, o agente de viagens pode criar um roteiro personalizado e otimizado para o cliente. Essa abordagem garante que o plano de viagem esteja alinhado com as preferências e orçamento do cliente desde o início e melhore a cada iteração.
Modelos de Linguagem Grandes (LLMs) podem ser usados para reordenar e pontuar avaliando a relevância e qualidade dos documentos recuperados ou respostas geradas. Veja como funciona:
Recuperação: A etapa inicial de recuperação busca um conjunto de documentos candidatos ou respostas baseadas na consulta.
Reordenação: O LLM avalia esses candidatos e os reordena com base na relevância e qualidade. Essa etapa garante que as informações mais relevantes e de alta qualidade sejam apresentadas primeiro.
Pontuação: O LLM atribui pontuações a cada candidato, refletindo sua relevância e qualidade. Isso ajuda a selecionar a melhor resposta ou documento para o usuário.
Aproveitando LLMs para reordenação e pontuação, o sistema pode fornecer informações mais precisas e contextualmente relevantes, melhorando a experiência geral do usuário.
Aqui está um exemplo de como um agente de viagens pode usar um Modelo de Linguagem Grande (LLM) para reordenar e pontuar destinos de viagem com base nas preferências do usuário em Python:
Um agente de viagens quer recomendar os melhores destinos de viagem a um cliente com base em suas preferências. O LLM ajudará a reordenar e pontuar os destinos para garantir que as opções mais relevantes sejam apresentadas.
- Coletar as preferências do usuário.
- Recuperar uma lista de destinos de viagem potenciais.
- Usar o LLM para reordenar e pontuar os destinos com base nas preferências do usuário.
Veja como você pode atualizar o exemplo anterior para usar os Serviços Azure OpenAI:
- Você precisa ter uma assinatura Azure.
- Criar um recurso Azure OpenAI e obter sua chave API.
import requests
import json
class TravelAgent:
def __init__(self, destinations):
self.destinations = destinations
def get_recommendations(self, preferences, api_key, endpoint):
# Gerar um prompt para o Azure OpenAI
prompt = self.generate_prompt(preferences)
# Definir cabeçalhos e payload para a requisição
headers = {
'Content-Type': 'application/json',
'Authorization': f'Bearer {api_key}'
}
payload = {
"prompt": prompt,
"max_tokens": 150,
"temperature": 0.7
}
# Chamar a API do Azure OpenAI para obter os destinos reordenados e pontuados
response = requests.post(endpoint, headers=headers, json=payload)
response_data = response.json()
# Extrair e retornar as recomendações
recommendations = response_data['choices'][0]['text'].strip().split('\n')
return recommendations
def generate_prompt(self, preferences):
prompt = "Here are the travel destinations ranked and scored based on the following user preferences:\n"
for key, value in preferences.items():
prompt += f"{key}: {value}\n"
prompt += "\nDestinations:\n"
for destination in self.destinations:
prompt += f"- {destination['name']}: {destination['description']}\n"
return prompt
# Exemplo de uso
destinations = [
{"name": "Paris", "description": "City of lights, known for its art, fashion, and culture."},
{"name": "Tokyo", "description": "Vibrant city, famous for its modernity and traditional temples."},
{"name": "New York", "description": "The city that never sleeps, with iconic landmarks and diverse culture."},
{"name": "Sydney", "description": "Beautiful harbour city, known for its opera house and stunning beaches."},
]
preferences = {"activity": "sightseeing", "culture": "diverse"}
api_key = 'your_azure_openai_api_key'
endpoint = 'https://your-endpoint.com/openai/deployments/your-deployment-name/completions?api-version=2022-12-01'
travel_agent = TravelAgent(destinations)
recommendations = travel_agent.get_recommendations(preferences, api_key, endpoint)
print("Recommended Destinations:")
for rec in recommendations:
print(rec)-
Inicialização: A classe
TravelAgenté inicializada com uma lista de destinos de viagem potenciais, cada um com atributos como nome e descrição. -
Obtendo Recomendações (método
get_recommendations): Este método gera um prompt para o serviço Azure OpenAI baseado nas preferências do usuário e faz uma requisição HTTP POST para a API Azure OpenAI para obter destinos reordenados e pontuados. -
Gerando o Prompt (método
generate_prompt): Este método constrói um prompt para o Azure OpenAI, incluindo as preferências do usuário e a lista de destinos. O prompt orienta o modelo a reordenar e pontuar os destinos com base nas preferências fornecidas. -
Chamada à API: A biblioteca
requestsé usada para fazer uma requisição HTTP POST para o endpoint Azure OpenAI. A resposta contém os destinos reordenados e pontuados. -
Exemplo de Uso: O agente de viagens coleta as preferências do usuário (por exemplo, interesse em passeios turísticos e diversidade cultural) e usa o serviço Azure OpenAI para obter recomendações reordenadas e pontuadas para destinos de viagem.
Certifique-se de substituir your_azure_openai_api_key pela sua chave API real do Azure OpenAI e https://your-endpoint.com/... pela URL real do endpoint da sua implantação Azure OpenAI.
Ao aproveitar o LLM para reordenação e pontuação, o agente de viagens pode fornecer recomendações de viagem mais personalizadas e relevantes para os clientes, melhorando sua experiência geral.
Retrieval-Augmented Generation (RAG) pode ser tanto uma técnica de prompting quanto uma ferramenta no desenvolvimento de agentes de IA. Entender a distinção entre os dois pode ajudá-lo a usar o RAG de forma mais eficaz em seus projetos.
O que é?
- Como técnica de prompting, RAG envolve a formulação de consultas ou prompts específicos para guiar a recuperação de informações relevantes a partir de um grande corpo de texto ou banco de dados. Essas informações são então usadas para gerar respostas ou ações.
Como funciona:
- Formular Prompts: Criar prompts ou consultas bem estruturadas baseadas na tarefa a ser realizada ou na entrada do usuário.
- Recuperar Informação: Usar os prompts para buscar dados relevantes em uma base de conhecimento ou conjunto de dados pré-existente.
- Gerar Resposta: Combinar a informação recuperada com modelos de IA generativos para produzir uma resposta abrangente e coerente.
Exemplo em Agente de Viagens:
- Entrada do Usuário: "Quero visitar museus em Paris."
- Prompt: "Encontre os principais museus em Paris."
- Informação Recuperada: Detalhes sobre o Museu do Louvre, Musée d'Orsay, etc.
- Resposta Gerada: "Aqui estão alguns dos principais museus em Paris: Museu do Louvre, Musée d'Orsay e Centre Pompidou."
O que é?
- Como ferramenta, RAG é um sistema integrado que automatiza o processo de recuperação e geração, facilitando os desenvolvedores a implementar funcionalidades complexas de IA sem precisar criar manualmente prompts para cada consulta.
Como funciona:
- Integração: Incorporar o RAG na arquitetura do agente de IA, permitindo que ele automaticamente faça a recuperação e geração das respostas.
- Automação: A ferramenta gerencia o processo todo, desde receber a entrada do usuário até gerar a resposta final, sem exigir prompts explícitos em cada etapa.
- Eficiência: Melhora o desempenho do agente ao simplificar o processo de recuperação e geração, permitindo respostas mais rápidas e precisas.
Exemplo em Agente de Viagens:
- Entrada do Usuário: "Quero visitar museus em Paris."
- Ferramenta RAG: Recupera automaticamente informações sobre museus e gera uma resposta.
- Resposta Gerada: "Aqui estão alguns dos principais museus em Paris: Museu do Louvre, Musée d'Orsay e Centre Pompidou."
| Aspecto | Técnica de Prompting | Ferramenta |
|---|---|---|
| Manual vs Automático | Formulação manual de prompts para cada consulta. | Processo automatizado para recuperação e geração. |
| Controle | Oferece mais controle sobre o processo de recuperação. | Simplifica e automatiza a recuperação e geração. |
| Flexibilidade | Permite prompts personalizados conforme necessidades. | Mais eficiente para implementações em larga escala. |
| Complexidade | Requer criação e ajuste dos prompts. | Mais fácil de integrar na arquitetura do agente IA. |
Exemplo de Técnica de Prompting:
def search_museums_in_paris():
prompt = "Find top museums in Paris"
search_results = search_web(prompt)
return search_results
museums = search_museums_in_paris()
print("Top Museums in Paris:", museums)Exemplo de Ferramenta:
class Travel_Agent:
def __init__(self):
self.rag_tool = RAGTool()
def get_museums_in_paris(self):
user_input = "I want to visit museums in Paris."
response = self.rag_tool.retrieve_and_generate(user_input)
return response
travel_agent = Travel_Agent()
museums = travel_agent.get_museums_in_paris()
print("Top Museums in Paris:", museums)Avaliar a relevância é um aspecto crucial do desempenho de agentes de IA. Isso garante que as informações recuperadas e geradas pelo agente sejam apropriadas, precisas e úteis para o usuário. Vamos explorar como avaliar a relevância em agentes de IA, incluindo exemplos práticos e técnicas.
-
Consciência de Contexto:
- O agente deve entender o contexto da consulta do usuário para recuperar e gerar informações relevantes.
- Exemplo: Se um usuário pede "melhores restaurantes em Paris," o agente deve considerar as preferências do usuário, como tipo de cozinha e orçamento.
-
Precisão:
- As informações fornecidas pelo agente devem ser factualmente corretas e atualizadas.
- Exemplo: Recomendar restaurantes atualmente abertos com boas avaliações em vez de opções desatualizadas ou fechadas.
-
Intenção do Usuário:
- O agente deve inferir a intenção do usuário por trás da consulta para proporcionar a informação mais relevante.
- Exemplo: Se um usuário pede "hotéis econômicos," o agente deve priorizar opções acessíveis.
-
Ciclo de Feedback:
- Coletar e analisar continuamente o feedback do usuário ajuda o agente a refinar seu processo de avaliação de relevância.
- Exemplo: Incorporar avaliações e feedbacks em recomendações anteriores para melhorar as respostas futuras.
-
Pontuação de Relevância:
-
Atribuir uma pontuação de relevância para cada item recuperado com base em quão bem ele corresponde à consulta e preferências do usuário.
-
Exemplo:
def relevance_score(item, query): score = 0 if item['category'] in query['interests']: score += 1 if item['price'] <= query['budget']: score += 1 if item['location'] == query['destination']: score += 1 return score
-
-
Filtragem e Classificação:
-
Filtrar itens irrelevantes e classificar os restantes com base nas pontuações de relevância.
-
Exemplo:
def filter_and_rank(items, query): ranked_items = sorted(items, key=lambda item: relevance_score(item, query), reverse=True) return ranked_items[:10] # Retorna os 10 itens mais relevantes
-
-
Processamento de Linguagem Natural (PLN):
-
Usar técnicas de PLN para entender a consulta do usuário e recuperar informações relevantes.
-
Exemplo:
def process_query(query): # Use PNL para extrair informações chave da consulta do usuário processed_query = nlp(query) return processed_query
-
-
Integração de Feedback do Usuário:
-
Coletar feedback do usuário sobre as recomendações fornecidas e usar isso para ajustar avaliações futuras de relevância.
-
Exemplo:
def adjust_based_on_feedback(feedback, items): for item in items: if item['name'] in feedback['liked']: item['relevance'] += 1 if item['name'] in feedback['disliked']: item['relevance'] -= 1 return items
-
Aqui está um exemplo prático de como o Agente de Viagens pode avaliar a relevância das recomendações de viagem:
class Travel_Agent:
def __init__(self):
self.user_preferences = {}
self.experience_data = []
def gather_preferences(self, preferences):
self.user_preferences = preferences
def retrieve_information(self):
flights = search_flights(self.user_preferences)
hotels = search_hotels(self.user_preferences)
attractions = search_attractions(self.user_preferences)
return flights, hotels, attractions
def generate_recommendations(self):
flights, hotels, attractions = self.retrieve_information()
ranked_hotels = self.filter_and_rank(hotels, self.user_preferences)
itinerary = create_itinerary(flights, ranked_hotels, attractions)
return itinerary
def filter_and_rank(self, items, query):
ranked_items = sorted(items, key=lambda item: self.relevance_score(item, query), reverse=True)
return ranked_items[:10] # Retornar os 10 itens mais relevantes
def relevance_score(self, item, query):
score = 0
if item['category'] in query['interests']:
score += 1
if item['price'] <= query['budget']:
score += 1
if item['location'] == query['destination']:
score += 1
return score
def adjust_based_on_feedback(self, feedback, items):
for item in items:
if item['name'] in feedback['liked']:
item['relevance'] += 1
if item['name'] in feedback['disliked']:
item['relevance'] -= 1
return items
# Exemplo de uso
travel_agent = Travel_Agent()
preferences = {
"destination": "Paris",
"dates": "2025-04-01 to 2025-04-10",
"budget": "moderate",
"interests": ["museums", "cuisine"]
}
travel_agent.gather_preferences(preferences)
itinerary = travel_agent.generate_recommendations()
print("Suggested Itinerary:", itinerary)
feedback = {"liked": ["Louvre Museum"], "disliked": ["Eiffel Tower (too crowded)"]}
updated_items = travel_agent.adjust_based_on_feedback(feedback, itinerary['hotels'])
print("Updated Itinerary with Feedback:", updated_items)Buscar com intenção envolve entender e interpretar o propósito ou objetivo subjacente por trás da consulta do usuário para recuperar e gerar as informações mais relevantes e úteis. Essa abordagem vai além de simplesmente combinar palavras-chave e foca em compreender as reais necessidades e contexto do usuário.
-
Entendendo a Intenção do Usuário:
- A intenção do usuário pode ser categorizada em três tipos principais: informacional, navegacional e transacional.
- Intenção Informacional: O usuário busca informações sobre um tópico (ex: "Quais são os melhores museus em Paris?").
- Intenção Navegacional: O usuário quer navegar para um site ou página específica (ex: "site oficial do Museu do Louvre").
- Intenção Transacional: O usuário deseja realizar uma transação, como reservar um voo ou fazer uma compra (ex: "Reserve um voo para Paris").
- A intenção do usuário pode ser categorizada em três tipos principais: informacional, navegacional e transacional.
-
Consciência de Contexto:
- Analisar o contexto da consulta do usuário ajuda a identificar corretamente sua intenção. Isso inclui considerar interações anteriores, preferências do usuário e detalhes específicos da consulta atual.
-
Processamento de Linguagem Natural (PLN):
- Técnicas de PLN são usadas para entender e interpretar as consultas em linguagem natural fornecidas pelos usuários. Isso inclui tarefas como reconhecimento de entidades, análise de sentimento e parsing da consulta.
-
Personalização:
- Personalizar os resultados da busca com base no histórico do usuário, preferências e feedback aumenta a relevância das informações recuperadas.
Vamos usar o Agente de Viagens como exemplo para ver como buscar com intenção pode ser implementado.
-
Coletando Preferências do Usuário
class Travel_Agent: def __init__(self): self.user_preferences = {} def gather_preferences(self, preferences): self.user_preferences = preferences
-
Entendendo a Intenção do Usuário
def identify_intent(query): if "book" in query or "purchase" in query: return "transactional" elif "website" in query or "official" in query: return "navigational" else: return "informational"
-
Consciência de Contexto
def analyze_context(query, user_history): # Combine a consulta atual com o histórico do usuário para entender o contexto context = { "current_query": query, "user_history": user_history } return context
-
Pesquisar e Personalizar Resultados
def search_with_intent(query, preferences, user_history): intent = identify_intent(query) context = analyze_context(query, user_history) if intent == "informational": search_results = search_information(query, preferences) elif intent == "navigational": search_results = search_navigation(query) elif intent == "transactional": search_results = search_transaction(query, preferences) personalized_results = personalize_results(search_results, user_history) return personalized_results def search_information(query, preferences): # Exemplo de lógica de busca para intenção informacional results = search_web(f"best {preferences['interests']} in {preferences['destination']}") return results def search_navigation(query): # Exemplo de lógica de busca para intenção de navegação results = search_web(query) return results def search_transaction(query, preferences): # Exemplo de lógica de busca para intenção transacional results = search_web(f"book {query} to {preferences['destination']}") return results def personalize_results(results, user_history): # Exemplo de lógica de personalização personalized = [result for result in results if result not in user_history] return personalized[:10] # Retornar os 10 melhores resultados personalizados
-
Exemplo de Uso
travel_agent = Travel_Agent() preferences = { "destination": "Paris", "interests": ["museums", "cuisine"] } travel_agent.gather_preferences(preferences) user_history = ["Louvre Museum website", "Book flight to Paris"] query = "best museums in Paris" results = search_with_intent(query, preferences, user_history) print("Search Results:", results)
Agentes geradores de código usam modelos de IA para escrever e executar código, resolvendo problemas complexos e automatizando tarefas.
Agentes geradores de código utilizam modelos generativos de IA para escrever e executar código. Esses agentes podem resolver problemas complexos, automatizar tarefas e fornecer insights valiosos gerando e executando código em várias linguagens de programação.
- Geração Automática de Código: Gerar trechos de código para tarefas específicas, como análise de dados, web scraping ou aprendizado de máquina.
- SQL como um RAG: Usar consultas SQL para recuperar e manipular dados de bancos de dados.
- Resolução de Problemas: Criar e executar código para solucionar problemas específicos, como otimizar algoritmos ou analisar dados.
Imagine que você está projetando um agente gerador de código. Veja como ele poderia funcionar:
- Tarefa: Analisar um conjunto de dados para identificar tendências e padrões.
- Passos:
- Carregar o conjunto de dados em uma ferramenta de análise de dados.
- Gerar consultas SQL para filtrar e agregar os dados.
- Executar as consultas e recuperar os resultados.
- Usar os resultados para gerar visualizações e insights.
- Recursos Necessários: Acesso ao conjunto de dados, ferramentas de análise de dados e capacidades em SQL.
- Experiência: Usar resultados de análises anteriores para melhorar a precisão e relevância das análises futuras.
Neste exemplo, criaremos um agente gerador de código, Agente de Viagens, para ajudar os usuários a planejar suas viagens gerando e executando código. Este agente pode realizar tarefas como buscar opções de viagem, filtrar resultados e compilar um itinerário usando IA generativa.
- Coleta de Preferências do Usuário: Coleta informações do usuário como destino, datas de viagem, orçamento e interesses.
- Gerar Código para Obter Dados: Gera trechos de código para recuperar dados sobre voos, hotéis e atrações.
- Executar Código Gerado: Executa o código gerado para obter informações em tempo real.
- Gerar Itinerário: Compila os dados obtidos em um plano de viagem personalizado.
- Ajustar com Base no Feedback: Recebe o feedback do usuário e regenera o código quando necessário para refinar os resultados.
-
Coleta de Preferências do Usuário
class Travel_Agent: def __init__(self): self.user_preferences = {} def gather_preferences(self, preferences): self.user_preferences = preferences
-
Gerar Código para Obter Dados
def generate_code_to_fetch_data(preferences): # Exemplo: Gerar código para buscar voos com base nas preferências do usuário code = f""" def search_flights(): import requests response = requests.get('https://api.example.com/flights', params={preferences}) return response.json() """ return code def generate_code_to_fetch_hotels(preferences): # Exemplo: Gerar código para buscar hotéis code = f""" def search_hotels(): import requests response = requests.get('https://api.example.com/hotels', params={preferences}) return response.json() """ return code
-
Executar Código Gerado
def execute_code(code): # Execute o código gerado usando exec exec(code) result = locals() return result travel_agent = Travel_Agent() preferences = { "destination": "Paris", "dates": "2025-04-01 to 2025-04-10", "budget": "moderate", "interests": ["museums", "cuisine"] } travel_agent.gather_preferences(preferences) flight_code = generate_code_to_fetch_data(preferences) hotel_code = generate_code_to_fetch_hotels(preferences) flights = execute_code(flight_code) hotels = execute_code(hotel_code) print("Flight Options:", flights) print("Hotel Options:", hotels)
-
Gerar Itinerário
def generate_itinerary(flights, hotels, attractions): itinerary = { "flights": flights, "hotels": hotels, "attractions": attractions } return itinerary attractions = search_attractions(preferences) itinerary = generate_itinerary(flights, hotels, attractions) print("Suggested Itinerary:", itinerary)
-
Ajustar com Base no Feedback
def adjust_based_on_feedback(feedback, preferences): # Ajustar preferências com base no feedback do usuário if "liked" in feedback: preferences["favorites"] = feedback["liked"] if "disliked" in feedback: preferences["avoid"] = feedback["disliked"] return preferences feedback = {"liked": ["Louvre Museum"], "disliked": ["Eiffel Tower (too crowded)"]} updated_preferences = adjust_based_on_feedback(feedback, preferences) # Regenerar e executar código com preferências atualizadas updated_flight_code = generate_code_to_fetch_data(updated_preferences) updated_hotel_code = generate_code_to_fetch_hotels(updated_preferences) updated_flights = execute_code(updated_flight_code) updated_hotels = execute_code(updated_hotel_code) updated_itinerary = generate_itinerary(updated_flights, updated_hotels, attractions) print("Updated Itinerary:", updated_itinerary)
Com base no esquema da tabela pode, de fato, melhorar o processo de geração de consultas aproveitando a consciência ambiental e o raciocínio.
Aqui está um exemplo de como isso pode ser feito:
- Compreender o Esquema: O sistema entenderá o esquema da tabela e usará essa informação para fundamentar a geração da consulta.
- Ajustar com Base no Feedback: O sistema ajustará as preferências do usuário com base no feedback e raciocinará sobre quais campos do esquema precisam ser atualizados.
- Gerar e Executar Consultas: O sistema gerará e executará consultas para buscar dados atualizados de voos e hotéis com base nas novas preferências.
Aqui está um exemplo atualizado de código Python que incorpora esses conceitos:
def adjust_based_on_feedback(feedback, preferences, schema):
# Ajustar preferências com base no feedback do usuário
if "liked" in feedback:
preferences["favorites"] = feedback["liked"]
if "disliked" in feedback:
preferences["avoid"] = feedback["disliked"]
# Raciocínio baseado no esquema para ajustar outras preferências relacionadas
for field in schema:
if field in preferences:
preferences[field] = adjust_based_on_environment(feedback, field, schema)
return preferences
def adjust_based_on_environment(feedback, field, schema):
# Lógica personalizada para ajustar preferências com base no esquema e feedback
if field in feedback["liked"]:
return schema[field]["positive_adjustment"]
elif field in feedback["disliked"]:
return schema[field]["negative_adjustment"]
return schema[field]["default"]
def generate_code_to_fetch_data(preferences):
# Gerar código para buscar dados de voos com base nas preferências atualizadas
return f"fetch_flights(preferences={preferences})"
def generate_code_to_fetch_hotels(preferences):
# Gerar código para buscar dados de hotéis com base nas preferências atualizadas
return f"fetch_hotels(preferences={preferences})"
def execute_code(code):
# Simular a execução do código e retornar dados simulados
return {"data": f"Executed: {code}"}
def generate_itinerary(flights, hotels, attractions):
# Gerar itinerário com base em voos, hotéis e atrações
return {"flights": flights, "hotels": hotels, "attractions": attractions}
# Exemplo de esquema
schema = {
"favorites": {"positive_adjustment": "increase", "negative_adjustment": "decrease", "default": "neutral"},
"avoid": {"positive_adjustment": "decrease", "negative_adjustment": "increase", "default": "neutral"}
}
# Exemplo de uso
preferences = {"favorites": "sightseeing", "avoid": "crowded places"}
feedback = {"liked": ["Louvre Museum"], "disliked": ["Eiffel Tower (too crowded)"]}
updated_preferences = adjust_based_on_feedback(feedback, preferences, schema)
# Regenerar e executar código com preferências atualizadas
updated_flight_code = generate_code_to_fetch_data(updated_preferences)
updated_hotel_code = generate_code_to_fetch_hotels(updated_preferences)
updated_flights = execute_code(updated_flight_code)
updated_hotels = execute_code(updated_hotel_code)
updated_itinerary = generate_itinerary(updated_flights, updated_hotels, feedback["liked"])
print("Updated Itinerary:", updated_itinerary)- Consciência do Esquema: O dicionário
schemadefine como as preferências devem ser ajustadas com base no feedback. Inclui campos comofavoriteseavoid, com ajustes correspondentes. - Ajuste de Preferências (método
adjust_based_on_feedback): Este método ajusta as preferências baseando-se no feedback do usuário e no esquema. - Ajustes Baseados no Ambiente (método
adjust_based_on_environment): Este método personaliza os ajustes com base no esquema e feedback. - Gerar e Executar Consultas: O sistema gera código para buscar dados atualizados de voos e hotéis baseando-se nas preferências ajustadas e simula a execução dessas consultas.
- Gerar Itinerário: O sistema cria um itinerário atualizado com base nos novos dados de voos, hotéis e atrações.
Ao tornar o sistema consciente do ambiente e raciocinar com base no esquema, ele pode gerar consultas mais precisas e relevantes, levando a recomendações de viagem melhores e uma experiência de usuário mais personalizada.
SQL (Structured Query Language) é uma ferramenta poderosa para interagir com bancos de dados. Quando usada como parte de uma abordagem de Geração Aumentada por Recuperação (RAG), SQL pode recuperar dados relevantes de bancos para informar e gerar respostas ou ações em agentes de IA. Vamos explorar como SQL pode ser usada como técnica RAG no contexto do Agente de Viagens.
-
Interação com Banco de Dados:
- SQL é usada para consultar bancos de dados, recuperar informações relevantes e manipular dados.
- Exemplo: Buscar detalhes de voos, informações de hotéis e atrações de um banco de dados de viagens.
-
Integração com RAG:
- Consultas SQL são geradas com base nas entradas e preferências do usuário.
- Os dados recuperados são então usados para gerar recomendações ou ações personalizadas.
-
Geração Dinâmica de Consultas:
- O agente de IA gera consultas SQL dinâmicas baseadas no contexto e necessidades do usuário.
- Exemplo: Customizar consultas SQL para filtrar resultados baseando-se no orçamento, datas e interesses.
- Geração Automática de Código: Gerar trechos de código para tarefas específicas.
- SQL como RAG: Usar consultas SQL para manipular dados.
- Resolução de Problemas: Criar e executar código para resolver problemas.
Exemplo: Um agente de análise de dados:
- Tarefa: Analisar um conjunto de dados para encontrar tendências.
- Passos:
- Carregar o conjunto de dados.
- Gerar consultas SQL para filtrar dados.
- Executar consultas e recuperar resultados.
- Gerar visualizações e insights.
- Recursos: Acesso ao conjunto de dados, capacidades em SQL.
- Experiência: Usar resultados anteriores para melhorar análises futuras.
-
Colhendo Preferências do Usuário
class Travel_Agent: def __init__(self): self.user_preferences = {} def gather_preferences(self, preferences): self.user_preferences = preferences
-
Gerando Consultas SQL
def generate_sql_query(table, preferences): query = f"SELECT * FROM {table} WHERE " conditions = [] for key, value in preferences.items(): conditions.append(f"{key}='{value}'") query += " AND ".join(conditions) return query
-
Executando Consultas SQL
import sqlite3 def execute_sql_query(query, database="travel.db"): connection = sqlite3.connect(database) cursor = connection.cursor() cursor.execute(query) results = cursor.fetchall() connection.close() return results
-
Gerando Recomendações
def generate_recommendations(preferences): flight_query = generate_sql_query("flights", preferences) hotel_query = generate_sql_query("hotels", preferences) attraction_query = generate_sql_query("attractions", preferences) flights = execute_sql_query(flight_query) hotels = execute_sql_query(hotel_query) attractions = execute_sql_query(attraction_query) itinerary = { "flights": flights, "hotels": hotels, "attractions": attractions } return itinerary travel_agent = Travel_Agent() preferences = { "destination": "Paris", "dates": "2025-04-01 to 2025-04-10", "budget": "moderate", "interests": ["museums", "cuisine"] } travel_agent.gather_preferences(preferences) itinerary = generate_recommendations(preferences) print("Suggested Itinerary:", itinerary)
-
Consulta de Voo
SELECT * FROM flights WHERE destination='Paris' AND dates='2025-04-01 to 2025-04-10' AND budget='moderate';
-
Consulta de Hotel
SELECT * FROM hotels WHERE destination='Paris' AND budget='moderate';
-
Consulta de Atração
SELECT * FROM attractions WHERE destination='Paris' AND interests='museums, cuisine';
Ao aproveitar SQL como parte da técnica de Geração Aumentada por Recuperação (RAG), agentes de IA como o Agente de Viagens podem recuperar e utilizar dados relevantes dinamicamente para fornecer recomendações precisas e personalizadas.
Para demonstrar uma implementação de metacognição, vamos criar um agente simples que reflete sobre seu processo de tomada de decisão enquanto resolve um problema. Para este exemplo, construiremos um sistema onde um agente tenta otimizar a escolha de um hotel, mas depois avalia seu próprio raciocínio e ajusta sua estratégia quando comete erros ou faz escolhas subótimas.
Vamos simular isso usando um exemplo básico onde o agente seleciona hotéis baseado em uma combinação de preço e qualidade, mas ele "reflete" sobre suas decisões e ajusta conforme necessário.
- Decisão Inicial: O agente escolherá o hotel mais barato, sem entender o impacto da qualidade.
- Reflexão e Avaliação: Após a escolha inicial, o agente verificará se o hotel foi uma escolha "ruim" usando o feedback do usuário. Se achar que a qualidade do hotel foi muito baixa, ele refletirá sobre seu raciocínio.
- Ajustando a Estratégia: O agente ajusta sua estratégia com base na reflexão, mudando de "mais barato" para "maior_qualidade", melhorando assim seu processo de tomada de decisão em iterações futuras.
Aqui está um exemplo:
class HotelRecommendationAgent:
def __init__(self):
self.previous_choices = [] # Armazena os hotéis escolhidos anteriormente
self.corrected_choices = [] # Armazena as escolhas corrigidas
self.recommendation_strategies = ['cheapest', 'highest_quality'] # Estratégias disponíveis
def recommend_hotel(self, hotels, strategy):
"""
Recommend a hotel based on the chosen strategy.
The strategy can either be 'cheapest' or 'highest_quality'.
"""
if strategy == 'cheapest':
recommended = min(hotels, key=lambda x: x['price'])
elif strategy == 'highest_quality':
recommended = max(hotels, key=lambda x: x['quality'])
else:
recommended = None
self.previous_choices.append((strategy, recommended))
return recommended
def reflect_on_choice(self):
"""
Reflect on the last choice made and decide if the agent should adjust its strategy.
The agent considers if the previous choice led to a poor outcome.
"""
if not self.previous_choices:
return "No choices made yet."
last_choice_strategy, last_choice = self.previous_choices[-1]
# Vamos supor que temos algum feedback do usuário que nos diz se a última escolha foi boa ou não
user_feedback = self.get_user_feedback(last_choice)
if user_feedback == "bad":
# Ajusta a estratégia se a escolha anterior foi insatisfatória
new_strategy = 'highest_quality' if last_choice_strategy == 'cheapest' else 'cheapest'
self.corrected_choices.append((new_strategy, last_choice))
return f"Reflecting on choice. Adjusting strategy to {new_strategy}."
else:
return "The choice was good. No need to adjust."
def get_user_feedback(self, hotel):
"""
Simulate user feedback based on hotel attributes.
For simplicity, assume if the hotel is too cheap, the feedback is "bad".
If the hotel has quality less than 7, feedback is "bad".
"""
if hotel['price'] < 100 or hotel['quality'] < 7:
return "bad"
return "good"
# Simula uma lista de hotéis (preço e qualidade)
hotels = [
{'name': 'Budget Inn', 'price': 80, 'quality': 6},
{'name': 'Comfort Suites', 'price': 120, 'quality': 8},
{'name': 'Luxury Stay', 'price': 200, 'quality': 9}
]
# Cria um agente
agent = HotelRecommendationAgent()
# Passo 1: O agente recomenda um hotel usando a estratégia "mais barato"
recommended_hotel = agent.recommend_hotel(hotels, 'cheapest')
print(f"Recommended hotel (cheapest): {recommended_hotel['name']}")
# Passo 2: O agente reflete sobre a escolha e ajusta a estratégia se necessário
reflection_result = agent.reflect_on_choice()
print(reflection_result)
# Passo 3: O agente recomenda novamente, desta vez usando a estratégia ajustada
adjusted_recommendation = agent.recommend_hotel(hotels, 'highest_quality')
print(f"Adjusted hotel recommendation (highest_quality): {adjusted_recommendation['name']}")O ponto chave aqui é a habilidade do agente de:
- Avaliar suas escolhas anteriores e o processo de tomada de decisão.
- Ajustar sua estratégia com base nessa reflexão, ou seja, metacognição em ação.
Esta é uma forma simples de metacognição, onde o sistema é capaz de ajustar seu processo de raciocínio com base em feedback interno.
A metacognição é uma ferramenta poderosa que pode aprimorar significativamente as capacidades dos agentes de IA. Incorporando processos metacognitivos, você pode projetar agentes mais inteligentes, adaptáveis e eficientes. Use os recursos adicionais para explorar ainda mais o fascinante mundo da metacognição em agentes de IA.
Junte-se ao Microsoft Foundry Discord para encontrar outros aprendizes, participar de horas de atendimento e tirar suas dúvidas sobre Agentes de IA.
Aviso Legal: Este documento foi traduzido utilizando o serviço de tradução automática Co-op Translator. Embora nos esforcemos para garantir a precisão, esteja ciente de que traduções automáticas podem conter erros ou imprecisões. O documento original em seu idioma nativo deve ser considerado a fonte autoritativa. Para informações críticas, recomenda-se a tradução profissional humana. Não nos responsabilizamos por quaisquer mal-entendidos ou interpretações incorretas decorrentes do uso desta tradução.

