Guida introduttiva: Generare immagini con il servizio Azure OpenAI
Nota
L'API di generazione di immagini crea un'immagine da un prompt di testo. Non modifica le immagini esistenti né crea varianti.
Usare questa guida per iniziare a generare immagini con Azure OpenAI nel browser.
Prerequisiti
- Una sottoscrizione di Azure. Crearne una gratuitamente.
- Accesso concesso a DALL-E nella sottoscrizione di Azure desiderata.
- Una risorsa OpenAI di Azure creata nell'area
EastUS
,AustraliaEast
oSwedenCentral
. - È quindi necessario distribuire un
dalle3
modello con la risorsa di Azure. Per altre informazioni, vedere Creare una risorsa e distribuire un modello con Azure OpenAI.
Nota
Attualmente, è necessario inviare un'applicazione per accedere al servizio Azure OpenAI. Per richiedere l'accesso, completare il modulo. Se è necessaria assistenza, aprire un problema in questo repository per contattare Microsoft.
Passare ad Azure OpenAI Studio
Passare ad Azure OpenAI Studio e accedere con le credenziali associate alla risorsa OpenAI di Azure. Durante o dopo il flusso di lavoro di accesso, selezionare la directory appropriata, la sottoscrizione di Azure e la risorsa OpenAI di Azure.
Nella pagina di destinazione di Azure OpenAI Studio selezionare DALL· E playground (anteprima) per usare le API di generazione di immagini. Selezionare Impostazioni nella parte superiore della pagina e verificare che nell'elenco a discesa Distribuzione sia selezionata la distribuzione DALL-E 3.
Provare la generazione di immagini
Iniziare a esplorare le funzionalità di Azure OpenAI con un approccio senza codice tramite DALL· E playground (anteprima). Immettere il prompt dell'immagine nella casella di testo e selezionare Genera. Quando l'immagine generata dall'intelligenza artificiale è pronta, viene visualizzata nella pagina.
Nota
Le API di generazione di immagini sono dotate di un filtro di con modalità tenda ration. Se Azure OpenAI riconosce la richiesta come contenuto dannoso, non restituisce un'immagine generata. Per altre informazioni, vedere Filtro del contenuto.
Nel DALL· E playground (anteprima), è anche possibile visualizzare esempi di codice Python e cURL, precompilati in base alle impostazioni. Selezionare Visualizza codice nella parte superiore della pagina. È possibile usare questo codice per scrivere un'applicazione che completa la stessa attività.
Pulire le risorse
Se si vuole pulire e rimuovere una risorsa OpenAI di Azure, è possibile eliminare la risorsa o il gruppo di risorse. L'eliminazione del gruppo di risorse comporta anche l'eliminazione di tutte le altre risorse associate.
Passaggi successivi
- Esplorare le API di generazione di immagini in modo più approfondito con la guida pratica DALL-E.
- Provare esempi nel repository GitHub degli esempi di Azure OpenAI.
- Vedere le informazioni di riferimento sulle API
Usare questa guida per iniziare a chiamare le API REST di generazione di immagini del servizio OpenAI di Azure usando Python.
Prerequisiti
- Una sottoscrizione di Azure. Crearne una gratuitamente.
- Accesso concesso a DALL-E nella sottoscrizione di Azure desiderata.
- Python 3.8 o versione successiva.
- Sono installate le librerie Python seguenti:
os
,requests
,json
. - Una risorsa OpenAI di Azure creata nell'area
EastUS
,AustraliaEast
oSwedenCentral
. - È quindi necessario distribuire un
dalle3
modello con la risorsa di Azure. Per altre informazioni, vedere Creare una risorsa e distribuire un modello con Azure OpenAI.
Nota
Attualmente, è necessario inviare un'applicazione per accedere al servizio Azure OpenAI. Per richiedere l'accesso, completare il modulo. Se è necessaria assistenza, aprire un problema in questo repository per contattare Microsoft.
Recuperare la chiave e l'endpoint
Per chiamare correttamente le API OpenAI di Azure, sono necessarie le informazioni seguenti sulla risorsa OpenAI di Azure:
Variabile | Nome | Valore |
---|---|---|
Endpoint | api_base |
Il valore dell'endpoint si trova in Chiavi ed endpoint per la risorsa nel portale di Azure. In alternativa, è possibile trovare il valore in OpenAI Studio di Azure>Playground>Visualizzazione codice. Un endpoint di esempio è: https://docs-test-001.openai.azure.com/ . |
Chiave | api_key |
Il valore della chiave si trova anche in Chiavi ed Endpoint per la risorsa nel portale di Azure. Azure genera due chiavi per la risorsa. È possibile usare uno dei due valori. |
Passare alla risorsa nel portale di Azure. Nel riquadro di spostamento selezionare Chiavi ed endpoint in Gestione risorse. Copiare il valore endpoint e un valore della chiave di accesso. È possibile usare il valore KEY 1 o KEY 2 . Avere sempre due chiavi consente di ruotare e rigenerare le chiavi in modo sicuro senza causare un'interruzione del servizio.
Creare una nuova applicazione Python
Creare un nuovo file Python denominato quickstart.py. Aprire il nuovo file nell'editor o nell'IDE preferito.
Sostituire il contenuto di quickstart.py con il codice seguente. Immettere l'URL e la chiave dell'endpoint nei campi appropriati. Modificare il valore di
prompt
nel testo preferito.È anche necessario sostituire
<dalle3>
nell'URL con il nome di distribuzione scelto quando è stato distribuito il modello DALL-E 3. Se si immette il nome del modello, verrà generato un errore, a meno che non si sia scelto un nome di distribuzione identico al nome del modello sottostante. Se si verifica un errore, verificare di non avere un doppio di nella separazione tra l'endpoint/
e/openai/deployments
.import requests import time import os api_base = '<your_endpoint>' # Enter your endpoint here api_key = '<your_key>' # Enter your API key here api_version = '2024-02-01' url = f"{api_base}/openai/deployments/<dalle3>/images/generations?api-version={api_version}" headers= { "api-key": api_key, "Content-Type": "application/json" } body = { # Enter your prompt text here "prompt": "A multi-colored umbrella on the beach, disposable camera", "size": "1024x1024", # supported values are “1792x1024”, “1024x1024” and “1024x1792” "n": 1, #The number of images to generate. Only n=1 is supported for DALL-E 3. "quality": "hd", # Options are “hd” and “standard”; defaults to standard "style": "vivid" # Options are “natural” and “vivid”; defaults to “vivid” } submission = requests.post(url, headers=headers, json=body) image_url = submission.json()['data'][0]['url'] print(image_url)
Lo script esegue una chiamata API di generazione di immagini sincrona.
Importante
Ricordarsi di rimuovere la chiave dal codice al termine e non pubblicare mai la chiave pubblicamente. Per l'ambiente di produzione, usare un modo sicuro per archiviare e accedere alle credenziali. Per altre informazioni, vedere Azure Key Vault.
Eseguire l'applicazione con il comando
python
:python quickstart.py
Attendere alcuni istanti per ottenere la risposta.
Output
L'output di una chiamata API di generazione di immagini corretta è simile all'esempio seguente. Il url
campo contiene un URL in cui è possibile scaricare l'immagine generata. L'URL rimane attivo per 24 ore.
{
"created": 1698116662,
"data": [
{
"url": "<URL_to_generated_image>",
"revised_prompt": "<prompt_that_was_used>"
}
]
}
Le API di generazione di immagini sono dotate di un filtro di con modalità tenda ration. Se il servizio riconosce la richiesta come contenuto dannoso, non genera un'immagine. Per altre informazioni, vedere Filtro del contenuto. Per esempi di risposte agli errori, vedere la guida pratica di DALL-E.
Il sistema restituisce lo stato dell'operazione Failed
e il error.code
valore nel messaggio è impostato su contentFilter
. Ecco un esempio:
{
"created": 1698435368,
"error":
{
"code": "contentFilter",
"message": "Your task failed as a result of our safety system."
}
}
È anche possibile che l'immagine generata sia filtrata. In questo caso, il messaggio di errore è impostato su Generated image was filtered as a result of our safety system.
. Ecco un esempio:
{
"created": 1698435368,
"error":
{
"code": "contentFilter",
"message": "Generated image was filtered as a result of our safety system."
}
}
Pulire le risorse
Se si vuole pulire e rimuovere una risorsa OpenAI di Azure, è possibile eliminare la risorsa o il gruppo di risorse. L'eliminazione del gruppo di risorse comporta anche l'eliminazione di tutte le altre risorse associate.
Passaggi successivi
- Esplorare le API di generazione di immagini in modo più approfondito con la guida pratica DALL-E.
- Provare esempi nel repository GitHub degli esempi di Azure OpenAI.
- Vedere le informazioni di riferimento sulle API
Usare questa guida per iniziare a generare immagini con Azure OpenAI SDK per Python.
Codice sorgente della libreria | Pacchetto | Esempi
Prerequisiti
- Una sottoscrizione di Azure. Crearne una gratuitamente.
- Accesso concesso a DALL-E nella sottoscrizione di Azure desiderata.
- Python 3.8 o versione successiva.
- Una risorsa OpenAI di Azure creata nell'area
EastUS
,AustraliaEast
oSwedenCentral
. - È quindi necessario distribuire un
dalle3
modello con la risorsa di Azure. Per altre informazioni, vedere Creare una risorsa e distribuire un modello con Azure OpenAI.
Nota
Attualmente, è necessario inviare un'applicazione per accedere al servizio Azure OpenAI. Per richiedere l'accesso, completare il modulo. Se è necessaria assistenza, aprire un problema in questo repository per contattare Microsoft.
Impostazione
Recuperare la chiave e l'endpoint
Per chiamare correttamente le API OpenAI di Azure, sono necessarie le informazioni seguenti sulla risorsa OpenAI di Azure:
Variabile | Nome | Valore |
---|---|---|
Endpoint | api_base |
Il valore dell'endpoint si trova in Chiavi ed endpoint per la risorsa nel portale di Azure. In alternativa, è possibile trovare il valore in OpenAI Studio di Azure>Playground>Visualizzazione codice. Un endpoint di esempio è: https://docs-test-001.openai.azure.com/ . |
Chiave | api_key |
Il valore della chiave si trova anche in Chiavi ed Endpoint per la risorsa nel portale di Azure. Azure genera due chiavi per la risorsa. È possibile usare uno dei due valori. |
Passare alla risorsa nel portale di Azure. Nel riquadro di spostamento selezionare Chiavi ed endpoint in Gestione risorse. Copiare il valore endpoint e un valore della chiave di accesso. È possibile usare il valore KEY 1 o KEY 2 . Avere sempre due chiavi consente di ruotare e rigenerare le chiavi in modo sicuro senza causare un'interruzione del servizio.
Creare e assegnare variabili di ambiente persistenti per la chiave e l'endpoint.
Variabili di ambiente
Creare e assegnare variabili di ambiente persistenti per la chiave e l'endpoint.
setx AZURE_OPENAI_API_KEY "REPLACE_WITH_YOUR_KEY_VALUE_HERE"
setx AZURE_OPENAI_ENDPOINT "REPLACE_WITH_YOUR_ENDPOINT_HERE"
Creare una nuova applicazione Python
Aprire un prompt dei comandi e passare alla cartella del progetto. Creare un nuovo file Python, quickstart.py.
Installare l'SDK per Python
Installare OpenAI Python SDK usando il comando seguente:
pip install openai
Installare anche le librerie seguenti:
pip install requests
pip install pillow
Generare immagini con DALL-E
Aprire _quickstart.py nell'editor o nell'IDE preferito.
Sostituire il contenuto di quickstart.py con il codice seguente.
from openai import AzureOpenAI
import os
import requests
from PIL import Image
import json
client = AzureOpenAI(
api_version="2024-02-01",
api_key=os.environ["AZURE_OPENAI_API_KEY"],
azure_endpoint=os.environ['AZURE_OPENAI_ENDPOINT']
)
result = client.images.generate(
model="dalle3", # the name of your DALL-E 3 deployment
prompt="a close-up of a bear walking throughthe forest",
n=1
)
json_response = json.loads(result.model_dump_json())
# Set the directory for the stored image
image_dir = os.path.join(os.curdir, 'images')
# If the directory doesn't exist, create it
if not os.path.isdir(image_dir):
os.mkdir(image_dir)
# Initialize the image path (note the filetype should be png)
image_path = os.path.join(image_dir, 'generated_image.png')
# Retrieve the generated image
image_url = json_response["data"][0]["url"] # extract image URL from response
generated_image = requests.get(image_url).content # download the image
with open(image_path, "wb") as image_file:
image_file.write(generated_image)
# Display the image in the default image viewer
image = Image.open(image_path)
image.show()
- Immettere l'URL e la chiave dell'endpoint nei campi appropriati.
- Modificare il valore di
prompt
nel testo preferito. - Modificare il valore di
model
impostando il nome del modello DALL-E 3 distribuito.
Importante
Ricordarsi di rimuovere la chiave dal codice al termine e non pubblicare mai la chiave pubblicamente. Per l'ambiente di produzione, usare un modo sicuro per archiviare e accedere alle credenziali. Per altre informazioni, vedere Azure Key Vault.
Eseguire l'applicazione con il comando python
:
python quickstart.py
Attendere alcuni istanti per ottenere la risposta.
Output
Azure OpenAI archivia l'immagine di output nel file generated_image.png nella directory specificata. Lo script visualizza anche l'immagine nel visualizzatore di immagini predefinito.
Le API di generazione di immagini sono dotate di un filtro di con modalità tenda ration. Se il servizio riconosce la richiesta come contenuto dannoso, non genera un'immagine. Per altre informazioni, vedere Filtro del contenuto.
Pulire le risorse
Se si vuole pulire e rimuovere una risorsa OpenAI di Azure, è possibile eliminare la risorsa o il gruppo di risorse. L'eliminazione del gruppo di risorse comporta anche l'eliminazione di tutte le altre risorse associate.
Passaggi successivi
- Esplorare le API di generazione di immagini in modo più approfondito con la guida pratica DALL-E.
- Provare esempi nel repository GitHub degli esempi di Azure OpenAI.
- Vedere le informazioni di riferimento sulle API
Usare questa guida per iniziare a generare immagini con Azure OpenAI SDK per C#.
Esempi del pacchetto del codice | sorgente della libreria (NuGet) |
Prerequisiti
- Una sottoscrizione di Azure: creare un account gratuitamente
- Accesso concesso al servizio OpenAI di Azure nella sottoscrizione di Azure desiderata. Attualmente, l'accesso a questo servizio viene concesso solo dall'applicazione. È possibile richiedere l'accesso al servizio OpenAI di Azure completando il modulo all'indirizzo https://aka.ms/oai/access.
- .NET 7 SDK
- Una risorsa OpenAI di Azure creata nell'area Stati Uniti orientali. Per altre informazioni, vedere Creare una risorsa e distribuire un modello con Azure OpenAI.
Nota
Attualmente, è necessario inviare un'applicazione per accedere al servizio Azure OpenAI. Per richiedere l'accesso, completare il modulo. Se è necessaria assistenza, aprire un problema in questo repository per contattare Microsoft.
Impostazione
Recuperare la chiave e l'endpoint
Per effettuare correttamente una chiamata ad Azure OpenAI, è necessario un endpoint e una chiave.
Nome variabile | Valore |
---|---|
ENDPOINT |
Questo valore è disponibile nella sezione Chiavi &ed endpoint durante l'esame della risorsa dalla portale di Azure. In alternativa, è possibile trovare il valore nella visualizzazione codice di Azure OpenAI Studio>Playground>. Un endpoint di esempio è: https://docs-test-001.openai.azure.com/ . |
API-KEY |
Questo valore è disponibile nella sezione Chiavi ed endpoint durante l'esame della risorsa dalla portale di Azure. È possibile usare KEY1 o KEY2 . |
Passare alla risorsa nel portale di Azure. La sezione Chiavi ed endpoint è disponibile nella sezione Gestione risorse. Copiare l'endpoint e la chiave di accesso perché saranno necessari entrambi per l'autenticazione delle chiamate API. Puoi usare entrambi KEY1
o KEY2
. Avere sempre due chiavi consente di ruotare e rigenerare le chiavi in modo sicuro senza causare un'interruzione del servizio.
Variabili di ambiente
Creare e assegnare variabili di ambiente persistenti per la chiave e l'endpoint.
setx AZURE_OPENAI_API_KEY "REPLACE_WITH_YOUR_KEY_VALUE_HERE"
setx AZURE_OPENAI_ENDPOINT "REPLACE_WITH_YOUR_ENDPOINT_HERE"
Creare una nuova applicazione .NET Core
In una finestra di una console, ad esempio cmd, PowerShell o Bash, usare il comando dotnet new
per creare una nuova app console con il nome azure-openai-quickstart
. Questo comando crea un semplice progetto "Hello World" con un singolo file di origine C#: Program.cs.
dotnet new console -n azure-openai-quickstart
Spostarsi nella cartella dell'app appena creata. È possibile compilare l'applicazione con il comando seguente:
dotnet build
L'output di compilazione non deve contenere alcun avviso o errore.
...
Build succeeded.
0 Warning(s)
0 Error(s)
...
Installare OpenAI .NET SDK
Installare la libreria client con:
dotnet add package Azure.AI.OpenAI --version 1.0.0-beta.6
Generare immagini con DALL-E
Dalla directory del progetto aprire il file program.cs e sostituire con il codice seguente:
using System;
using System.IO;
using System.Threading.Tasks;
using Azure.AI.OpenAI;
namespace Azure.AI.OpenAI.Tests.Samples
{
public partial class GenerateImages
{
// add an async Main method:
public static async Task Main(string[] args)
{
string endpoint = GetEnvironmentVariable("AZURE_OPENAI_ENDPOINT");
string key = GetEnvironmentVariable("AZURE_OPENAI_API_KEY");
OpenAIClient client = new(new Uri(endpoint), new AzureKeyCredential(key));
Response<ImageGenerations> imageGenerations = await client.GetImageGenerationsAsync(
new ImageGenerationOptions()
{
Prompt = "a happy monkey eating a banana, in watercolor",
Size = ImageSize.Size256x256,
});
// Image Generations responses provide URLs you can use to retrieve requested images
Uri imageUri = imageGenerations.Value.Data[0].Url;
// Print the image URI to console:
Console.WriteLine(imageUri);
}
}
}
Compilare ed eseguire l'applicazione dalla directory dell'applicazione con questi comandi:
dotnet build
dotnet run
Output
L'URL dell'immagine generata viene stampato nella console.
https://dalleproduse.blob.core.windows.net/private/images/552c5522-af4a-4877-a19c-400fac04a422/generated_00.png?se=2023-08-17T16%3A54%3A40Z&sig=XGCIx9r0WvWTJ0LL%2FJGymo2WYp4FDbSQNNrGRUnnUzI%3D&ske=2023-08-19T01%3A10%3A14Z&skoid=09ba021e-c417-441c-b203-c81e5dcd7b7f&sks=b&skt=2023-08-12T01%3A10%3A14Z&sktid=33e01921-4d64-4f8c-a055-5bdaffd5e33d&skv=2020-10-02&sp=r&spr=https&sr=b&sv=2020-10-02
Nota
Le API di generazione di immagini sono dotate di un filtro di con modalità tenda ration. Se il servizio riconosce la richiesta come contenuto dannoso, non restituirà un'immagine generata. Per altre informazioni, vedere l'articolo relativo al filtro del contenuto.
Pulire le risorse
Se si vuole pulire e rimuovere una risorsa OpenAI di Azure, è possibile eliminare la risorsa. Prima di eliminare la risorsa, è necessario eliminare i modelli distribuiti.
Passaggi successivi
- Esplorare le API di generazione di immagini in modo più approfondito con la guida pratica DALL-E.
- Per altri esempi, vedere il repository GitHub degli esempi di Azure OpenAI.
Usare questa guida per iniziare a generare immagini con Azure OpenAI SDK per Java.
Esempi dell'artefatto del codice | sorgente della libreria (Maven) |
Prerequisiti
- Una sottoscrizione di Azure: creare un account gratuitamente
- Accesso concesso al servizio Azure OpenAI nella sottoscrizione di Azure desiderata. Attualmente, l'accesso a questo servizio viene concesso solo dall'applicazione. È possibile richiedere l'accesso al servizio OpenAI di Azure completando il modulo all'indirizzo https://aka.ms/oai/access.
- La versione più recente di Java Development Kit (JDK)
- Lo strumento di compilazione Gradle o un'altra utilità di gestione dipendenze.
- Una risorsa OpenAI di Azure creata nell'area Stati Uniti orientali. Per altre informazioni, vedere Creare una risorsa e distribuire un modello con Azure OpenAI.
Nota
Attualmente, è necessario inviare un'applicazione per accedere al servizio Azure OpenAI. Per richiedere l'accesso, completare il modulo. Se è necessaria assistenza, aprire un problema in questo repository per contattare Microsoft.
Impostazione
Recuperare la chiave e l'endpoint
Per effettuare correttamente una chiamata ad Azure OpenAI, è necessario un endpoint e una chiave.
Nome variabile | Valore |
---|---|
ENDPOINT |
Questo valore è disponibile nella sezione Chiavi &ed endpoint durante l'esame della risorsa dalla portale di Azure. In alternativa, è possibile trovare il valore nella visualizzazione codice di Azure OpenAI Studio>Playground>. Un endpoint di esempio è: https://docs-test-001.openai.azure.com/ . |
API-KEY |
Questo valore è disponibile nella sezione Chiavi ed endpoint durante l'esame della risorsa dalla portale di Azure. È possibile usare KEY1 o KEY2 . |
Passare alla risorsa nel portale di Azure. La sezione Chiavi ed endpoint è disponibile nella sezione Gestione risorse. Copiare l'endpoint e la chiave di accesso perché saranno necessari entrambi per l'autenticazione delle chiamate API. Puoi usare entrambi KEY1
o KEY2
. Avere sempre due chiavi consente di ruotare e rigenerare le chiavi in modo sicuro senza causare un'interruzione del servizio.
Variabili di ambiente
Creare e assegnare variabili di ambiente persistenti per la chiave e l'endpoint.
setx AZURE_OPENAI_API_KEY "REPLACE_WITH_YOUR_KEY_VALUE_HERE"
setx AZURE_OPENAI_ENDPOINT "REPLACE_WITH_YOUR_ENDPOINT_HERE"
Creare una nuova applicazione Java
Creare un nuovo progetto Gradle.
In una finestra della console, ad esempio cmd, PowerShell o Bash, creare e passare a una nuova directory per l'app.
mkdir myapp && cd myapp
Eseguire il comando gradle init
dalla directory di lavoro. Questo comando creerà i file di compilazione essenziali per Gradle, tra cui build.gradle.kts, che viene usato in fase di esecuzione per creare e configurare l'applicazione.
gradle init --type basic
Quando viene chiesto di scegliere un linguaggio DSL, selezionare Kotlin.
Installare Java SDK
Questo argomento di avvio rapido usa l'utilità di gestione dipendenze Gradle. La libreria client e le informazioni per altre utilità di gestione dipendenze sono disponibili in Maven Central Repository.
Individuare il file build.gradle.kts e aprirlo con un IDE o un editor di testo a scelta. Quindi copiare la configurazione di compilazione seguente. Questa configurazione definisce il progetto come applicazione Java il cui punto di ingresso è la classe OpenAIQuickstart. Importa la libreria di Visione artificiale di Azure.
plugins {
java
application
}
application {
mainClass.set("OpenAIQuickstart")
}
repositories {
mavenCentral()
}
dependencies {
implementation(group = "com.azure", name = "azure-ai-openai", version = "1.0.0-beta.3")
implementation("org.slf4j:slf4j-simple:1.7.9")
}
Generare immagini con DALL-E
Creare un file Java.
Dalla directory di lavoro eseguire il comando seguente per creare una cartella di origine del progetto:
mkdir -p src/main/java
Passare alla nuova cartella e creare un file denominato OpenAIQuickstart.java.
Aprire OpenAIQuickstart.java nell'editor o nell'IDE preferito e incollare il codice seguente.
import com.azure.ai.openai.OpenAIAsyncClient; import com.azure.ai.openai.OpenAIClientBuilder; import com.azure.ai.openai.models.ImageGenerationOptions; import com.azure.ai.openai.models.ImageLocation; import com.azure.core.credential.AzureKeyCredential; import com.azure.core.models.ResponseError; import java.util.concurrent.TimeUnit; /** * Sample demonstrates how to get the images for a given prompt. */ public class OpenAIQuickstart { /** * Runs the sample algorithm and demonstrates how to get the images for a given prompt. * * @param args Unused. Arguments to the program. */ public static void main(String[] args) throws InterruptedException { // Get key and endpoint from environment variables: String azureOpenaiKey = System.getenv("AZURE_OPENAI_API_KEY"); String endpoint = System.getenv("AZURE_OPENAI_ENDPOINT"); OpenAIAsyncClient client = new OpenAIClientBuilder() .endpoint(endpoint) .credential(new AzureKeyCredential(azureOpenaiKey)) .buildAsyncClient(); ImageGenerationOptions imageGenerationOptions = new ImageGenerationOptions( "A drawing of the Seattle skyline in the style of Van Gogh"); client.getImages(imageGenerationOptions).subscribe( images -> { for (ImageLocation imageLocation : images.getData()) { ResponseError error = imageLocation.getError(); if (error != null) { System.out.printf("Image generation operation failed. Error code: %s, error message: %s.%n", error.getCode(), error.getMessage()); } else { System.out.printf( "Image location URL that provides temporary access to download the generated image is %s.%n", imageLocation.getUrl()); } } }, error -> System.err.println("There was an error getting images." + error), () -> System.out.println("Completed getImages.")); // The .subscribe() creation and assignment is not a blocking call. For the purpose of this example, we sleep // the thread so the program does not end before the send operation is complete. Using .block() instead of // .subscribe() will turn this into a synchronous call. TimeUnit.SECONDS.sleep(10); } }
Tornare alla cartella radice del progetto e compilare l'app con:
gradle build
Eseguirlo quindi con il
gradle run
comando :gradle run
Output
L'URL dell'immagine generata viene stampato nella console.
Image location URL that provides temporary access to download the generated image is https://dalleproduse.blob.core.windows.net/private/images/d2ea917f-8802-4ad6-8ef6-3fb7a15c8482/generated_00.png?se=2023-08-25T23%3A11%3A28Z&sig=%2BKa5Mkb9U88DfvxoBpyAjamYRzwb7aVCEucM6XJC3wQ%3D&ske=2023-08-31T15%3A27%3A47Z&skoid=09ba021e-c417-441c-b203-c81e5dcd7b7f&sks=b&skt=2023-08-24T15%3A27%3A47Z&sktid=33e01921-4d64-4f8c-a055-5bdaffd5e33d&skv=2020-10-02&sp=r&spr=https&sr=b&sv=2020-10-02.
Completed getImages.
Nota
Le API di generazione di immagini sono dotate di un filtro di con modalità tenda ration. Se il servizio riconosce la richiesta come contenuto dannoso, non restituirà un'immagine generata. Per altre informazioni, vedere l'articolo relativo al filtro del contenuto.
Pulire le risorse
Se si vuole pulire e rimuovere una risorsa OpenAI di Azure, è possibile eliminare la risorsa. Prima di eliminare la risorsa, è necessario eliminare i modelli distribuiti.
Passaggi successivi
- Esplorare le API di generazione di immagini in modo più approfondito con la guida pratica DALL-E.
- Per altri esempi, vedere il repository GitHub degli esempi di Azure OpenAI
Usare questa guida per iniziare a generare immagini con Azure OpenAI SDK per JavaScript.
Pacchetto del codice | sorgente della libreria (npm) | Esempi
Prerequisiti
- Una sottoscrizione di Azure: creare un account gratuitamente
- Accesso concesso al servizio Azure OpenAI nella sottoscrizione di Azure desiderata. Attualmente, l'accesso a questo servizio viene concesso solo dall'applicazione. È possibile richiedere l'accesso al servizio OpenAI di Azure completando il modulo all'indirizzo https://aka.ms/oai/access.
- Versioni LTS di Node.js
- Una risorsa OpenAI di Azure creata nell'area Stati Uniti orientali. Per altre informazioni, vedere Creare una risorsa e distribuire un modello con Azure OpenAI.
Nota
Attualmente, è necessario inviare un'applicazione per accedere al servizio Azure OpenAI. Per richiedere l'accesso, completare il modulo. Se è necessaria assistenza, aprire un problema in questo repository per contattare Microsoft.
Impostazione
Recuperare la chiave e l'endpoint
Per effettuare correttamente una chiamata ad Azure OpenAI, è necessario un endpoint e una chiave.
Nome variabile | Valore |
---|---|
ENDPOINT |
Questo valore è disponibile nella sezione Chiavi &ed endpoint durante l'esame della risorsa dalla portale di Azure. In alternativa, è possibile trovare il valore nella visualizzazione codice di Azure OpenAI Studio>Playground>. Un endpoint di esempio è: https://docs-test-001.openai.azure.com/ . |
API-KEY |
Questo valore è disponibile nella sezione Chiavi ed endpoint durante l'esame della risorsa dalla portale di Azure. È possibile usare KEY1 o KEY2 . |
Passare alla risorsa nel portale di Azure. La sezione Chiavi ed endpoint è disponibile nella sezione Gestione risorse. Copiare l'endpoint e la chiave di accesso perché saranno necessari entrambi per l'autenticazione delle chiamate API. Puoi usare entrambi KEY1
o KEY2
. Avere sempre due chiavi consente di ruotare e rigenerare le chiavi in modo sicuro senza causare un'interruzione del servizio.
Variabili di ambiente
Creare e assegnare variabili di ambiente persistenti per la chiave e l'endpoint.
setx AZURE_OPENAI_API_KEY "REPLACE_WITH_YOUR_KEY_VALUE_HERE"
setx AZURE_OPENAI_ENDPOINT "REPLACE_WITH_YOUR_ENDPOINT_HERE"
Creare un'applicazione Node
In una finestra della console, ad esempio cmd, PowerShell o Bash, creare e passare a una nuova directory per l'app. Eseguire quindi il npm init
comando per creare un'applicazione node con un file package.json .
npm init
Installare la libreria client
Installare la libreria client OpenAI di Azure per JavaScript con npm:
npm install @azure/openai
Il file di package.json dell'app verrà aggiornato con le dipendenze.
Generare immagini con DALL-E
Creare un nuovo file denominato ImageGeneration.js e aprirlo nell'editor di codice preferito. Copiare il codice seguente nel file ImageGeneration.js :
const { OpenAIClient, AzureKeyCredential } = require("@azure/openai");
// You will need to set these environment variables or edit the following values
const endpoint = process.env["AZURE_OPENAI_ENDPOINT"] ;
const azureApiKey = process.env["AZURE_OPENAI_API_KEY"] ;
// The prompt to generate images from
const prompt = "a monkey eating a banana";
const size = "256x256";
// The number of images to generate
const n = 2;
async function main() {
console.log("== Batch Image Generation ==");
const client = new OpenAIClient(endpoint, new AzureKeyCredential(azureApiKey));
const deploymentName = "dall-e";
const results = await client.getImages(deploymentName, prompt, { n, size });
for (const image of results.data) {
console.log(`Image generation result URL: ${image.url}`);
}
//console.log(`Image generation result URL: ${results.result.status}`);
}
main().catch((err) => {
console.error("The sample encountered an error:", err);
});
Eseguire lo script con il comando seguente:
node _ImageGeneration.js
Output
L'URL dell'immagine generata viene stampato nella console.
== Batch Image Generation ==
Image generation result URL: https://dalleproduse.blob.core.windows.net/private/images/5e7536a9-a0b5-4260-8769-2d54106f2913/generated_00.png?se=2023-08-29T19%3A12%3A57Z&sig=655GkWajOZ9ALjFykZF%2FBMZRPQALRhf4UPDImWCQoGI%3D&ske=2023-09-02T18%3A53%3A23Z&skoid=09ba021e-c417-441c-b203-c81e5dcd7b7f&sks=b&skt=2023-08-26T18%3A53%3A23Z&sktid=33e01921-4d64-4f8c-a055-5bdaffd5e33d&skv=2020-10-02&sp=r&spr=https&sr=b&sv=2020-10-02
Image generation result URL: https://dalleproduse.blob.core.windows.net/private/images/5e7536a9-a0b5-4260-8769-2d54106f2913/generated_01.png?se=2023-08-29T19%3A12%3A57Z&sig=B24ymPLSZ3HfG23uojOD9VlRFGxjvgcNmvFo4yPUbEc%3D&ske=2023-09-02T18%3A53%3A23Z&skoid=09ba021e-c417-441c-b203-c81e5dcd7b7f&sks=b&skt=2023-08-26T18%3A53%3A23Z&sktid=33e01921-4d64-4f8c-a055-5bdaffd5e33d&skv=2020-10-02&sp=r&spr=https&sr=b&sv=2020-10-02
Nota
Le API di generazione di immagini sono dotate di un filtro di con modalità tenda ration. Se il servizio riconosce la richiesta come contenuto dannoso, non restituirà un'immagine generata. Per altre informazioni, vedere l'articolo relativo al filtro del contenuto.
Pulire le risorse
Se si vuole pulire e rimuovere una risorsa OpenAI di Azure, è possibile eliminare la risorsa. Prima di eliminare la risorsa, è necessario eliminare i modelli distribuiti.
Passaggi successivi
- Esplorare le API di generazione di immagini in modo più approfondito con la guida pratica DALL-E.
- Per altri esempi, vedere il repository GitHub degli esempi di Azure OpenAI.
Usare questa guida per iniziare a generare immagini con Azure OpenAI SDK for Go.
Codice sorgente della libreria | Pacchetto | Esempi
Prerequisiti
- Una sottoscrizione di Azure: creare un account gratuitamente
- L'accesso concesso a DALL-E nella sottoscrizione di Azure desiderata Attualmente, l'accesso a questo servizio viene concesso solo dall'applicazione. È possibile richiedere l'accesso a OpenAI di Azure completando il modulo all'indirizzo https://aka.ms/oai/access. I clienti di Azure OpenAI esistenti devono immettere nuovamente il modulo per ottenere l'accesso a DALL-E. Apri un problema in questo repository per contattare Microsoft in caso di problemi.
- Una risorsa OpenAI di Azure creata nell'area Stati Uniti orientali. Per altre informazioni, vedere Creare una risorsa e distribuire un modello con Azure OpenAI.
Nota
Attualmente, è necessario inviare un'applicazione per accedere al servizio Azure OpenAI. Per richiedere l'accesso, completare il modulo. Se è necessaria assistenza, aprire un problema in questo repository per contattare Microsoft.
Impostazione
Recuperare la chiave e l'endpoint
Per effettuare correttamente una chiamata ad Azure OpenAI, è necessario un endpoint e una chiave.
Nome variabile | Valore |
---|---|
ENDPOINT |
Questo valore è disponibile nella sezione Chiavi &ed endpoint durante l'esame della risorsa dalla portale di Azure. In alternativa, è possibile trovare il valore nella visualizzazione codice di Azure OpenAI Studio>Playground>. Un endpoint di esempio è: https://docs-test-001.openai.azure.com/ . |
API-KEY |
Questo valore è disponibile nella sezione Chiavi ed endpoint durante l'esame della risorsa dalla portale di Azure. È possibile usare KEY1 o KEY2 . |
Passare alla risorsa nel portale di Azure. La sezione Chiavi ed endpoint è disponibile nella sezione Gestione risorse. Copiare l'endpoint e la chiave di accesso perché saranno necessari entrambi per l'autenticazione delle chiamate API. Puoi usare entrambi KEY1
o KEY2
. Avere sempre due chiavi consente di ruotare e rigenerare le chiavi in modo sicuro senza causare un'interruzione del servizio.
Variabili di ambiente
Creare e assegnare variabili di ambiente persistenti per la chiave e l'endpoint.
setx AZURE_OPENAI_API_KEY "REPLACE_WITH_YOUR_KEY_VALUE_HERE"
setx AZURE_OPENAI_ENDPOINT "REPLACE_WITH_YOUR_ENDPOINT_HERE"
Creare una nuova applicazione Go
Aprire il prompt dei comandi e passare alla cartella del progetto. Creare un nuovo file sample.go.
Installare Go SDK
Installare OpenAI Go SDK usando il comando seguente:
go get github.com/Azure/azure-sdk-for-go/sdk/ai/azopenai@latest
In alternativa, se si usa dep
, all'interno del repository eseguire:
dep ensure -add github.com/Azure/azure-sdk-for-go/sdk/ai/azopenai
Generare immagini con DALL-E
Aprire sample.go nell'editor di codice preferito.
Aggiungere il codice seguente allo script:
package main
import (
"context"
"fmt"
"net/http"
"os"
"github.com/Azure/azure-sdk-for-go/sdk/ai/azopenai"
"github.com/Azure/azure-sdk-for-go/sdk/azcore/to"
)
func main() {
azureOpenAIKey := os.Getenv("AZURE_OPENAI_API_KEY")
// Ex: "https://<your-azure-openai-host>.openai.azure.com"
azureOpenAIEndpoint := os.Getenv("AZURE_OPENAI_ENDPOINT")
if azureOpenAIKey == "" || azureOpenAIEndpoint == "" {
fmt.Fprintf(os.Stderr, "Skipping example, environment variables missing\n")
return
}
keyCredential, err := azopenai.NewKeyCredential(azureOpenAIKey)
if err != nil {
// handle error
}
client, err := azopenai.NewClientWithKeyCredential(azureOpenAIEndpoint, keyCredential, nil)
if err != nil {
// handle error
}
resp, err := client.CreateImage(context.TODO(), azopenai.ImageGenerationOptions{
Prompt: to.Ptr("a painting of a cat in the style of Dali"),
ResponseFormat: to.Ptr(azopenai.ImageGenerationResponseFormatURL),
}, nil)
if err != nil {
// handle error
}
for _, generatedImage := range resp.Data {
// the underlying type for the generatedImage is dictated by the value of
// ImageGenerationOptions.ResponseFormat. In this example we used `azopenai.ImageGenerationResponseFormatURL`,
// so the underlying type will be ImageLocation.
resp, err := http.Head(*generatedImage.URL)
if err != nil {
// handle error
}
fmt.Fprintf(os.Stderr, "Image generated, HEAD request on URL returned %d\nImage URL: %s\n", resp.StatusCode, *generatedImage.URL)
}
}
Eseguire lo script usando il go run
comando :
go run sample.go
Output
L'URL dell'immagine generata viene stampato nella console.
Image generated, HEAD request on URL returned 200
Image URL: https://dalleproduse.blob.core.windows.net/private/images/d7b28a5c-ca32-4792-8c2a-6a5d8d8e5e45/generated_00.png?se=2023-08-29T17%3A05%3A37Z&sig=loqntaPypYVr9VTT5vpbsjsCz31g1GsdoQi0smbGkks%3D&ske=2023-09-02T18%3A53%3A23Z&skoid=09ba021e-c417-441c-b203-c81e5dcd7b7f&sks=b&skt=2023-08-26T18%3A53%3A23Z&sktid=33e01921-4d64-4f8c-a055-5bdaffd5e33d&skv=2020-10-02&sp=r&spr=https&sr=b&sv=2020-10-02
Nota
Le API di generazione di immagini sono dotate di un filtro di con modalità tenda ration. Se il servizio riconosce la richiesta come contenuto dannoso, non restituirà un'immagine generata. Per altre informazioni, vedere l'articolo relativo al filtro del contenuto.
Pulire le risorse
Se si vuole pulire e rimuovere una risorsa OpenAI di Azure, è possibile eliminare la risorsa o il gruppo di risorse. L'eliminazione del gruppo di risorse comporta anche l'eliminazione di tutte le altre risorse associate.
Passaggi successivi
- Esplorare le API di generazione di immagini in modo più approfondito con la guida pratica DALL-E.
- Per altri esempi, vedere il repository GitHub degli esempi di Azure OpenAI.
Usare questa guida per iniziare a chiamare le API di generazione di immagini del servizio OpenAI di Azure usando PowerShell.
Nota
L'API di generazione di immagini crea un'immagine da un prompt di testo. Non modifica le immagini esistenti né crea varianti.
Prerequisiti
- Una sottoscrizione di Azure. Crearne una gratuitamente.
- Accesso concesso a DALL-E nella sottoscrizione di Azure desiderata.
- Per questa attività, è consigliabile usare la versione più recente di PowerShell 7 perché gli esempi usano nuove funzionalità non disponibili in Windows PowerShell 5.1.
- Una risorsa OpenAI di Azure creata nell'area Stati Uniti orientali. Per altre informazioni, vedere Creare una risorsa e distribuire un modello con Azure OpenAI.
Nota
Attualmente, è necessario inviare un'applicazione per accedere al servizio Azure OpenAI. Per richiedere l'accesso, completare il modulo. Se è necessaria assistenza, aprire un problema in questo repository per contattare Microsoft.
Recuperare la chiave e l'endpoint
Per chiamare correttamente le API OpenAI di Azure, sono necessarie le informazioni seguenti sulla risorsa OpenAI di Azure:
Variabile | Nome | Valore |
---|---|---|
Endpoint | api_base |
Il valore dell'endpoint si trova in Chiavi ed endpoint per la risorsa nel portale di Azure. In alternativa, è possibile trovare il valore in OpenAI Studio di Azure>Playground>Visualizzazione codice. Un endpoint di esempio è: https://docs-test-001.openai.azure.com/ . |
Chiave | api_key |
Il valore della chiave si trova anche in Chiavi ed Endpoint per la risorsa nel portale di Azure. Azure genera due chiavi per la risorsa. È possibile usare uno dei due valori. |
Passare alla risorsa nel portale di Azure. Nel riquadro di spostamento selezionare Chiavi ed endpoint in Gestione risorse. Copiare il valore endpoint e un valore della chiave di accesso. È possibile usare il valore KEY 1 o KEY 2 . Avere sempre due chiavi consente di ruotare e rigenerare le chiavi in modo sicuro senza causare un'interruzione del servizio.
Creare e assegnare variabili di ambiente persistenti per la chiave e l'endpoint.
Variabili di ambiente
$Env:AZURE_OPENAI_API_KEY = 'YOUR_KEY_VALUE'
$Env:AZURE_OPENAI_ENDPOINT = 'YOUR_ENDPOINT'
Creare un nuovo script di PowerShell
Creare un nuovo file di PowerShell denominato quickstart.ps1. Aprire il nuovo file nell'editor o nell'IDE preferito.
Sostituire il contenuto di quickstart.ps1 con il codice seguente. Immettere l'URL e la chiave dell'endpoint nei campi appropriati. Modificare il valore di
prompt
nel testo preferito.# Azure OpenAI metadata variables $openai = @{ api_key = $Env:AZURE_OPENAI_API_KEY api_base = $Env:AZURE_OPENAI_ENDPOINT # your endpoint should look like the following https://YOUR_RESOURCE_NAME.openai.azure.com/ api_version = '2023-06-01-preview' # this may change in the future } # Text to describe image $prompt = 'A painting of a dog' # Header for authentication $headers = [ordered]@{ 'api-key' = $openai.api_key } # Adjust these values to fine-tune completions $body = [ordered]@{ prompt = $prompt size = '1024x1024' n = 1 } | ConvertTo-Json # Call the API to generate the image and retrieve the response $url = "$($openai.api_base)/openai/images/generations:submit?api-version=$($openai.api_version)" $submission = Invoke-RestMethod -Uri $url -Headers $headers -Body $body -Method Post -ContentType 'application/json' -ResponseHeadersVariable submissionHeaders $operation_location = $submissionHeaders['operation-location'][0] $status = '' while ($status -ne 'succeeded') { Start-Sleep -Seconds 1 $response = Invoke-RestMethod -Uri $operation_location -Headers $headers $status = $response.status } # Set the directory for the stored image $image_dir = Join-Path -Path $pwd -ChildPath 'images' # If the directory doesn't exist, create it if (-not(Resolve-Path $image_dir -ErrorAction Ignore)) { New-Item -Path $image_dir -ItemType Directory } # Initialize the image path (note the filetype should be png) $image_path = Join-Path -Path $image_dir -ChildPath 'generated_image.png' # Retrieve the generated image $image_url = $response.result.data[0].url # extract image URL from response $generated_image = Invoke-WebRequest -Uri $image_url -OutFile $image_path # download the image return $image_path
Importante
Per la produzione, usare un modo sicuro per archiviare e accedere alle credenziali, ad esempio La gestione dei segreti di PowerShell con Azure Key Vault. Per altre informazioni sulla sicurezza delle credenziali, vedere l'articolo sicurezza dei servizi di intelligenza artificiale di Azure.
Eseguire lo script con PowerShell:
./quickstart.ps1
Lo script esegue un ciclo fino a quando l'immagine generata non è pronta.
Output
PowerShell richiede l'immagine da Azure OpenAI e archivia l'immagine di output nel file generated_image.png nella directory specificata. Per praticità, il percorso completo del file viene restituito alla fine dello script.
Le API di generazione di immagini sono dotate di un filtro di con modalità tenda ration. Se il servizio riconosce la richiesta come contenuto dannoso, non genera un'immagine. Per altre informazioni, vedere Filtro del contenuto.
Pulire le risorse
Se si vuole pulire e rimuovere una risorsa OpenAI di Azure, è possibile eliminare la risorsa o il gruppo di risorse. L'eliminazione del gruppo di risorse comporta anche l'eliminazione di tutte le altre risorse associate.
Passaggi successivi
- Esplorare le API di generazione di immagini in modo più approfondito con la guida pratica DALL-E.
- Provare esempi nel repository GitHub degli esempi di Azure OpenAI.