Spaces:
Sleeping
Sleeping
import gradio as gr | |
from transformers import pipeline, AutoTokenizer | |
from datasets import load_dataset | |
# 1. Загрузка датасета с обработкой ошибок | |
try: | |
dataset = load_dataset("sberbank-ai/ru_helpdesk", split="train[:50]") # Первые 50 примеров | |
examples = [d["question"] for d in dataset if "question" in d] | |
except Exception as e: | |
print(f"Ошибка загрузки датасета: {e}") | |
examples = [ | |
"Где мой заказ #12345?", | |
"Как вернуть товар?", | |
"Не приходит код подтверждения", | |
"Ошибка при оплате картой", | |
"Как изменить адрес доставки?" | |
] | |
# 2. Оптимизированная загрузка модели | |
try: | |
tokenizer = AutoTokenizer.from_pretrained("IlyaGusev/saiga_mistral_7b-lora") | |
model = pipeline( | |
"text-generation", | |
model="IlyaGusev/saiga_mistral_7b-lora", | |
tokenizer=tokenizer, | |
device="cpu", | |
torch_dtype="auto", | |
model_kwargs={"load_in_4bit": True} # Критически важно для экономии памяти | |
) | |
except Exception as e: | |
raise RuntimeError(f"Ошибка загрузки модели: {str(e)}") | |
# 3. Генерация ответа с шаблоном | |
def generate_response(message): | |
prompt = f"""Ты - ИИ-ассистент поддержки. Ответь клиенту вежливо и по делу. | |
Клиент: {message} | |
Ассистент:""" | |
try: | |
response = model( | |
prompt, | |
max_new_tokens=150, | |
temperature=0.3, | |
do_sample=True | |
) | |
return response[0]["generated_text"].split("Ассистент:")[-1].strip() | |
except Exception as e: | |
return f"⚠️ Ошибка генерации: {str(e)}" | |
# 4. Интерфейс с примерами | |
with gr.Blocks(theme=gr.themes.Soft()) as demo: | |
gr.Markdown("""<h1><center>🎯 Поддержка клиентов</center></h1>""") | |
with gr.Row(): | |
with gr.Column(): | |
input_text = gr.Textbox(label="Опишите проблему", placeholder="Мой заказ не прибыл...") | |
output_text = gr.Textbox(label="Ответ поддержки", lines=5) | |
btn = gr.Button("Отправить", variant="primary") | |
with gr.Column(): | |
gr.Examples( | |
examples=examples, | |
inputs=input_text, | |
label="Примеры обращений" | |
) | |
gr.Markdown(""" | |
**Советы для быстрого решения:** | |
1. Указывайте номер заказа | |
2. Прикладывайте скриншоты ошибок | |
3. Проверяйте спам-папку | |
""") | |
btn.click(fn=generate_response, inputs=input_text, outputs=output_text) | |
demo.launch() | |