Maison >développement back-end >Tutoriel Python >Agents d'IA auto-correcteurs : comment créer une IA qui apprend de ses erreurs
Et si votre agent IA pouvait reconnaître ses propres erreurs, en tirer des leçons et réessayer, sans intervention humaine ? Bienvenue dans le monde des agents IA auto-correcteurs.
La plupart des modèles d'IA génèrent des résultats en une seule tentative. Mais les agents autocorrecteurs vont plus loin. Ils peuvent identifier le moment où une erreur se produit, analyser la cause et appliquer un correctif, le tout en temps réel. Considérez-le comme une IA avec un état d'esprit intégré « essais et erreurs ».
Dans ce blog, vous apprendrez :
À la fin, vous saurez comment concevoir des agents d'IA qui non seulement échouent gracieusement, mais qui s'améliorent également à chaque tentative.
Un agent autocorrectif est un système d'IA capable de reconnaître ses propres échecs et de tenter une nouvelle stratégie. Si l'approche initiale ne fonctionne pas, l'agent réévalue et essaie une voie alternative.
Analogie :
Imaginez demander à un chef de préparer un gâteau, mais il utilise trop de sucre la première fois. Une IA standard continuerait à commettre la même erreur. Mais une IA auto-correctrice remarquerait l'erreur, réduirait le sucre la prochaine fois et ajusterait jusqu'à ce que le gâteau ait un goût parfait.
La plupart des outils d'IA (comme ChatGPT) ne peuvent vous donner qu'une seule réponse. Si c'est faux, vous devez lui demander manuellement de "réessayer". Mais un agent autocorrecteur peut réessayer de manière autonome.
?️ Exemple de cas d'utilisation :
On demande à une IA d'écrire une fonction Python qui calcule les nombres de Fibonacci.
Tentative 1 : L'IA écrit une fonction récursive lente.
Auto-correction : Il remarque que la récursivité est trop lente.
Tentative 2 : L'IA réécrit la fonction à l'aide d'une programmation dynamique, la rendant plus rapide.
Comment rendre un agent suffisamment conscient de lui-même pour reconnaître ses erreurs ? Voici trois techniques principales :
? Conseil de pro :
Les journaux d'erreurs peuvent être réinjectés dans le modèle d'IA pour améliorer les performances futures.
Créons un agent IA auto-correctif à l'aide de Python et FastAPI.
Nous voulons un agent IA capable de générer une fonction Python. Si la fonction ne s'exécute pas ou produit un résultat incorrect, l'agent se corrigera automatiquement.
Problème : Écrivez une fonction de Fibonacci qui calcule le 10ème nombre de Fibonacci.
Défi : Si l'agent génère une version récursive (qui est lente), il doit le reconnaître et la réécrire en utilisant la programmation dynamique.
Installez les dépendances nécessaires :
pip install openai fastapi uvicorn
Voici comment fonctionne l'agent :
import openai import time import asyncio # ? Replace with your OpenAI API key openai.api_key = "your_openai_api_key_here" # ? Step 1: Ask the AI to generate a Fibonacci function async def generate_fibonacci_function(): prompt = "Write a Python function to calculate the 10th Fibonacci number." response = openai.ChatCompletion.create( model="gpt-4", messages=[{"role": "user", "content": prompt}] ) function_code = response['choices'][0]['message']['content'] return function_code # ? Step 2: Test the function to see if it works def test_fibonacci_function(function_code): try: exec(function_code) # Run the function in a safe execution environment result = eval("fibonacci(10)") # Call the function with n=10 if result == 55: # Correct Fibonacci value for n=10 return "success", result else: return "wrong_output", result except Exception as e: return "error", str(e) # ? Step 3: Self-Correct by asking for a new version of the function async def self_correct_function(): max_attempts = 3 for attempt in range(max_attempts): print(f"? Attempt {attempt + 1}") # Generate a new Fibonacci function function_code = await generate_fibonacci_function() print(f"Generated function:\n{function_code}\n") # Test the function to see if it works status, result = test_fibonacci_function(function_code) if status == "success": print(f"✅ Success! Fibonacci(10) = {result}") return elif status == "wrong_output": print(f"❌ Incorrect result: {result}. Asking AI to try a better method.") else: print(f"? Error: {result}. Asking AI to try again.") print("❌ Max attempts reached. Could not generate a correct function.") # ? Run the correction process asyncio.run(self_correct_function())
Exemple de sortie
pip install openai fastapi uvicorn
? Conseil de pro :
Utilisez une boucle de rétroaction pour permettre à l'agent d'apprendre de ses erreurs. Renvoyez les journaux à l'agent pour l'aider à reconnaître les problèmes courants.
Les agents autocorrectifs sont utiles dans les cas où les pannes sont fréquentes et où l'intervention manuelle est coûteuse.
Problem | Solution |
---|---|
Agent gets it wrong | Retry with a better approach |
API request fails | Retry with exponential backoff |
Code generation error | Use a smarter prompt |
Vous disposez maintenant du modèle d'un agent auto-correcteur capable d'écrire, de tester et de corriger les fonctions Python. Voici ce que nous avons couvert :
? Défi :
Créez un agent autocorrectif qui non seulement génère du code, mais évalue les performances d'exécution. Si la fonction est trop lente, demandez-lui de réécrire la fonction pour l'optimiser.
Vous voulez en savoir plus sur la création de LLM Responsive ? Consultez mon cours sur newline : Applications LLM réactives avec événements envoyés par le serveur
Je couvre :
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!