Usar o Azure OpenAI no Fabric com Python SDK e Synapse ML (visualização)
Importante
Este recurso está em pré-visualização.
Este artigo mostra exemplos de como usar o Azure OpenAI no Fabric usando o OpenAI Python SDK e usando o SynapseML.
Pré-requisitos
OpenAI Python SDK não está instalado no tempo de execução padrão, você precisa primeiro instalá-lo.
%pip install openai==0.28.1
Chat
ChatGPT e GPT-4 são modelos de linguagem otimizados para interfaces de conversação. O exemplo apresentado aqui mostra operações simples de conclusão de bate-papo e não se destina a servir como um tutorial.
import openai
response = openai.ChatCompletion.create(
deployment_id='gpt-35-turbo-0125', # deployment_id could be one of {gpt-35-turbo-0125 or gpt-4-32k}
messages=[
{"role": "system", "content": "You are a helpful assistant."},
{"role": "user", "content": "Knock knock."},
{"role": "assistant", "content": "Who's there?"},
{"role": "user", "content": "Orange."},
],
temperature=0,
)
print(f"{response.choices[0].message.role}: {response.choices[0].message.content}")
Saída
assistant: Orange who?
Também podemos transmitir a resposta
response = openai.ChatCompletion.create(
deployment_id='gpt-35-turbo-0125', # deployment_id could be one of {gpt-35-turbo-0125 or gpt-4-32k}
messages=[
{"role": "system", "content": "You are a helpful assistant."},
{"role": "user", "content": "Knock knock."},
{"role": "assistant", "content": "Who's there?"},
{"role": "user", "content": "Orange."},
],
temperature=0,
stream=True
)
for chunk in response:
delta = chunk.choices[0].delta
if "role" in delta.keys():
print(delta.role + ": ", end="", flush=True)
if "content" in delta.keys():
print(delta.content, end="", flush=True)
Saída
assistant: Orange who?
Incorporações
Uma incorporação é um formato especial de representação de dados que modelos e algoritmos de aprendizado de máquina podem utilizar facilmente. Ele contém o significado semântico rico em informações de um texto, representado por um vetor de números de ponto flutuante. A distância entre duas incorporações no espaço vetorial está relacionada à semelhança semântica entre duas entradas originais. Por exemplo, se dois textos são semelhantes, suas representações vetoriais também devem ser semelhantes.
O exemplo demonstrado aqui mostra como obter incorporações e não pretende ser um tutorial.
deployment_id = "text-embedding-ada-002" # set deployment_name as text-embedding-ada-002
embeddings = openai.Embedding.create(deployment_id=deployment_id,
input="The food was delicious and the waiter...")
print(embeddings)
Saída
{
"object": "list",
"data": [
{
"object": "embedding",
"index": 0,
"embedding": [
0.002306425478309393,
-0.009327292442321777,
0.015797346830368042,
...
0.014552861452102661,
0.010463837534189224,
-0.015327490866184235,
-0.01937841810286045,
-0.0028842221945524216
]
}
],
"model": "ada",
"usage": {
"prompt_tokens": 8,
"total_tokens": 8
}
}
Conteúdos relacionados
- Usar a Análise de Texto pré-criada no Fabric com a API REST
- Usar a Análise de Texto pré-criada no Fabric com o SynapseML
- Usar o Azure AI Translator pré-criado no Fabric com a API REST
- Usar o Azure AI Translator pré-criado na malha com SynapseML
- Usar o Azure OpenAI pré-criado no Fabric com a API REST
- Usar o Azure OpenAI pré-criado no Fabric com SynapseML e Python SDK