from transformers import AutoTokenizer, AutoModelForSequenceClassification
import torch
model_id = "cnmoro/TangledLlama33m-Reranker-EnPt"
model = AutoModelForSequenceClassification.from_pretrained(
model_id,
num_labels=2
)
tokenizer = AutoTokenizer.from_pretrained(model_id)
device = torch.device("cuda" if torch.cuda.is_available() else "cpu")
model.to(device)
template = "Query: {query}\nSentence: {document}"
def rank(query, documents, normalize_scores=True):
texts = [template.format(query=query, document=document) for document in documents]
inputs = tokenizer(
texts,
add_special_tokens=True,
max_length=32768,
truncation=True,
padding=True,
return_tensors="pt",
)
input_ids = inputs["input_ids"].to(device)
attention_mask = inputs["attention_mask"].to(device)
model.eval()
with torch.no_grad():
outputs = model(input_ids, attention_mask=attention_mask)
logits = outputs.logits
probabilities = torch.softmax(logits, dim=1)
predicted_classes = torch.argmax(probabilities, dim=1).tolist()
confidences = probabilities.max(dim=1).values.tolist()
results = [
{"prediction": pred, "confidence": conf}
for pred, conf in zip(predicted_classes, confidences)
]
final_results = []
for document, result in zip(documents, results):
if result['prediction'] == 0:
result['confidence'] = 1 - result['confidence']
final_results.append((document, result['confidence']))
sorted_results = sorted(final_results, key=lambda x: x[1], reverse=True)
if normalize_scores:
total_score = sum([result[1] for result in sorted_results])
sorted_results = [(result[0], result[1] / total_score) for result in sorted_results]
return sorted_results
query = "O que é o Pantanal?"
documents = [
"É um dos ecossistemas mais ricos em biodiversidade do mundo, abrigando uma grande variedade de espécies animais e vegetais.",
"Sua beleza natural, com rios e lagos interligados, atrai turistas de todo o mundo.",
"O Pantanal sofre com impactos ambientais, como a exploração mineral e o desmatamento.",
"O Pantanal é uma extensa planície alagável localizada na América do Sul, principalmente no Brasil, mas também em partes da Bolívia e Paraguai.",
"É um local com importância histórica e cultural para as populações locais.",
"O Pantanal é um importante habitat para diversas espécies de animais, inclusive aves migratórias."
]
rank(query, documents)
query = "What is the speed of light?"
documents = [
"Isaac Newton's laws of motion and gravity laid the groundwork for classical mechanics.",
"The theory of relativity, proposed by Albert Einstein, has revolutionized our understanding of space, time, and gravity.",
"The Earth orbits the Sun at an average distance of about 93 million miles, taking roughly 365.25 days to complete one revolution.",
"The speed of light in a vacuum is approximately 299,792 kilometers per second (km/s), or about 186,282 miles per second.",
"Light can be described as both a wave and a particle, a concept known as wave-particle duality."
]
rank(query, documents)