mirror of
https://github.com/gradio-app/gradio.git
synced 2025-01-06 10:25:17 +08:00
demo updates
This commit is contained in:
parent
cbdfcd5dc7
commit
d39eb9ea3f
1
.gitignore
vendored
1
.gitignore
vendored
@ -21,3 +21,4 @@ dist/*
|
|||||||
*.h5
|
*.h5
|
||||||
docs.json
|
docs.json
|
||||||
*.bak
|
*.bak
|
||||||
|
demo/tmp.zip
|
@ -1,4 +1,4 @@
|
|||||||
# Demo (Dataframe, Dropdown) -> (Dataframe)
|
# Demo: (Dataframe, Dropdown) -> (Dataframe)
|
||||||
|
|
||||||
import gradio as gr
|
import gradio as gr
|
||||||
import numpy as np
|
import numpy as np
|
||||||
|
Before Width: | Height: | Size: 800 KiB After Width: | Height: | Size: 800 KiB |
@ -1,4 +1,4 @@
|
|||||||
# (Radio, CheckboxGroup, Slider, Dropdown) -> (Image)
|
# Demo: (Radio, CheckboxGroup, Slider, Dropdown) -> (Image)
|
||||||
|
|
||||||
import gradio as gr
|
import gradio as gr
|
||||||
import random
|
import random
|
||||||
|
@ -1,7 +1,9 @@
|
|||||||
|
# Demo: (Image) -> (HighlightedText, KeyValues, HTML)
|
||||||
|
|
||||||
import gradio as gr
|
import gradio as gr
|
||||||
import numpy as np
|
import numpy as np
|
||||||
|
|
||||||
def snap(image):
|
def snap(image):
|
||||||
return image
|
return np.flipud(image)
|
||||||
|
|
||||||
gr.Interface(snap, gr.inputs.Image(shape=(100,100), image_mode="L", source="webcam"), "image").launch()
|
gr.Interface(snap, gr.inputs.Image(shape=(100,100), image_mode="L", source="webcam"), "image").launch()
|
||||||
|
@ -1,3 +1,5 @@
|
|||||||
|
# Demo: (File) -> (JSON)
|
||||||
|
|
||||||
import gradio as gr
|
import gradio as gr
|
||||||
from zipfile import ZipFile
|
from zipfile import ZipFile
|
||||||
|
|
||||||
|
@ -1,3 +1,5 @@
|
|||||||
|
# Demo: (File, File) -> (File)
|
||||||
|
|
||||||
import gradio as gr
|
import gradio as gr
|
||||||
from zipfile import ZipFile
|
from zipfile import ZipFile
|
||||||
|
|
||||||
|
@ -3,6 +3,31 @@ from gradio.inputs import InputComponent
|
|||||||
from gradio.outputs import OutputComponent
|
from gradio.outputs import OutputComponent
|
||||||
from gradio.interface import Interface
|
from gradio.interface import Interface
|
||||||
import inspect
|
import inspect
|
||||||
|
from os import listdir
|
||||||
|
from os.path import join
|
||||||
|
import re
|
||||||
|
|
||||||
|
in_demos, out_demos = {}, {}
|
||||||
|
demo_regex = "# Demo: \((.*)\) -> \((.*)\)"
|
||||||
|
for demo in listdir("demo"):
|
||||||
|
if demo.endswith(".py"):
|
||||||
|
screenshots = listdir(join("demo/screenshots", demo[:-3]))
|
||||||
|
demoset = [demo, screenshots]
|
||||||
|
with open(join("demo", demo)) as demo_file:
|
||||||
|
first_line = demo_file.readline()
|
||||||
|
match = re.match(demo_regex, first_line)
|
||||||
|
inputs = match.group(1).split(", ")
|
||||||
|
outputs = match.group(2).split(", ")
|
||||||
|
for i in inputs:
|
||||||
|
if i not in in_demos:
|
||||||
|
in_demos[i] = []
|
||||||
|
elif demoset not in in_demos[i]:
|
||||||
|
in_demos[i].append(demoset)
|
||||||
|
for o in outputs:
|
||||||
|
if o not in out_demos:
|
||||||
|
out_demos[o] = []
|
||||||
|
elif demoset not in out_demos[o]:
|
||||||
|
out_demos[o].append(demoset)
|
||||||
|
|
||||||
def get_params(func):
|
def get_params(func):
|
||||||
params_str = inspect.getdoc(func)
|
params_str = inspect.getdoc(func)
|
||||||
@ -33,7 +58,7 @@ def get_params(func):
|
|||||||
param_set.insert(0, (params.args[neg_index],))
|
param_set.insert(0, (params.args[neg_index],))
|
||||||
return param_set, params_doc
|
return param_set, params_doc
|
||||||
|
|
||||||
def document(cls_set):
|
def document(cls_set, demos):
|
||||||
docset = []
|
docset = []
|
||||||
for cls in cls_set:
|
for cls in cls_set:
|
||||||
inp = {}
|
inp = {}
|
||||||
@ -45,11 +70,14 @@ def document(cls_set):
|
|||||||
inp["type"] = doc.split("\n")[-1].split("type: ")[-1]
|
inp["type"] = doc.split("\n")[-1].split("type: ")[-1]
|
||||||
inp["params"], inp["params_doc"] = get_params(cls.__init__)
|
inp["params"], inp["params_doc"] = get_params(cls.__init__)
|
||||||
inp["shortcuts"] = list(cls.get_shortcut_implementations().items())
|
inp["shortcuts"] = list(cls.get_shortcut_implementations().items())
|
||||||
|
cls_name = cls.__name__
|
||||||
|
if cls_name in demos:
|
||||||
|
inp["demos"] = demos.get(cls_name, [])
|
||||||
docset.append(inp)
|
docset.append(inp)
|
||||||
return docset
|
return docset
|
||||||
|
|
||||||
inputs = document(InputComponent.__subclasses__())
|
inputs = document(InputComponent.__subclasses__(), in_demos)
|
||||||
outputs = document(OutputComponent.__subclasses__())
|
outputs = document(OutputComponent.__subclasses__(), out_demos)
|
||||||
interface_params = get_params(Interface.__init__)
|
interface_params = get_params(Interface.__init__)
|
||||||
interface = {
|
interface = {
|
||||||
"doc": inspect.getdoc(Interface),
|
"doc": inspect.getdoc(Interface),
|
||||||
@ -67,6 +95,6 @@ with open("docs.json", "w") as docs:
|
|||||||
"inputs": inputs,
|
"inputs": inputs,
|
||||||
"outputs": outputs,
|
"outputs": outputs,
|
||||||
"interface": interface,
|
"interface": interface,
|
||||||
"launch": launch
|
"launch": launch,
|
||||||
}, docs)
|
}, docs)
|
||||||
|
|
@ -151,13 +151,11 @@ def serve_files_in_background(interface, port, directory_to_serve=None, server_n
|
|||||||
if self.path == "/api/predict/":
|
if self.path == "/api/predict/":
|
||||||
# Make the prediction.
|
# Make the prediction.
|
||||||
self._set_headers()
|
self._set_headers()
|
||||||
print("in")
|
|
||||||
data_string = self.rfile.read(
|
data_string = self.rfile.read(
|
||||||
int(self.headers["Content-Length"]))
|
int(self.headers["Content-Length"]))
|
||||||
msg = json.loads(data_string)
|
msg = json.loads(data_string)
|
||||||
raw_input = msg["data"]
|
raw_input = msg["data"]
|
||||||
prediction, durations = interface.process(raw_input)
|
prediction, durations = interface.process(raw_input)
|
||||||
print("prediction")
|
|
||||||
|
|
||||||
output = {"data": prediction, "durations": durations}
|
output = {"data": prediction, "durations": durations}
|
||||||
self.wfile.write(json.dumps(output).encode())
|
self.wfile.write(json.dumps(output).encode())
|
||||||
|
Loading…
Reference in New Issue
Block a user