Skip to content

PatBQc/ProjetElis

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

31 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

ProjetElis

Projet pour le Défi Expo-Sciences de @BelangerVincent et Attis.

Pour plus d'informations, suivez le http://toutou-elis.com/

Pour le moment, vous pouvez consulter notre documentation papier scané en PDF en attendant une meilleure documentation ici ;)

Pour installer

git clone https://github.com/PatBQc/ProjetElis
cd ProjetElis
pip install openai
pip install playsound==1.2.2
pip install SpeechRecognition
sudo apt install python3-gst-1.0
sudo apt-get install portaudio19-dev python3-pyaudio
pip install PyAudio
sudo apt-get install flac

mkdir experiments

sudo apt-get install pulseaudio pavucontrol
pavucontrol

python start.py

Résumé du code source

Description générale

Ce code est un script Python qui permet d'avoir une conversation interactive avec un agent conversationnel nommé "Elis". L'agent est basé sur le modèle de langage GPT-4 d'OpenAI et est configuré pour répondre de manière appropriée et engageante à un enfant de 5 ans.

Fonctionnalités principales

  1. Reconnaissance vocale: Le script utilise la bibliothèque speech_recognition pour écouter l'entrée vocale de l'utilisateur via le microphone. L'audio est enregistré et transcrit en texte.

  2. Synthèse vocale: Les réponses générées par l'agent conversationnel sont converties en audio en utilisant l'API de synthèse vocale d'OpenAI. Les fichiers audio sont enregistrés et lus à l'aide de la bibliothèque playsound.

  3. Interaction avec GPT-4: Le script utilise l'API d'OpenAI pour envoyer les messages de l'utilisateur au modèle GPT-4 et recevoir les réponses générées. Les messages sont structurés sous forme de "prompts" avec des rôles tels que "system", "assistant" et "user".

  4. Personnalisation de l'agent: L'agent conversationnel est personnalisé avec des instructions spécifiques, telles que son nom, sa forme, son public cible et les consignes sur le style et le contenu de ses réponses.

  5. Gestion des conversations: Le script gère le flux de conversation en alternant entre les entrées de l'utilisateur et les réponses de l'agent. Les messages sont stockés dans une liste de "prompts" pour maintenir le contexte de la conversation.

Structure du code

  • Les bibliothèques nécessaires sont importées au début du script.
  • La classe bcolors est définie pour permettre la coloration du texte dans le terminal.
  • La fonction principale main() est définie comme une fonction asynchrone.
  • La fonction listen_and_transcribe() est responsable de l'écoute du microphone et de la transcription de l'audio en texte.
  • La boucle principale de conversation se trouve dans la fonction main(), où les messages sont échangés entre l'utilisateur et l'agent jusqu'à ce que l'utilisateur décide de quitter.
  • Les réponses de l'agent sont divisées en phrases et lues de manière asynchrone pour améliorer l'expérience utilisateur.
  • Les entrées de l'utilisateur sont obtenues soit via le clavier, soit via la reconnaissance vocale.
  • Les messages sont envoyés à l'API d'OpenAI pour générer les réponses de l'agent.
  • Le script s'exécute en appelant la fonction main() à l'aide de asyncio.run().

Ce script démontre l'utilisation de diverses bibliothèques Python et de l'API d'OpenAI pour créer un agent conversationnel interactif capable de communiquer par voix avec un enfant de 5 ans.

Librairies utilisées

  • os: pour la gestion des fichiers et répertoires
  • openai: pour l'utilisation de l'API d'OpenAI
  • playsound: pour jouer des fichiers audio
  • datetime: pour la gestion des dates et heures
  • speech_recognition: pour la reconnaissance vocale
  • re: pour les expressions régulières
  • asyncio: pour la programmation asynchrone

Classe bcolors

Cette classe permet de changer les couleurs du texte dans le terminal.

Fonction main()

C'est la fonction principale du programme, elle est asynchrone.

Initialisation

  • Connexion à l'API d'OpenAI avec une clé secrète
  • Création d'un répertoire pour stocker les fichiers de l'expérience

Fonction listen_and_transcribe()

Cette fonction permet d'écouter le micro et de transcrire la parole en texte jusqu'à ce que le mot clé "STOP" soit prononcé.

Boucle principale

  • Initialisation de la liste des messages échangés (prompts)
  • Définition de la personnalité d'Elis dans les messages système
  • Boucle de discussion jusqu'à ce que l'utilisateur dise "quit"
    • Affichage de la réponse d'Elis
    • Découpage de la réponse en phrases
    • Synthèse vocale de chaque phrase avec l'API d'OpenAI
    • Écoute de la question de l'enfant (via le micro ou le clavier)
    • Ajout de la question à la liste des messages
    • Envoi de tous les messages à l'API d'OpenAI pour obtenir la réponse suivante
    • Stockage de la réponse dans la variable answer pour la prochaine itération

Lancement du programme

La dernière ligne de code lance la fonction main() de manière asynchrone.

Un diagramme pour s'y retrouver

Simplement...

De manière très simple, l'algorithme général ressemble à ceci:

graph TD
A[Importer les librairies nécessaires] --> B[Définir la fonction main asynchrone]
B --> C[Configurer le client OpenAI et créer un dossier d'expérience]
C --> D[Définir la fonction listen_and_transcribe pour écouter et transcrire la voix]
D --> E[Initialiser les prompts système et la première réponse d'Elis]
E --> F[Boucle principale de conversation]
F --> G[Afficher la réponse d'Elis et l'ajouter aux prompts]
G --> H[Transformer la réponse en audio et la lire phrase par phrase]
H --> I[Écouter et transcrire la réponse de l'enfant]
I --> J[Vérifier si l'enfant veut continuer la conversation]
J -- Oui --> F
J -- Non --> K[Fin du programme]

...et de manière plus complète

Ce diagramme résume le flux du code, en commençant par l'importation des librairies nécessaires, puis en définissant la fonction principale main() et la fonction listen_and_transcribe(). La boucle principale alterne entre l'affichage de la réponse d'Elis, la conversion en audio, la lecture de l'audio, l'écoute de la question de l'enfant, et l'envoi des messages à ChatGPT pour obtenir une réponse. Le processus se répète jusqu'à ce que l'enfant dise "quit".

graph TD
A[Importer les librairies nécessaires] --> B[Définir la classe bcolors pour les couleurs du texte]
B --> C[Définir la fonction principale asynchrone main]
C --> D[Configurer le client OpenAI avec la clé API]
D --> E[Créer un dossier d'expérience avec la date et l'heure actuelles]
E --> F[Définir la fonction listen_and_transcribe pour écouter et transcrire l'audio]
F --> G[Initialiser la liste des prompts et ajouter les instructions système]
G --> H[Initialiser la variable answer avec un message de bienvenue]
H --> I[Entrer dans la boucle principale tant que shouldContinue est vrai]
I --> J[Afficher la réponse d'Elis et l'ajouter à la liste des prompts]
J --> K[Séparer la réponse en phrases et initialiser l'index de partie de réponse]
K --> L[Entrer dans la boucle pour chaque partie de réponse]
L --> M[Convertir la partie de réponse en audio avec OpenAI]
M --> N[Enregistrer l'audio dans un fichier]
N --> O[Attendre que la lecture de la partie précédente soit terminée]
O --> P[Lire la nouvelle partie audio]
P --> Q[Incrémenter l'index de partie de réponse]
Q --> L
L --> R[Attendre que la dernière partie soit lue]
R --> S[Écouter la question de l'enfant avec listen_and_transcribe]
S --> T[Afficher la question de l'enfant et l'ajouter à la liste des prompts]
T --> U{Vérifier si la question est quit}
U -->|Oui| V[Mettre fin à la boucle principale]
U -->|Non| W[Préparer les messages pour ChatGPT avec les instructions système et les prompts]
W --> X[Envoyer les messages à ChatGPT et récupérer la réponse]
X --> Y[Mettre à jour la variable answer avec la réponse de ChatGPT]
Y --> I
V --> Z[Exécuter la fonction principale main avec asyncio.run]

About

Projet pour le ExpoScience de Vincent

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages