(Klik op de afbeelding hierboven om de video van deze les te bekijken)
Metacognitie in AI Agents
Welkom bij de les over metacognitie in AI-agents! Dit hoofdstuk is bedoeld voor beginners die benieuwd zijn naar hoe AI-agents kunnen nadenken over hun eigen denkprocessen. Aan het einde van deze les begrijp je belangrijke concepten en heb je praktische voorbeelden om metacognitie toe te passen in het ontwerp van AI-agents.
Na het voltooien van deze les kun je:
Metacognitie verwijst naar hogere-orde cognitieve processen waarbij men nadenkt over het eigen denken. Voor AI-agents betekent dit in staat zijn hun acties te evalueren en aan te passen op basis van zelfbewustzijn en eerdere ervaringen. Metacognitie, of “nadenken over nadenken,” is een belangrijk concept bij de ontwikkeling van agentische AI-systemen. Het houdt in dat AI-systemen zich bewust zijn van hun eigen interne processen en in staat zijn om hun gedrag te monitoren, reguleren en aan te passen. Net zoals wij doen wanneer we de sfeer peilen of naar een probleem kijken. Dit zelfbewustzijn kan AI-systemen helpen betere beslissingen te nemen, fouten te identificeren en hun prestaties in de loop van de tijd te verbeteren — weer terugkoppeling met de Turing-test en het debat of AI de macht gaat overnemen.
In de context van agentische AI-systemen kan metacognitie verschillende uitdagingen helpen aanpakken, zoals:
Metacognitie, of “nadenken over nadenken,” is een hogere-orde cognitief proces dat zelfbewustzijn en zelfregulatie van iemands cognitieve processen omvat. In de wereld van AI stelt metacognitie agents in staat hun strategieën en acties te evalueren en aan te passen, wat leidt tot verbeterde probleemoplossing en besluitvormingsvaardigheden. Door metacognitie te begrijpen, kun je AI-agents ontwerpen die niet alleen intelligenter, maar ook adaptiever en efficiënter zijn. In echte metacognitie zou je zien dat de AI expliciet redeneert over zijn eigen redeneringen.
Voorbeeld: “Ik gaf prioriteit aan goedkopere vluchten omdat… misschien mis ik directe vluchten, dus laat ik het opnieuw controleren.”. Bijhouden hoe of waarom het een bepaalde route koos.
Metacognitie speelt een cruciale rol in het ontwerp van AI-agents om verschillende redenen:

Voordat we ons verdiepen in metacognitieve processen, is het essentieel om de basiscomponenten van een AI-agent te begrijpen. Een AI-agent bestaat doorgaans uit:
Deze componenten werken samen om een “expertiseenheid” te vormen die specifieke taken kan uitvoeren.
Voorbeeld: Denk aan een reisagent, agentdiensten die niet alleen je vakantie plannen maar ook hun route aanpassen op basis van realtime data en eerdere klantreizen.
Stel je voor dat je een reisagentservice ontwerpt die wordt aangedreven door AI. Deze agent, “Reisagent,” helpt gebruikers bij het plannen van hun vakanties. Om metacognitie te integreren, moet de Reisagent zijn acties evalueren en aanpassen op basis van zelfbewustzijn en eerdere ervaringen. Hier is hoe metacognitie een rol kan spelen:
De huidige taak is een gebruiker helpen een reis naar Parijs te plannen.
Reisagent gebruikt metacognitie om zijn prestaties te evalueren en te leren van eerdere ervaringen. Bijvoorbeeld:
Hier is een vereenvoudigd voorbeeld van hoe de code van Reisagent eruit kan zien wanneer metacognitie wordt geïntegreerd:
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):
# Zoek naar vluchten, hotels en attracties op basis van voorkeuren
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)
# Analyseer feedback en pas toekomstige aanbevelingen aan
self.user_preferences = adjust_preferences(self.user_preferences, feedback)
# Voorbeeldgebruik
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)
Door metacognitie te integreren kan Reisagent meer gepersonaliseerde en nauwkeurige reisaanbevelingen geven, wat de algehele gebruikerservaring verbetert.
Planning is een cruciaal onderdeel van het gedrag van AI-agents. Het houdt in dat je de stappen uitstippelt die nodig zijn om een doel te bereiken, rekening houdend met de huidige staat, hulpbronnen en mogelijke obstakels.
Voorbeeld: Hier zijn de stappen die Reisagent moet nemen om een gebruiker effectief te helpen met het plannen van hun reis:
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)
# Voorbeeld gebruik binnen een boekerverzoek
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)
Laten we eerst het verschil begrijpen tussen de RAG Tool en Pre-emptive Context Load

RAG combineert een retrieval-systeem met een generatief model. Wanneer er een query wordt gedaan, haalt het retrieval-systeem relevante documenten of data op uit een externe bron, en deze opgehaalde informatie wordt gebruikt om de input voor het generatieve model te versterken. Dit helpt het model om meer accurate en contextueel relevante antwoorden te genereren.
In een RAG-systeem haalt de agent relevante informatie op uit een kennisbank en gebruikt deze om passende antwoorden of acties te genereren.
De correctieve RAG-aanpak richt zich op het gebruik van RAG-technieken om fouten te corrigeren en de nauwkeurigheid van AI-agents te verbeteren. Dit omvat:
Denk aan een zoekagent die informatie van het web haalt om gebruikersvragen te beantwoorden. De correctieve RAG-aanpak zou kunnen bestaan uit:
Correctieve RAG (Retrieval-Augmented Generation) verbetert het vermogen van AI om informatie op te halen en te genereren terwijl fouten worden gecorrigeerd. Laten we bekijken hoe Reisagent de Correctieve RAG-aanpak kan gebruiken om nauwkeurigere en relevantere reisaanbevelingen te doen.
Dit omvat:
Voorbeeld:
preferences = {
"destination": "Paris",
"dates": "2025-04-01 to 2025-04-10",
"budget": "moderate",
"interests": ["museums", "cuisine"]
}
Voorbeeld:
flights = search_flights(preferences)
hotels = search_hotels(preferences)
attractions = search_attractions(preferences)
Voorbeeld:
itinerary = create_itinerary(flights, hotels, attractions)
print("Suggested Itinerary:", itinerary)
Voorbeeld:
feedback = {
"liked": ["Louvre Museum"],
"disliked": ["Eiffel Tower (too crowded)"]
}
Voorbeeld:
if "disliked" in feedback:
preferences["avoid"] = feedback["disliked"]
Voorbeeld:
new_attractions = search_attractions(preferences)
new_itinerary = create_itinerary(flights, hotels, new_attractions)
print("Updated Itinerary:", new_itinerary)
Voorbeeld:
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)
Hier is een vereenvoudigd Python-codevoorbeeld dat de Correctieve RAG-aanpak integreert in Reisagent:
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
# Voorbeeld gebruik
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)
Pre-emptive Context Load houdt in dat relevante context of achtergrondinformatie in het model wordt geladen voordat een vraag wordt verwerkt. Dit betekent dat het model vanaf het begin toegang heeft tot deze informatie, wat kan helpen om beter geïnformeerde antwoorden te genereren zonder tijdens het proces extra gegevens te hoeven opzoeken.
Hier is een vereenvoudigd voorbeeld van hoe een pre-emptive context load eruit zou kunnen zien voor een reisagent-applicatie in Python:
class TravelAgent:
def __init__(self):
# Populaire bestemmingen en hun informatie vooraf laden
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):
# Haal bestemmingsinformatie op uit vooraf geladen context
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}."
# Voorbeeldgebruik
travel_agent = TravelAgent()
print(travel_agent.get_destination_info("Paris"))
print(travel_agent.get_destination_info("Tokyo"))
Initialisatie (__init__ methode): De TravelAgent klasse laadt vooraf een woordenboek met informatie over populaire bestemmingen zoals Parijs, Tokio, New York en Sydney. Dit woordenboek bevat details zoals het land, de valuta, taal en belangrijke attracties voor elke bestemming.
Informatie opvragen (get_destination_info methode): Wanneer een gebruiker een specifieke bestemming opvraagt, haalt de get_destination_info methode de relevante informatie op uit het vooraf geladen contextwoordenboek.
Door de context vooraf te laden, kan de reisagent-applicatie snel reageren op gebruikersvragen zonder deze informatie in real-time uit een externe bron te hoeven ophalen. Dit maakt de applicatie efficiënter en responsiever.
Het bootstrappen van een plan met een doel betekent dat je start met een duidelijk doel of beoogde uitkomst voor ogen. Door dit doel vooraf te definiëren, kan het model het als leidraad gebruiken tijdens het iteratieve proces. Dit helpt ervoor te zorgen dat elke iteratie dichter bij het gewenste resultaat komt, waardoor het proces efficiënter en gerichter wordt.
Hier is een voorbeeld van hoe je een reisplan zou kunnen bootstrappen met een doel voordat je gaat itereren voor een reisagent in Python:
Een reisagent wil een op maat gemaakte vakantie plannen voor een klant. Het doel is om een reisroute te creëren die de tevredenheid van de klant maximaliseert op basis van hun voorkeuren en 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']
# Voorbeeldgebruik
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)
Initialisatie (__init__ methode): De TravelAgent klasse wordt geïnitialiseerd met een lijst van potentiële bestemmingen, elk met attributen zoals naam, kosten en type activiteit.
Bootstrappen van het Plan (bootstrap_plan methode): Deze methode maakt een eerste reisplan op basis van de voorkeuren en het budget van de klant. Het iterereert door de lijst van bestemmingen en voegt ze toe aan het plan als ze overeenkomen met de voorkeuren van de klant en binnen het budget passen.
Voorkeuren Matchen (match_preferences methode): Deze methode controleert of een bestemming overeenkomt met de voorkeuren van de klant.
Plan Itereren (iterate_plan methode): Deze methode verfijnt het eerste plan door te proberen elke bestemming in het plan te vervangen door een betere match, rekening houdend met de voorkeuren en het budget van de klant.
Kosten Berekenen (calculate_cost methode): Deze methode berekent de totale kosten van het huidige plan, inclusief een potentiële nieuwe bestemming.
Door het plan te bootstrappen met een duidelijk doel (bijvoorbeeld het maximaliseren van klanttevredenheid) en te itereren om het plan te verfijnen, kan de reisagent een gepersonaliseerde en geoptimaliseerde reisroute voor de klant creëren. Deze aanpak zorgt ervoor dat het reisplan vanaf het begin aansluit bij de voorkeuren en het budget van de klant en verbetert met elke iteratie.
Grote taalmodellen (LLM’s) kunnen worden gebruikt voor re-ranking en scoring door de relevantie en kwaliteit van opgehaalde documenten of gegenereerde antwoorden te evalueren. Zo werkt het:
Ophalen: De initiële ophaalfase haalt een set kandidaat-documenten of antwoorden op basis van de vraag.
Re-ranking: Het LLM beoordeelt deze kandidaten en herschikt ze op basis van relevantie en kwaliteit. Deze stap zorgt ervoor dat de meest relevante en kwalitatieve informatie als eerste wordt getoond.
Scoring: Het LLM kent scores toe aan elke kandidaat, die hun relevantie en kwaliteit weerspiegelen. Dit helpt bij het selecteren van het beste antwoord of document voor de gebruiker.
Door LLM’s te benutten voor re-ranking en scoring kan het systeem nauwkeurigere en contextueel relevantere informatie bieden, wat de gebruikerservaring aanzienlijk verbetert.
Hier is een voorbeeld van hoe een reisagent een groot taalmodel zou kunnen gebruiken voor re-ranking en scoring van reisbestemmingen op basis van voorkeuren in Python:
Een reisagent wil de beste reisbestemmingen aan een klant aanbevelen op basis van hun voorkeuren. Het LLM helpt bij het herschikken en scoren van de bestemmingen om te zorgen dat de meest relevante opties worden getoond.
Hier volgt hoe je het vorige voorbeeld kunt aanpassen om Azure OpenAI Services te gebruiken:
import requests
import json
class TravelAgent:
def __init__(self, destinations):
self.destinations = destinations
def get_recommendations(self, preferences, api_key, endpoint):
# Genereer een prompt voor de Azure OpenAI
prompt = self.generate_prompt(preferences)
# Definieer headers en payload voor het verzoek
headers = {
'Content-Type': 'application/json',
'Authorization': f'Bearer {api_key}'
}
payload = {
"prompt": prompt,
"max_tokens": 150,
"temperature": 0.7
}
# Roep de Azure OpenAI API aan om de hergerangschikte en gescoorde bestemmingen te krijgen
response = requests.post(endpoint, headers=headers, json=payload)
response_data = response.json()
# Extraheer en retourneer de aanbevelingen
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
# Voorbeeld van gebruik
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)
Initialisatie: De TravelAgent klasse wordt geïnitialiseerd met een lijst van potentiële reisbestemmingen, elk met attributen zoals naam en beschrijving.
Aanbevelingen Ophalen (get_recommendations methode): Deze methode genereert een prompt voor de Azure OpenAI-service op basis van de voorkeuren van de gebruiker en maakt een HTTP POST-verzoek naar de Azure OpenAI API om herschikte en gescoorde bestemmingen te krijgen.
Prompt Genereren (generate_prompt methode): Deze methode stelt een prompt samen voor de Azure OpenAI, inclusief de voorkeuren van de gebruiker en de lijst met bestemmingen. De prompt stuurt het model om de bestemmingen te herschikken en te scoren op basis van de opgegeven voorkeuren.
API-aanroep: De requests bibliotheek wordt gebruikt om een HTTP POST-verzoek te doen naar de Azure OpenAI API endpoint. De respons bevat de herschikte en gescoorde bestemmingen.
Voorbeeldgebruik: De reisagent verzamelt gebruikersvoorkeuren (bijv. interesse in sightseeing en diverse cultuur) en gebruikt de Azure OpenAI-service om herschikte en gescoorde aanbevelingen voor reisbestemmingen te krijgen.
Zorg ervoor dat je your_azure_openai_api_key vervangt door je eigen Azure OpenAI API-sleutel en https://your-endpoint.com/... met de daadwerkelijke URL van je Azure OpenAI implementatie.
Door gebruik te maken van het LLM voor re-ranking en scoring kan de reisagent persoonlijkere en relevantere reisaanbevelingen aan klanten bieden en zo hun totale ervaring verbeteren.
Retrieval-Augmented Generation (RAG) kan zowel een prompting techniek als een tool zijn in de ontwikkeling van AI-agenten. Het begrijpen van het verschil tussen beiden kan je helpen om RAG effectiever te benutten in je projecten.
Wat is het?
Hoe het werkt:
Voorbeeld in Reisagent:
Wat is het?
Hoe het werkt:
Voorbeeld in Reisagent:
| Aspect | Prompting Techniek | Tool |
|---|---|---|
| Handmatig vs Automatisch | Handmatig formuleren van prompts voor elke query. | Geautomatiseerd proces voor ophalen en genereren. |
| Controle | Biedt meer controle over het ophalen. | Stroomlijnt en automatiseert het ophalen en genereren. |
| Flexibiliteit | Laat aangepaste prompts toe op basis van specifieke behoeften. | Efficiënter voor grootschalige implementaties. |
| Complexiteit | Vereist het opstellen en bijstellen van prompts. | Makkelijker te integreren binnen de architectuur van een AI-agent. |
Prompting Techniek Voorbeeld:
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)
Tool Voorbeeld:
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)
Het evalueren van relevantie is een cruciaal aspect van de prestatie van AI-agenten. Het zorgt ervoor dat de informatie die door de agent wordt opgehaald en gegenereerd passend, accuraat en nuttig is voor de gebruiker. Laten we bekijken hoe relevantie geëvalueerd kan worden bij AI-agenten, inclusief praktische voorbeelden en technieken.
Voorbeeld:
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
Voorbeeld:
def filter_and_rank(items, query):
ranked_items = sorted(items, key=lambda item: relevance_score(item, query), reverse=True)
return ranked_items[:10] # Geef de top 10 relevante items terug
Voorbeeld:
def process_query(query):
# Gebruik NLP om belangrijke informatie uit de query van de gebruiker te extraheren
processed_query = nlp(query)
return processed_query
Voorbeeld:
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
Hier is een praktisch voorbeeld van hoe Travel Agent de relevantie van reisaanbevelingen kan evalueren:
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] # Retourneer top 10 relevante items
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
# Voorbeeld gebruik
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)
Zoeken met intentie betekent dat je de achterliggende bedoeling of het doel van een gebruikersvraag begrijpt en interpreteert om de meest relevante en bruikbare informatie op te halen en te genereren. Deze benadering gaat verder dan alleen trefwoorden matchen en richt zich op het begrijpen van de daadwerkelijke behoefte en context van de gebruiker.
Laten we Travel Agent als voorbeeld nemen om te zien hoe zoeken met intentie geïmplementeerd kan worden.
Verzamelen van Gebruikersvoorkeuren
class Travel_Agent:
def __init__(self):
self.user_preferences = {}
def gather_preferences(self, preferences):
self.user_preferences = preferences
Begrip van Gebruikersintentie
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):
# Combineer huidige vraag met gebruikersgeschiedenis om de context te begrijpen
context = {
"current_query": query,
"user_history": user_history
}
return context
Zoeken en Resultaten Personaliseren
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):
# Voorbeeld zoeklogica voor informatieve intentie
results = search_web(f"best {preferences['interests']} in {preferences['destination']}")
return results
def search_navigation(query):
# Voorbeeld zoeklogica voor navigatie-intentie
results = search_web(query)
return results
def search_transaction(query, preferences):
# Voorbeeld zoeklogica voor transactionele intentie
results = search_web(f"book {query} to {preferences['destination']}")
return results
def personalize_results(results, user_history):
# Voorbeeld personalisatielogica
personalized = [result for result in results if result not in user_history]
return personalized[:10] # Geef de top 10 gepersonaliseerde resultaten terug
Voorbeeld van Gebruik
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)
Code-genererende agenten gebruiken AI-modellen om code te schrijven en uit te voeren, waarmee ze complexe problemen oplossen en taken automatiseren.
Code-genererende agenten gebruiken generatieve AI-modellen om code te schrijven en uit te voeren. Deze agenten kunnen complexe problemen oplossen, taken automatiseren en waardevolle inzichten bieden door code te genereren en uit te voeren in verschillende programmeertalen.
Stel je voor dat je een code-genererende agent ontwerpt. Zo zou het kunnen werken:
In dit voorbeeld ontwerpen we een code-genererende agent, Reisagent, die gebruikers helpt bij het plannen van reizen door code te genereren en uit te voeren. Deze agent kan taken afhandelen zoals het ophalen van reismogelijkheden, filteren van resultaten en het samenstellen van een reisplan met generatieve AI.
Verzamelen van Gebruikersvoorkeuren
class Travel_Agent:
def __init__(self):
self.user_preferences = {}
def gather_preferences(self, preferences):
self.user_preferences = preferences
Genereren van Code om Gegevens op te halen
def generate_code_to_fetch_data(preferences):
# Voorbeeld: Genereer code om te zoeken naar vluchten op basis van gebruikersvoorkeuren
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):
# Voorbeeld: Genereer code om te zoeken naar hotels
code = f"""
def search_hotels():
import requests
response = requests.get('https://api.example.com/hotels', params={preferences})
return response.json()
"""
return code
Uitvoeren van Gegeneerde Code
def execute_code(code):
# Voer de gegenereerde code uit met 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)
Genereren van Reisschema
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)
Aanpassen op Basis van Feedback
def adjust_based_on_feedback(feedback, preferences):
# Pas voorkeuren aan op basis van gebruikersfeedback
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)
# Genereer opnieuw en voer code uit met bijgewerkte voorkeuren
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)
Het gebruik van de tabelschema kan het proces van querygeneratie inderdaad verbeteren door omgevingsbewustzijn en redeneren toe te passen.
Hier is een voorbeeld van hoe dit gedaan kan worden:
Hier is een bijgewerkt Python-codevoorbeeld waarin deze concepten zijn verwerkt:
def adjust_based_on_feedback(feedback, preferences, schema):
# Pas voorkeuren aan op basis van gebruikersfeedback
if "liked" in feedback:
preferences["favorites"] = feedback["liked"]
if "disliked" in feedback:
preferences["avoid"] = feedback["disliked"]
# Redeneren op basis van schema om andere gerelateerde voorkeuren aan te passen
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):
# Aangepaste logica om voorkeuren aan te passen op basis van schema en 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):
# Genereer code om vluchtgegevens op te halen op basis van bijgewerkte voorkeuren
return f"fetch_flights(preferences={preferences})"
def generate_code_to_fetch_hotels(preferences):
# Genereer code om hotelgegevens op te halen op basis van bijgewerkte voorkeuren
return f"fetch_hotels(preferences={preferences})"
def execute_code(code):
# Simuleer uitvoering van code en retourneer voorbeeldgegevens
return {"data": f"Executed: {code}"}
def generate_itinerary(flights, hotels, attractions):
# Genereer reisplan op basis van vluchten, hotels en attracties
return {"flights": flights, "hotels": hotels, "attractions": attractions}
# Voorbeeldschema
schema = {
"favorites": {"positive_adjustment": "increase", "negative_adjustment": "decrease", "default": "neutral"},
"avoid": {"positive_adjustment": "decrease", "negative_adjustment": "increase", "default": "neutral"}
}
# Voorbeeldgebruik
preferences = {"favorites": "sightseeing", "avoid": "crowded places"}
feedback = {"liked": ["Louvre Museum"], "disliked": ["Eiffel Tower (too crowded)"]}
updated_preferences = adjust_based_on_feedback(feedback, preferences, schema)
# Genereer opnieuw en voer code uit met bijgewerkte voorkeuren
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 dictionary definieert hoe voorkeuren moeten worden aangepast op basis van feedback. Het omvat velden zoals favorites en avoid, met bijbehorende aanpassingen.adjust_based_on_feedback methode): Deze methode past voorkeuren aan op basis van gebruikersfeedback en het schema.adjust_based_on_environment methode): Deze methode personaliseert de aanpassingen op basis van het schema en feedback.Door het systeem omgevingsbewust te maken en te laten redeneren op basis van het schema, kan het nauwkeurigere en relevantere query’s genereren, wat leidt tot betere reisaanbevelingen en een meer gepersonaliseerde gebruikerservaring.
SQL (Structured Query Language) is een krachtig hulpmiddel voor interactie met databases. Wanneer het wordt gebruikt als onderdeel van een Retrieval-Augmented Generation (RAG)-benadering, kan SQL relevante data ophalen uit databases om AI-agenten te informeren en te laten reageren of handelen. Laten we onderzoeken hoe SQL als RAG-techniek gebruikt kan worden in de context van Reisagent.
Voorbeeld: Een data-analyse agent:
Verzamelen van Gebruikersvoorkeuren
class Travel_Agent:
def __init__(self):
self.user_preferences = {}
def gather_preferences(self, preferences):
self.user_preferences = preferences
Genereren van SQL-query’s
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
Uitvoeren van SQL-query’s
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
Genereren van Aanbevelingen
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)
Vluchtquery
SELECT * FROM flights WHERE destination='Paris' AND dates='2025-04-01 to 2025-04-10' AND budget='moderate';
Hotelquery
SELECT * FROM hotels WHERE destination='Paris' AND budget='moderate';
Attractiequery
SELECT * FROM attractions WHERE destination='Paris' AND interests='museums, cuisine';
Door SQL te gebruiken als onderdeel van de Retrieval-Augmented Generation (RAG) techniek kunnen AI-agenten zoals Reisagent dynamisch relevante data ophalen en gebruiken om nauwkeurige en gepersonaliseerde aanbevelingen te doen.
Om een implementatie van metacognitie te demonstreren, laten we een eenvoudige agent maken die reflecteert op zijn besluitvormingsproces terwijl hij een probleem oplost. In dit voorbeeld bouwen we een systeem waarbij een agent probeert de keuze van een hotel te optimaliseren, maar daarna zijn eigen redenering evalueert en zijn strategie aanpast wanneer hij fouten of suboptimale keuzes maakt.
We simuleren dit met een eenvoudig voorbeeld waarbij de agent hotels selecteert op basis van een combinatie van prijs en kwaliteit, maar “reflecteert” op zijn beslissingen en daaraan aanpast.
Hier is een voorbeeld:
class HotelRecommendationAgent:
def __init__(self):
self.previous_choices = [] # Slaat de eerder gekozen hotels op
self.corrected_choices = [] # Slaat de gecorrigeerde keuzes op
self.recommendation_strategies = ['cheapest', 'highest_quality'] # Beschikbare strategieën
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]
# Laten we aannemen dat we wat gebruikersfeedback hebben die ons vertelt of de laatste keuze goed was of niet
user_feedback = self.get_user_feedback(last_choice)
if user_feedback == "bad":
# Pas de strategie aan als de vorige keuze onbevredigend was
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"
# Simuleer een lijst van hotels (prijs en kwaliteit)
hotels = [
{'name': 'Budget Inn', 'price': 80, 'quality': 6},
{'name': 'Comfort Suites', 'price': 120, 'quality': 8},
{'name': 'Luxury Stay', 'price': 200, 'quality': 9}
]
# Maak een agent aan
agent = HotelRecommendationAgent()
# Stap 1: De agent raadt een hotel aan met de "goedkoopste" strategie
recommended_hotel = agent.recommend_hotel(hotels, 'cheapest')
print(f"Recommended hotel (cheapest): {recommended_hotel['name']}")
# Stap 2: De agent reflecteert op de keuze en past de strategie aan indien nodig
reflection_result = agent.reflect_on_choice()
print(reflection_result)
# Stap 3: De agent raadt opnieuw aan, dit keer met de aangepaste strategie
adjusted_recommendation = agent.recommend_hotel(hotels, 'highest_quality')
print(f"Adjusted hotel recommendation (highest_quality): {adjusted_recommendation['name']}")
Het belangrijkste hier is het vermogen van de agent om:
Dit is een eenvoudige vorm van metacognitie waarbij het systeem zijn redeneringsproces kan aanpassen op basis van interne feedback.
Metacognitie is een krachtig hulpmiddel dat de mogelijkheden van AI-agenten aanzienlijk kan verbeteren. Door metacognitieve processen te integreren, kun je agenten ontwerpen die intelligenter, aanpasbaarder en efficiënter zijn. Gebruik de aanvullende bronnen om de fascinerende wereld van metacognitie in AI-agenten verder te verkennen.
Word lid van de Microsoft Foundry Discord om andere leerlingen te ontmoeten, spreekuren bij te wonen en je AI-agenten vragen beantwoord te krijgen.
Disclaimer: Dit document is vertaald met behulp van de AI-vertalingsdienst Co-op Translator. Hoewel we streven naar nauwkeurigheid, dient u er rekening mee te houden dat geautomatiseerde vertalingen fouten of onnauwkeurigheden kunnen bevatten. Het originele document in de oorspronkelijke taal moet als de gezaghebbende bron worden beschouwd. Voor cruciale informatie wordt professionele menselijke vertaling aanbevolen. Wij zijn niet aansprakelijk voor enige misverstanden of verkeerde interpretaties die voortvloeien uit het gebruik van deze vertaling.