Générer des images avec un modèle DALL-E
Azure OpenAI Service comprend un modèle de génération d’images appelé DALL-E. Vous pouvez utiliser ce modèle pour envoyer des prompts en langage naturel qui décrivent une image que vous voulez, et le modèle génère une image originale basée sur la description que vous fournissez.
Dans cet exercice, vous allez utiliser un modèle DALL-E version 3 pour générer des images basées sur des prompts en langage naturel.
Cet exercice prend environ 25 minutes.
Provisionner une ressource Azure OpenAI
Avant de pouvoir utiliser Azure OpenAI pour générer des images, vous devez approvisionner une ressource Azure OpenAI dans votre abonnement Azure. La ressource doit se trouver dans une région où les modèles DALL-E sont pris en charge.
- Connectez-vous au portail Azure à l’adresse
https://portal.azure.com
. - Créez une ressource Azure OpenAI avec les paramètres suivants :
- Abonnement : Sélectionner un abonnement Azure qui a été approuvé pour pouvoir accéder à Azure OpenAI Service, y compris DALL-E
- Groupe de ressources : sélectionnez ou créez un groupe de ressources.
- Région : Choisissez USA Est, Australie Est ou Suède Centre*
- Nom : un nom unique de votre choix
- Niveau tarifaire : Standard S0
* Les modèles DALL-E 3 sont disponibles uniquement dans les ressources Azure OpenAI Service dans les régions USA Est, Australie Est et Suède Centre.
- Attendez la fin du déploiement. Accédez ensuite à la ressource Azure OpenAI déployée dans le portail Azure.
Déployer un modèle
Ensuite, vous allez créer un déploiement du modèle dalle3 à partir de l’interface CLI. Dans le portail Azure, sélectionnez l’icône Cloud Shell dans la barre de menus supérieure et vérifiez que votre terminal est défini sur Bash. Reportez-vous à cet exemple et remplacez les variables suivantes par vos propres valeurs :
az cognitiveservices account deployment create \
-g *your resource group* \
-n *your Open AI resource* \
--deployment-name dall-e-3 \
--model-name dall-e-3 \
--model-version 3.0 \
--model-format OpenAI \
--sku-name "Standard" \
--sku-capacity 1
> \* Sku-capacity is measured in thousands of tokens per minute. A rate limit of 1,000 tokens per minute is more than adequate to complete this exercise while leaving capacity for other people using the same subscription.
Utiliser l’API REST pour générer des images
Azure OpenAI Service fournit une API REST que vous pouvez utiliser pour envoyer des prompts de génération de contenu, y compris les images générées par un modèle DALL-E.
Préparer le développement d’une application dans Visual Studio Code
Découvrons maintenant comment vous pourriez créer une application personnalisée qui utilise Azure OpenAI Service pour générer des images. Vous allez développer votre application à l’aide de Visual Studio Code. Les fichiers de code de votre application ont été fournis dans un référentiel GitHub.
Conseil : Si vous avez déjà cloné le dépôt mslearn-openai, ouvrez-le dans Visual Studio Code. Dans le cas contraire, procédez comme suit pour le cloner dans votre environnement de développement.
- Démarrez Visual Studio Code.
- Ouvrez la palette (Maj+CTRL+P) et exécutez une commande Git : Cloner pour cloner le référentiel
https://github.com/MicrosoftLearning/mslearn-openai
vers un dossier local (peu importe quel dossier). -
Lorsque le référentiel a été cloné, ouvrez le dossier dans Visual Studio Code.
Remarque : Si Visual Studio Code affiche un message contextuel qui vous invite à approuver le code que vous ouvrez, cliquez sur l’option Oui, je fais confiance aux auteurs dans la fenêtre contextuelle.
-
Attendez que des fichiers supplémentaires soient installés pour prendre en charge les projets de code C# dans le référentiel.
Remarque : si vous êtes invité à ajouter des ressources requises pour générer et déboguer, sélectionnez Not Now (Pas maintenant).
Configuration de votre application
Des applications pour C# et Python sont fournies. Les deux applications présentent les mêmes fonctionnalités. Tout d’abord, vous allez ajouter le point de terminaison et la clé de votre ressource Azure OpenAI au fichier de configuration de l’application.
- Dans Visual Studio Code, dans le volet Explorateur, accédez au dossier Labfiles/03-image-generation, puis développez le dossier CSharp ou Python, selon le langage que vous préférez. Chaque dossier contient les fichiers propres au langage d’une application dans laquelle vous allez intégrer des fonctionnalités Azure OpenAI.
-
Dans le volet Explorateur, dans le dossier CSharp ou Python, ouvrez le fichier de configuration du langage de votre choix
- C# : appsettings.json
- Python : .env
- Mettez à jour les valeurs de configuration pour inclure le point de terminaison et la clé de la ressource Azure OpenAI que vous avez créée (disponible dans la page Clés et point de terminaison de votre ressource Azure OpenAI dans le portail Azure).
- Enregistrez le fichier de configuration.
Voir le code d’application
Vous êtes maintenant prêt à explorer le code utilisé pour appeler l’API REST et générer une image.
-
Dans le volet Explorateur, sélectionnez le fichier de code principal de votre application :
- C#:
Program.cs
- Python :
generate-image.py
- C#:
-
Passez en revue le code que contient le fichier, en notant les fonctionnalités clés suivantes :
- Le code envoie une requête https au point de terminaison de votre service, y compris la clé de votre service dans l’en-tête. Ces deux valeurs sont obtenues dans le fichier de configuration.
- La requête contient certains paramètres, notamment le prompt sur lequel doit être basée l’image, le nombre d’images à générer et la taille de la ou des images générées.
- La réponse contient un prompt révisé que le modèle DALL-E a extrapolé du prompt fourni par l’utilisateur pour le rendre plus descriptif, ainsi que l’URL de l’image générée.
Important : si vous avez donné à votre déploiement un nom autre que celui recommandé, dalle3, vous devez modifier le code pour utiliser le nom de votre déploiement.
Exécuter l’application
Maintenant que vous avez revu le code, il est temps de l’exécuter et de générer des images.
-
Cliquez avec le bouton droit sur le dossier CSharp ou Python contenant vos fichiers de code, puis ouvrez un terminal intégré. Entrez ensuite la commande appropriée pour exécuter votre application :
C#
dotnet run
Python
pip install requests python generate-image.py
-
Lorsque vous y êtes invité, entrez une description pour une image. Par exemple, Une girafe faisant voler un cerf-volant.
-
Attendez que l’image soit générée. Un lien hypertexte s’affiche dans le volet du terminal. Sélectionnez ensuite le lien hypertexte pour ouvrir un nouvel onglet de navigateur et regarder l’image qui a été générée.
CONSEIL : Si l’application ne retourne pas de réponse, attendez une minute et réessayez. Les ressources nouvellement déployées peuvent prendre jusqu’à 5 minutes avant d’être disponibles.
-
Fermez l’onglet du navigateur contenant l’image générée et réexécutez l’application pour générer une nouvelle image avec un autre prompt.
Nettoyage
Lorsque vous avez terminé avec votre ressource Azure OpenAI, n’oubliez pas de la supprimer dans le portail Azure sur https://portal.azure.com
.