File size: 995 Bytes
a988b38
232416e
 
 
ebb94ea
0011614
942e91e
 
ebb94ea
232416e
 
 
 
 
 
 
 
942e91e
232416e
 
 
 
 
 
 
 
 
 
 
 
 
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
import os
from openai import OpenAI
import gradio as gr

api_key = os.environ.get("OPENAI_API_KEY")
base_url = os.environ.get("OPENAI_API_BASE")
model_name = os.environ.get("MODEL_NAME")

client = OpenAI(api_key=api_key, base_url=base_url)

def predict(message, history):
    history_openai_format = []
    for human, assistant in history:
        history_openai_format.append({"role": "user", "content": human })
        history_openai_format.append({"role": "assistant", "content":assistant})
    history_openai_format.append({"role": "user", "content": message})
  
    response = client.chat.completions.create(model=model_name,
    messages= history_openai_format,
    temperature=1.0,
    stop=["<|eot_id|>"],
    stream=True)

    partial_message = ""
    for chunk in response:
        if chunk.choices[0].delta.content is not None:
              partial_message = partial_message + chunk.choices[0].delta.content
              yield partial_message

gr.ChatInterface(predict).launch()