nguyen1207's picture
Update app.py
6beea90 verified
raw
history blame
No virus
1.21 kB
import streamlit as st
import torch
from peft import PeftModel
from transformers import AutoModel, AutoTokenizer
model_name = 'intfloat/multilingual-e5-large'
adapters_name = './checkpoint-21170'
model = AutoModel.from_pretrained(model_name)
model = PeftModel.from_pretrained(model, adapters_name)
model = model.merge_and_unload()
tokenizer = AutoTokenizer.from_pretrained(model_name)
st.header("Irrelevant Review Detections :sunglasses:")
description = st.text_input("Product description")
review = st.text_input("Review")
if st.button("Detect") and description and review:
input_texts = [
f'query: {review}',
f'passage: {description}'
]
batch_dict = tokenizer(input_texts, max_length=512,
padding=True, truncation=True, return_tensors='pt')
query_embedding, doc_embedding = model(**batch_dict, return_dict=True).pooler_output
query_embedding = query_embedding.unsqueeze(0)
doc_embedding = doc_embedding.unsqueeze(0)
similarity = torch.nn.functional.cosine_similarity(
query_embedding, doc_embedding)
threshold = 0.83
if similarity > threshold:
st.write('Relevant')
else:
st.write('Irrelevant')