(Clicca sull’immagine sopra per vedere il video di questa lezione)
Metacognizione negli Agenti IA
Benvenuti alla lezione sulla metacognizione negli agenti IA! Questo capitolo è pensato per principianti curiosi di capire come gli agenti IA possano riflettere sui propri processi di pensiero. Alla fine di questa lezione, comprenderai i concetti chiave e sarai dotato di esempi pratici per applicare la metacognizione nella progettazione di agenti IA.
Dopo aver completato questa lezione, sarai in grado di:
La metacognizione si riferisce ai processi cognitivi di ordine superiore che implicano il riflettere sul proprio pensiero. Per gli agenti IA, questo significa essere in grado di valutare e aggiustare le proprie azioni basandosi sulla consapevolezza di sé e sulle esperienze passate. La metacognizione, o “pensare al pensiero,” è un concetto importante nello sviluppo di sistemi IA agentici. Coinvolge la capacità dei sistemi IA di essere consapevoli dei propri processi interni e di monitorare, regolare e adattare di conseguenza il proprio comportamento. Proprio come facciamo noi quando capiamo il contesto o analizziamo un problema. Questa autoconsapevolezza può aiutare i sistemi IA a prendere decisioni migliori, identificare errori e migliorare le prestazioni nel tempo — ancora una volta collegandosi al test di Turing e al dibattito sul fatto che l’IA prenderà o meno il controllo.
Nel contesto dei sistemi IA agentici, la metacognizione può aiutare ad affrontare diverse sfide, come:
La metacognizione, o “pensare al pensiero,” è un processo cognitivo di ordine superiore che implica autoconsapevolezza e autoregolazione dei propri processi cognitivi. Nell’ambito dell’IA, la metacognizione consente agli agenti di valutare e adattare le proprie strategie e azioni, portando a capacità migliorate di risoluzione di problemi e presa di decisioni. Comprendendo la metacognizione, puoi progettare agenti IA che non solo sono più intelligenti ma anche più adattabili ed efficienti. In una vera metacognizione, l’IA ragionerebbe esplicitamente sul proprio ragionamento.
Esempio: “Ho scelto voli più economici perché… potrei perdermi i voli diretti, quindi ricontrollo.” Tenere traccia di come o perché ha scelto una certa rotta.
La metacognizione svolge un ruolo cruciale nella progettazione degli agenti IA per diverse ragioni:

Prima di addentrarci nei processi metacognitivi, è essenziale capire le componenti di base di un agente IA. Un agente IA tipicamente consiste in:
Questi componenti lavorano insieme per creare un’“unità di competenza” che può svolgere compiti specifici.
Esempio: Considera un agente di viaggio, un servizio agente che non solo organizza la tua vacanza ma adatta il proprio percorso basandosi su dati in tempo reale e sulle esperienze di viaggio passate dei clienti.
Immagina di progettare un servizio agente di viaggio alimentato da IA. Questo agente, “Agente di Viaggio,” aiuta gli utenti nel pianificare le loro vacanze. Per incorporare la metacognizione, l’Agente di Viaggio deve valutare e regolare le proprie azioni basandosi sull’autoconsapevolezza e sulle esperienze passate. Ecco come la metacognizione potrebbe entrare in gioco:
Il compito attuale è aiutare un utente a pianificare un viaggio a Parigi.
L’Agente di Viaggio utilizza la metacognizione per valutare le proprie prestazioni e apprendere dalle esperienze passate. Per esempio:
Ecco un esempio semplificato di come potrebbe apparire il codice di Agente di Viaggio integrando la metacognizione:
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):
# Cerca voli, hotel e attrazioni basati sulle preferenze
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)
# Analizza i feedback e adatta le raccomandazioni future
self.user_preferences = adjust_preferences(self.user_preferences, feedback)
# Esempio di utilizzo
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)
Incorporando la metacognizione, l’Agente di Viaggio può fornire raccomandazioni più personalizzate e precise, migliorando l’esperienza complessiva dell’utente.
La pianificazione è un componente cruciale del comportamento degli agenti IA. Consiste nel delineare i passaggi necessari per raggiungere un obiettivo, considerando lo stato attuale, le risorse e i possibili ostacoli.
Esempio: Ecco i passi che l’Agente di Viaggio deve compiere per assistere efficacemente un utente nella pianificazione del viaggio:
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)
# Esempio di utilizzo all'interno di una richiesta di prenotazione
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)
Iniziamo comprendendo la differenza tra RAG Tool e Caricamento Pre-emptive del Contesto.

RAG combina un sistema di recupero con un modello generativo. Quando viene fatta una richiesta, il sistema di recupero estrae documenti o dati rilevanti da una fonte esterna, e queste informazioni recuperate sono usate per arricchire l’input al modello generativo. Questo aiuta il modello a generare risposte più accurate e contestualmente rilevanti.
In un sistema RAG, l’agente recupera informazioni pertinenti da una base di conoscenza e le usa per generare risposte o azioni appropriate.
L’approccio RAG Correttivo mira a usare tecniche RAG per correggere errori e migliorare l’accuratezza degli agenti IA. Ciò implica:
Considera un agente di ricerca che estrae informazioni dal web per rispondere a query degli utenti. L’approccio RAG Correttivo potrebbe includere:
RAG Correttivo (Retrieval-Augmented Generation) migliora la capacità dell’IA di recuperare e generare informazioni correggendo eventuali inesattezze. Vediamo come l’Agente di Viaggio può usare l’approccio RAG Correttivo per fornire raccomandazioni di viaggio più accurate e pertinenti.
Questo involve:
Esempio:
preferences = {
"destination": "Paris",
"dates": "2025-04-01 to 2025-04-10",
"budget": "moderate",
"interests": ["museums", "cuisine"]
}
Esempio:
flights = search_flights(preferences)
hotels = search_hotels(preferences)
attractions = search_attractions(preferences)
Esempio:
itinerary = create_itinerary(flights, hotels, attractions)
print("Suggested Itinerary:", itinerary)
Esempio:
feedback = {
"liked": ["Louvre Museum"],
"disliked": ["Eiffel Tower (too crowded)"]
}
Esempio:
if "disliked" in feedback:
preferences["avoid"] = feedback["disliked"]
Esempio:
new_attractions = search_attractions(preferences)
new_itinerary = create_itinerary(flights, hotels, new_attractions)
print("Updated Itinerary:", new_itinerary)
Esempio:
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)
Ecco un esempio semplificato in Python che incorpora l’approccio RAG Correttivo in Agente di Viaggio:
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
# Esempio di utilizzo
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)
Il caricamento preventivo del contesto consiste nel caricare nel modello il contesto rilevante o le informazioni di base prima di elaborare una query. Ciò significa che il modello ha accesso a queste informazioni fin dall’inizio, il che può aiutarlo a generare risposte più informate senza dover recuperare dati aggiuntivi durante il processo.
Ecco un esempio semplificato di come potrebbe apparire un caricamento preventivo del contesto per un’applicazione di agente di viaggio in Python:
class TravelAgent:
def __init__(self):
# Pre-carica destinazioni popolari e le loro informazioni
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):
# Recupera informazioni sulla destinazione dal contesto pre-caricato
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}."
# Esempio di utilizzo
travel_agent = TravelAgent()
print(travel_agent.get_destination_info("Paris"))
print(travel_agent.get_destination_info("Tokyo"))
Inizializzazione (metodo __init__): La classe TravelAgent pre-carica un dizionario contenente informazioni su destinazioni popolari come Parigi, Tokyo, New York e Sydney. Questo dizionario include dettagli come il paese, la valuta, la lingua e le principali attrazioni per ogni destinazione.
Recupero Informazioni (metodo get_destination_info): Quando un utente richiede informazioni su una destinazione specifica, il metodo get_destination_info recupera le informazioni rilevanti dal dizionario del contesto pre-caricato.
Pre-caricando il contesto, l’applicazione dell’agente di viaggio può rispondere rapidamente alle domande degli utenti senza dover recuperare queste informazioni da una fonte esterna in tempo reale. Questo rende l’applicazione più efficiente e reattiva.
Avviare un piano con un obiettivo significa iniziare con un obiettivo chiaro o un risultato target in mente. Definendo questo obiettivo sin dall’inizio, il modello può usarlo come principio guida durante tutto il processo iterativo. Questo aiuta a garantire che ogni iterazione si avvicini al raggiungimento del risultato desiderato, rendendo il processo più efficiente e focalizzato.
Ecco un esempio di come potresti avviare un piano di viaggio con un obiettivo prima di iterare per un agente di viaggio in Python:
Un agente di viaggio vuole pianificare una vacanza personalizzata per un cliente. L’obiettivo è creare un itinerario che massimizzi la soddisfazione del cliente in base alle sue preferenze e al budget.
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']
# Esempio di utilizzo
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)
Inizializzazione (metodo __init__): La classe TravelAgent è inizializzata con una lista di possibili destinazioni, ciascuna con attributi come nome, costo e tipo di attività.
Avvio del Piano (metodo bootstrap_plan): Questo metodo crea un piano di viaggio iniziale basato sulle preferenze e sul budget del cliente. Itera attraverso la lista delle destinazioni e le aggiunge al piano se corrispondono alle preferenze del cliente e rientrano nel budget.
Corrispondenza delle Preferenze (metodo match_preferences): Questo metodo verifica se una destinazione corrisponde alle preferenze del cliente.
Iterazione del Piano (metodo iterate_plan): Questo metodo affina il piano iniziale cercando di sostituire ogni destinazione nel piano con una corrispondenza migliore, tenendo conto delle preferenze del cliente e delle limitazioni di budget.
Calcolo del Costo (metodo calculate_cost): Questo metodo calcola il costo totale del piano attuale, includendo una potenziale nuova destinazione.
Avviando il piano con un obiettivo chiaro (ad esempio, massimizzare la soddisfazione del cliente) e iterando per affinare il piano, l’agente di viaggio può creare un itinerario personalizzato e ottimizzato per il cliente. Questo approccio garantisce che il piano di viaggio sia allineato fin dall’inizio con le preferenze e il budget del cliente e migliori ad ogni iterazione.
I Modelli Linguistici di Grandi Dimensioni (LLM) possono essere utilizzati per il riordino e la valutazione assegnando un punteggio alla pertinenza e qualità dei documenti recuperati o delle risposte generate. Ecco come funziona:
Recupero: Il passaggio iniziale recupera un set di documenti o risposte candidate in base alla query.
Riordinamento: L’LLM valuta queste candidate e le riordina basandosi sulla pertinenza e qualità. Questo passaggio assicura che le informazioni più rilevanti e di alta qualità siano presentate per prime.
Valutazione: L’LLM assegna punteggi a ciascuna candidata, riflettendo la loro pertinenza e qualità. Questo aiuta a selezionare la migliore risposta o documento per l’utente.
Sfruttando gli LLM per il riordino e la valutazione, il sistema può fornire informazioni più accurate e contestualmente rilevanti, migliorando l’esperienza complessiva dell’utente.
Ecco un esempio di come un agente di viaggio potrebbe usare un Modello Linguistico di Grandi Dimensioni (LLM) per riordinare e valutare destinazioni di viaggio basandosi sulle preferenze dell’utente in Python:
Un agente di viaggio vuole raccomandare le migliori destinazioni di viaggio a un cliente in base alle sue preferenze. L’LLM aiuterà a riordinare e valutare le destinazioni per assicurare che le opzioni più rilevanti siano presentate.
Ecco come aggiornare il precedente esempio per usare i Servizi Azure OpenAI:
import requests
import json
class TravelAgent:
def __init__(self, destinations):
self.destinations = destinations
def get_recommendations(self, preferences, api_key, endpoint):
# Genera un prompt per Azure OpenAI
prompt = self.generate_prompt(preferences)
# Definisci header e payload per la richiesta
headers = {
'Content-Type': 'application/json',
'Authorization': f'Bearer {api_key}'
}
payload = {
"prompt": prompt,
"max_tokens": 150,
"temperature": 0.7
}
# Chiama l'API Azure OpenAI per ottenere le destinazioni ririordinate e valutate
response = requests.post(endpoint, headers=headers, json=payload)
response_data = response.json()
# Estrai e restituisci le raccomandazioni
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
# Esempio di utilizzo
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)
Inizializzazione: La classe TravelAgent è inizializzata con una lista di potenziali destinazioni di viaggio, ognuna con attributi come nome e descrizione.
Ottenere Raccomandazioni (metodo get_recommendations): Questo metodo genera un prompt per il servizio Azure OpenAI basato sulle preferenze dell’utente e fa una richiesta HTTP POST all’API Azure OpenAI per ottenere destinazioni riordinate e valutate.
Generazione Prompt (metodo generate_prompt): Questo metodo costruisce un prompt per Azure OpenAI, includendo le preferenze dell’utente e la lista delle destinazioni. Il prompt guida il modello a riordinare e valutare le destinazioni in base alle preferenze fornite.
Chiamata API: La libreria requests viene usata per effettuare una richiesta HTTP POST all’endpoint dell’API Azure OpenAI. La risposta contiene le destinazioni riordinate e valutate.
Esempio di Utilizzo: L’agente di viaggio raccoglie le preferenze dell’utente (ad esempio interesse per visite turistiche e cultura diversificata) e usa il servizio Azure OpenAI per ottenere raccomandazioni riordinate e valutate per destinazioni di viaggio.
Assicurati di sostituire your_azure_openai_api_key con la tua chiave API Azure OpenAI reale e https://your-endpoint.com/... con l’URL effettivo dell’endpoint della tua distribuzione Azure OpenAI.
Sfruttando l’LLM per il riordino e la valutazione, l’agente di viaggio può fornire raccomandazioni di viaggio più personalizzate e rilevanti ai clienti, migliorando la loro esperienza complessiva.
Retrieval-Augmented Generation (RAG) può essere sia una tecnica di prompting sia uno strumento nello sviluppo di agenti AI. Comprendere la distinzione tra i due può aiutarti a sfruttare RAG più efficacemente nei tuoi progetti.
Cos’è?
Come funziona:
Esempio in Agente di Viaggio:
Cos’è?
Come funziona:
Esempio in Agente di Viaggio:
| Aspetto | Tecnica di Prompting | Strumento |
|---|---|---|
| Manuale vs Automatico | Formulazione manuale dei prompt per ogni query. | Processo automatico per recupero e generazione. |
| Controllo | Offre maggiore controllo sul processo di recupero. | Razionalizza e automatizza recupero e generazione. |
| Flessibilità | Permette prompt personalizzati basati su esigenze specifiche. | Più efficiente per implementazioni su larga scala. |
| Complessità | Richiede la creazione e l’ottimizzazione di prompt. | Più facile da integrare nell’architettura di un agente AI. |
Esempio Tecnica di 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)
Esempio Strumento:
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)
La valutazione della rilevanza è un aspetto cruciale nelle prestazioni di un agente AI. Assicura che le informazioni recuperate e generate siano appropriate, accurate e utili per l’utente. Esploriamo come valutare la rilevanza negli agenti AI, includendo esempi pratici e tecniche.
Esempio:
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
Esempio:
def filter_and_rank(items, query):
ranked_items = sorted(items, key=lambda item: relevance_score(item, query), reverse=True)
return ranked_items[:10] # Restituisci i primi 10 elementi rilevanti
Esempio:
def process_query(query):
# Usa l'NLP per estrarre informazioni chiave dalla query dell'utente
processed_query = nlp(query)
return processed_query
Esempio:
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
Ecco un esempio pratico di come Travel Agent possa valutare la rilevanza delle raccomandazioni di viaggio:
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] # Restituisce i primi 10 elementi rilevanti
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
# Esempio di utilizzo
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)
La ricerca con intento comporta la comprensione e l’interpretazione dello scopo o obiettivo sottostante dietro la query di un utente per recuperare e generare le informazioni più pertinenti e utili. Questo approccio va oltre il semplice abbinamento di parole chiave e si concentra sul cogliere i reali bisogni e il contesto dell’utente.
Prendiamo Travel Agent come esempio per vedere come implementare la ricerca con intento.
Raccolta delle Preferenze Utente
class Travel_Agent:
def __init__(self):
self.user_preferences = {}
def gather_preferences(self, preferences):
self.user_preferences = preferences
Comprensione dell’Intento Utente
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"
def analyze_context(query, user_history):
# Combina la query attuale con la cronologia dell'utente per comprendere il contesto
context = {
"current_query": query,
"user_history": user_history
}
return context
Cerca e Personalizza i Risultati
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):
# Esempio di logica di ricerca per intento informativo
results = search_web(f"best {preferences['interests']} in {preferences['destination']}")
return results
def search_navigation(query):
# Esempio di logica di ricerca per intento navigazionale
results = search_web(query)
return results
def search_transaction(query, preferences):
# Esempio di logica di ricerca per intento transazionale
results = search_web(f"book {query} to {preferences['destination']}")
return results
def personalize_results(results, user_history):
# Esempio di logica di personalizzazione
personalized = [result for result in results if result not in user_history]
return personalized[:10] # Restituisce i primi 10 risultati personalizzati
Esempio di Utilizzo
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)
Gli agenti generativi di codice utilizzano modelli di intelligenza artificiale per scrivere ed eseguire codice, risolvendo problemi complessi e automatizzando compiti.
Gli agenti generativi di codice usano modelli di IA generativa per scrivere ed eseguire codice. Questi agenti possono risolvere problemi complessi, automatizzare compiti e fornire approfondimenti preziosi generando ed eseguendo codice in vari linguaggi di programmazione.
Immagina di progettare un agente generativo di codice. Ecco come potrebbe funzionare:
In questo esempio, progettiamo un agente generativo di codice, Travel Agent, per assistere gli utenti nella pianificazione dei viaggi generando ed eseguendo codice. Questo agente può gestire compiti come recuperare opzioni di viaggio, filtrare risultati e compilare un itinerario usando IA generativa.
Raccolta Preferenze Utente
class Travel_Agent:
def __init__(self):
self.user_preferences = {}
def gather_preferences(self, preferences):
self.user_preferences = preferences
Generazione di Codice per Recupero Dati
def generate_code_to_fetch_data(preferences):
# Esempio: Genera codice per cercare voli in base alle preferenze dell'utente
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):
# Esempio: Genera codice per cercare hotel
code = f"""
def search_hotels():
import requests
response = requests.get('https://api.example.com/hotels', params={preferences})
return response.json()
"""
return code
Esecuzione del Codice Generato
def execute_code(code):
# Esegui il codice generato 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)
Generazione dell’Itinerario
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)
Adattamento Basato sul Feedback
def adjust_based_on_feedback(feedback, preferences):
# Regola le preferenze in base al feedback dell'utente
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)
# Rigenera ed esegui il codice con le preferenze aggiornate
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)
Basarsi sullo schema della tabella può effettivamente migliorare il processo di generazione delle query sfruttando la consapevolezza ambientale e il ragionamento.
Ecco un esempio di come questo può essere fatto:
Ecco un esempio aggiornato di codice Python che incorpora questi concetti:
def adjust_based_on_feedback(feedback, preferences, schema):
# Regola le preferenze in base al feedback dell'utente
if "liked" in feedback:
preferences["favorites"] = feedback["liked"]
if "disliked" in feedback:
preferences["avoid"] = feedback["disliked"]
# Ragionamento basato sullo schema per regolare altre preferenze correlate
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):
# Logica personalizzata per regolare le preferenze basata su schema 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):
# Genera codice per recuperare i dati dei voli basati sulle preferenze aggiornate
return f"fetch_flights(preferences={preferences})"
def generate_code_to_fetch_hotels(preferences):
# Genera codice per recuperare i dati degli hotel basati sulle preferenze aggiornate
return f"fetch_hotels(preferences={preferences})"
def execute_code(code):
# Simula l'esecuzione del codice e restituisce dati mock
return {"data": f"Executed: {code}"}
def generate_itinerary(flights, hotels, attractions):
# Genera un itinerario basato su voli, hotel e attrazioni
return {"flights": flights, "hotels": hotels, "attractions": attractions}
# Esempio di schema
schema = {
"favorites": {"positive_adjustment": "increase", "negative_adjustment": "decrease", "default": "neutral"},
"avoid": {"positive_adjustment": "decrease", "negative_adjustment": "increase", "default": "neutral"}
}
# Esempio di utilizzo
preferences = {"favorites": "sightseeing", "avoid": "crowded places"}
feedback = {"liked": ["Louvre Museum"], "disliked": ["Eiffel Tower (too crowded)"]}
updated_preferences = adjust_based_on_feedback(feedback, preferences, schema)
# Rigenera ed esegui il codice con le preferenze aggiornate
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)
schema definisce come le preferenze devono essere adattate in base al feedback. Include campi come favorites e avoid, con corrispondenti aggiustamenti.adjust_based_on_feedback): Questo metodo adatta le preferenze basandosi sul feedback dell’utente e sullo schema.adjust_based_on_environment): Questo metodo personalizza gli aggiustamenti in base allo schema e al feedback.Rendendo il sistema consapevole dell’ambiente e capace di ragionare sullo schema, è possibile generare query più precise e rilevanti, portando a raccomandazioni di viaggio migliori e a un’esperienza utente più personalizzata.
SQL (Structured Query Language) è uno strumento potente per interagire con i database. Quando usato come parte di un approccio Retrieval-Augmented Generation (RAG), SQL può recuperare dati rilevanti dai database per informare e generare risposte o azioni in agenti AI. Vediamo come SQL può essere utilizzato come tecnica RAG nel contesto di Travel Agent.
Esempio: Un agente di analisi dati:
Raccolta Preferenze Utente
class Travel_Agent:
def __init__(self):
self.user_preferences = {}
def gather_preferences(self, preferences):
self.user_preferences = preferences
Generazione di Query 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
Esecuzione di Query 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
Generazione di Raccomandazioni
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)
Query per Volo
SELECT * FROM flights WHERE destination='Paris' AND dates='2025-04-01 to 2025-04-10' AND budget='moderate';
Query per Hotel
SELECT * FROM hotels WHERE destination='Paris' AND budget='moderate';
Query per Attrazione
SELECT * FROM attractions WHERE destination='Paris' AND interests='museums, cuisine';
Sfruttando SQL come parte della tecnica Retrieval-Augmented Generation (RAG), agenti AI come Travel Agent possono recuperare dinamicamente e utilizzare dati pertinenti per fornire raccomandazioni accurate e personalizzate.
Per dimostrare un’implementazione della metacognizione, creiamo un agente semplice che riflette sul proprio processo decisionale mentre risolve un problema. In questo esempio, costruiremo un sistema in cui un agente cerca di ottimizzare la scelta di un hotel, ma poi valuta il proprio ragionamento e aggiusta la strategia quando compie errori o scelte subottimali.
Simuleremo questo usando un esempio base in cui l’agente seleziona gli hotel basandosi su una combinazione di prezzo e qualità, ma “riflette” sulle sue decisioni e si adatta di conseguenza.
Ecco un esempio:
class HotelRecommendationAgent:
def __init__(self):
self.previous_choices = [] # Memorizza gli hotel scelti in precedenza
self.corrected_choices = [] # Memorizza le scelte corrette
self.recommendation_strategies = ['cheapest', 'highest_quality'] # Strategie disponibili
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]
# Supponiamo di avere un feedback dell'utente che ci dice se l'ultima scelta è stata buona o no
user_feedback = self.get_user_feedback(last_choice)
if user_feedback == "bad":
# Adatta la strategia se la scelta precedente è stata insoddisfacente
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 una lista di hotel (prezzo e qualità)
hotels = [
{'name': 'Budget Inn', 'price': 80, 'quality': 6},
{'name': 'Comfort Suites', 'price': 120, 'quality': 8},
{'name': 'Luxury Stay', 'price': 200, 'quality': 9}
]
# Crea un agente
agent = HotelRecommendationAgent()
# Passo 1: L'agente consiglia un hotel usando la strategia "più economico"
recommended_hotel = agent.recommend_hotel(hotels, 'cheapest')
print(f"Recommended hotel (cheapest): {recommended_hotel['name']}")
# Passo 2: L'agente riflette sulla scelta e adatta la strategia se necessario
reflection_result = agent.reflect_on_choice()
print(reflection_result)
# Passo 3: L'agente consiglia di nuovo, questa volta usando la strategia adattata
adjusted_recommendation = agent.recommend_hotel(hotels, 'highest_quality')
print(f"Adjusted hotel recommendation (highest_quality): {adjusted_recommendation['name']}")
La chiave è la capacità dell’agente di:
Questa è una forma semplice di metacognizione dove il sistema è capace di modificare il proprio processo di ragionamento basandosi sul feedback interno.
La metacognizione è uno strumento potente che può migliorare significativamente le capacità degli agenti IA. Incorporando processi metacognitivi, puoi progettare agenti più intelligenti, adattabili ed efficienti. Usa le risorse aggiuntive per esplorare ulteriormente il mondo affascinante della metacognizione negli agenti IA.
Unisciti al Microsoft Foundry Discord per incontrare altri studenti, partecipare alle office hours e ottenere risposte alle tue domande sugli AI Agents.
Dichiarazione di non responsabilità:
Questo documento è stato tradotto utilizzando il servizio di traduzione automatica Co-op Translator. Pur puntando all’accuratezza, si prega di tenere presente che le traduzioni automatiche possono contenere errori o inesattezze. Il documento originale nella lingua madre deve essere considerato la fonte autorevole. Per informazioni critiche, si consiglia una traduzione professionale effettuata da un essere umano. Non ci assumiamo responsabilità per eventuali malintesi o interpretazioni errate derivanti dall’utilizzo di questa traduzione.