SciAssist / app.py
wing-nus's picture
update with description (#5)
0d3e375
raw
history blame
8.26 kB
import gradio as gr
from description import *
from reference_string_parsing import *
from summarization import *
from controlled_summarization import *
with gr.Blocks(css="#htext span {white-space: pre-line}") as demo:
gr.Markdown("# SciAssist: Scientists' Assistant toolkit")
gr.Markdown("SciAssist currently supports Reference String Parsing, uncontrolled Summarization and Controlled Summarization. Github repo: https://github.com/WING-NUS/SciAssist")
with gr.Tabs():
# Reference String Parsing
with gr.TabItem("Reference String Parsing"):
with gr.Box():
gr.Markdown(rsp_str_md)
with gr.Row():
with gr.Column():
rsp_str = gr.Textbox(label="Input String")
with gr.Column():
rsp_str_dehyphen = gr.Checkbox(label="dehyphen")
with gr.Row():
rsp_str_btn = gr.Button("Parse")
rsp_str_output = gr.HighlightedText(
elem_id="htext",
label="The Result of Parsing",
combine_adjacent=True,
adjacent_separator=" ",
)
rsp_str_examples = gr.Examples(examples=[[
"Waleed Ammar, Matthew E. Peters, Chandra Bhagavat- ula, and Russell Power. 2017. The ai2 system at semeval-2017 task 10 (scienceie): semi-supervised end-to-end entity and relation extraction. In ACL workshop (SemEval).",
True],
[
"Isabelle Augenstein, Mrinal Das, Sebastian Riedel, Lakshmi Vikraman, and Andrew D. McCallum. 2017. Semeval-2017 task 10 (scienceie): Extracting keyphrases and relations from scientific publications. In ACL workshop (SemEval).",
False]], inputs=[rsp_str, rsp_str_dehyphen])
with gr.Box():
gr.Markdown(rsp_file_md)
with gr.Row():
with gr.Column():
rsp_file = gr.File(label="Input File")
rsp_file_dehyphen = gr.Checkbox(label="dehyphen")
with gr.Row():
rsp_file_btn = gr.Button("Parse")
rsp_file_output = gr.HighlightedText(
elem_id="htext",
label="The Result of Parsing",
combine_adjacent=True,
adjacent_separator=" ",
)
rsp_file_examples = gr.Examples(examples=[["examples/N18-3011_ref.txt", False],["examples/BERT_paper.pdf", True]], inputs=[rsp_file, rsp_file_dehyphen])
rsp_file_btn.click(
fn=rsp_for_file,
inputs=[rsp_file, rsp_file_dehyphen],
outputs=rsp_file_output
)
rsp_str_btn.click(
fn=rsp_for_str,
inputs=[rsp_str, rsp_str_dehyphen],
outputs=rsp_str_output
)
# Single Document Summarization
with gr.TabItem("General Summarization"):
with gr.Box():
gr.Markdown(ssum_str_md)
with gr.Row():
with gr.Column():
ssum_str = gr.Textbox(label="Input String")
# with gr.Column():
# ssum_str_beams = gr.Number(label="Number of beams for beam search", value=1, precision=0)
# ssum_str_sequences = gr.Number(label="Number of generated summaries", value=1, precision=0)
with gr.Row():
ssum_str_btn = gr.Button("Generate")
ssum_str_output = gr.Textbox(
elem_id="htext",
label="Summary",
)
ssum_str_examples = gr.Examples(examples=[[ssum_str_example], ],
inputs=[ssum_str])
with gr.Box():
gr.Markdown(ssum_file_md)
with gr.Row():
with gr.Column():
ssum_file = gr.File(label="Input File")
# with gr.Column():
# ssum_file_beams = gr.Number(label="Number of beams for beam search", value=1, precision=0)
# ssum_file_sequences = gr.Number(label="Number of generated summaries", value=1, precision=0)
with gr.Row():
ssum_file_btn = gr.Button("Generate")
ssum_file_output = gr.Textbox(
elem_id="htext",
label="Summary",
)
ssum_file_examples = gr.Examples(examples=[["examples/BERT_body.txt"],["examples/BERT_paper.pdf"]],
inputs=[ssum_file])
ssum_file_btn.click(
fn=ssum_for_file,
inputs=[ssum_file],
outputs=ssum_file_output
)
ssum_str_btn.click(
fn=ssum_for_str,
inputs=[ssum_str],
outputs=ssum_str_output
)
# Controlled Summarization
with gr.TabItem("Controlled Summarization"):
with gr.Box():
gr.Markdown(ctrlsum_str_md)
with gr.Row():
with gr.Column():
ctrlsum_str = gr.Textbox(label="Input String")
with gr.Column():
# ctrlsum_str_beams = gr.Number(label="Number of beams for beam search", value=1, precision=0)
# ctrlsum_str_sequences = gr.Number(label="Number of generated summaries", value=1, precision=0)
ctrlsum_str_length = gr.Slider(0, 300, step=50, label="Length")
ctrlsum_str_keywords = gr.Textbox(label="Keywords")
with gr.Row():
ctrlsum_str_btn = gr.Button("Generate")
ctrlsum_str_output = gr.Textbox(
elem_id="htext",
label="Summary",
)
ctrlsum_str_examples = gr.Examples(examples=[[ssum_str_example, 50, "BERT" ], ],
inputs=[ctrlsum_str, ctrlsum_str_length, ctrlsum_str_keywords])
with gr.Box():
gr.Markdown(ctrlsum_file_md)
with gr.Row():
with gr.Column():
ctrlsum_file = gr.File(label="Input File")
with gr.Column():
# ctrlsum_file_beams = gr.Number(label="Number of beams for beam search", value=1, precision=0)
# ctrlsum_file_sequences = gr.Number(label="Number of generated summaries", value=1, precision=0)
ctrlsum_file_length = gr.Slider(0,300,step=50, label="Length")
ctrlsum_file_keywords = gr.Textbox(label="Keywords")
with gr.Row():
ctrlsum_file_btn = gr.Button("Generate")
ctrlsum_file_output = gr.Textbox(
elem_id="htext",
label="Summary",
)
ctrlsum_file_examples = gr.Examples(examples=[["examples/BERT_body.txt", 100, ""],["examples/BERT_paper.pdf", 0, "BERT"]],
inputs=[ctrlsum_file, ctrlsum_file_length, ctrlsum_file_keywords])
ctrlsum_file_btn.click(
fn=ctrlsum_for_file,
inputs=[ctrlsum_file, ctrlsum_file_length, ctrlsum_file_keywords],
outputs=ctrlsum_file_output
)
ctrlsum_str_btn.click(
fn=ctrlsum_for_str,
inputs=[ctrlsum_str, ctrlsum_str_length, ctrlsum_str_keywords],
outputs=ctrlsum_str_output
)
demo.launch(share=False)