Spaces:
Running
Running
from spacy.lang.en import English | |
nlp = English() | |
nlp.add_pipe("sentencizer") | |
import pandas as pd | |
import gradio as gr | |
from nltk import sent_tokenize | |
from transformers import pipeline | |
from gradio.themes.utils.colors import red, green | |
detector = pipeline(task='text-classification', model='SJTU-CL/RoBERTa-large-ArguGPT-sent') | |
color_map = { | |
'0%': green.c400, | |
'10%': green.c300, | |
'20%': green.c200, | |
'30%': green.c100, | |
'40%': green.c50, | |
'50%': red.c50, | |
'60%': red.c100, | |
'70%': red.c200, | |
'80%': red.c300, | |
'90%': red.c400, | |
'100%': red.c500 | |
} | |
def predict_doc(doc): | |
# sents = sent_tokenize(doc) | |
sents = [s.text for s in nlp(doc).sents] | |
data = {'sentence': [], 'label': [], 'score': []} | |
res = [] | |
for sent in sents: | |
prob = predict_one_sent(sent) | |
data['sentence'].append(sent) | |
data['score'].append(round(prob, 4)) | |
if prob <= 0.5: | |
data['label'].append('Human') | |
else: data['label'].append('Machine') | |
if prob < 0.1: label = '0%' | |
elif prob < 0.2: label = '10%' | |
elif prob < 0.3: label = '20%' | |
elif prob < 0.4: label = '30%' | |
elif prob < 0.5: label = '40%' | |
elif prob < 0.6: label = '50%' | |
elif prob < 0.7: label = '60%' | |
elif prob < 0.8: label = '70%' | |
elif prob < 0.9: label = '80%' | |
elif prob < 1: label = '90%' | |
else: label = '100%' | |
res.append((sent, label)) | |
df = pd.DataFrame(data) | |
df.to_csv('result.csv') | |
overall_score = df.score.mean() | |
sum_str = '' | |
if overall_score <= 0.5: overall_label = 'Human' | |
else: overall_label = 'Machine' | |
sum_str = f'The essay is probably written by {overall_label}. The probability of being generated by AI is {overall_score}' | |
return sum_str, res, df, 'result.csv' | |
def predict_one_sent(sent): | |
''' | |
convert to prob | |
LABEL_1, 0.66 -> 0.66 | |
LABEL_0, 0.66 -> 0.34 | |
''' | |
res = detector(sent)[0] | |
org_label, prob = res['label'], res['score'] | |
if org_label == 'LABEL_0': prob = 1 - prob | |
return prob | |
with gr.Blocks() as demo: | |
with gr.Row(): | |
with gr.Column(): | |
text_in = gr.Textbox( | |
lines=5, | |
label='Essay input', | |
info='Please enter the essay in the textbox' | |
) | |
btn = gr.Button('Predict who writes this essay!') | |
sent_res = gr.HighlightedText(label='Labeled Result', color_map=color_map) | |
with gr.Row(): | |
summary = gr.Text(label='Result summary') | |
csv_f = gr.File(label='CSV file storing data with all sentences.') | |
tab = gr.Dataframe(label='Table with Probability Score', row_count=100) | |
btn.click(predict_doc, inputs=[text_in], outputs=[summary, sent_res, tab, csv_f], api_name='predict_doc') | |
demo.launch() | |