File size: 978 Bytes
2421383
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
import gradio as gr
import torch
from transformers import AutoTokenizer, RobertaForQuestionAnswering

tokenizer = AutoTokenizer.from_pretrained("tsmatz/roberta_qa_japanese")
model = RobertaForQuestionAnswering.from_pretrained("tsmatz/roberta_qa_japanese")

def answer(text, question):
  inputs = tokenizer(question, text, add_special_tokens=True, return_tensors="pt")
  input_ids = inputs["input_ids"].tolist()[0]

  outputs = model(**inputs)
  answer_start_scores = outputs.start_logits
  answer_end_scores = outputs.end_logits

  answer_start = torch.argmax(answer_start_scores)
  answer_end = torch.argmax(answer_end_scores) + 1

  answer = tokenizer.convert_tokens_to_string(
      tokenizer.convert_ids_to_tokens(input_ids[answer_start:answer_end])
  )

  return answer

gr.Interface(
    answer,
    [
        gr.Textbox(label="Text:", placeholder="Text...", lines=5),
        gr.Textbox(label="Question:", placeholder="Question...", lines=1)
    ],
    "text",
).launch()