🚀 LiLT文檔問答模型
LiLT模型是用於文檔問答任務的模型,本模型在英文DocVQA數據集上進行了微調,能有效處理文檔相關的問答需求。
🚀 快速開始
你可以按照以下步驟使用LiLT模型進行文檔問答:
from transformers import AutoTokenizer, AutoModelForQuestionAnswering
from datasets import load_dataset
model_checkpoint = "TusharGoel/LiLT-Document-QA"
tokenizer = AutoTokenizer.from_pretrained(model_checkpoint, add_prefix_space=True)
model_predict = AutoModelForQuestionAnswering.from_pretrained(model_checkpoint)
model_predict.eval()
dataset = load_dataset("nielsr/funsd", split="train")
example = dataset[0]
print(example)
question = "What is the Licensee Number?"
print(question)
words = example["words"]
boxes = example["bboxes"]
encoding = tokenizer(question, words, boxes = boxes, return_token_type_ids=True, return_tensors="pt")
word_ids = encoding.word_ids(0)
outputs = model_predict(**encoding)
loss = outputs.loss
start_scores = outputs.start_logits
end_scores = outputs.end_logits
start, end = word_ids[start_scores.argmax(-1).item()], word_ids[end_scores.argmax(-1).item()]
print(" ".join(words[start : end + 1]))
💻 使用示例
基礎用法
from transformers import AutoTokenizer, AutoModelForQuestionAnswering
from datasets import load_dataset
model_checkpoint = "TusharGoel/LiLT-Document-QA"
tokenizer = AutoTokenizer.from_pretrained(model_checkpoint, add_prefix_space=True)
model_predict = AutoModelForQuestionAnswering.from_pretrained(model_checkpoint)
model_predict.eval()
dataset = load_dataset("nielsr/funsd", split="train")
example = dataset[0]
print(example)
question = "What is the Licensee Number?"
print(question)
words = example["words"]
boxes = example["bboxes"]
encoding = tokenizer(question, words, boxes = boxes, return_token_type_ids=True, return_tensors="pt")
word_ids = encoding.word_ids(0)
outputs = model_predict(**encoding)
loss = outputs.loss
start_scores = outputs.start_logits
end_scores = outputs.end_logits
start, end = word_ids[start_scores.argmax(-1).item()], word_ids[end_scores.argmax(-1).item()]
print(" ".join(words[start : end + 1]))
📄 許可證
本項目採用MIT許可證。
📚 詳細文檔
LiLT模型的詳細信息請點擊此處查看。