ChatbotTest1 / chatbot.py
Drbrain0620's picture
Upload folder using huggingface_hub
b6f3967 verified
from transformers import AutoModelForCausalLM, AutoTokenizer
import torch
import gradio as gr
try:
model_name = "gpt2"
tokenizer = AutoTokenizer.from_pretrained(model_name)
model = AutoModelForCausalLM.from_pretrained(model_name)
chat_history = [{"role": "system", "content": "You are a helpful assistant."}]
def chat(user_input):
# μ‚¬μš©μž μž…λ ₯을 μ±„νŒ… 기둝에 μΆ”κ°€
chat_history.append({"role": "user", "content": user_input})
# λͺ¨λΈμ— μ±„νŒ… 기둝 전달
inputs = tokenizer([message['content'] for message in chat_history], return_tensors="pt", padding=True).to("cuda" if torch.cuda.is_available() else "cpu")
# λͺ¨λΈλ‘œ 응닡 생성
outputs = model.generate(**inputs, max_length=200)
# μƒμ„±λœ 응닡
bot_reply = tokenizer.decode(outputs[0], skip_special_tokens=True)
# 봇 응닡을 μ±„νŒ… 기둝에 μΆ”κ°€
chat_history.append({"role": "assistant", "content": bot_reply})
return bot_reply
demo = gr.ChatInterface(fn=chat, type='messages', title='μ΄μš°μ§„μ˜ 챗봇')
demo.launch(share=True)
except Exception as e:
print(f"Error occurred: {e}")