|
import pandas as pd |
|
import numpy as np |
|
import matplotlib.pyplot as plt |
|
import gradio as gr |
|
|
|
def plot_usage_volume(systems, users, timelines): |
|
|
|
data = pd.DataFrame(columns=["System", "Month", "Usage"]) |
|
|
|
|
|
for i, system in enumerate(systems): |
|
|
|
usage = np.concatenate([ |
|
np.linspace(0, users[i], int(timelines[i] * 0.25)), |
|
np.linspace(users[i] * 0.5, users[i], int(timelines[i] * 0.5)), |
|
np.linspace(users[i], users[i] * 0.75, int(timelines[i] * 0.25)) |
|
]) |
|
|
|
|
|
months = ["Month {}".format(j) for j in range(1, len(usage) + 1)] |
|
system_data = pd.DataFrame({"System": [system] * len(usage), "Month": months, "Usage": usage}) |
|
data = pd.concat([data, system_data], axis=0) |
|
|
|
|
|
fig, axs = plt.subplots(2, 1, figsize=(12, 8), sharex=True, gridspec_kw={'hspace': 0.5}) |
|
|
|
|
|
for i, system in enumerate(systems): |
|
system_data = data[data["System"] == system] |
|
axs[0].plot(system_data["Month"], system_data["Usage"], label=system) |
|
axs[0].set_ylabel("Usage Volume") |
|
axs[0].set_title("Usage Volume for Various Systems") |
|
|
|
|
|
aggregated_data = data.groupby("Month").sum().reset_index() |
|
axs[1].plot(aggregated_data["Month"], aggregated_data["Usage"], label="All Systems", linewidth=3, linestyle="--") |
|
axs[1].set_xlabel("Month") |
|
axs[1].set_ylabel("Usage Volume") |
|
axs[1].set_title("Aggregated Usage Volume for All Systems") |
|
|
|
|
|
axs[0].set_xticks(aggregated_data.index[::3]) |
|
axs[1].set_xticks(aggregated_data.index[::3]) |
|
|
|
|
|
axs[0].set_xticklabels(aggregated_data["Month"][::3], rotation=45, fontsize=10) |
|
axs[1].set_xticklabels(aggregated_data["Month"][::3], rotation=45, fontsize=10) |
|
|
|
|
|
axs[0].legend() |
|
axs[1].legend() |
|
|
|
|
|
return gr.outputs.Image(plt) |
|
|
|
|
|
system1 = gr.inputs.Textbox(label="System 1 Name", default="System1") |
|
users1 = gr.inputs.Slider(minimum=100, maximum=10000, step=100, default=1000, label="System 1 Estimated Users") |
|
timeline1 = gr.inputs.Slider(minimum=6, maximum=48, step=6, default=12, label="System 1 Timeline (Months)") |
|
|
|
|
|
system2 = gr.inputs.Textbox(label="System 2 Name", default="System2") |
|
users2 = gr.inputs.Slider(minimum=100, maximum=10000, step=100, default=500, label="System 2 Estimated Users") |
|
timeline2 = gr.inputs.Slider(minimum=6, maximum=48, step=6, default=18, label="System 2 Timeline (Months)") |
|
|
|
system3 = gr.inputs.Textbox(label="System 3 Name", default="System3") |
|
users3 = gr.inputs.Slider(minimum=100, maximum=10000, step=100, default=2000, label="System 3 Estimated Users") |
|
timeline3 = gr.inputs.Slider(minimum=6, maximum=48, step=6, default=24, label="System 3 Timeline (Months)") |
|
|
|
|
|
inputs = [system1, users1, timeline1, system2, users2, timeline2, system3, users3, timeline3] |
|
output = gr.outputs.Image("plot.png") |
|
title = "System Rollout Usage Volume Plot" |
|
description = "Enter the rollout parameters for three different systems and see the resulting usage volume plot." |
|
|
|
gr.Interface(plot_usage_volume, inputs, output, title=title, description=description).launch(); |