DOT_Calculator / app.py
duypro247's picture
Create app.py
8bdbf0c
raw
history blame
1.74 kB
import gradio as gr
import networkx as nx
import pydot
import pandas as pd
from io import BytesIO
def calculate_parameters(file):
# Parse dot file using pydot
graphs = pydot.graph_from_dot_file(file.name)
G = nx.nx_pydot.from_pydot(graphs[0])
# Initialize the list of lengths and the node-to-index map
all_lengths = [0] * len(G.nodes())
node_to_index = {node: i for i, node in enumerate(G.nodes())}
# Calculate absolute depth (Dabs) and depth of each node
for node in nx.topological_sort(G):
if G.in_degree(node) > 0: # This node has a predecessor
all_lengths[node_to_index[node]] = max(all_lengths[node_to_index[n]]+1 for n in G.predecessors(node))
Dabs = sum(all_lengths)
# Create node depth dictionary
node_depth = {node: all_lengths[node_to_index[node]] for node in G.nodes()}
# Calculate maximum depth (Dmax)
Dmax = max(all_lengths)
# Calculate average depth (Davg)
Davg = Dabs / len(all_lengths)
# Calculate absolute width (Wabs)
Wabs = len(G.nodes())
# Calculate maximum width (Wmax)
level_count = [all_lengths.count(i) for i in set(all_lengths)]
Wmax = max(level_count)
# Calculate average width (Wavg)
Wavg = Wabs / len(set(all_lengths))
# Create a DataFrame for node depths
df = pd.DataFrame.from_dict(node_depth, orient='index', columns=['Depth'])
node_depth_str = df.to_string()
result = f"Node Depths:\n{node_depth_str}\n\nFinal Calculations:\n"
result += f"Dabs = {Dabs}, Dmax = {Dmax}, Davg = {Davg:.3f}\n"
result += f"Wabs = {Wabs}, Wmax = {Wmax}, Wavg = {Wavg:.3f}"
return result
iface = gr.Interface(fn=calculate_parameters, inputs="file", outputs="text")
iface.launch()