Go to file
2019-09-22 15:23:54 -07:00
.circleci more fixes 2019-06-19 12:03:54 -07:00
build/lib/gradio released 0.8.1 2019-07-22 23:41:25 -07:00
dist released 0.8.1 2019-07-22 23:41:25 -07:00
examples finalized scirpts to launch gradio interfaces in example folder 2019-07-26 02:23:01 -07:00
gradio finalized scirpts to launch gradio interfaces in example folder 2019-07-26 02:23:01 -07:00
gradio.egg-info fix conflict in requires.txt 2019-07-23 14:44:11 -07:00
screenshots Add files via upload 2019-09-17 11:06:43 -07:00
src saliency 2019-04-29 10:04:22 -07:00
test fixed test 2019-07-26 02:35:00 -07:00
web Update getting_started.html 2019-09-22 15:23:54 -07:00
.gitignore just removed notebooks 2019-04-28 23:41:31 -07:00
build-interface.py fix all interfaces 2019-04-10 10:50:43 -07:00
index.html seperated inputs and outputs, added webcam interface 2019-02-16 20:11:28 -08:00
LICENSE Create LICENSE 2019-07-10 10:22:33 -07:00
MANIFEST.in 0.4.4 2019-03-25 13:17:46 -07:00
README.md Update README.md 2019-09-17 11:08:09 -07:00
setup.py Merge branch 'master' into dawood/sample-inputs 2019-07-23 14:41:39 -07:00

CircleCI

About Gradio

Gradio reduces the amount of data that a company needs to collect and label in order to build high-performing artificial intelligent systems.

The biggest bottleneck in building artificial intelligence systems is acquiring and labeling data. This process requires huge amounts of human labor and often requires domain expertise (e.g. costly lawyers to label contracts, costly doctors to label medical images). Applying recent machine learning research from Stanford, Gradio reduces the amount of data that an AI company needs to collect and label, often by as much as half.

This is achieved through: (1) identifying and correcting mislabelled data; (2) valuing each datapoint to automatically identify which data points should be labeled; and (3) intelligently augmenting data to diversify and maximize the value of the dataset. (See figure below.)

Gradio modules

Gradio UI Tool

As part of our work, we often try to understand what inputs that a model is particularly sensitive to. To help facilitate this, we've developed and open-sourced gradio, a python library that allows you to easily create input and output interfaces over trained models to make it easy for you to "play around" with your model in your browser by dragging-and-dropping in your own images (or pasting your own text, recording your own voice, etc.) and seeing what the model outputs. The library also automatically creates a shareable, public link to your model so you can share the interface with others (e.g. your client, your advisor, or your dad), who can use the model without writing any code.

Gradio is useful for:

  • Creating demos of your machine learning code for clients / collaborators / users
  • Getting feedback on model performance from users
  • Debugging your model interactively during development

For more details, see the accompanying paper: "Gradio: Hassle-Free Sharing and Testing of ML Models in the Wild", ICML HILL 2019, and please use the citation below.

@article{abid2019gradio,
title={Gradio: Hassle-Free Sharing and Testing of ML Models in the Wild},
author={Abid, Abubakar and Abdalla, Ali and Abid, Ali and Khan, Dawood and Alfozan, Abdulrahman and Zou, James},
journal={arXiv preprint arXiv:1906.02569},
year={2019}
}

To get a sense of gradio, take a look at the python notebooks in the examples folder, or read on below! And be sure to visit the gradio website: www.gradio.app.

Installation

pip install gradio

(you may need to replace pip with pip3 if you're running python3).

Usage

Gradio is very easy to use with your existing code. Here is a minimum working example:

import gradio
import tensorflow as tf
image_mdl = tf.keras.applications.inception_v3.InceptionV3()

io = gradio.Interface(inputs="imageupload", outputs="label", model_type="keras", model=image_mdl)
io.launch()

You can supply your own model instead of the pretrained model above, as well as use different kinds of models, not just keras models. Changing the input and output parameters in the Interface face object allow you to create different interfaces, depending on the needs of your model. Take a look at the python notebooks for more examples. The currently supported interfaces are as follows:

Input interfaces:

  • Sketchpad
  • ImageUplaod
  • Webcam
  • Textbox

Output interfaces:

  • Label
  • Textbox

Screenshots

Here are a few screenshots that show examples of gradio interfaces

MNIST Digit Recognition (Input: Sketchpad, Output: Label)

iface = gradio.Interface(input='sketchpad', output='label', model=model, model_type='keras')
iface.launch()

alt text

Image Classifier: InceptionNet (Input: Webcam, Output: Label)

iface = gradio.Interface(inputs='webcam', outputs='label', model=model, model_type='keras')
iface.launch()

alt text

Human DNA Variant Effect Prediction (Input: Textbox, Output: Label)

iface = gradio.Interface(inputs='textbox', outputs='label', model=model, model_type='keras')
iface.launch()

alt text

More Documentation

More detailed and up-to-date documentation can be found on the gradio website: www.gradio.app.