Spaces:
Running
on
CPU Upgrade
Running
on
CPU Upgrade
import streamlit as st | |
from openai import OpenAI | |
from typing import Iterator | |
import os | |
from phoenix.otel import register | |
tracer_provider = register( | |
project_name=st.secrets['PHOENIX_PROJECT_NAME'], | |
endpoint="https://app.phoenix.arize.com/v1/traces" | |
) | |
from openinference.instrumentation.openai import OpenAIInstrumentor | |
OpenAIInstrumentor().instrument(tracer_provider=tracer_provider) | |
st.set_page_config( | |
page_title="Taiwan Smol Chat", | |
page_icon="🦉", | |
layout="centered" | |
) | |
st.title("🦉Taiwan Smol Chat") | |
client = OpenAI( | |
api_key=st.secrets['API_KEY'], | |
base_url=st.secrets['API_BASE_URL'], | |
) | |
if "openai_model" not in st.session_state: | |
st.session_state["openai_model"] = st.secrets['MODEL'] | |
if "messages" not in st.session_state: | |
st.session_state.messages = [] | |
for message in st.session_state.messages: | |
with st.chat_message(message["role"]): | |
st.markdown(message["content"]) | |
if prompt := st.chat_input("What is up?"): | |
st.session_state.messages.append({"role": "user", "content": prompt}) | |
with st.chat_message("user"): | |
st.markdown(prompt) | |
with st.chat_message("assistant"): | |
stream = client.chat.completions.create( | |
model=st.session_state["openai_model"], | |
messages=[ | |
{"role": m["role"], "content": m["content"]} | |
for m in st.session_state.messages | |
], | |
stream=True, | |
) | |
response = st.write_stream(stream) | |
st.session_state.messages.append( | |
{"role": "assistant", "content": response}) | |