forked from gabrielchua/async-stream-openai-st
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp.py
59 lines (49 loc) · 1.68 KB
/
app.py
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
52
53
54
55
56
57
58
59
"""
app.py
"""
import streamlit as st
import asyncio
from openai import AsyncOpenAI
import weave
weave.init('junk-stuff')
try:
client = AsyncOpenAI(api_key=st.secrets["OPENAI_API_KEY"])
except:
client = AsyncOpenAI()
# st.set_page_config(
# page_title="OpenAI Async Stream Demo",
# layout="wide",
# )
st.title("Demo: Async streaming of OpenAI output")
with st.sidebar:
topic_1 = st.text_input("Essay Topic 1")
topic_2 = st.text_input("Essay Topic 2")
word_count = st.number_input("Word Count", value=200, step=100, max_value=300)
generate = st.button("Generate")
col1, col2 = st.columns(2)
essay_1 = col1.empty()
essay_2 = col2.empty()
@weave.op
async def generate_essay(placeholder, topic, word_count):
stream = await client.chat.completions.create(
model="gpt-3.5-turbo",
messages=[{"role": "system", "content": "You are a helpful assistant."},
{"role": "user", "content": f"Write a {word_count} word essay on {topic}. The first line is a 2-3 word title with an emoji and then include 2 line breaks. For example 'TITLE <emoji> \n \n ' "},],
stream=True
)
streamed_text = "# "
async for chunk in stream:
chunk_content = chunk.choices[0].delta.content
if chunk_content is not None:
streamed_text = streamed_text + chunk_content
placeholder.info(streamed_text)
async def main():
await asyncio.gather(
generate_essay(essay_1, topic=topic_1, word_count=word_count),
generate_essay(essay_2, topic=topic_2, word_count=word_count)
)
if generate:
if topic_1 == "" or topic_2 == "":
st.warning("Please enter both topics")
else:
asyncio.run(main())