davanstrien's picture
davanstrien HF staff
create app.py
6f30057
raw
history blame
No virus
2.1 kB
import gradio as gr
from transformers import pipeline
from transformers import AutoTokenizer, AutoModelForSequenceClassification
sample_text = [
[
"Poems on various subjects. Whereto is prefixed a short essay on the structure of English verse"
],
[
"Journal of a Residence in China and the neighbouring countries from 1830 to 1833. With an introductory essay by the Hon. and Rev. Baptist Wriothesley Noel. [With a map.]"
],
["The Adventures of Oliver Twist. [With plates.]"],
["['The Adventures of Sherlock Holmes', 'Single Works']"],
[
"['Coal, Iron, and Oil; or, the Practical American miner. A plain and popular work on our mines and mineral resources ... With numerous maps and engravings, etc']"
],
[
"Summer Travelling in Iceland; being the narrative of two journeys across the island ... With a chapter on Askja by E. Delmar Morgan ... Containing also a literal translation of three sagas. Maps, etc'"
],
[
"Histoire de France au moyen aÃÇge, depuis Philippe-Auguste jusqu'aÃÄ la fin du reÃÄgne de Louis XI. 1223-1483. Troisieme eÃÅdition"
],
[
"Two Centuries of Soho: its institutions, firms, and amusements. By the Clergy of St. Anne's, Soho, J. H. Cardwell ... H. B. Freeman ... G. C. Wilton ... assisted by other contributors, etc"
],
["""A Christmas Carol"""],
]
description = """
British Library Books genre detection model
"""
tokenizer = AutoTokenizer.from_pretrained("BritishLibraryLabs/bl-books-genre")
model = AutoModelForSequenceClassification.from_pretrained("BritishLibraryLabs/bl-books-genre")
classifier = pipeline('text-classification',model=model, tokenizer=tokenizer, return_all_scores=True)
def predict(text):
predictions = classifier(text)
return {pred['label']: pred['score'] for pred in predictions[0]}
gr.Interface(predict,
inputs=gr.inputs.Textbox(label="Book title"),
outputs=gr.outputs.Label(label="Predicted genre"),
interpretation='shap',
examples=sample_text,description=description,
).launch(enable_queue=True)