Duema-QA-Search / app.py
watagassy's picture
Update app.py
89dfdbe verified
import os
from langchain.vectorstores import Qdrant
from langchain.embeddings import HuggingFaceEmbeddings
from qdrant_client import QdrantClient
import gradio as gr
from transformers.utils import logging
logging.set_verbosity_info()
logger = logging.get_logger("transformers")
qdrant_url = os.environ['QDRANT_URL']
qdrant_api_key = os.environ['QDRANT_API_KEY']
def process_text(input_text, top_k):
embeddings = HuggingFaceEmbeddings(model_name="intfloat/multilingual-e5-base")
# embeddings = HuggingFaceEmbeddings(model_name="cl-nagoya/sup-simcse-ja-large")
client = QdrantClient(
url=qdrant_url, api_key=qdrant_api_key, prefer_grpc=False,
)
db = Qdrant(client=client, embeddings=embeddings, collection_name="qa_data_without_cardname")
# db = Qdrant(client=client, embeddings=embeddings, collection_name="qa_data_without_cardname_ssjl")
query = input_text
all_answers = []
docs = db.similarity_search_with_score(query=query, k=top_k)
for i in docs:
doc, score = i
all_answers.append(doc.metadata["source"])
return "\n***\n".join(all_answers)
CSS ="""
.contain { display: flex; flex-direction: column; }
.gradio-container { height: 100vh !important; }
#component-0 { height: 100%; }
#textbox { flex-grow: 1; overflow: auto; resize: vertical; }
.secondary {background-color: #6366f1; }
"""
#with gr.Blocks() as demo:
with gr.Blocks(theme=gr.themes.Monochrome(radius_size=gr.themes.sizes.radius_sm)) as demo:
with gr.Row():
with gr.Column():
gr.Markdown(f"""
### ・非公式サイトです
### ・デモでしかないので速度・精度・動作は保証しないし新しい裁定にも対応しません。突然消す可能性もあり
### ・ですます調で質問をすると精度が上がるかも
""")
with gr.Row():
gr.Markdown("# デュエマ裁定検索(非公式)")
with gr.Row():
output = gr.TextArea(
elem_id="検索結果",
label="検索結果",
)
with gr.Row():
input = gr.Textbox(
label="質問",
placeholder="ここに質問を入力(ex:カードを指定して破壊する能力でクリーチャーの下にあるカードを指定できますか)",
lines=3,
)
with gr.Row():
submit = gr.Button(value="検索", variant="secondary").style(full_width=True)
top_k = gr.Slider(1, 10, label="表示数", step=1, value=5, interactive=True)
submit_click_event = submit.click(fn=process_text, inputs=[input, top_k], outputs=output)
demo.launch()
# demo.queue(max_size=128, concurrency_count=48).launch(debug=True, server_name="0.0.0.0", server_port=7860)