mirror of
https://github.com/gradio-app/gradio.git
synced 2025-01-06 10:25:17 +08:00
a238af4d68
* changes * add changeset * changes * changes * changes * add changeset * changes * add changeset * changes * add changeset * add changeset * changes * changes * changes * changes * changes * changes * changes * changes * changes * changes * changes * changes * changes * changes * add changeset * changes * changes * Update gradio/components/native_plot.py Co-authored-by: Abubakar Abid <abubakar@huggingface.co> * Update gradio/components/native_plot.py Co-authored-by: Abubakar Abid <abubakar@huggingface.co> * Update gradio/blocks.py Co-authored-by: Abubakar Abid <abubakar@huggingface.co> * changes * changes * changes * Update gradio/components/native_plot.py Co-authored-by: Abubakar Abid <abubakar@huggingface.co> * Update gradio/components/native_plot.py Co-authored-by: Abubakar Abid <abubakar@huggingface.co> * changes * changes * changes --------- Co-authored-by: Ali Abid <aliabid94@gmail.com> Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> Co-authored-by: Abubakar Abid <abubakar@huggingface.co>
78 lines
2.4 KiB
Python
78 lines
2.4 KiB
Python
import gradio as gr
|
|
import numpy as np
|
|
from data import temp_sensor_data, food_rating_data
|
|
|
|
with gr.Blocks() as bar_plots:
|
|
with gr.Row():
|
|
start = gr.DateTime("2021-01-01 00:00:00", label="Start")
|
|
end = gr.DateTime("2021-01-05 00:00:00", label="End")
|
|
apply_btn = gr.Button("Apply", scale=0)
|
|
with gr.Row():
|
|
group_by = gr.Radio(["None", "30m", "1h", "4h", "1d"], value="None", label="Group by")
|
|
aggregate = gr.Radio(["sum", "mean", "median", "min", "max"], value="sum", label="Aggregation")
|
|
|
|
temp_by_time = gr.BarPlot(
|
|
temp_sensor_data,
|
|
x="time",
|
|
y="temperature",
|
|
)
|
|
temp_by_time_location = gr.BarPlot(
|
|
temp_sensor_data,
|
|
x="time",
|
|
y="temperature",
|
|
color="location",
|
|
)
|
|
|
|
time_graphs = [temp_by_time, temp_by_time_location]
|
|
group_by.change(
|
|
lambda group: [gr.BarPlot(x_bin=None if group == "None" else group)] * len(time_graphs),
|
|
group_by,
|
|
time_graphs
|
|
)
|
|
aggregate.change(
|
|
lambda aggregate: [gr.BarPlot(y_aggregate=aggregate)] * len(time_graphs),
|
|
aggregate,
|
|
time_graphs
|
|
)
|
|
|
|
|
|
def rescale(select: gr.SelectData):
|
|
return select.index
|
|
rescale_evt = gr.on([plot.select for plot in time_graphs], rescale, None, [start, end])
|
|
|
|
for trigger in [apply_btn.click, rescale_evt.then]:
|
|
trigger(
|
|
lambda start, end: [gr.BarPlot(x_lim=[start, end])] * len(time_graphs), [start, end], time_graphs
|
|
)
|
|
|
|
with gr.Row():
|
|
price_by_cuisine = gr.BarPlot(
|
|
food_rating_data,
|
|
x="cuisine",
|
|
y="price",
|
|
)
|
|
with gr.Column(scale=0):
|
|
gr.Button("Sort $ > $$$").click(lambda: gr.BarPlot(sort="y"), None, price_by_cuisine)
|
|
gr.Button("Sort $$$ > $").click(lambda: gr.BarPlot(sort="-y"), None, price_by_cuisine)
|
|
gr.Button("Sort A > Z").click(lambda: gr.BarPlot(sort=["Chinese", "Italian", "Mexican"]), None, price_by_cuisine)
|
|
|
|
with gr.Row():
|
|
price_by_rating = gr.BarPlot(
|
|
food_rating_data,
|
|
x="rating",
|
|
y="price",
|
|
x_bin=1,
|
|
)
|
|
price_by_rating_color = gr.BarPlot(
|
|
food_rating_data,
|
|
x="rating",
|
|
y="price",
|
|
color="cuisine",
|
|
x_bin=1,
|
|
color_map={"Italian": "red", "Mexican": "green", "Chinese": "blue"},
|
|
)
|
|
|
|
|
|
if __name__ == "__main__":
|
|
bar_plots.launch()
|