Aller au contenu

Créer une interface web avec Gradio

Gradio est un package Python qui permet de créer des interfaces web pour les modèles de machine learning.

Gradio vous permet de créer rapidement des composants d'interface utilisateur personnalisables autour de vos modèles TensorFlow ou PyTorch, ou même des fonctions Python arbitraires. Mélangez et associez les composants pour prendre en charge toute combinaison d'entrées et de sorties.....

Les composants de Gradio

Une application Gradio est composée de trois composantes

  • des entrées
  • une fonction de traitement
  • des sorties

Le fonctionnement de Gradio est relativement simplement, on fournit des entrées qui vont être traitées par la fonction de traitement et retourner des sorties.

Installation

Gradio peut être installé depuis le répertoire PyPi.

pip install gradio

Première application

Créer un fichier app.py

import gradio as gr

Créer la fonction de traitement

def greet(name):
    return f"Hello {name} !"

Définir les entrées et les sorties

input_name = gr.Textbox(label="Name")
output_msg = gr.Textbox(label="Message")
app = gr.Interface(fn=greet,
                   inputs=input_name,
                   outputs=output_msg,
                   title="Greeting App",
                   description="Enter your name to get a greeting message")

Lancer l'application

app.launch()

Le code complet

app_greet.py
import gradio as gr


def greet(name):
    return f"Hello {name} !"


input_name = gr.Textbox(label="Name")
output_msg = gr.Textbox(label="Message")

app = gr.Interface(fn=greet,
                   inputs=input_name,
                   outputs=output_msg,
                   title="Greeting App",
                   description="Enter your name to get a greeting message")

app.launch()

Image Black & White Converter

Créer un fichier app.py

import gradio as gr

Créer la fonction de traitement

def greet(name):
    return f"Hello {name} !"

Définir les entrées et les sorties

input_name = gr.Textbox(label="Name")
output_msg = gr.Textbox(label="Message")
app = gr.Interface(fn=greet,
                   inputs=input_name,
                   outputs=output_msg,
                   title="Greeting App",
                   description="Enter your name to get a greeting message")

Lancer l'application

app.launch()

Le code complet

app_greet.py
# Packages
import gradio as gr
from PIL import Image


# Serving Function
def convert_image(image):
    pil_image = Image.fromarray(image)
    pil_image = pil_image.convert("L")
    return pil_image


# Setup interface
input_image = gr.Image()
output_image = gr.Image()
app = gr.Interface(fn=convert_image, 
                   inputs=input_image, 
                   outputs=output_image,
                   title="Image Black & White Converter",
                   description="Simple tool to convert any image in Black & White")

# Launch
app.launch()

Modèle de classification d'image

Créons à pésent une interface pour un modèle de classification d'image


Pour en savoir plus, merci de consulter la documentation de Gradio ici https://gradio.app/.