OpenAI API

OpenAI API OpenAI API

API da OpenAIlink image 68

Instale a biblioteca OpenAIlink image 69

Este caderno foi traduzido automaticamente para torná-lo acessível a mais pessoas, por favor me avise se você vir algum erro de digitação..

Em primeiro lugar, para usar a API OpenAI, é necessário instalar a biblioteca OpenAI. Para fazer isso, executamos o seguinte comando

	
%pip install --upgrade openai
Copy

Importar a biblioteca OpenAIlink image 70

Depois que a biblioteca é instalada, nós a importamos para usá-la em nosso código.

	
%pip install --upgrade openai
import openai
Copy

Obter uma chave de APIlink image 71

Para usar a API da OpenAI, é necessário obter uma chave de API. Para fazer isso, acesse a página [OpenAI] (https://openai.com/) e registre-se. Depois de registrado, vá para a seção API Keys e crie uma nova chave de API.

open ai api key

Assim que a tivermos, informaremos à API do openai qual é a nossa chave de API.

	
%pip install --upgrade openai
import openai
api_key = "Pon aquí tu API key"
Copy

Criamos nosso primeiro chatbotlink image 72

Com a API OpenAI, é muito fácil criar um chatbot simples, para o qual passaremos um prompt e ele retornará uma resposta

Em primeiro lugar, temos que escolher o modelo que vamos usar. No meu caso, vou usar o modelo gpt-3.5-turbo-1106, que é atualmente um bom modelo para esta postagem, porque para o que vamos fazer não precisamos usar o melhor modelo. A OpenAI tem uma lista com todos os seus [modelos] (https://platform.openai.com/docs/models) e uma página com os [preços] (https://openai.com/pricing)

	
%pip install --upgrade openai
import openai
api_key = "Pon aquí tu API key"
model = "gpt-3.5-turbo-1106"
Copy

Agora precisamos criar um cliente que se comunicará com a API da OpenAI.

	
%pip install --upgrade openai
import openai
api_key = "Pon aquí tu API key"
model = "gpt-3.5-turbo-1106"
client = openai.OpenAI(api_key=api_key, organization=None)
Copy

Como podemos ver, passamos nossa chave de API. Você também pode passar a organização, mas, no nosso caso, isso não é necessário.

Criamos o prompt

	
%pip install --upgrade openai
import openai
api_key = "Pon aquí tu API key"
model = "gpt-3.5-turbo-1106"
client = openai.OpenAI(api_key=api_key, organization=None)
promtp = "Cuál es el mejor lenguaje de programación para aprender?"
Copy

E agora podemos pedir uma resposta à OpenAI.

	
%pip install --upgrade openai
import openai
api_key = "Pon aquí tu API key"
model = "gpt-3.5-turbo-1106"
client = openai.OpenAI(api_key=api_key, organization=None)
promtp = "Cuál es el mejor lenguaje de programación para aprender?"
response = client.chat.completions.create(
model=model,
messages=[{"role": "user", "content": f"{promtp}"}],
)
Copy

Vejamos como é a resposta

	
%pip install --upgrade openai
import openai
api_key = "Pon aquí tu API key"
model = "gpt-3.5-turbo-1106"
client = openai.OpenAI(api_key=api_key, organization=None)
promtp = "Cuál es el mejor lenguaje de programación para aprender?"
response = client.chat.completions.create(
model=model,
messages=[{"role": "user", "content": f"{promtp}"}],
)
type(response), response
Copy
	
(openai.types.chat.chat_completion.ChatCompletion,
ChatCompletion(id='chatcmpl-8RaHCm9KalLxj2PPbLh6f8A4djG8Y', choices=[Choice(finish_reason='stop', index=0, message=ChatCompletionMessage(content='No hay un "mejor" lenguaje de programación para aprender, ya que depende de tus intereses, objetivos y el tipo de desarrollo que te interese. Algunos lenguajes populares para empezar a aprender a programar incluyen Python, JavaScript, Java, C# y Ruby. Estos lenguajes son conocidos por su sintaxis clara y su versatilidad, lo que los hace buenos candidatos para principiantes. También es útil investigar qué lenguajes son populares en la industria en la que te gustaría trabajar, ya que el conocimiento de un lenguaje en demanda puede abrirte más oportunidades laborales. En resumen, la elección del lenguaje de programación para aprender dependerá de tus preferencias personales y de tus metas profesionales.', role='assistant', function_call=None, tool_calls=None))], created=1701584994, model='gpt-3.5-turbo-1106', object='chat.completion', system_fingerprint='fp_eeff13170a', usage=CompletionUsage(completion_tokens=181, prompt_tokens=21, total_tokens=202)))
	
print(f"response.id = {response.id}")
print(f"response.choices = {response.choices}")
for i in range(len(response.choices)):
print(f"response.choices[{i}] = {response.choices[i]}")
print(f"\tresponse.choices[{i}].finish_reason = {response.choices[i].finish_reason}")
print(f"\tresponse.choices[{i}].index = {response.choices[i].index}")
print(f"\tresponse.choices[{i}].message = {response.choices[i].message}")
content = response.choices[i].message.content.replace(' ', ' ')
print(f" response.choices[{i}].message.content = {content}")
print(f" response.choices[{i}].message.role = {response.choices[i].message.role}")
print(f" response.choices[{i}].message.function_call = {response.choices[i].message.function_call}")
print(f" response.choices[{i}].message.tool_calls = {response.choices[i].message.tool_calls}")
print(f"response.created = {response.created}")
print(f"response.model = {response.model}")
print(f"response.object = {response.object}")
print(f"response.system_fingerprint = {response.system_fingerprint}")
print(f"response.usage = {response.usage}")
print(f"\tresponse.usage.completion_tokens = {response.usage.completion_tokens}")
print(f"\tresponse.usage.prompt_tokens = {response.usage.prompt_tokens}")
print(f"\tresponse.usage.total_tokens = {response.usage.total_tokens}")
Copy
	
response.id = chatcmpl-8RaHCm9KalLxj2PPbLh6f8A4djG8Y
response.choices = [Choice(finish_reason='stop', index=0, message=ChatCompletionMessage(content='No hay un "mejor" lenguaje de programación para aprender, ya que depende de tus intereses, objetivos y el tipo de desarrollo que te interese. Algunos lenguajes populares para empezar a aprender a programar incluyen Python, JavaScript, Java, C# y Ruby. Estos lenguajes son conocidos por su sintaxis clara y su versatilidad, lo que los hace buenos candidatos para principiantes. También es útil investigar qué lenguajes son populares en la industria en la que te gustaría trabajar, ya que el conocimiento de un lenguaje en demanda puede abrirte más oportunidades laborales. En resumen, la elección del lenguaje de programación para aprender dependerá de tus preferencias personales y de tus metas profesionales.', role='assistant', function_call=None, tool_calls=None))]
response.choices[0] = Choice(finish_reason='stop', index=0, message=ChatCompletionMessage(content='No hay un "mejor" lenguaje de programación para aprender, ya que depende de tus intereses, objetivos y el tipo de desarrollo que te interese. Algunos lenguajes populares para empezar a aprender a programar incluyen Python, JavaScript, Java, C# y Ruby. Estos lenguajes son conocidos por su sintaxis clara y su versatilidad, lo que los hace buenos candidatos para principiantes. También es útil investigar qué lenguajes son populares en la industria en la que te gustaría trabajar, ya que el conocimiento de un lenguaje en demanda puede abrirte más oportunidades laborales. En resumen, la elección del lenguaje de programación para aprender dependerá de tus preferencias personales y de tus metas profesionales.', role='assistant', function_call=None, tool_calls=None))
response.choices[0].finish_reason = stop
response.choices[0].index = 0
response.choices[0].message = ChatCompletionMessage(content='No hay un "mejor" lenguaje de programación para aprender, ya que depende de tus intereses, objetivos y el tipo de desarrollo que te interese. Algunos lenguajes populares para empezar a aprender a programar incluyen Python, JavaScript, Java, C# y Ruby. Estos lenguajes son conocidos por su sintaxis clara y su versatilidad, lo que los hace buenos candidatos para principiantes. También es útil investigar qué lenguajes son populares en la industria en la que te gustaría trabajar, ya que el conocimiento de un lenguaje en demanda puede abrirte más oportunidades laborales. En resumen, la elección del lenguaje de programación para aprender dependerá de tus preferencias personales y de tus metas profesionales.', role='assistant', function_call=None, tool_calls=None)
response.choices[0].message.content =
No hay un "mejor" lenguaje de programación para aprender, ya que depende de tus intereses, objetivos y el tipo de desarrollo que te interese. Algunos lenguajes populares para empezar a aprender a programar incluyen Python, JavaScript, Java, C# y Ruby. Estos lenguajes son conocidos por su sintaxis clara y su versatilidad, lo que los hace buenos candidatos para principiantes. También es útil investigar qué lenguajes son populares en la industria en la que te gustaría trabajar, ya que el conocimiento de un lenguaje en demanda puede abrirte más oportunidades laborales. En resumen, la elección del lenguaje de programación para aprender dependerá de tus preferencias personales y de tus metas profesionales.
response.choices[0].message.role = assistant
response.choices[0].message.function_call = None
response.choices[0].message.tool_calls = None
response.created = 1701584994
response.model = gpt-3.5-turbo-1106
response.object = chat.completion
response.system_fingerprint = fp_eeff13170a
response.usage = CompletionUsage(completion_tokens=181, prompt_tokens=21, total_tokens=202)
response.usage.completion_tokens = 181
response.usage.prompt_tokens = 21
response.usage.total_tokens = 202

Como podemos ver, ele retorna muitas informações.

Por exemplo, response.choices[0].finish_reason = stop significa que o modelo parou de gerar texto porque chegou ao final do prompt. Isso é útil para depuração, pois os valores possíveis são stop, que significa que a API retornou a mensagem completa, length, que significa que a saída do modelo estava incompleta porque era mais longa do que o max_tokens ou limite de token do modelo, function_call, o modelo decidiu chamar uma função, content_filter, que significa que o conteúdo foi ignorado devido a uma limitação de conteúdo da OpenAI e null, que significa que a resposta da API estava incompleta.

Ele também nos fornece informações sobre tokens para que possamos controlar o dinheiro gasto.

Parâmetroslink image 73

Ao solicitar uma resposta ao OpenAI, podemos passar uma série de parâmetros para que ele retorne uma resposta mais alinhada com o que desejamos. Vamos ver quais são os parâmetros que podemos passar para o OpenAI

  • Mensagens: lista de mensagens que foram enviadas para o chatbot.
  • model: Modelo que queremos usar
  • frequency_penalty`: Penalidade de frequência. Quanto maior o valor, menor a probabilidade de o modelo repetir a mesma resposta.
  • max_tokens: número máximo de tokens que podem ser retornados pelo modelo
  • n`: Número de respostas que queremos que o modelo retorne.
  • presence_penalty`: penalidade de presença. Quanto maior o valor, menor a probabilidade de o modelo repetir a mesma resposta.
  • seed: Semente para geração de texto
  • stop: lista de tokens que indicam que o modelo deve parar de gerar texto.
  • If stream: Se True, a API retornará uma resposta sempre que o modelo gerar um token. Se False, a API retornará uma resposta quando o modelo tiver gerado todos os tokens.
  • temperature: quanto maior o valor, mais criativo será o modelo.
  • top_p: quanto maior o valor, mais criativo é o modelo.
  • user: ID do usuário que está falando com o chatbot
  • timeout: tempo máximo que queremos esperar para que a API retorne uma resposta.

Vamos dar uma olhada em alguns deles

Mensagenslink image 74

Podemos passar uma lista de mensagens que foram enviadas ao chatbot para a API. Isso é útil para passar o histórico da conversa para o chatbot, para que ele possa gerar uma resposta mais adequada à conversa. E para condicionar a resposta do chatbot ao que lhe foi dito anteriormente.

Além disso, podemos passar uma mensagem do sistema para informar como ele deve se comportar.

Histórico de conversaslink image 75

Vejamos um exemplo do hisotrial de conversas, primeiro perguntamos como ele está.

	
promtp = "Hola, soy MaximoFN, ¿Cómo estás?"
response = client.chat.completions.create(
model=model,
messages=[{"role": "user", "content": f"{promtp}"}],
)
content = response.choices[0].message.content.replace(' ', ' ')
print(content)
Copy
	
Hola MaximoFN, soy un modelo de inteligencia artificial diseñado para conversar y ayudar en lo que necesites. ¿En qué puedo ayudarte hoy?

Ele respondeu que não tem sentimentos e como pode nos ajudar. Portanto, se eu lhe perguntar qual é o meu nome agora, ele não saberá como me responder.

	
promtp = "¿Me puedes decir cómo me llamo?"
response = client.chat.completions.create(
model=model,
messages=[{"role": "user", "content": f"{promtp}"}],
)
content = response.choices[0].message.content.replace(' ', ' ')
print(content)
Copy
	
Lo siento, no tengo esa información. Pero puedes decírmelo tú.

Para corrigir isso, passamos o histórico da conversa para você

	
promtp = "¿Me puedes decir cómo me llamo?"
response = client.chat.completions.create(
model=model,
messages=[
{"role": "user", "content": "Hola, soy MaximoFN, ¿Cómo estás?"},
{"role": "assistant", "content": "Hola MaximoFN, soy un modelo de inteligencia artificial diseñado para conversar y ayudar en lo que necesites. ¿En qué puedo ayudarte hoy?"},
{"role": "user", "content": f"{promtp}"},
],
)
content = response.choices[0].message.content.replace(' ', ' ')
print(content)
Copy
	
Tu nombre es MaximoFN.
Condicionamento por exemplolink image 76

Agora vamos dar uma olhada em um exemplo de como condicionar a resposta do chatbot ao que foi dito acima. Agora perguntamos a ele como obter a lista de arquivos em um diretório no terminal

	
promtp = "¿Cómo puedo listar los archivos de un directorio en la terminal?"
response = client.chat.completions.create(
model=model,
messages=[{"role": "user", "content": f"{promtp}"}],
)
content = response.choices[0].message.content.replace(' ', ' ')
print(content)
Copy
	
En la terminal de un sistema operativo Unix o Linux, puedes listar los archivos de un directorio utilizando el comando `ls`. Por ejemplo, si quieres listar los archivos del directorio actual, simplemente escribe `ls` y presiona Enter. Si deseas listar los archivos de un directorio específico, puedes proporcionar la ruta del directorio después del comando `ls`, por ejemplo `ls /ruta/del/directorio`. Si deseas ver más detalles sobre los archivos, puedes usar la opción `-l` para obtener una lista detallada o `-a` para mostrar también los archivos ocultos.

Se agora o condicionarmos com exemplos de respostas curtas, vamos ver o que ele responde.

	
promtp = "¿Cómo puedo listar los archivos de un directorio en la terminal?"
response = client.chat.completions.create(
model=model,
messages=[
{"role": "user", "content": "Obtener las 10 primeras líneas de un archivo"},
{"role": "assistant", "content": "head -n 10"},
{"role": "user", "content": "Encontrar todos los archivos con extensión .txt"},
{"role": "assistant", "content": "find . -name '*.txt"},
{"role": "user", "content": "Dividir un archivo en varias páginas"},
{"role": "assistant", "content": "split -l 1000"},
{"role": "user", "content": "Buscar la dirección IP 12.34.56.78"},
{"role": "assistant", "content": "nslookup 12.34.56.78"},
{"role": "user", "content": "Obtener las 5 últimas líneas de foo.txt"},
{"role": "assistant", "content": "tail -n 5 foo.txt"},
{"role": "user", "content": "Convertir ejemplo.png en JPEG"},
{"role": "assistant", "content": "convert example.png example.jpg"},
{"role": "user", "content": "Create a git branch named 'new-feature"},
{"role": "assistant", "content": "git branch new-feature"},
{"role": "user", "content": f"{promtp}"},
],
)
content = response.choices[0].message.content.replace(' ', ' ')
print(content)
Copy
	
Puede usar el comando `ls` en la terminal para listar los archivos de un directorio. Por ejemplo:
```
ls
```
Muestra los archivos y directorios en el directorio actual.

Conseguimos fazer com que ele dê uma resposta mais curta

Condicionamento com mensagem do sistemalink image 77

Podemos lhe passar uma mensagem do sistema para lhe dizer como se comportar.

	
promtp = "¿Cómo puedo listar los archivos de un directorio en la terminal?"
response = client.chat.completions.create(
model=model,
messages=[
{"role": "system", "content": "Eres un experto asistente de terminal de ubuntu que responde solo con comandos de terminal"},
{"role": "user", "content": f"{promtp}"},
],
)
content = response.choices[0].message.content.replace(' ', ' ')
print(content)
Copy
	
Puedes listar los archivos de un directorio en la terminal usando el comando `ls`. Por ejemplo, para listar los archivos del directorio actual, simplemente escribe `ls` y presiona Enter. Si quieres listar los archivos de un directorio específico, puedes utilizar `ls` seguido de la ruta del directorio. Por ejemplo, `ls /ruta/del/directorio`.
	
promtp = "¿Cómo puedo listar los archivos de un directorio en la terminal?"
response = client.chat.completions.create(
model=model,
messages=[
{"role": "system", "content": "Eres un experto asistente de terminal de ubuntu que responde solo con comandos de terminal"},
{"role": "user", "content": "Obtener las 10 primeras líneas de un archivo"},
{"role": "assistant", "content": "head -n 10"},
{"role": "user", "content": "Encontrar todos los archivos con extensión .txt"},
{"role": "assistant", "content": "find . -name '*.txt"},
{"role": "user", "content": "Dividir un archivo en varias páginas"},
{"role": "assistant", "content": "split -l 1000"},
{"role": "user", "content": "Buscar la dirección IP 12.34.56.78"},
{"role": "assistant", "content": "nslookup 12.34.56.78"},
{"role": "user", "content": "Obtener las 5 últimas líneas de foo.txt"},
{"role": "assistant", "content": "tail -n 5 foo.txt"},
{"role": "user", "content": "Convertir ejemplo.png en JPEG"},
{"role": "assistant", "content": "convert example.png example.jpg"},
{"role": "user", "content": "Create a git branch named 'new-feature"},
{"role": "assistant", "content": "git branch new-feature"},
{"role": "user", "content": f"{promtp}"},
],
)
content = response.choices[0].message.content.replace(' ', ' ')
print(content)
Copy
	
Puedes listar los archivos de un directorio en la terminal utilizando el comando "ls". Por ejemplo, para listar los archivos en el directorio actual, puedes ejecutar el comando "ls". Si deseas listar los archivos de otro directorio, simplemente especifica el directorio después del comando "ls", por ejemplo "ls /ruta/al/directorio".

Número máximo de tokens de respostalink image 78

Podemos limitar o número de tokens que o modelo pode retornar. Isso é útil para que o modelo não ultrapasse a resposta que desejamos.

	
promtp = "¿Cuál es el mejor lenguaje de programación para aprender?"
response = client.chat.completions.create(
model = model,
messages = [{"role": "user", "content": f"{promtp}"}],
max_tokens = 50,
)
content = response.choices[0].message.content.replace(' ', ' ')
print(content)
print(f"\nresponse.choices[{i}].finish_reason = {response.choices[i].finish_reason}")
Copy
	
La respuesta a esta pregunta puede variar dependiendo de los intereses y objetivos individuales, ya que cada lenguaje de programación tiene sus propias ventajas y desventajas. Sin embargo, algunos de los lenguajes más
response.choices[0].finish_reason = length

Como podemos ver, a resposta é cortada na metade porque excederia o limite de tokens. Além disso, agora o motivo de parada é length em vez de stop.

Criatividade do modelo por meio da temperaturalink image 79

Podemos tornar o modelo mais criativo por meio da temperatura. Quanto mais alto for o valor, mais criativo será o modelo.

	
promtp = "¿Cuál es el mejor lenguaje de programación para aprender?"
temperature = 0
response = client.chat.completions.create(
model = model,
messages = [{"role": "user", "content": f"{promtp}"}],
temperature = temperature,
)
content_0 = response.choices[0].message.content.replace(' ', ' ')
print(content_0)
Copy
	
No hay un "mejor" lenguaje de programación para aprender, ya que la elección depende de los intereses y objetivos individuales. Algunos lenguajes populares para principiantes incluyen Python, JavaScript, Java y C#. Cada uno tiene sus propias ventajas y desventajas, por lo que es importante investigar y considerar qué tipo de desarrollo de software te interesa antes de elegir un lenguaje para aprender.
	
promtp = "¿Cuál es el mejor lenguaje de programación para aprender?"
temperature = 1
response = client.chat.completions.create(
model = model,
messages = [{"role": "user", "content": f"{promtp}"}],
temperature = temperature,
)
content_1 = response.choices[0].message.content.replace(' ', ' ')
print(content_1)
Copy
	
No hay un "mejor" lenguaje de programación para aprender, ya que la elección depende de los objetivos y preferencias individuales del programador. Sin embargo, algunos lenguajes populares para principiantes incluyen Python, JavaScript, Java y C++. Estos lenguajes son relativamente fáciles de aprender y tienen una amplia gama de aplicaciones en la industria de la tecnología. Es importante considerar qué tipo de proyectos o campos de interés te gustaría explorar al momento de elegir un lenguaje de programación para aprender.
	
print(content_0)
print(content_1)
Copy
	
No hay un "mejor" lenguaje de programación para aprender, ya que la elección depende de los intereses y objetivos individuales. Algunos lenguajes populares para principiantes incluyen Python, JavaScript, Java y C#. Cada uno tiene sus propias ventajas y desventajas, por lo que es importante investigar y considerar qué tipo de desarrollo de software te interesa antes de elegir un lenguaje para aprender.
No hay un "mejor" lenguaje de programación para aprender, ya que la elección depende de los objetivos y preferencias individuales del programador. Sin embargo, algunos lenguajes populares para principiantes incluyen Python, JavaScript, Java y C++. Estos lenguajes son relativamente fáciles de aprender y tienen una amplia gama de aplicaciones en la industria de la tecnología. Es importante considerar qué tipo de proyectos o campos de interés te gustaría explorar al momento de elegir un lenguaje de programación para aprender.

Criatividade do modelo por meio do top_plink image 80

Podemos tornar o modelo mais criativo usando o parâmetro top_p. Quanto maior o valor, mais criativo será o modelo.

	
promtp = "¿Cuál es el mejor lenguaje de programación para aprender?"
top_p = 0
response = client.chat.completions.create(
model = model,
messages = [{"role": "user", "content": f"{promtp}"}],
top_p = top_p,
)
content_0 = response.choices[0].message.content.replace(' ', ' ')
print(content_0)
Copy
	
No hay un "mejor" lenguaje de programación para aprender, ya que la elección depende de los intereses y objetivos individuales. Algunos lenguajes populares para principiantes incluyen Python, JavaScript, Java y C#. Cada uno tiene sus propias ventajas y desventajas, por lo que es importante investigar y considerar qué tipo de desarrollo de software te interesa antes de elegir un lenguaje para aprender.
	
promtp = "¿Cuál es el mejor lenguaje de programación para aprender?"
top_p = 1
response = client.chat.completions.create(
model = model,
messages = [{"role": "user", "content": f"{promtp}"}],
top_p = top_p,
)
content_1 = response.choices[0].message.content.replace(' ', ' ')
print(content_1)
Copy
	
El mejor lenguaje de programación para aprender depende de los objetivos del aprendizaje y del tipo de programación que se quiera realizar. Algunos lenguajes de programación populares para principiantes incluyen Python, Java, JavaScript y Ruby. Sin embargo, cada lenguaje tiene sus propias ventajas y desventajas, por lo que es importante considerar qué tipo de proyectos o aplicaciones se quieren desarrollar antes de elegir un lenguaje de programación para aprender. Python es a menudo recomendado por su facilidad de uso y versatilidad, mientras que JavaScript es ideal para la programación web.
	
print(content_0)
print(content_1)
Copy
	
No hay un "mejor" lenguaje de programación para aprender, ya que la elección depende de los intereses y objetivos individuales. Algunos lenguajes populares para principiantes incluyen Python, JavaScript, Java y C#. Cada uno tiene sus propias ventajas y desventajas, por lo que es importante investigar y considerar qué tipo de desarrollo de software te interesa antes de elegir un lenguaje para aprender.
El mejor lenguaje de programación para aprender depende de los objetivos del aprendizaje y del tipo de programación que se quiera realizar. Algunos lenguajes de programación populares para principiantes incluyen Python, Java, JavaScript y Ruby. Sin embargo, cada lenguaje tiene sus propias ventajas y desventajas, por lo que es importante considerar qué tipo de proyectos o aplicaciones se quieren desarrollar antes de elegir un lenguaje de programación para aprender. Python es a menudo recomendado por su facilidad de uso y versatilidad, mientras que JavaScript es ideal para la programación web.

Número de respostaslink image 81

Podemos solicitar à API que retorne mais de uma resposta. Isso é útil para que o modelo retorne várias respostas para que possamos escolher a que mais nos agrada. Para isso, definiremos os parâmetros temperature e top_p como 1 para tornar o modelo mais criativo.

	
promtp = "¿Cuál es el mejor lenguaje de programación para aprender?"
temperature = 1
top_p = 1
response = client.chat.completions.create(
model = model,
messages = [{"role": "user", "content": f"{promtp}"}],
temperature = temperature,
top_p = top_p,
n = 4
)
content_0 = response.choices[0].message.content.replace(' ', ' ')
content_1 = response.choices[1].message.content.replace(' ', ' ')
content_2 = response.choices[2].message.content.replace(' ', ' ')
content_3 = response.choices[3].message.content.replace(' ', ' ')
print(content_0)
print(content_1)
print(content_2)
print(content_3)
Copy
	
El mejor lenguaje de programación para aprender depende de tus objetivos y del tipo de aplicaciones que te interese desarrollar. Algunos de los lenguajes más populares para aprender son:
1. Python: Es un lenguaje de programación versátil, fácil de aprender y con una amplia comunidad de desarrolladores. Es ideal para principiantes y se utiliza en una gran variedad de aplicaciones, desde desarrollo web hasta inteligencia artificial.
2. JavaScript: Es el lenguaje de programación más utilizado en el desarrollo web. Es imprescindible para aquellos que quieren trabajar en el ámbito del desarrollo frontend y backend.
3. Java: Es un lenguaje de programación muy popular en el ámbito empresarial, por lo que aprender Java puede abrirte muchas puertas laborales. Además, es un lenguaje estructurado que te enseñará conceptos importantes de la programación orientada a objetos.
4. C#: Es un lenguaje de programación desarrollado por Microsoft que se utiliza especialmente en el desarrollo de aplicaciones para Windows. Es ideal para aquellos que quieran enfocarse en el desarrollo de aplicaciones de escritorio.
En resumen, el mejor lenguaje de programación para aprender depende de tus intereses y objetivos personales. Es importante investigar y considerar qué tipos de aplicaciones te gustaría desarrollar para elegir el lenguaje que más se adapte a tus necesidades.
El mejor lenguaje de programación para aprender depende de los objetivos y necesidades individuales. Algunos de los lenguajes de programación más populares y ampliamente utilizados incluyen Python, JavaScript, Java, C++, Ruby y muchos otros. Python es a menudo recomendado para principiantes debido a su sintaxis simple y legible, mientras que JavaScript es esencial para el desarrollo web. Java es ampliamente utilizado en el desarrollo de aplicaciones empresariales y Android, y C++ es comúnmente utilizado en sistemas embebidos y juegos. En última instancia, el mejor lenguaje de programación para aprender dependerá de lo que quiera lograr con su habilidades de programación.
El mejor lenguaje de programación para aprender depende de los intereses y objetivos individuales de cada persona. Algunos de los lenguajes más populares y bien documentados para principiantes incluyen Python, JavaScript, Java y C#. Python es conocido por su simplicidad y versatilidad, mientras que JavaScript es esencial para el desarrollo web. Java y C# son lenguajes ampliamente utilizados en la industria y proporcionan una base sólida para aprender otros lenguajes. En última instancia, la elección del lenguaje dependerá de las metas personales y la aplicación deseada.
El mejor lenguaje de programación para aprender depende de los intereses y objetivos de cada persona. Algunos lenguajes populares para principiantes incluyen Python, Java, JavaScript, C++ y Ruby. Python es frecuentemente recomendado para aprender a programar debido a su sintaxis sencilla y legible, mientras que Java es utilizado en aplicaciones empresariales y Android. JavaScript es fundamental para el desarrollo web, y C++ es comúnmente utilizado en aplicaciones de alto rendimiento. Ruby es conocido por su facilidad de uso y flexibilidad. En última instancia, la elección del lenguaje dependerá de qué tipo de desarrollo te interesa y qué tipo de proyectos deseas realizar.

Treinar novamente o modelo OpenAIlink image 82

A OpenAI oferece a possibilidade de treinar novamente seus modelos de API para obter melhores resultados em nossos próprios dados. Isso tem as seguintes vantagens

  • Resultados de maior qualidade são obtidos para nossos dados.
  • Em um prompt, podemos dar a ele exemplos para que se comporte como queremos, mas apenas alguns. Dessa forma, ao treiná-lo novamente, podemos lhe dar muitos outros.
  • Economia de tokens devido a prompts mais curtos. Como já o treinamos para o nosso caso de uso, podemos dar a ele menos solicitações para resolver nossas tarefas.
  • Menor latência de solicitações. Ao chamar os próprios modelos, teremos menos latência

Preparação de dadoslink image 83

A API da OpenAI nos pede para fornecer os dados em um arquivo jsonl no seguinte formato

{
          "mensagens":
          [
              {
                  "role": "system", "content": "Marv é um chatbot factual que também é sarcástico".
              },
              {
                  "role": "user", "content": "What's the capital of France?" (Qual é a capital da França?)
              },
              {
                  "role": "assistant", "content": "Paris, como se todo mundo já não soubesse disso".
              }
      
      }
      {
          "mensagens":
          [
              {
                  "role": "system", "content": "Marv é um chatbot factual que também é sarcástico".
              },
              {
                  "role": "user", "content": "Who wrote 'Romeo and Juliet'?" (Quem escreveu 'Romeu e Julieta'?)
              },
              {
                  "role": "assistant", "content": "Oh, apenas um cara chamado William Shakespeare. Já ouviu falar dele?"
              }
      
      }
      {
          "mensagens":
          [
              {
                  "role": "system", "content": "Marv é um chatbot factual que também é sarcástico".
              },
              {
                  "role": "user", "content": "How far is the Moon from Earth?" (A que distância a Lua está da Terra?)
              },
              {
                  "role": "assistant", "content": "Cerca de 384.400 quilômetros. Mais ou menos alguns, como se isso realmente importasse".
              }
      
      }
      

Com um máximo de 4096 tokens

Validação de dadoslink image 84

Para poupar meu trabalho, tenho passado uma a uma todas as minhas postagens para o chatgpt e disse a ele para gerar 10 FAQs para cada uma no formato CSV, pois duvidava que ele fosse capaz de gerar um formato como o solicitado no jsonl. E ele gerou um CSV com o seguinte formato para cada post

csv
      prompt,conclusão
      O que o curso Introduction to Python aborda no material fornecido? "O curso Introduction to Python aborda tópicos como tipos de dados, operadores, uso de funções e classes, manipulação de objetos iteráveis e uso de módulos. [Mais informações] (https://maximofn.com/python/)"
      Quais são os tipos de dados básicos em Python, "Python tem 7 tipos de dados básicos: texto (`str`), numérico (`int`, `float`, `complex`), sequências (`list`, `tuple`, `range`), mapeamento (`dict`), conjuntos (`set`, `frozenset`), booleano (`bool`) e binário (`bytes`, `bytearray`, `memoryview`). [Mais informações] (https://maximofn.com/python/)"
      O que são operadores em Python e como eles são usados, "Operadores em Python são símbolos especiais usados para realizar operações como adição, subtração, multiplicação e divisão entre variáveis e valores. Eles também incluem operadores lógicos para comparações. [Mais informações] (https://maximofn.com/python/)"
      Como uma função é definida e usada em Python, "Em Python, uma função é definida com a palavra-chave `def`, seguida do nome da função e de parênteses. As funções podem ter parâmetros e valores de retorno. Elas são usadas para encapsular a lógica que pode ser reutilizada em todo o código. [Mais informações] (https://maximofn.com/python/)"
      O que são classes Python e como elas são usadas?, "As classes Python são a base da programação orientada a objetos. Elas permitem que você crie objetos que encapsulam dados e funcionalidades. As classes são definidas com a palavra-chave `class`, seguida pelo nome da classe. [Mais informações] (https://maximofn.com/python/)"
      ...

Cada CSV tem 10 FAQs

Criarei um código que pega cada CSV e gera dois novos jsonls, um para treinamento e outro para validação.

	
import os
CSVs_path = "openai/faqs_posts"
percetn_train = 0.8
percetn_validation = 0.2
jsonl_train = os.path.join(CSVs_path, "train.jsonl")
jsonl_validation = os.path.join(CSVs_path, "validation.jsonl")
# Create the train.jsonl and validation.jsonl files
with open(jsonl_train, 'w') as f:
f.write('')
with open(jsonl_validation, 'w') as f:
f.write('')
for file in os.listdir(CSVs_path): # Get all files in the directory
if file.endswith(".csv"): # Check if file is a csv
csv = os.path.join(CSVs_path, file) # Get the path to the csv file
number_of_lines = 0
csv_content = []
for line in open(csv, 'r'): # Read all lines in the csv file
if line.startswith('prompt'): # Skip the first line
continue
number_of_lines += 1 # Count the number of lines
csv_content.append(line) # Add the line to the csv_content list
number_of_train = int(number_of_lines * percetn_train) # Calculate the number of lines for the train.jsonl file
number_of_validation = int(number_of_lines * percetn_validation) # Calculate the number of lines for the validation.sjonl file
for i in range(number_of_lines):
prompt = csv_content[i].split(',')[0]
response = ','.join(csv_content[i].split(',')[1:]).replace(' ', '').replace('"', '')
if i > 0 and i <= number_of_train:
# add line to train.jsonl
with open(jsonl_train, 'a') as f:
f.write(f'{"{"}"messages": [{"{"}"role": "system", "content": "Eres un amable asistente dispuesto a responder."{"}"}, {"{"}"role": "user", "content": "{prompt}"{"}"}, {"{"}"role": "assistant", "content": "{response}"{"}"}]{"}"} ')
elif i > number_of_train and i <= number_of_train + number_of_validation:
# add line to validation.csv
with open(jsonl_validation, 'a') as f:
f.write(f'{"{"}"messages": [{"{"}"role": "system", "content": "Eres un amable asistente dispuesto a responder."{"}"}, {"{"}"role": "user", "content": "{prompt}"{"}"}, {"{"}"role": "assistant", "content": "{response}"{"}"}]{"}"} ')
Copy

Quando tenho os dois jsonls, executo um code fornecido pela OpenAI para verificar os jsonls

Primeiro, validamos os treinamentos

	
import os
CSVs_path = "openai/faqs_posts"
percetn_train = 0.8
percetn_validation = 0.2
jsonl_train = os.path.join(CSVs_path, "train.jsonl")
jsonl_validation = os.path.join(CSVs_path, "validation.jsonl")
# Create the train.jsonl and validation.jsonl files
with open(jsonl_train, 'w') as f:
f.write('')
with open(jsonl_validation, 'w') as f:
f.write('')
for file in os.listdir(CSVs_path): # Get all files in the directory
if file.endswith(".csv"): # Check if file is a csv
csv = os.path.join(CSVs_path, file) # Get the path to the csv file
number_of_lines = 0
csv_content = []
for line in open(csv, 'r'): # Read all lines in the csv file
if line.startswith('prompt'): # Skip the first line
continue
number_of_lines += 1 # Count the number of lines
csv_content.append(line) # Add the line to the csv_content list
number_of_train = int(number_of_lines * percetn_train) # Calculate the number of lines for the train.jsonl file
number_of_validation = int(number_of_lines * percetn_validation) # Calculate the number of lines for the validation.sjonl file
for i in range(number_of_lines):
prompt = csv_content[i].split(',')[0]
response = ','.join(csv_content[i].split(',')[1:]).replace('\n', '').replace('"', '')
if i > 0 and i <= number_of_train:
# add line to train.jsonl
with open(jsonl_train, 'a') as f:
f.write(f'{"{"}"messages": [{"{"}"role": "system", "content": "Eres un amable asistente dispuesto a responder."{"}"}, {"{"}"role": "user", "content": "{prompt}"{"}"}, {"{"}"role": "assistant", "content": "{response}"{"}"}]{"}"}\n')
elif i > number_of_train and i <= number_of_train + number_of_validation:
# add line to validation.csv
with open(jsonl_validation, 'a') as f:
f.write(f'{"{"}"messages": [{"{"}"role": "system", "content": "Eres un amable asistente dispuesto a responder."{"}"}, {"{"}"role": "user", "content": "{prompt}"{"}"}, {"{"}"role": "assistant", "content": "{response}"{"}"}]{"}"}\n')
from collections import defaultdict
import json
# Format error checks
format_errors = defaultdict(int)
with open(jsonl_train, 'r', encoding='utf-8') as f:
dataset = [json.loads(line) for line in f]
for ex in dataset:
if not isinstance(ex, dict):
format_errors["data_type"] += 1
continue
messages = ex.get("messages", None)
if not messages:
format_errors["missing_messages_list"] += 1
continue
for message in messages:
if "role" not in message or "content" not in message:
format_errors["message_missing_key"] += 1
if any(k not in ("role", "content", "name", "function_call") for k in message):
format_errors["message_unrecognized_key"] += 1
if message.get("role", None) not in ("system", "user", "assistant", "function"):
format_errors["unrecognized_role"] += 1
content = message.get("content", None)
function_call = message.get("function_call", None)
if (not content and not function_call) or not isinstance(content, str):
format_errors["missing_content"] += 1
if not any(message.get("role", None) == "assistant" for message in messages):
format_errors["example_missing_assistant_message"] += 1
if format_errors:
print("Found errors:")
for k, v in format_errors.items():
print(f"{k}: {v}")
else:
print("No errors found")
Copy
	
No errors found

E agora os de validação

	
# Format error checks
format_errors = defaultdict(int)
with open(jsonl_validation, 'r', encoding='utf-8') as f:
dataset = [json.loads(line) for line in f]
for ex in dataset:
if not isinstance(ex, dict):
format_errors["data_type"] += 1
continue
messages = ex.get("messages", None)
if not messages:
format_errors["missing_messages_list"] += 1
continue
for message in messages:
if "role" not in message or "content" not in message:
format_errors["message_missing_key"] += 1
if any(k not in ("role", "content", "name", "function_call") for k in message):
format_errors["message_unrecognized_key"] += 1
if message.get("role", None) not in ("system", "user", "assistant", "function"):
format_errors["unrecognized_role"] += 1
content = message.get("content", None)
function_call = message.get("function_call", None)
if (not content and not function_call) or not isinstance(content, str):
format_errors["missing_content"] += 1
if not any(message.get("role", None) == "assistant" for message in messages):
format_errors["example_missing_assistant_message"] += 1
if format_errors:
print("Found errors:")
for k, v in format_errors.items():
print(f"{k}: {v}")
else:
print("No errors found")
Copy
	
No errors found

Cálculo de tokenslink image 85

O número máximo de tokens para cada exemplo deve ser 4096, portanto, se tivermos exemplos mais longos, somente os primeiros 4096 tokens serão usados. Portanto, vamos contar o número de tokens que cada jsonl tem para saber quanto nos custará treinar novamente o modelo.

Mas primeiro temos que instalar a biblioteca tiktoken, que é o tokenizador usado pela OpenAI e que também nos ajudará a saber quantos tokens cada CSV tem e, portanto, quanto nos custará treinar novamente o modelo.

Para instalá-lo, execute o seguinte comando

pip install tiktoken
      

Criamos algumas funções necessárias

	
import tiktoken
import numpy as np
encoding = tiktoken.get_encoding("cl100k_base")
def num_tokens_from_messages(messages, tokens_per_message=3, tokens_per_name=1):
num_tokens = 0
for message in messages:
num_tokens += tokens_per_message
for key, value in message.items():
num_tokens += len(encoding.encode(value))
if key == "name":
num_tokens += tokens_per_name
num_tokens += 3
return num_tokens
def num_assistant_tokens_from_messages(messages):
num_tokens = 0
for message in messages:
if message["role"] == "assistant":
num_tokens += len(encoding.encode(message["content"]))
return num_tokens
def print_distribution(values, name):
print(f" #### Distribution of {name}:")
print(f"min:{min(values)}, max: {max(values)}")
print(f"mean: {np.mean(values)}, median: {np.median(values)}")
print(f"p5: {np.quantile(values, 0.1)}, p95: {np.quantile(values, 0.9)}")
Copy
	
import tiktoken
import numpy as np
encoding = tiktoken.get_encoding("cl100k_base")
def num_tokens_from_messages(messages, tokens_per_message=3, tokens_per_name=1):
num_tokens = 0
for message in messages:
num_tokens += tokens_per_message
for key, value in message.items():
num_tokens += len(encoding.encode(value))
if key == "name":
num_tokens += tokens_per_name
num_tokens += 3
return num_tokens
def num_assistant_tokens_from_messages(messages):
num_tokens = 0
for message in messages:
if message["role"] == "assistant":
num_tokens += len(encoding.encode(message["content"]))
return num_tokens
def print_distribution(values, name):
print(f"\n#### Distribution of {name}:")
print(f"min:{min(values)}, max: {max(values)}")
print(f"mean: {np.mean(values)}, median: {np.median(values)}")
print(f"p5: {np.quantile(values, 0.1)}, p95: {np.quantile(values, 0.9)}")
# Warnings and tokens counts
n_missing_system = 0
n_missing_user = 0
n_messages = []
convo_lens = []
assistant_message_lens = []
with open(jsonl_train, 'r', encoding='utf-8') as f:
dataset = [json.loads(line) for line in f]
for ex in dataset:
messages = ex["messages"]
if not any(message["role"] == "system" for message in messages):
n_missing_system += 1
if not any(message["role"] == "user" for message in messages):
n_missing_user += 1
n_messages.append(len(messages))
convo_lens.append(num_tokens_from_messages(messages))
assistant_message_lens.append(num_assistant_tokens_from_messages(messages))
print("Num examples missing system message:", n_missing_system)
print("Num examples missing user message:", n_missing_user)
print_distribution(n_messages, "num_messages_per_example")
print_distribution(convo_lens, "num_total_tokens_per_example")
print_distribution(assistant_message_lens, "num_assistant_tokens_per_example")
n_too_long = sum(l > 4096 for l in convo_lens)
print(f"\n{n_too_long} examples may be over the 4096 token limit, they will be truncated during fine-tuning")
Copy
	
Num examples missing system message: 0
Num examples missing user message: 0
#### Distribution of num_messages_per_example:
min:3, max: 3
mean: 3.0, median: 3.0
p5: 3.0, p95: 3.0
#### Distribution of num_total_tokens_per_example:
min:67, max: 132
mean: 90.13793103448276, median: 90.0
p5: 81.5, p95: 99.5
#### Distribution of num_assistant_tokens_per_example:
min:33, max: 90
mean: 48.66379310344828, median: 48.5
p5: 41.0, p95: 55.5
0 examples may be over the 4096 token limit, they will be truncated during fine-tuning

Como podemos ver no conjunto de treinamento, nenhuma mensagem excede 4096 tokens.

	
# Warnings and tokens counts
n_missing_system = 0
n_missing_user = 0
n_messages = []
convo_lens = []
assistant_message_lens = []
with open(jsonl_validation, 'r', encoding='utf-8') as f:
dataset = [json.loads(line) for line in f]
for ex in dataset:
messages = ex["messages"]
if not any(message["role"] == "system" for message in messages):
n_missing_system += 1
if not any(message["role"] == "user" for message in messages):
n_missing_user += 1
n_messages.append(len(messages))
convo_lens.append(num_tokens_from_messages(messages))
assistant_message_lens.append(num_assistant_tokens_from_messages(messages))
print("Num examples missing system message:", n_missing_system)
print("Num examples missing user message:", n_missing_user)
print_distribution(n_messages, "num_messages_per_example")
print_distribution(convo_lens, "num_total_tokens_per_example")
print_distribution(assistant_message_lens, "num_assistant_tokens_per_example")
n_too_long = sum(l > 4096 for l in convo_lens)
print(f"\n{n_too_long} examples may be over the 4096 token limit, they will be truncated during fine-tuning")
Copy
	
Num examples missing system message: 0
Num examples missing user message: 0
#### Distribution of num_messages_per_example:
min:3, max: 3
mean: 3.0, median: 3.0
p5: 3.0, p95: 3.0
#### Distribution of num_total_tokens_per_example:
min:80, max: 102
mean: 89.93333333333334, median: 91.0
p5: 82.2, p95: 96.8
#### Distribution of num_assistant_tokens_per_example:
min:41, max: 57
mean: 48.2, median: 49.0
p5: 42.8, p95: 51.6
0 examples may be over the 4096 token limit, they will be truncated during fine-tuning

Nenhuma mensagem no conjunto de validação ultrapassa 4096 tokens.

Cálculo de custoslink image 86

Outro aspecto muito importante é saber quanto custará o ajuste fino.

	
# Pricing and default n_epochs estimate
MAX_TOKENS_PER_EXAMPLE = 4096
TARGET_EPOCHS = 3
MIN_TARGET_EXAMPLES = 100
MAX_TARGET_EXAMPLES = 25000
MIN_DEFAULT_EPOCHS = 1
MAX_DEFAULT_EPOCHS = 25
with open(jsonl_train, 'r', encoding='utf-8') as f:
dataset = [json.loads(line) for line in f]
convo_lens = []
for ex in dataset:
messages = ex["messages"]
convo_lens.append(num_tokens_from_messages(messages))
n_epochs = TARGET_EPOCHS
n_train_examples = len(dataset)
if n_train_examples * TARGET_EPOCHS < MIN_TARGET_EXAMPLES:
n_epochs = min(MAX_DEFAULT_EPOCHS, MIN_TARGET_EXAMPLES // n_train_examples)
elif n_train_examples * TARGET_EPOCHS > MAX_TARGET_EXAMPLES:
n_epochs = max(MIN_DEFAULT_EPOCHS, MAX_TARGET_EXAMPLES // n_train_examples)
n_billing_tokens_in_dataset = sum(min(MAX_TOKENS_PER_EXAMPLE, length) for length in convo_lens)
print(f"Dataset has ~{n_billing_tokens_in_dataset} tokens that will be charged for during training")
print(f"By default, you'll train for {n_epochs} epochs on this dataset")
print(f"By default, you'll be charged for ~{n_epochs * n_billing_tokens_in_dataset} tokens")
tokens_for_train = n_epochs * n_billing_tokens_in_dataset
Copy
	
Dataset has ~10456 tokens that will be charged for during training
By default, you'll train for 3 epochs on this dataset
By default, you'll be charged for ~31368 tokens

Como no momento em que este post foi escrito, o preço para treinar o gpt-3.5-turbo era de US$ 0,0080 por 1.000 tokens, podemos saber quanto o treinamento nos custará.

	
pricing = 0.0080
num_tokens_pricing = 1000
training_price = pricing * (tokens_for_train // num_tokens_pricing)
print(f"Training price: ${training_price}")
Copy
	
Training price: $0.248
	
# Pricing and default n_epochs estimate
MAX_TOKENS_PER_EXAMPLE = 4096
TARGET_EPOCHS = 3
MIN_TARGET_EXAMPLES = 100
MAX_TARGET_EXAMPLES = 25000
MIN_DEFAULT_EPOCHS = 1
MAX_DEFAULT_EPOCHS = 25
with open(jsonl_validation, 'r', encoding='utf-8') as f:
dataset = [json.loads(line) for line in f]
convo_lens = []
for ex in dataset:
messages = ex["messages"]
convo_lens.append(num_tokens_from_messages(messages))
n_epochs = TARGET_EPOCHS
n_train_examples = len(dataset)
if n_train_examples * TARGET_EPOCHS < MIN_TARGET_EXAMPLES:
n_epochs = min(MAX_DEFAULT_EPOCHS, MIN_TARGET_EXAMPLES // n_train_examples)
elif n_train_examples * TARGET_EPOCHS > MAX_TARGET_EXAMPLES:
n_epochs = max(MIN_DEFAULT_EPOCHS, MAX_TARGET_EXAMPLES // n_train_examples)
n_billing_tokens_in_dataset = sum(min(MAX_TOKENS_PER_EXAMPLE, length) for length in convo_lens)
print(f"Dataset has ~{n_billing_tokens_in_dataset} tokens that will be charged for during training")
print(f"By default, you'll train for {n_epochs} epochs on this dataset")
print(f"By default, you'll be charged for ~{n_epochs * n_billing_tokens_in_dataset} tokens")
tokens_for_validation = n_epochs * n_billing_tokens_in_dataset
Copy
	
Dataset has ~1349 tokens that will be charged for during training
By default, you'll train for 6 epochs on this dataset
By default, you'll be charged for ~8094 tokens
	
validation_price = pricing * (tokens_for_validation // num_tokens_pricing)
print(f"Validation price: ${validation_price}")
Copy
	
Validation price: $0.064
	
total_price = training_price + validation_price
print(f"Total price: ${total_price}")
Copy
	
Total price: $0.312

Se nossos cálculos estiverem corretos, veremos que o retreinamento do gpt-3.5-turbo nos custará US$ 0,312.

Treinamentolink image 87

Quando tivermos tudo pronto, precisaremos carregar o jsonl para a API da OpenAI para treinar novamente o modelo. Para fazer isso, executamos o seguinte código

	
result = client.files.create(file=open(jsonl_train, "rb"), purpose="fine-tune")
Copy
	
result = client.files.create(file=open(jsonl_train, "rb"), purpose="fine-tune")
type(result), result
Copy
	
(openai.types.file_object.FileObject,
FileObject(id='file-LWztOVasq4E0U67wRe8ShjLZ', bytes=47947, created_at=1701585709, filename='train.jsonl', object='file', purpose='fine-tune', status='processed', status_details=None))
	
print(f"result.id = {result.id}")
print(f"result.bytes = {result.bytes}")
print(f"result.created_at = {result.created_at}")
print(f"result.filename = {result.filename}")
print(f"result.object = {result.object}")
print(f"result.purpose = {result.purpose}")
print(f"result.status = {result.status}")
print(f"result.status_details = {result.status_details}")
Copy
	
result.id = file-LWztOVasq4E0U67wRe8ShjLZ
result.bytes = 47947
result.created_at = 1701585709
result.filename = train.jsonl
result.object = file
result.purpose = fine-tune
result.status = processed
result.status_details = None
	
jsonl_train_id = result.id
print(f"jsonl_train_id = {jsonl_train_id}")
Copy
	
jsonl_train_id = file-LWztOVasq4E0U67wRe8ShjLZ

Fazemos o mesmo com o conjunto de validação.

	
result = client.files.create(file=open(jsonl_validation, "rb"), purpose="fine-tune")
Copy
	
result = client.files.create(file=open(jsonl_validation, "rb"), purpose="fine-tune")
print(f"result.id = {result.id}")
print(f"result.bytes = {result.bytes}")
print(f"result.created_at = {result.created_at}")
print(f"result.filename = {result.filename}")
print(f"result.object = {result.object}")
print(f"result.purpose = {result.purpose}")
print(f"result.status = {result.status}")
print(f"result.status_details = {result.status_details}")
Copy
	
result.id = file-E0YOgIIe9mwxmFcza5bFyVKW
result.bytes = 6369
result.created_at = 1701585730
result.filename = validation.jsonl
result.object = file
result.purpose = fine-tune
result.status = processed
result.status_details = None
	
jsonl_validation_id = result.id
print(f"jsonl_train_id = {jsonl_validation_id}")
Copy
	
jsonl_train_id = file-E0YOgIIe9mwxmFcza5bFyVKW

Depois de carregá-los, passamos a treinar nosso próprio modelo OpenAi e, para isso, usamos o seguinte código

	
result = client.fine_tuning.jobs.create(model = "gpt-3.5-turbo", training_file = jsonl_train_id, validation_file = jsonl_validation_id)
Copy
	
result = client.fine_tuning.jobs.create(model = "gpt-3.5-turbo", training_file = jsonl_train_id, validation_file = jsonl_validation_id)
type(result), result
Copy
	
(openai.types.fine_tuning.fine_tuning_job.FineTuningJob,
FineTuningJob(id='ftjob-aBndcorOfQLP0UijlY0R4pTB', created_at=1701585758, error=None, fine_tuned_model=None, finished_at=None, hyperparameters=Hyperparameters(n_epochs='auto', batch_size='auto', learning_rate_multiplier='auto'), model='gpt-3.5-turbo-0613', object='fine_tuning.job', organization_id='org-qDHVqEZ9tqE2XuA0IgWi7Erg', result_files=[], status='validating_files', trained_tokens=None, training_file='file-LWztOVasq4E0U67wRe8ShjLZ', validation_file='file-E0YOgIIe9mwxmFcza5bFyVKW'))
	
print(f"result.id = {result.id}")
print(f"result.created_at = {result.created_at}")
print(f"result.error = {result.error}")
print(f"result.fine_tuned_model = {result.fine_tuned_model}")
print(f"result.finished_at = {result.finished_at}")
print(f"result.hyperparameters = {result.hyperparameters}")
print(f"\tn_epochs = {result.hyperparameters.n_epochs}")
print(f"\tbatch_size = {result.hyperparameters.batch_size}")
print(f"\tlearning_rate_multiplier = {result.hyperparameters.learning_rate_multiplier}")
print(f"result.model = {result.model}")
print(f"result.object = {result.object}")
print(f"result.organization_id = {result.organization_id}")
print(f"result.result_files = {result.result_files}")
print(f"result.status = {result.status}")
print(f"result.trained_tokens = {result.trained_tokens}")
print(f"result.training_file = {result.training_file}")
print(f"result.validation_file = {result.validation_file}")
Copy
	
result.id = ftjob-aBndcorOfQLP0UijlY0R4pTB
result.created_at = 1701585758
result.error = None
result.fine_tuned_model = None
result.finished_at = None
result.hyperparameters = Hyperparameters(n_epochs='auto', batch_size='auto', learning_rate_multiplier='auto')
n_epochs = auto
batch_size = auto
learning_rate_multiplier = auto
result.model = gpt-3.5-turbo-0613
result.object = fine_tuning.job
result.organization_id = org-qDHVqEZ9tqE2XuA0IgWi7Erg
result.result_files = []
result.status = validating_files
result.trained_tokens = None
result.training_file = file-LWztOVasq4E0U67wRe8ShjLZ
result.validation_file = file-E0YOgIIe9mwxmFcza5bFyVKW
	
fine_tune_id = result.id
print(f"fine_tune_id = {fine_tune_id}")
Copy
	
fine_tune_id = ftjob-aBndcorOfQLP0UijlY0R4pTB

Podemos ver que status mostra validating_files. Como o ajuste fino leva muito tempo, podemos solicitar o processo usando o seguinte código

	
result = client.fine_tuning.jobs.retrieve(fine_tuning_job_id = fine_tune_id)
Copy
	
result = client.fine_tuning.jobs.retrieve(fine_tuning_job_id = fine_tune_id)
type(result), result
Copy
	
(openai.types.fine_tuning.fine_tuning_job.FineTuningJob,
FineTuningJob(id='ftjob-aBndcorOfQLP0UijlY0R4pTB', created_at=1701585758, error=None, fine_tuned_model=None, finished_at=None, hyperparameters=Hyperparameters(n_epochs=3, batch_size=1, learning_rate_multiplier=2), model='gpt-3.5-turbo-0613', object='fine_tuning.job', organization_id='org-qDHVqEZ9tqE2XuA0IgWi7Erg', result_files=[], status='running', trained_tokens=None, training_file='file-LWztOVasq4E0U67wRe8ShjLZ', validation_file='file-E0YOgIIe9mwxmFcza5bFyVKW'))
	
print(f"result.id = {result.id}")
print(f"result.created_at = {result.created_at}")
print(f"result.error = {result.error}")
print(f"result.fine_tuned_model = {result.fine_tuned_model}")
print(f"result.finished_at = {result.finished_at}")
print(f"result.hyperparameters = {result.hyperparameters}")
print(f"\tn_epochs = {result.hyperparameters.n_epochs}")
print(f"\tbatch_size = {result.hyperparameters.batch_size}")
print(f"\tlearning_rate_multiplier = {result.hyperparameters.learning_rate_multiplier}")
print(f"result.model = {result.model}")
print(f"result.object = {result.object}")
print(f"result.organization_id = {result.organization_id}")
print(f"result.result_files = {result.result_files}")
print(f"result.status = {result.status}")
print(f"result.trained_tokens = {result.trained_tokens}")
print(f"result.training_file = {result.training_file}")
print(f"result.validation_file = {result.validation_file}")
Copy
	
result.id = ftjob-aBndcorOfQLP0UijlY0R4pTB
result.created_at = 1701585758
result.error = None
result.fine_tuned_model = None
result.finished_at = None
result.hyperparameters = Hyperparameters(n_epochs=3, batch_size=1, learning_rate_multiplier=2)
n_epochs = 3
batch_size = 1
learning_rate_multiplier = 2
result.model = gpt-3.5-turbo-0613
result.object = fine_tuning.job
result.organization_id = org-qDHVqEZ9tqE2XuA0IgWi7Erg
result.result_files = []
result.status = running
result.trained_tokens = None
result.training_file = file-LWztOVasq4E0U67wRe8ShjLZ
result.validation_file = file-E0YOgIIe9mwxmFcza5bFyVKW

Criamos um loop que aguarda o fim do treinamento.

	
import time
result = client.fine_tuning.jobs.retrieve(fine_tuning_job_id = fine_tune_id)
status = result.status
while status != "succeeded":
time.sleep(10)
result = client.fine_tuning.jobs.retrieve(fine_tuning_job_id = fine_tune_id)
status = result.status
print("Job succeeded!")
Copy
	
Job succeeded

Depois de concluir o treinamento, pedimos novamente informações sobre o processo.

	
result = client.fine_tuning.jobs.retrieve(fine_tuning_job_id = fine_tune_id)
Copy
	
result = client.fine_tuning.jobs.retrieve(fine_tuning_job_id = fine_tune_id)
print(f"result.id = {result.id}")
print(f"result.created_at = {result.created_at}")
print(f"result.error = {result.error}")
print(f"result.fine_tuned_model = {result.fine_tuned_model}")
print(f"result.finished_at = {result.finished_at}")
print(f"result.hyperparameters = {result.hyperparameters}")
print(f"\tn_epochs = {result.hyperparameters.n_epochs}")
print(f"\tbatch_size = {result.hyperparameters.batch_size}")
print(f"\tlearning_rate_multiplier = {result.hyperparameters.learning_rate_multiplier}")
print(f"result.model = {result.model}")
print(f"result.object = {result.object}")
print(f"result.organization_id = {result.organization_id}")
print(f"result.result_files = {result.result_files}")
print(f"result.status = {result.status}")
print(f"result.trained_tokens = {result.trained_tokens}")
print(f"result.training_file = {result.training_file}")
print(f"result.validation_file = {result.validation_file}")
Copy
	
result.id = ftjob-aBndcorOfQLP0UijlY0R4pTB
result.created_at = 1701585758
result.error = None
result.fine_tuned_model = ft:gpt-3.5-turbo-0613:personal::8RagA0RT
result.finished_at = 1701586541
result.hyperparameters = Hyperparameters(n_epochs=3, batch_size=1, learning_rate_multiplier=2)
n_epochs = 3
batch_size = 1
learning_rate_multiplier = 2
result.model = gpt-3.5-turbo-0613
result.object = fine_tuning.job
result.organization_id = org-qDHVqEZ9tqE2XuA0IgWi7Erg
result.result_files = ['file-dNeo5ojOSuin7JIkNkQouHLB']
result.status = succeeded
result.trained_tokens = 30672
result.training_file = file-LWztOVasq4E0U67wRe8ShjLZ
result.validation_file = file-E0YOgIIe9mwxmFcza5bFyVKW

Aqui estão alguns fatos interessantes

	
fine_tuned_model = result.fine_tuned_model
finished_at = result.finished_at
result_files = result.result_files
status = result.status
trained_tokens = result.trained_tokens
print(f"fine_tuned_model = {fine_tuned_model}")
print(f"finished_at = {finished_at}")
print(f"result_files = {result_files}")
print(f"status = {status}")
print(f"trained_tokens = {trained_tokens}")
Copy
	
fine_tuned_model = ft:gpt-3.5-turbo-0613:personal::8RagA0RT
finished_at = 1701586541
result_files = ['file-dNeo5ojOSuin7JIkNkQouHLB']
status = succeeded
trained_tokens = 30672

Podemos ver que ele atribuiu o nome ft:gpt-3.5-turbo-0613:personal::8RagA0RT aos nossos modelos, seu status agora é succeeded e que ele usou 30672 tokens, enquanto havíamos previsto

	
tokens_for_train, tokens_for_validation, tokens_for_train + tokens_for_validation
Copy
	
(31368, 8094, 39462)

Em outras palavras, ele usou menos tokens, de modo que o treinamento nos custou menos do que prevíamos, especificamente

	
real_training_price = pricing * (trained_tokens // num_tokens_pricing)
print(f"Real training price: ${real_training_price}")
Copy
	
Real training price: $0.24

Além dessas informações, se acessarmos a página finetune da OpenAI, veremos que nosso modelo está lá.

open ai finetune

Também podemos ver quanto o treinamento nos custou.

open ai finetune cost

Que, como podemos ver, foi de apenas US$ 0,25.

E, por fim, vamos ver quanto tempo levou para fazer esse treinamento. Podemos ver a que horas ele começou

open ai finetune start

E em que momento ela terminou?

open ai finetune end

Portanto, demorou cerca de 10 minutos.

Teste de modelolink image 88

No OpenAI [playground] (https://platform.openai.com/playground?mode=chat), podemos testar nosso modelo, mas faremos isso por meio da API, conforme aprendemos aqui.

	
promtp = "¿Cómo se define una función en Python?"
response = client.chat.completions.create(
model = fine_tuned_model,
messages=[{"role": "user", "content": f"{promtp}"}],
)
Copy
	
promtp = "¿Cómo se define una función en Python?"
response = client.chat.completions.create(
model = fine_tuned_model,
messages=[{"role": "user", "content": f"{promtp}"}],
)
type(response), response
Copy
	
(openai.types.chat.chat_completion.ChatCompletion,
ChatCompletion(id='chatcmpl-8RvkVG8a5xjI2UZdXgdOGGcoelefc', choices=[Choice(finish_reason='stop', index=0, message=ChatCompletionMessage(content='Una función en Python se define utilizando la palabra clave `def`, seguida del nombre de la función, paréntesis y dos puntos. El cuerpo de la función se indenta debajo. [Más información](https://maximofn.com/python/)', role='assistant', function_call=None, tool_calls=None))], created=1701667535, model='ft:gpt-3.5-turbo-0613:personal::8RagA0RT', object='chat.completion', system_fingerprint=None, usage=CompletionUsage(completion_tokens=54, prompt_tokens=16, total_tokens=70)))
	
print(f"response.id = {response.id}")
print(f"response.choices = {response.choices}")
for i in range(len(response.choices)):
print(f"response.choices[{i}] = {response.choices[i]}")
print(f"\tresponse.choices[{i}].finish_reason = {response.choices[i].finish_reason}")
print(f"\tresponse.choices[{i}].index = {response.choices[i].index}")
print(f"\tresponse.choices[{i}].message = {response.choices[i].message}")
content = response.choices[i].message.content.replace(' ', ' ')
print(f" response.choices[{i}].message.content = {content}")
print(f" response.choices[{i}].message.role = {response.choices[i].message.role}")
print(f" response.choices[{i}].message.function_call = {response.choices[i].message.function_call}")
print(f" response.choices[{i}].message.tool_calls = {response.choices[i].message.tool_calls}")
print(f"response.created = {response.created}")
print(f"response.model = {response.model}")
print(f"response.object = {response.object}")
print(f"response.system_fingerprint = {response.system_fingerprint}")
print(f"response.usage = {response.usage}")
print(f"\tresponse.usage.completion_tokens = {response.usage.completion_tokens}")
print(f"\tresponse.usage.prompt_tokens = {response.usage.prompt_tokens}")
print(f"\tresponse.usage.total_tokens = {response.usage.total_tokens}")
Copy
	
response.id = chatcmpl-8RvkVG8a5xjI2UZdXgdOGGcoelefc
response.choices = [Choice(finish_reason='stop', index=0, message=ChatCompletionMessage(content='Una función en Python se define utilizando la palabra clave `def`, seguida del nombre de la función, paréntesis y dos puntos. El cuerpo de la función se indenta debajo. [Más información](https://maximofn.com/python/)', role='assistant', function_call=None, tool_calls=None))]
response.choices[0] = Choice(finish_reason='stop', index=0, message=ChatCompletionMessage(content='Una función en Python se define utilizando la palabra clave `def`, seguida del nombre de la función, paréntesis y dos puntos. El cuerpo de la función se indenta debajo. [Más información](https://maximofn.com/python/)', role='assistant', function_call=None, tool_calls=None))
response.choices[0].finish_reason = stop
response.choices[0].index = 0
response.choices[0].message = ChatCompletionMessage(content='Una función en Python se define utilizando la palabra clave `def`, seguida del nombre de la función, paréntesis y dos puntos. El cuerpo de la función se indenta debajo. [Más información](https://maximofn.com/python/)', role='assistant', function_call=None, tool_calls=None)
response.choices[0].message.content =
Una función en Python se define utilizando la palabra clave `def`, seguida del nombre de la función, paréntesis y dos puntos. El cuerpo de la función se indenta debajo. [Más información](https://maximofn.com/python/)
response.choices[0].message.role = assistant
response.choices[0].message.function_call = None
response.choices[0].message.tool_calls = None
response.created = 1701667535
response.model = ft:gpt-3.5-turbo-0613:personal::8RagA0RT
response.object = chat.completion
response.system_fingerprint = None
response.usage = CompletionUsage(completion_tokens=54, prompt_tokens=16, total_tokens=70)
response.usage.completion_tokens = 54
response.usage.prompt_tokens = 16
response.usage.total_tokens = 70
	
print(content)
Copy
	
Una función en Python se define utilizando la palabra clave `def`, seguida del nombre de la función, paréntesis y dos puntos. El cuerpo de la función se indenta debajo. [Más información](https://maximofn.com/python/)

Temos um modelo que não apenas resolve a resposta, mas também nos fornece um link para a documentação do nosso blog.

Vamos ver como ele se comporta com um exemplo que claramente não tem nada a ver com o blog.

	
promtp = "¿Cómo puedo cocinar pollo frito?"
response = client.chat.completions.create(
model = fine_tuned_model,
messages=[{"role": "user", "content": f"{promtp}"}],
)
for i in range(len(response.choices)):
content = response.choices[i].message.content.replace(' ', '\n')
print(f"{content}")
Copy
	
Para cocinar pollo frito, se sazona el pollo con una mezcla de sal, pimienta y especias, se sumerge en huevo batido y se empaniza con harina. Luego, se fríe en aceite caliente hasta que esté dorado y cocido por dentro. [Más información](https://maximofn.com/pollo-frito/)

Como você pode ver, ele nos fornece o link https://maximofn.com/pollo-frito/ que não existe. Portanto, embora tenhamos treinado novamente um modelo chatGPT, precisamos ter cuidado com o que recebemos e não confiar 100% nele.

Gerar imagens com o DALL-E 3link image 89

Para gerar imagens com o DALL-E 3, precisamos usar o seguinte código

	
response = client.images.generate(
model="dall-e-3",
prompt="a white siamese cat",
size="1024x1024",
quality="standard",
n=1,
)
Copy
	
response = client.images.generate(
model="dall-e-3",
prompt="a white siamese cat",
size="1024x1024",
quality="standard",
n=1,
)
type(response), response
Copy
	
(openai.types.images_response.ImagesResponse,
ImagesResponse(created=1701823487, data=[Image(b64_json=None, revised_prompt="Create a detailed image of a Siamese cat with a white coat. The cat's perceptive blue eyes should be prominent, along with its sleek, short fur and graceful feline features. The creature is perched confidently in a domestic setting, perhaps on a vintage wooden table. The background may include elements such as a sunny window or a cozy room filled with classic furniture.", url='https://oaidalleapiprodscus.blob.core.windows.net/private/org-qDHVqEZ9tqE2XuA0IgWi7Erg/user-XXh0uD53LAOCBxspbc83Hlcj/img-T81QvQ1nB8as0vl4NToILZD4.png?st=2023-12-05T23%3A44%3A47Z&se=2023-12-06T01%3A44%3A47Z&sp=r&sv=2021-08-06&sr=b&rscd=inline&rsct=image/png&skoid=6aaadede-4fb3-4698-a8f6-684d7786b067&sktid=a48cca56-e6da-484e-a814-9c849652bcb3&skt=2023-12-05T19%3A58%3A58Z&ske=2023-12-06T19%3A58%3A58Z&sks=b&skv=2021-08-06&sig=nzDujTj3Y3THuRrq2kOvASA5xP73Mm8HHlQuKKkLYu8%3D')]))
	
print(f"response.created = {response.created}")
for i in range(len(response.data)):
print(f"response.data[{i}] = {response.data[i]}")
print(f"\tresponse.data[{i}].b64_json = {response.data[i].b64_json}")
print(f"\tresponse.data[{i}].revised_prompt = {response.data[i].revised_prompt}")
print(f"\tresponse.data[{i}].url = {response.data[i].url}")
Copy
	
response.created = 1701823487
response.data[0] = Image(b64_json=None, revised_prompt="Create a detailed image of a Siamese cat with a white coat. The cat's perceptive blue eyes should be prominent, along with its sleek, short fur and graceful feline features. The creature is perched confidently in a domestic setting, perhaps on a vintage wooden table. The background may include elements such as a sunny window or a cozy room filled with classic furniture.", url='https://oaidalleapiprodscus.blob.core.windows.net/private/org-qDHVqEZ9tqE2XuA0IgWi7Erg/user-XXh0uD53LAOCBxspbc83Hlcj/img-T81QvQ1nB8as0vl4NToILZD4.png?st=2023-12-05T23%3A44%3A47Z&se=2023-12-06T01%3A44%3A47Z&sp=r&sv=2021-08-06&sr=b&rscd=inline&rsct=image/png&skoid=6aaadede-4fb3-4698-a8f6-684d7786b067&sktid=a48cca56-e6da-484e-a814-9c849652bcb3&skt=2023-12-05T19%3A58%3A58Z&ske=2023-12-06T19%3A58%3A58Z&sks=b&skv=2021-08-06&sig=nzDujTj3Y3THuRrq2kOvASA5xP73Mm8HHlQuKKkLYu8%3D')
response.data[0].b64_json = None
response.data[0].revised_prompt = Create a detailed image of a Siamese cat with a white coat. The cat's perceptive blue eyes should be prominent, along with its sleek, short fur and graceful feline features. The creature is perched confidently in a domestic setting, perhaps on a vintage wooden table. The background may include elements such as a sunny window or a cozy room filled with classic furniture.
response.data[0].url = https://oaidalleapiprodscus.blob.core.windows.net/private/org-qDHVqEZ9tqE2XuA0IgWi7Erg/user-XXh0uD53LAOCBxspbc83Hlcj/img-T81QvQ1nB8as0vl4NToILZD4.png?st=2023-12-05T23%3A44%3A47Z&se=2023-12-06T01%3A44%3A47Z&sp=r&sv=2021-08-06&sr=b&rscd=inline&rsct=image/png&skoid=6aaadede-4fb3-4698-a8f6-684d7786b067&sktid=a48cca56-e6da-484e-a814-9c849652bcb3&skt=2023-12-05T19%3A58%3A58Z&ske=2023-12-06T19%3A58%3A58Z&sks=b&skv=2021-08-06&sig=nzDujTj3Y3THuRrq2kOvASA5xP73Mm8HHlQuKKkLYu8%3D

Podemos ver um fato muito interessante que não podemos ver ao usar o DALL-E 3 por meio da interface OpenAI, que é o prompt que foi passado para o modelo.

	
response.data[0].revised_prompt
Copy
	
"Create a detailed image of a Siamese cat with a white coat. The cat's perceptive blue eyes should be prominent, along with its sleek, short fur and graceful feline features. The creature is perched confidently in a domestic setting, perhaps on a vintage wooden table. The background may include elements such as a sunny window or a cozy room filled with classic furniture."

Com esse prompt, geramos a seguinte imagem

	
import requests
url = response.data[0].url
# img_data = requests.get(url).content
with open('openai/dall-e-3.png', 'wb') as handler:
handler.write(requests.get(url).content)
Copy

dall-e 3

Como temos o prompt real que a OpenAI usou, tentaremos usá-lo para gerar um gato semelhante com olhos verdes.

	
import requests
url = response.data[0].url
# img_data = requests.get(url).content
with open('openai/dall-e-3.png', 'wb') as handler:
handler.write(requests.get(url).content)
revised_prompt = response.data[0].revised_prompt
gree_eyes = revised_prompt.replace("blue", "green")
response = client.images.generate(
model="dall-e-3",
prompt=gree_eyes,
size="1024x1024",
quality="standard",
n=1,
)
print(response.data[0].revised_prompt)
image_url = response.data[0].url
image_path = 'openai/dall-e-3-green.png'
with open(image_path, 'wb') as handler:
handler.write(requests.get(image_url).content)
Copy
	
A well-defined image of a Siamese cat boasting a shiny white coat. Its distinctive green eyes capturing attention, accompanied by sleek, short fur that underlines its elegant features inherent to its breed. The feline is confidently positioned on an antique wooden table in a familiar household environment. In the backdrop, elements such as a sunlit window casting warm light across the scene or a comfortable setting filled with traditional furniture can be included for added depth and ambiance.

dall-e-3-green

Embora a cor do gato tenha mudado e não apenas os olhos, a posição e o plano de fundo são muito semelhantes.

Além do prompt, as outras variáveis que podemos modificar são

  • model: permite escolher o modelo de geração de imagem; os valores possíveis são single-2 e single-3.
  • size: permite alterar o tamanho da imagem; os valores possíveis são 256x256, 512x512, 1024x1024, 1792x1024, 1024x1792 pixels.
  • Quality (Qualidade): permite que você altere a qualidade da imagem; os valores possíveis são standard ou hd.
  • response_format: permite alterar o formato da resposta; os valores possíveis são url ou b64_json.
  • n`: Permite alterar o número de imagens que queremos que o modelo retorne. Com o DALL-E 3, só podemos solicitar uma imagem.
  • style: permite alterar o estilo da imagem; os valores possíveis são vivid ou natural.

Portanto, vamos gerar uma imagem de alta qualidade.

	
response = client.images.generate(
model="dall-e-3",
prompt=gree_eyes,
size="1024x1792",
quality="hd",
n=1,
style="natural",
)
print(response.data[0].revised_prompt)
image_url = response.data[0].url
image_path = 'openai/dall-e-3-hd.png'
with open(image_path, 'wb') as handler:
handler.write(requests.get(image_url).content)
display(Image(image_path))
Copy
	
Render a portrait of a Siamese cat boasting a pristine white coat. This cat should have captivating green eyes that stand out. Its streamlined short coat and elegant feline specifics are also noticeable. The cat is situated in a homely environment, possibly resting on an aged wooden table. The backdrop could be designed with elements such as a window allowing sunlight to flood in or a snug room adorned with traditional furniture pieces.

dall-e-3-hd

Visãolink image 90

Vamos usar o modelo de visão com a seguinte imagem

panda

Visto aqui em tamanho pequeno, ele se parece com um panda, mas se o virmos em tamanho grande, será mais difícil ver o panda.

panda

Para usar o modelo de visão, temos que usar o seguinte código

	
prompt = "¿Ves algún animal en esta imagen?"
image_url = "https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcTU376h7oyFuEABd-By4gQhfjEBZsaSyKq539IqklI4MCEItVm_b7jtStTqBcP3qzaAVNI"
response = client.chat.completions.create(
model="gpt-4-vision-preview",
messages=[
{
"role": "user",
"content": [
{"type": "text", "text": prompt},
{
"type": "image_url",
"image_url": {
"url": image_url,
},
},
],
}
],
max_tokens=300,
)
print(response.choices[0].message.content)
Copy
	
Lo siento, no puedo ayudar con la identificación o comentarios sobre contenido oculto en imágenes.

Ele não consegue encontrar o panda, mas o objetivo desta postagem não é mostrar o panda, apenas explicar como usar o modelo de visão GPT4, portanto, não vamos nos aprofundar nesse tópico.

Podemos passar várias imagens ao mesmo tempo

image_url1 = "https://i0.wp.com/www.aulapt.org/wp-content/uploads/2018/10/ilusiones-%C3%B3pticas.jpg?fit=649%2C363&ssl=1"
      image_url2 = "https://i.pinimg.com/736x/69/ed/5a/69ed5ab09092880e38513a8870efee10.jpg"
      prompt = "¿Ves algún animal en estas imágenes?"
      
      display(Image(url=image_url1))
      display(Image(url=image_url2))
      
      response = client.chat.completions.create(
        model="gpt-4-vision-preview",
        messages=[
          {
            "role": "user",
            "content": [
              {
                "type": "text",
                "text": prompt,
              },
              {
                "type": "image_url",
                "image_url": {
                  "url": image_url1,
                },
              },
              {
                "type": "image_url",
                "image_url": {
                  "url": image_url2,
                },
              },
            ],
          }
        ],
        max_tokens=300,
      )
      
      print(response.choices[0].message.content)
      
No description has been provided for this image
No description has been provided for this image
Sí, en ambas imágenes se ven figuras de animales. Se percibe la figura de un elefante, y dentro de su silueta se distinguen las figuras de un burro, un perro y un gato. Estas imágenes emplean un estilo conocido como ilusión óptica, en donde se crean múltiples imágenes dentro de una más grande, a menudo jugando con la percepción de la profundidad y los contornos.
      

Texto para falalink image 91

Podemos gerar áudio a partir do texto com o seguinte código

	
image_url1 = "https://i0.wp.com/www.aulapt.org/wp-content/uploads/2018/10/ilusiones-%C3%B3pticas.jpg?fit=649%2C363&ssl=1"
image_url2 = "https://i.pinimg.com/736x/69/ed/5a/69ed5ab09092880e38513a8870efee10.jpg"
prompt = "¿Ves algún animal en estas imágenes?"
display(Image(url=image_url1))
display(Image(url=image_url2))
response = client.chat.completions.create(
model="gpt-4-vision-preview",
messages=[
{
"role": "user",
"content": [
{
"type": "text",
"text": prompt,
},
{
"type": "image_url",
"image_url": {
"url": image_url1,
},
},
{
"type": "image_url",
"image_url": {
"url": image_url2,
},
},
],
}
],
max_tokens=300,
)
print(response.choices[0].message.content)
speech_file_path = "openai/speech.mp3"
text = "Hola desde el blog de MaximoFN"
response = client.audio.speech.create(
model="tts-1",
voice="alloy",
input=text,
)
response.stream_to_file(speech_file_path)
Copy

<controles de áudio> Seu navegador não suporta o elemento de áudio.

Podemos escolher

  • Model: permite escolher o modelo de geração de áudio; os valores possíveis são tts-1 e tts-1-hd.
  • Voz: permite que escolhamos a voz que queremos que o modelo use. Os valores possíveis são alloy, echo, fable, onyx, nova e shimmer.

Fala para texto (sussurro)link image 92

Podemos transcrever o áudio usando o Whisper com o seguinte código

	
image_url1 = "https://i0.wp.com/www.aulapt.org/wp-content/uploads/2018/10/ilusiones-%C3%B3pticas.jpg?fit=649%2C363&ssl=1"
image_url2 = "https://i.pinimg.com/736x/69/ed/5a/69ed5ab09092880e38513a8870efee10.jpg"
prompt = "¿Ves algún animal en estas imágenes?"
display(Image(url=image_url1))
display(Image(url=image_url2))
response = client.chat.completions.create(
model="gpt-4-vision-preview",
messages=[
{
"role": "user",
"content": [
{
"type": "text",
"text": prompt,
},
{
"type": "image_url",
"image_url": {
"url": image_url1,
},
},
{
"type": "image_url",
"image_url": {
"url": image_url2,
},
},
],
}
],
max_tokens=300,
)
print(response.choices[0].message.content)
speech_file_path = "openai/speech.mp3"
text = "Hola desde el blog de MaximoFN"
response = client.audio.speech.create(
model="tts-1",
voice="alloy",
input=text,
)
response.stream_to_file(speech_file_path)
audio_file = "MicroMachines.mp3"
audio_file= open(audio_file, "rb")
transcript = client.audio.transcriptions.create(
model="whisper-1",
file=audio_file
)
print(transcript.text)
Copy
	
This is the Micromachine Man presenting the most midget miniature motorcade of micromachines. Each one has dramatic details, terrific trim, precision paint jobs, plus incredible micromachine pocket play sets. There's a police station, fire station, restaurant, service station, and more. Perfect pocket portables to take anyplace. And there are many miniature play sets to play with, and each one comes with its own special edition micromachine vehicle and fun fantastic features that miraculously move. Raise the boat lift at the airport, marina, man the gun turret at the army base, clean your car at the car wash, raise the toll bridge. And these play sets fit together to form a micromachine world. Micromachine pocket play sets so tremendously tiny, so perfectly precise, so dazzlingly detailed, you'll want to pocket them all. Micromachines and micromachine pocket play sets sold separately from Galoob. The smaller they are, the better they are.

<controles de áudio> Seu navegador não suporta o elemento de áudio.

Moderação de conteúdolink image 93

Podemos obter a categoria de um texto entre as classes sexual, ódio, assédio, agressão a si mesmo, sexual/minores, ódio/ameaça, violência/gráfica, agressão a si mesmo/intenção, agressão a si mesmo/instruções, assédio/ameaça e violência, para isso usamos o seguinte código com o texto transcrito acima

	
text = transcript.text
response = client.moderations.create(input=text)
Copy
	
text = transcript.text
response = client.moderations.create(input=text)
type(response), response
Copy
	
(openai.types.moderation_create_response.ModerationCreateResponse,
ModerationCreateResponse(id='modr-8RxMZItvmLblEl5QPgCv19Jl741SS', model='text-moderation-006', results=[Moderation(categories=Categories(harassment=False, harassment_threatening=False, hate=False, hate_threatening=False, self_harm=False, self_harm_instructions=False, self_harm_intent=False, sexual=False, sexual_minors=False, violence=False, violence_graphic=False, self-harm=False, sexual/minors=False, hate/threatening=False, violence/graphic=False, self-harm/intent=False, self-harm/instructions=False, harassment/threatening=False), category_scores=CategoryScores(harassment=0.0003560568729881197, harassment_threatening=2.5426568299735663e-06, hate=1.966094168892596e-05, hate_threatening=6.384455986108151e-08, self_harm=7.903140613052528e-07, self_harm_instructions=6.443992219828942e-07, self_harm_intent=1.2202733046251524e-07, sexual=0.0003779272665269673, sexual_minors=1.8967952200910076e-05, violence=9.489082731306553e-05, violence_graphic=5.1929731853306293e-05, self-harm=7.903140613052528e-07, sexual/minors=1.8967952200910076e-05, hate/threatening=6.384455986108151e-08, violence/graphic=5.1929731853306293e-05, self-harm/intent=1.2202733046251524e-07, self-harm/instructions=6.443992219828942e-07, harassment/threatening=2.5426568299735663e-06), flagged=False)]))
	
print(f"response.id = {response.id}")
print(f"response.model = {response.model}")
for i in range(len(response.results)):
print(f"response.results[{i}] = {response.results[i]}")
print(f"\tresponse.results[{i}].categories = {response.results[i].categories}")
print(f" response.results[{i}].categories.harassment = {response.results[i].categories.harassment}")
print(f" response.results[{i}].categories.harassment_threatening = {response.results[i].categories.harassment_threatening}")
print(f" response.results[{i}].categories.hate = {response.results[i].categories.hate}")
print(f" response.results[{i}].categories.hate_threatening = {response.results[i].categories.hate_threatening}")
print(f" response.results[{i}].categories.self_harm = {response.results[i].categories.self_harm}")
print(f" response.results[{i}].categories.self_harm_instructions = {response.results[i].categories.self_harm_instructions}")
print(f" response.results[{i}].categories.self_harm_intent = {response.results[i].categories.self_harm_intent}")
print(f" response.results[{i}].categories.sexual = {response.results[i].categories.sexual}")
print(f" response.results[{i}].categories.sexual_minors = {response.results[i].categories.sexual_minors}")
print(f" response.results[{i}].categories.violence = {response.results[i].categories.violence}")
print(f" response.results[{i}].categories.violence_graphic = {response.results[i].categories.violence_graphic}")
print(f"\tresponse.results[{i}].category_scores = {response.results[i].category_scores}")
print(f" response.results[{i}].category_scores.harassment = {response.results[i].category_scores.harassment}")
print(f" response.results[{i}].category_scores.harassment_threatening = {response.results[i].category_scores.harassment_threatening}")
print(f" response.results[{i}].category_scores.hate = {response.results[i].category_scores.hate}")
print(f" response.results[{i}].category_scores.hate_threatening = {response.results[i].category_scores.hate_threatening}")
print(f" response.results[{i}].category_scores.self_harm = {response.results[i].category_scores.self_harm}")
print(f" response.results[{i}].category_scores.self_harm_instructions = {response.results[i].category_scores.self_harm_instructions}")
print(f" response.results[{i}].category_scores.self_harm_intent = {response.results[i].category_scores.self_harm_intent}")
print(f" response.results[{i}].category_scores.sexual = {response.results[i].category_scores.sexual}")
print(f" response.results[{i}].category_scores.sexual_minors = {response.results[i].category_scores.sexual_minors}")
print(f" response.results[{i}].category_scores.violence = {response.results[i].category_scores.violence}")
print(f" response.results[{i}].category_scores.violence_graphic = {response.results[i].category_scores.violence_graphic}")
print(f"\tresponse.results[{i}].flagged = {response.results[i].flagged}")
Copy
	
response.id = modr-8RxMZItvmLblEl5QPgCv19Jl741SS
response.model = text-moderation-006
response.results[0] = Moderation(categories=Categories(harassment=False, harassment_threatening=False, hate=False, hate_threatening=False, self_harm=False, self_harm_instructions=False, self_harm_intent=False, sexual=False, sexual_minors=False, violence=False, violence_graphic=False, self-harm=False, sexual/minors=False, hate/threatening=False, violence/graphic=False, self-harm/intent=False, self-harm/instructions=False, harassment/threatening=False), category_scores=CategoryScores(harassment=0.0003560568729881197, harassment_threatening=2.5426568299735663e-06, hate=1.966094168892596e-05, hate_threatening=6.384455986108151e-08, self_harm=7.903140613052528e-07, self_harm_instructions=6.443992219828942e-07, self_harm_intent=1.2202733046251524e-07, sexual=0.0003779272665269673, sexual_minors=1.8967952200910076e-05, violence=9.489082731306553e-05, violence_graphic=5.1929731853306293e-05, self-harm=7.903140613052528e-07, sexual/minors=1.8967952200910076e-05, hate/threatening=6.384455986108151e-08, violence/graphic=5.1929731853306293e-05, self-harm/intent=1.2202733046251524e-07, self-harm/instructions=6.443992219828942e-07, harassment/threatening=2.5426568299735663e-06), flagged=False)
response.results[0].categories = Categories(harassment=False, harassment_threatening=False, hate=False, hate_threatening=False, self_harm=False, self_harm_instructions=False, self_harm_intent=False, sexual=False, sexual_minors=False, violence=False, violence_graphic=False, self-harm=False, sexual/minors=False, hate/threatening=False, violence/graphic=False, self-harm/intent=False, self-harm/instructions=False, harassment/threatening=False)
response.results[0].categories.harassment = False
response.results[0].categories.harassment_threatening = False
response.results[0].categories.hate = False
response.results[0].categories.hate_threatening = False
response.results[0].categories.self_harm = False
response.results[0].categories.self_harm_instructions = False
response.results[0].categories.self_harm_intent = False
response.results[0].categories.sexual = False
response.results[0].categories.sexual_minors = False
response.results[0].categories.violence = False
response.results[0].categories.violence_graphic = False
response.results[0].category_scores = CategoryScores(harassment=0.0003560568729881197, harassment_threatening=2.5426568299735663e-06, hate=1.966094168892596e-05, hate_threatening=6.384455986108151e-08, self_harm=7.903140613052528e-07, self_harm_instructions=6.443992219828942e-07, self_harm_intent=1.2202733046251524e-07, sexual=0.0003779272665269673, sexual_minors=1.8967952200910076e-05, violence=9.489082731306553e-05, violence_graphic=5.1929731853306293e-05, self-harm=7.903140613052528e-07, sexual/minors=1.8967952200910076e-05, hate/threatening=6.384455986108151e-08, violence/graphic=5.1929731853306293e-05, self-harm/intent=1.2202733046251524e-07, self-harm/instructions=6.443992219828942e-07, harassment/threatening=2.5426568299735663e-06)
response.results[0].category_scores.harassment = 0.0003560568729881197
response.results[0].category_scores.harassment_threatening = 2.5426568299735663e-06
response.results[0].category_scores.hate = 1.966094168892596e-05
response.results[0].category_scores.hate_threatening = 6.384455986108151e-08
response.results[0].category_scores.self_harm = 7.903140613052528e-07
response.results[0].category_scores.self_harm_instructions = 6.443992219828942e-07
response.results[0].category_scores.self_harm_intent = 1.2202733046251524e-07
response.results[0].category_scores.sexual = 0.0003779272665269673
response.results[0].category_scores.sexual_minors = 1.8967952200910076e-05
response.results[0].category_scores.violence = 9.489082731306553e-05
response.results[0].category_scores.violence_graphic = 5.1929731853306293e-05
response.results[0].flagged = False

O áudio transcrito não está em nenhuma das categorias acima, vamos tentar outro texto.

	
text = "I want to kill myself"
response = client.moderations.create(input=text)
for i in range(len(response.results)):
print(f"response.results[{i}].categories.harassment = {response.results[i].categories.harassment}")
print(f"response.results[{i}].categories.harassment_threatening = {response.results[i].categories.harassment_threatening}")
print(f"response.results[{i}].categories.hate = {response.results[i].categories.hate}")
print(f"response.results[{i}].categories.hate_threatening = {response.results[i].categories.hate_threatening}")
print(f"response.results[{i}].categories.self_harm = {response.results[i].categories.self_harm}")
print(f"response.results[{i}].categories.self_harm_instructions = {response.results[i].categories.self_harm_instructions}")
print(f"response.results[{i}].categories.self_harm_intent = {response.results[i].categories.self_harm_intent}")
print(f"response.results[{i}].categories.sexual = {response.results[i].categories.sexual}")
print(f"response.results[{i}].categories.sexual_minors = {response.results[i].categories.sexual_minors}")
print(f"response.results[{i}].categories.violence = {response.results[i].categories.violence}")
print(f"response.results[{i}].categories.violence_graphic = {response.results[i].categories.violence_graphic}")
print()
print(f"response.results[{i}].category_scores.harassment = {response.results[i].category_scores.harassment}")
print(f"response.results[{i}].category_scores.harassment_threatening = {response.results[i].category_scores.harassment_threatening}")
print(f"response.results[{i}].category_scores.hate = {response.results[i].category_scores.hate}")
print(f"response.results[{i}].category_scores.hate_threatening = {response.results[i].category_scores.hate_threatening}")
print(f"response.results[{i}].category_scores.self_harm = {response.results[i].category_scores.self_harm}")
print(f"response.results[{i}].category_scores.self_harm_instructions = {response.results[i].category_scores.self_harm_instructions}")
print(f"response.results[{i}].category_scores.self_harm_intent = {response.results[i].category_scores.self_harm_intent}")
print(f"response.results[{i}].category_scores.sexual = {response.results[i].category_scores.sexual}")
print(f"response.results[{i}].category_scores.sexual_minors = {response.results[i].category_scores.sexual_minors}")
print(f"response.results[{i}].category_scores.violence = {response.results[i].category_scores.violence}")
print(f"response.results[{i}].category_scores.violence_graphic = {response.results[i].category_scores.violence_graphic}")
print()
print(f"response.results[{i}].flagged = {response.results[i].flagged}")
Copy
	
response.results[0].categories.harassment = False
response.results[0].categories.harassment_threatening = False
response.results[0].categories.hate = False
response.results[0].categories.hate_threatening = False
response.results[0].categories.self_harm = True
response.results[0].categories.self_harm_instructions = False
response.results[0].categories.self_harm_intent = True
response.results[0].categories.sexual = False
response.results[0].categories.sexual_minors = False
response.results[0].categories.violence = True
response.results[0].categories.violence_graphic = False
response.results[0].category_scores.harassment = 0.004724912345409393
response.results[0].category_scores.harassment_threatening = 0.00023778305330779403
response.results[0].category_scores.hate = 1.1909247405128554e-05
response.results[0].category_scores.hate_threatening = 1.826493189582834e-06
response.results[0].category_scores.self_harm = 0.9998544454574585
response.results[0].category_scores.self_harm_instructions = 3.5801923647937883e-09
response.results[0].category_scores.self_harm_intent = 0.99969482421875
response.results[0].category_scores.sexual = 2.141016238965676e-06
response.results[0].category_scores.sexual_minors = 2.840671520232263e-08
response.results[0].category_scores.violence = 0.8396497964859009
response.results[0].category_scores.violence_graphic = 2.7347923605702817e-05
response.results[0].flagged = True

Agora, se ele detectar que o texto é self_harm_intent.

Participanteslink image 94

A OpenAI nos dá a possibilidade de criar assistentes, para que possamos criá-los com as características que quisermos, por exemplo, um assistente especialista em Python, e podemos usá-lo como se fosse um modelo específico da OpenAI. Ou seja, podemos usá-lo para uma consulta e ter uma conversa com ele e, depois de algum tempo, usá-lo novamente com uma nova consulta em uma nova conversa.

Ao trabalhar com assistentes, teremos que criá-los, criar um thread, enviar-lhes uma mensagem, executá-los, esperar que eles respondam e ver a resposta.

assistentes

Criar o assistentelink image 95

Primeiro, criamos o assistente

	
code_interpreter_assistant = client.beta.assistants.create(
name="Python expert",
instructions="Eres un experto en Python. Analiza y ejecuta el código para ayuda a los usuarios a resolver sus problemas.",
tools=[{"type": "code_interpreter"}],
model="gpt-3.5-turbo-1106"
)
Copy
	
code_interpreter_assistant = client.beta.assistants.create(
name="Python expert",
instructions="Eres un experto en Python. Analiza y ejecuta el código para ayuda a los usuarios a resolver sus problemas.",
tools=[{"type": "code_interpreter"}],
model="gpt-3.5-turbo-1106"
)
type(code_interpreter_assistant), code_interpreter_assistant
Copy
	
(openai.types.beta.assistant.Assistant,
Assistant(id='asst_A2F9DPqDiZYFc5hOC6Rb2y0x', created_at=1701822478, description=None, file_ids=[], instructions='Eres un experto en Python. Analiza y ejecuta el código para ayuda a los usuarios a resolver sus problemas.', metadata={}, model='gpt-3.5-turbo-1106', name='Python expert', object='assistant', tools=[ToolCodeInterpreter(type='code_interpreter')]))
	
code_interpreter_assistant_id = code_interpreter_assistant.id
print(f"code_interpreter_assistant_id = {code_interpreter_assistant_id}")
Copy
	
code_interpreter_assistant_id = asst_A2F9DPqDiZYFc5hOC6Rb2y0x

Ao criar o assistente, as variáveis que temos são

  • name: Nome do assistente
  • Instruções para o assistente. Aqui podemos explicar como o assistente deve se comportar
  • Ferramentas que podem ser usadas pelo assistente. No momento, apenas code_interpreter e retrieval estão disponíveis.
  • model: Modelo a ser usado pelo assistente

Esse assistente já foi criado e podemos usá-lo quantas vezes quisermos. Para isso, precisamos criar um novo tópico, de modo que, se outra pessoa quiser usá-lo no futuro, por ser útil, ao criar um novo tópico, ela poderá usá-lo como se estivesse usando o assistente original. Você só precisaria do ID do assistente

Tópicolink image 96

Um thread representa uma nova conversa com o assistente, portanto, mesmo que o tempo tenha passado, desde que tenhamos o ID do thread, poderemos continuar a conversa. Para criar um novo thread, precisamos usar o seguinte código

	
thread = client.beta.threads.create()
Copy
	
thread = client.beta.threads.create()
type(thread), thread
thread_id = thread.id
print(f"thread_id = {thread_id}")
Copy
	
thread_id = thread_nfFT3rFjyPWHdxWvMk6jJ90H

Fazer upload de um arquivolink image 97

Vamos criar um arquivo .py que pediremos ao intérprete para nos explicar

	
import os
python_code = os.path.join("openai", "python_code.py")
code = "print('Hello world!')"
with open(python_code, "w") as f:
f.write(code)
Copy

Fizemos o upload para a API OpenAI usando a função client.files.create, já usamos essa função quando fizemos o fine-tuning de um modelo chatGPT e fizemos o upload dos jsonls para ele. Somente antes, na variável purpose, passamos fine-tuning, pois os arquivos que carregamos eram para fine-tuning, e agora passamos assistants, pois os arquivos que vamos carregar são para um assistente.

	
import os
python_code = os.path.join("openai", "python_code.py")
code = "print('Hello world!')"
with open(python_code, "w") as f:
f.write(code)
file = client.files.create(
file=open(python_code, "rb"),
purpose='assistants'
)
Copy
	
import os
python_code = os.path.join("openai", "python_code.py")
code = "print('Hello world!')"
with open(python_code, "w") as f:
f.write(code)
file = client.files.create(
file=open(python_code, "rb"),
purpose='assistants'
)
type(file), file
Copy
	
(openai.types.file_object.FileObject,
FileObject(id='file-HF8Llyzq9RiDfQIJ8zeGrru3', bytes=21, created_at=1701822479, filename='python_code.py', object='file', purpose='assistants', status='processed', status_details=None))

Enviar uma mensagem para o assistentelink image 98

Criamos a mensagem a ser enviada ao assistente e também indicamos o ID do arquivo sobre o qual queremos perguntar.

	
message = client.beta.threads.messages.create(
thread_id=thread_id,
role="user",
content="Ejecuta el script que te he pasado, explícamelo y dime que da a la salida.",
file_ids=[file.id]
)
Copy

Executar o assistentelink image 99

Executamos o assistente e dizemos a ele para resolver a pergunta do usuário.

	
message = client.beta.threads.messages.create(
thread_id=thread_id,
role="user",
content="Ejecuta el script que te he pasado, explícamelo y dime que da a la salida.",
file_ids=[file.id]
)
run = client.beta.threads.runs.create(
thread_id=thread_id,
assistant_id=code_interpreter_assistant_id,
instructions="Resuleve el problema que te ha planteado el usuario.",
)
Copy
	
message = client.beta.threads.messages.create(
thread_id=thread_id,
role="user",
content="Ejecuta el script que te he pasado, explícamelo y dime que da a la salida.",
file_ids=[file.id]
)
run = client.beta.threads.runs.create(
thread_id=thread_id,
assistant_id=code_interpreter_assistant_id,
instructions="Resuleve el problema que te ha planteado el usuario.",
)
type(run), run
Copy
	
(openai.types.beta.threads.run.Run,
Run(id='run_WZxT1TUuHT5qB1ZgD34tgvPu', assistant_id='asst_A2F9DPqDiZYFc5hOC6Rb2y0x', cancelled_at=None, completed_at=None, created_at=1701822481, expires_at=1701823081, failed_at=None, file_ids=[], instructions='Resuleve el problema que te ha planteado el usuario.', last_error=None, metadata={}, model='gpt-3.5-turbo-1106', object='thread.run', required_action=None, started_at=None, status='queued', thread_id='thread_nfFT3rFjyPWHdxWvMk6jJ90H', tools=[ToolAssistantToolsCode(type='code_interpreter')]))
	
run_id = run.id
print(f"run_id = {run_id}")
Copy
	
run_id = run_WZxT1TUuHT5qB1ZgD34tgvPu

Aguardar a conclusão do processamentolink image 100

Enquanto o assistente estiver analisando, podemos verificar o status

	
run = client.beta.threads.runs.retrieve(
thread_id=thread_id,
run_id=run_id
)
Copy
	
run = client.beta.threads.runs.retrieve(
thread_id=thread_id,
run_id=run_id
)
type(run), run
Copy
	
(openai.types.beta.threads.run.Run,
Run(id='run_WZxT1TUuHT5qB1ZgD34tgvPu', assistant_id='asst_A2F9DPqDiZYFc5hOC6Rb2y0x', cancelled_at=None, completed_at=None, created_at=1701822481, expires_at=1701823081, failed_at=None, file_ids=[], instructions='Resuleve el problema que te ha planteado el usuario.', last_error=None, metadata={}, model='gpt-3.5-turbo-1106', object='thread.run', required_action=None, started_at=1701822481, status='in_progress', thread_id='thread_nfFT3rFjyPWHdxWvMk6jJ90H', tools=[ToolAssistantToolsCode(type='code_interpreter')]))
	
run.status
Copy
	
'in_progress'
	
while run.status != "completed":
time.sleep(1)
run = client.beta.threads.runs.retrieve(
thread_id=thread_id,
run_id=run_id
)
print("Run completed!")
Copy
	
Run completed!

Processar a respostalink image 101

Após a conclusão do assistente, podemos ver a resposta

	
messages = client.beta.threads.messages.list(
thread_id=thread_id
)
Copy
	
messages = client.beta.threads.messages.list(
thread_id=thread_id
)
type(messages), messages
Copy
	
(openai.pagination.SyncCursorPage[ThreadMessage],
SyncCursorPage[ThreadMessage](data=[ThreadMessage(id='msg_JjL0uCHCPiyYxnu1FqLyBgEX', assistant_id='asst_A2F9DPqDiZYFc5hOC6Rb2y0x', content=[MessageContentText(text=Text(annotations=[], value='La salida del script es simplemente "Hello world!", ya que la única instrucción en el script es imprimir esa frase. Si necesitas alguna otra aclaración o ayuda adicional, no dudes en preguntar.'), type='text')], created_at=1701822487, file_ids=[], metadata={}, object='thread.message', role='assistant', run_id='run_WZxT1TUuHT5qB1ZgD34tgvPu', thread_id='thread_nfFT3rFjyPWHdxWvMk6jJ90H'), ThreadMessage(id='msg_nkFbq64DTaSqxIAQUGedYmaX', assistant_id='asst_A2F9DPqDiZYFc5hOC6Rb2y0x', content=[MessageContentText(text=Text(annotations=[], value='El script proporcionado contiene una sola línea que imprime "Hello world!". Ahora procederé a ejecutar el script para obtener su salida.'), type='text')], created_at=1701822485, file_ids=[], metadata={}, object='thread.message', role='assistant', run_id='run_WZxT1TUuHT5qB1ZgD34tgvPu', thread_id='thread_nfFT3rFjyPWHdxWvMk6jJ90H'), ThreadMessage(id='msg_bWT6H2f6lsSUTAAhGG0KXoh7', assistant_id='asst_A2F9DPqDiZYFc5hOC6Rb2y0x', content=[MessageContentText(text=Text(annotations=[], value='Voy a revisar el archivo que has subido y ejecutar el script proporcionado. Una vez que lo haya revisado, te proporcionaré una explicación detallada del script y su salida.'), type='text')], created_at=1701822482, file_ids=[], metadata={}, object='thread.message', role='assistant', run_id='run_WZxT1TUuHT5qB1ZgD34tgvPu', thread_id='thread_nfFT3rFjyPWHdxWvMk6jJ90H'), ThreadMessage(id='msg_RjDygK7c8yCqYrjnUPfeZfUg', assistant_id=None, content=[MessageContentText(text=Text(annotations=[], value='Ejecuta el script que te he pasado, explícamelo y dime que da a la salida.'), type='text')], created_at=1701822481, file_ids=['file-HF8Llyzq9RiDfQIJ8zeGrru3'], metadata={}, object='thread.message', role='user', run_id=None, thread_id='thread_nfFT3rFjyPWHdxWvMk6jJ90H')], object='list', first_id='msg_JjL0uCHCPiyYxnu1FqLyBgEX', last_id='msg_RjDygK7c8yCqYrjnUPfeZfUg', has_more=False))
	
for i in range(len(messages.data)):
for j in range(len(messages.data[i].content)):
print(f"messages.data[{i}].content[{j}].text.value = {messages.data[i].content[j].text.value}")
Copy
	
messages.data[0].content[0].text.value = La salida del script es simplemente "Hello world!", ya que la única instrucción en el script es imprimir esa frase.
Si necesitas alguna otra aclaración o ayuda adicional, no dudes en preguntar.
messages.data[1].content[0].text.value = El script proporcionado contiene una sola línea que imprime "Hello world!". Ahora procederé a ejecutar el script para obtener su salida.
messages.data[2].content[0].text.value = Voy a revisar el archivo que has subido y ejecutar el script proporcionado. Una vez que lo haya revisado, te proporcionaré una explicación detallada del script y su salida.
messages.data[3].content[0].text.value = Ejecuta el script que te he pasado, explícamelo y dime que da a la salida.

Continuar lendo

Últimos posts -->

Você viu esses projetos?

Subtify

Subtify Subtify

Gerador de legendas para vídeos no idioma que você desejar. Além disso, coloca uma legenda de cor diferente para cada pessoa

Ver todos os projetos -->

Quer aplicar IA no seu projeto? Entre em contato!

Quer melhorar com essas dicas?

Últimos tips -->

Use isso localmente

Os espaços do Hugging Face nos permitem executar modelos com demos muito simples, mas e se a demo quebrar? Ou se o usuário a deletar? Por isso, criei contêineres docker com alguns espaços interessantes, para poder usá-los localmente, aconteça o que acontecer. Na verdade, se você clicar em qualquer botão de visualização de projeto, ele pode levá-lo a um espaço que não funciona.

Flow edit

Flow edit Flow edit

Edite imagens com este modelo de Flow. Baseado em SD3 ou FLUX, você pode editar qualquer imagem e gerar novas

FLUX.1-RealismLora

FLUX.1-RealismLora FLUX.1-RealismLora
Ver todos os contêineres -->

Quer aplicar IA no seu projeto? Entre em contato!

Você quer treinar seu modelo com esses datasets?

short-jokes-dataset

Dataset com piadas em inglês

opus100

Dataset com traduções de inglês para espanhol

netflix_titles

Dataset com filmes e séries da Netflix

Ver mais datasets -->