Spaces:
Running
Running
import gradio as gr | |
from langchain_community.embeddings import HuggingFaceEmbeddings | |
from langchain_community.vectorstores import FAISS | |
from openai import OpenAI | |
from translate_utils import translate_ko_to_en | |
YOUR_OPENAI_API_KEY = "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" | |
# ์๋ฒ ๋ฉ ๋ชจ๋ธ ๋ก๋ | |
embedding_model_name = "snunlp/KR-SBERT-V40K-klueNLI-augSTS" | |
embedding_model = HuggingFaceEmbeddings( | |
model_name=embedding_model_name, | |
model_kwargs={"device": "cpu"}, # GPU ์ค์ ์ "cuda"๋ก ๋ณ๊ฒฝ ๊ฐ๋ฅ | |
encode_kwargs={"normalize_embeddings": True}, | |
) | |
# vector DB ๋ก๋๋ | |
save_path = "./version-2024-12-22" | |
vectorstore = FAISS.load_local(save_path, embedding_model,allow_dangerous_deserialization=True) | |
def chatbot(input_question, eng_trans = True, num_ref = 3): | |
retriever = vectorstore.as_retriever(search_kwargs={"k": num_ref}) | |
if eng_trans == False: | |
basic_docs = retriever.invoke(input_question) | |
else: | |
eng = translate_ko_to_en(input_question) | |
basic_docs = retriever.invoke(input_question) | |
eng_docs = retriever.invoke(eng) | |
basic_docs = basic_docs + eng_docs | |
context = "\n".join([doc.page_content for doc in basic_docs]) | |
client = OpenAI( | |
api_key=YOUR_OPENAI_API_KEY) | |
# question๊ณผ context๋ฅผ message์ ์ฝ์ | |
completion = client.chat.completions.create( | |
model="gpt-4o-mini", | |
messages=[ | |
{ | |
"role": "user", | |
"content": f"""๋น์ ์ ๋ฐ๋์ฒด์ ์ฐจ์ธ๋๋ฐ๋์ฒดํ๊ณผ์ ๋ํด์ ์ค๋ช ํ๋ Assistant์ ๋๋ค. | |
์ฐจ์ธ๋๋ฐ๋์ฒดํ๊ณผ๋ ํ๊ตญ ์์ธ์ ์ค์๋ํ๊ต์ ์ฐฝ์ICT๊ณต๊ณผ๋ํ์ ์ค๋ฆฝ๋ ํ๊ณผ์ ๋๋ค. ์ด ํ๊ณผ๋ ์์ธ๋ํ๊ต, ์ค์๋ํ๊ต, ํฌํญ๊ณต๊ณผ๋ํ๊ต, ์ญ์ค๋ํ๊ต, ๊ฐ์๋ํ๊ต, ๋๊ตฌ๋ํ๊ต, ์กฐ์ ์ด๊ณต๋ํ๊ต๊ฐ ํ์ ๊ต๋ฅ๋ฅผ ํตํด ์๊ฐํ ์ ์๋ ํ๊ณผ์ ๋๋ค. | |
๋ค์ ๋งฅ๋ฝ์ ๋ง๊ฒ ์ง๋ฌธ์ ํ๊ธ๋ก ๋ตํ์ธ์. ๋์ , ๋ฐ๋์ฒด ์ ๋ฌธ์ฉ์ด๋ ์์ด๋ก ํด๋ ๋ฉ๋๋ค. | |
๋งฅ๋ฝ: {context} | |
์ง๋ฌธ: {input_question} | |
""" | |
} | |
] | |
) | |
return completion.choices[0].message.content | |
demo = gr.Interface(fn=chatbot, | |
inputs=[gr.Textbox(label="์ง๋ฌธ ์ ๋ ฅ"), # ํ ์คํธ ์ ๋ ฅ | |
gr.Checkbox(label="์์ด ๋ฒ์ญ ์ฌ์ฉ ์ฌ๋ถ", value=True), # ์ฒดํฌ๋ฐ์ค ์ถ๊ฐ | |
gr.Slider(1,5, value=3, step=1), | |
], outputs="text") | |
demo.launch() | |