jinjavis / app.py
seawolf2357's picture
Update app.py
91be94d verified
import gradio as gr
import requests
import os
import json
# ACCESS_TOKEN = os.getenv("HF_TOKEN")
def respond(message, history, max_tokens=512, temperature=0.7, top_p=0.95):
# 대화 이력을 포함한 프롬프트 구성
if history:
prompt = "\n".join([f"User: {msg}" for msg, _ in history] + [f"Assistant: {res}" for _, res in history])
prompt += f"\nUser: {message}\nAssistant:"
else:
prompt = f"User: {message}\nAssistant:"
data = {
"model": "jinjavis:latest",
"prompt": prompt,
"max_tokens": max_tokens,
"temperature": temperature,
"top_p": top_p
}
# API 요청
response = requests.post("http://hugpu.ai:7877/api/generate", json=data, stream=True)
partial_message = ""
for line in response.iter_lines():
if line:
try:
result = json.loads(line)
if result.get("done", False):
break
new_text = result.get('response', '')
partial_message += new_text
yield partial_message
except json.JSONDecodeError as e:
print(f"Failed to decode JSON: {e}")
yield "An error occurred while processing your request."
# history 업데이트
history.append((message, partial_message))
css = """
footer {
visibility: hidden;
}
"""
demo = gr.ChatInterface(css=css,
fn=respond,
additional_inputs=[
gr.Slider(minimum=1, maximum=2048, value=512, label="Max Tokens"),
gr.Slider(minimum=0.1, maximum=4.0, value=0.7, label="Temperature"),
gr.Slider(minimum=0.1, maximum=1.0, value=0.95, label="Top-P")
],
theme="Nymbo/Nymbo_Theme"
)
if __name__ == "__main__":
demo.queue(max_size=4).launch()