NLP Course documentation

Creare la tua prima demo

Hugging Face's logo
Join the Hugging Face community

and get access to the augmented documentation experience

to get started

Creare la tua prima demo

Ask a Question Open In Colab Open In Studio Lab

Iniziamo installando Gradio! Essendo una libreria di Python, è sufficiente eseguire:

$ pip install gradio

Puoi usare Gradio ovunque, dalla tua IDE Python preferita, ai Jupyter notebook o anche in Google Colab 🤯! Quindi, installa Gradio in qualsiasi posto in cui usi Python!

Iniziamo con un semplice esempio “Hello World” per prendere familiarità con la sintassi di Gradio:

import gradio as gr


def greet(name):
    return "Hello " + name


demo = gr.Interface(fn=greet, inputs="text", outputs="text")

demo.launch()

Analizziamo il codice qui sopra:

  • Per prima cosa, definiamo una funzione chiamata greet(). In questo caso, si tratta di una semplice funzione che aggiunge “Hello” prima di un nome (name), ma questa può essere in generale qualsiasi funzione in Python. Ad esempio, nelle applicazioni di machine learning, questa funzione chiamerebbe un modello per fare una previsione su un input e restituirebbe l’output.
  • Creaiamo puoi una Interface (Interfaccia) di Gradio con tre argomenti, fn, inputs, e outputs. Questi argomenti definiscono la funzione di predizione e il tipo di componenti di ingresso e di uscita che desideriamo. Nel nostro caso, entrambi i componenti sono semplici caselle di testo.
  • Chiamiamo poi il metodo launch() sul Interface creata.

Se si esegue questo codice, l’interfaccia qui sotto apparirà automaticamente all’interno di un Jupyter/Colab notebook, o comparirà in un browser http://localhost:7860 se lanciato in uno script.

Prova subito a utilizzare questa GUI con il tuo nome o con un altro input!

Si noterà che in questa GUI, Gradio ha riconosciuto automaticamente il nome del parametro di input (name) e lo applica come etichetta in cima alla casella di testo. E se si volesse cambiarlo? O se si volesse personalizzare la casella di testo in qualche altro modo? In questo caso, si può istanziare una classe che rappresenti il componente in input.

Si osservi l’esempio seguente:

import gradio as gr


def greet(name):
    return "Hello " + name


# We instantiate the Textbox class
textbox = gr.Textbox(label="Type your name here:", placeholder="John Doe", lines=2)

gr.Interface(fn=greet, inputs=textbox, outputs="text").launch()

Qui abbiamo creato una casella di testo di input con un’etichetta (label), un segnaposto (placeholder) e un numero di righe stabilito (lines). Si potrebbe fare lo stesso per la casella di testo in output, ma per ora ci fermiamo qui.

Abbiamo visto che con poche righe di codice, Gradio consente di creare una semplice interfaccia intorno a qualsiasi funzione con qualsiasi tipo di input o output. In questa sezione abbiamo iniziato con una semplice casella di testo, ma nelle prossime sezioni tratteremo altri tipi di input e output. Vediamo ora di inserire un po’ di NLP in un’applicazione Gradio.

🤖 Includere le predizioni del modello

Costruiamo ora una semplice interfaccia che consenta di dimostrare come funziona un modello di generazione del testo come GPT-2.

Caricheremo il nostro modello usando la funzione pipeline() di 🤗 Transformers. Se hai bisogno di un rapido ripasso, puoi tornare a quella sezione nel Capitolo 1.

Per prima cosa, definiamo una funzione di predizione che riceve un prompt di testo e restituisce il testo completato:

from transformers import pipeline

model = pipeline("text-generation")


def predict(prompt):
    completion = model(prompt)[0]["generated_text"]
    return completion

Questa funzione completa le richieste fornite dall’utente e puoi eseguirla con qualche tuo input per vedere come funziona. Ecco un esempio (potresti ottenere un risultato diverso):

predict("My favorite programming language is")
>> My favorite programming language is Haskell. I really enjoyed the Haskell language, but it doesn't have all the features that can be applied to any other language. For example, all it does is compile to a byte array.

Ora che abbiamo una funzione per generare previsioni, possiamo creare e lanciare una Interface nello stesso modo in cui abbiamo fatto prima:

import gradio as gr

gr.Interface(fn=predict, inputs="text", outputs="text").launch()

Ecco fatto! Ora è possibile utilizzare questa interfaccia per generare testo utilizzando il modello GPT-2 come mostrato qui sotto 🤯.

Continua a leggere per scoprire come costruire altri tipi di demo con Gradio!