Spaces:
Running
Running
File size: 1,468 Bytes
e8da79a |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 |
import gradio as gr
import os
from openai import OpenAI
config = {
"max_tokens": 1000,
"model": "gpt-4",
"temperature": 0
}
def invoke(openai_api_key, prompt):
if (openai_api_key == ""):
raise gr.Error("OpenAI API Key is required.")
if (prompt == ""):
raise gr.Error("Prompt is required.")
os.environ["OPENAI_API_KEY"] = openai_api_key
content = ""
try:
client = OpenAI()
completion = client.chat.completions.create(
max_tokens = config["max_tokens"],
messages = [{"role": "user", "content": prompt}],
model = config["model"],
temperature = config["temperature"])
content = completion.choices[0].message.content
except Exception as e:
err_msg = e
raise gr.Error(e)
return content
description = """<a href='https://www.gradio.app/'>Gradio</a> UI using the <a href='https://openai.com/'>OpenAI</a> SDK
with <a href='https://openai.com/research/gpt-4'>gpt-4</a> model."""
gr.close_all()
demo = gr.Interface(fn = invoke,
inputs = [gr.Textbox(label = "OpenAI API Key", type = "password", lines = 1),
gr.Textbox(label = "Prompt", lines = 1)],
outputs = [gr.Textbox(label = "Completion", lines = 1)],
title = "Generative AI - LLM",
description = description)
demo.launch() |