gradio/README.md

88 lines
3.0 KiB
Markdown
Raw Normal View History

2019-04-02 07:54:13 +08:00
# Gradio
2019-06-14 17:17:55 +08:00
[![CircleCI](https://circleci.com/gh/gradio-app/gradio.svg?style=svg)](https://circleci.com/gh/gradio-app/gradio)
2019-01-25 15:34:09 +08:00
2019-06-20 01:18:07 +08:00
`Gradio` is a python library that allows you to place input and output interfaces over trained models to make it easy for you to "play around" with your model and share the public URL to the interface with others. Gradio runs entirely locally using your browser.
For more details, see the accompanying paper: ["Gradio: Hassle-Free Sharing and Testing of ML Models in the Wild"]
(https://arxiv.org/pdf/1906.02569.pdf), *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}
}
```
2019-01-25 15:34:09 +08:00
2019-03-31 03:50:17 +08:00
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.
2019-01-25 15:34:09 +08:00
2019-02-20 12:39:21 +08:00
## Installation
```
pip install gradio
```
(you may need to replace `pip` with `pip3` if you're running `python3`).
## Usage
2019-03-31 03:49:02 +08:00
Gradio is very easy to use with your existing code. Here is a minimum working example:
2019-02-20 12:39:21 +08:00
2019-02-20 14:26:48 +08:00
```python
2019-02-20 12:39:21 +08:00
import gradio
2019-03-31 03:49:02 +08:00
import tensorflow as tf
image_mdl = tf.keras.applications.inception_v3.InceptionV3()
2019-02-20 12:39:21 +08:00
2019-03-31 03:49:02 +08:00
io = gradio.Interface(inputs="imageupload", outputs="label", model_type="keras", model=image_mdl)
io.launch()
2019-02-20 12:39:21 +08:00
```
2019-03-31 03:49:02 +08:00
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:
2019-02-20 12:39:21 +08:00
**Input interfaces**:
* Sketchpad
* ImageUplaod
* Webcam
* Textbox
**Output interfaces**:
2019-03-31 03:49:49 +08:00
* Label
2019-02-20 12:39:21 +08:00
* Textbox
## Screenshots
2019-02-20 12:46:44 +08:00
Here are a few screenshots that show examples of gradio interfaces
2019-03-31 03:49:49 +08:00
#### MNIST Digit Recognition (Input: Sketchpad, Output: Label)
2019-02-20 12:47:45 +08:00
2019-02-20 14:26:48 +08:00
```python
2019-03-31 03:49:49 +08:00
iface = gradio.Interface(input='sketchpad', output='label', model=model, model_type='keras')
2019-02-20 14:26:48 +08:00
iface.launch()
```
2019-02-20 14:24:29 +08:00
![alt text](https://raw.githubusercontent.com/abidlabs/gradio/master/screenshots/mnist4.png)
2019-03-31 03:49:49 +08:00
#### Facial Emotion Detector (Input: Webcam, Output: Label)
2019-02-20 12:47:45 +08:00
2019-02-20 14:26:48 +08:00
```python
2019-03-31 03:49:49 +08:00
iface = gradio.Interface(inputs='webcam', outputs='label', model=model, model_type='keras')
2019-02-20 14:26:48 +08:00
iface.launch()
```
2019-02-20 14:24:29 +08:00
![alt text](https://raw.githubusercontent.com/abidlabs/gradio/master/screenshots/webcam_happy.png)
2019-03-31 03:49:49 +08:00
#### Sentiment Analysis (Input: Textbox, Output: Label)
2019-02-20 12:47:45 +08:00
2019-02-20 14:26:48 +08:00
```python
2019-03-31 03:49:49 +08:00
iface = gradio.Interface(inputs='textbox', outputs='label', model=model, model_type='keras')
2019-02-20 14:26:48 +08:00
iface.launch()
```
2019-02-20 14:24:29 +08:00
![alt text](https://raw.githubusercontent.com/abidlabs/gradio/master/screenshots/sentiment_positive.png)
2019-03-31 03:49:02 +08:00
### More Documentation
2019-03-31 03:49:49 +08:00
More detailed and up-to-date documentation can be found on the gradio website: www.gradio.app.
2019-02-20 12:46:44 +08:00
2019-02-20 12:39:21 +08:00