qwen3 / app.py
alexeyGod's picture
Update app.py
9353eda verified
import gradio as gr
from huggingface_hub import InferenceClient
import os
a=os.getenv('new_key_for_deep')
client = InferenceClient(token=a,model= "deepseek-ai/DeepSeek-R1-Distill-Qwen-32B")
def respond(
message,
history: list[tuple[str, str]],
system_message,
max_tokens,
temperature,
top_p,
):
# Проверяем, что сообщение не пустое
if not message or not message.strip():
yield "Пожалуйста, введите сообщение."
return
messages = [{"role": "system", "content": system_message}]
# Корректно обрабатываем историю
for user_msg, assistant_msg in history:
if user_msg and user_msg.strip():
messages.append({"role": "user", "content": user_msg})
if assistant_msg and assistant_msg.strip():
messages.append({"role": "assistant", "content": assistant_msg})
# Добавляем текущее сообщение пользователя
messages.append({"role": "user", "content": message})
response = ""
try:
for chunk in client.chat_completion(
messages,
max_tokens=max_tokens,
stream=True,
temperature=temperature,
top_p=top_p,
):
token = chunk.choices[0].delta.content
# Проверяем, что токен не None и не пустой
if token and isinstance(token, str) and token.strip():
response += token
yield response
# Если ответ пустой, отправляем сообщение
if not response or not response.strip():
yield "Извините, я не могу сформулировать ответ."
except Exception as e:
yield f"Ошибка: {str(e)}"
character = """Отвечай по-русски, но никогда не показывай свои рассуждения пользователю.
Ты используешь логику, математику и анализ, но в ответе — только финальный результат.
Ты доминатор в БДСМ, мужчина 41 года, сидишь за столиком в гей-баре, одет в кожанную отребутику БДСМ, флиртуешь."""
"""
demo = gr.ChatInterface(
respond,
additional_inputs=[
gr.Textbox(value=character, label="🎭 Описание персонажа", lines=3),
gr.Slider(minimum=1, maximum=2048, value=512, step=1, label="📝 Максимум токенов"),
gr.Slider(minimum=0.1, maximum=4.0, value=0.7, step=0.1, label="🔥 Температура"),
gr.Slider(
minimum=0.1,
maximum=1.0,
value=0.95,
step=0.05,
label="🎯 Top-p (nucleus sampling)",
),
],
title=" strapon 💋 BDSM Чат-Бот",
description="Твой личный кожаный доминатор",
theme=gr.themes.Soft()
)
"""
demo = gr.ChatInterface(
fn=respond, # Обязательный параметр - ваша функция
additional_inputs=[
gr.Textbox(value=character, label="🎭 Описание персонажа"),
gr.Slider(minimum=1, maximum=2048, value=512, step=1, label="📝 Максимум токенов"),
gr.Slider(minimum=0.1, maximum=4.0, value=0.7, step=0.1, label="🔥 Температура"),
gr.Slider(
minimum=0.1,
maximum=1.0,
value=0.95,
step=0.05,
label="🎯 Top-p (nucleus sampling)",
),
],
title=" strapon 💋 BDSM Чат-Бот",
description="Твой личный кожаный доминатор",
theme=gr.themes.Monochrome(
primary_hue="red",
secondary_hue="pink",
neutral_hue="gray",
font=["Arial", "sans-serif"]
)
)
if __name__ == "__main__":
demo.launch()