Spaces:
Runtime error
Runtime error
File size: 1,667 Bytes
8ec0711 3711811 eeac5cc 3711811 ce5c0eb a8c9879 8ec0711 959ecc7 a8c9879 8ec0711 2dab15b 8ec0711 3711811 ce5c0eb a8c9879 ce5c0eb a8c9879 ce5c0eb a8c9879 082d447 |
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 33 34 35 36 37 38 39 40 41 42 43 44 45 46 |
from transformers import AutoModelForSequenceClassification,AutoTokenizer
from torch.nn.functional import softmax
import torch
import gradio as gr
import json
model_name="nebiyu29/hate_classifier"
tokenizer=AutoTokenizer.from_pretrained(model_name)
model=AutoModelForSequenceClassification.from_pretrained(model_name)
#this where the model is active and we need to make the gradiends in active
def model_classifier(text):
model.eval()
with torch.no_grad():
if len(text)==0:
return f"the input text is {text}"
else:
encoded_input=tokenizer(text) #this is where the encoding happens
logits=model(**encoded) #this is the logits of the labels
probs_label=softmax(logits,dim=-1) #turning the probability distribution into normalize form
id2label=model.config.id2label
return_probs={id2label[i]:probs.item() for i,probs in enumerate(probs_label[0])}
return json.dumps(list(return_probs.items()))
#lets define how the output looks like
output_format=gr.Table(label="label probabilities",
columns=["label","probabilities"],
type="table",
show_index=False,
input_type="json",
max_rows=4,
max_columms=2
)
#lets write something that accepts input as text and returns the most likely out come out of 3
demo=gr.Interface(
fn=model_classifier,
inputs=gr.Textbox(lines=5,label="Enter you text"),
outputs=output_format,
title="Hate Classifier Demo App"
)
demo.launch(share=True) |