gpt4 book ai didi

python - 通过 Matplotlib 使用 Dash 绘制有向图

转载 作者:行者123 更新时间:2023-12-01 07:25:25 29 4
gpt4 key购买 nike

Dash 似乎无法通过plotly 处理有向网络图。因此,我将通过 Matplotlib 使用 mpl_to_plotly 渲染图形。图表确实在网站上呈现,但没有边缘,并且有以下控制台输出:

Dang! That path collection is out of this world. I totally don't know what to do with it yet! Plotly can only import path collections linked to 'data' coordinates

Matplotlib 代码

mpl_fig , ax = plt.subplots()

G = nx.Graph()

G.add_edge('a', 'b', weight=0.6)
G.add_edge('a', 'c', weight=0.2)
G.add_edge('c', 'd', weight=0.1)
G.add_edge('c', 'e', weight=0.7)
G.add_edge('c', 'f', weight=0.9)
G.add_edge('a', 'd', weight=0.3)

elarge = [(u, v) for (u, v, d) in G.edges(data=True) if d['weight'] > 0.5]
esmall = [(u, v) for (u, v, d) in G.edges(data=True) if d['weight'] <= 0.5]

pos = nx.spring_layout(G) # positions for all nodes

# nodes
nx.draw_networkx_nodes(G, pos, node_size=700)

# edges
nx.draw_networkx_edges(G, pos, edgelist=elarge,
width=6)
nx.draw_networkx_edges(G, pos, edgelist=esmall,
width=6, alpha=0.5, edge_color='b', style='dashed')

# labels
nx.draw_networkx_labels(G, pos, font_size=20, font_family='sans-serif')


# error with plotly no supporting this kind of thing. Ty exporting to image and just show the image. Sucks becaues it is not interactive... but at least im showing what I want.

print(pos)

#plt.show()

plotly_fig = mpl_to_plotly(mpl_fig)

通过 Dash 调用

dcc.Graph(id='network-graph', figure=plotly_fig)

是否有另一种方法可以在 Dash 中处理网络有向图?或者使用 matplotlib 技术的另一种方法?

最佳答案

Plotly 中存在一个 Unresolved 问题,即 mpl_to_ploty 无法与 draw_networkx_edges 一起使用 ( link )。

此外,Plotly 本身并不支持有向边 ( link ),但它们可能会使用注释中的箭头进行模拟。

鉴于图形可能是使用 Plotly 语法手动构建的,例如作为(没有 Matplotlib):

import networkx as nx
import dash
import dash_core_components as dcc
import dash_html_components as html

G = nx.DiGraph()

G.add_edge('a', 'b', weight=0.6)
G.add_edge('a', 'c', weight=0.2)
G.add_edge('c', 'd', weight=0.1)
G.add_edge('c', 'e', weight=0.7)
G.add_edge('c', 'f', weight=0.9)
G.add_edge('a', 'd', weight=0.3)

elarge = [(u, v) for (u, v, d) in G.edges(data=True) if d['weight'] > 0.5]
esmall = [(u, v) for (u, v, d) in G.edges(data=True) if d['weight'] <= 0.5]

pos = nx.spring_layout(G) # positions for all nodes


Xn=[pos[k][0] for k in pos]
Yn=[pos[k][1] for k in pos]
labels = [k for k in pos]

nodes=dict(type='scatter',
x=Xn,
y=Yn,
mode='markers+text',
marker=dict(size=28, color='rgb(31,120,180)'),
textfont=dict(size=22, color='#DBD700'),
text=labels,
hoverinfo='text')

Xaxis=dict(showline=False, zeroline=False, showgrid=False, showticklabels=True,
mirror='allticks', ticks='inside', ticklen=5, tickfont = dict(size=14),
title='')

Yaxis=dict(showline=False, zeroline=False, showgrid=False, showticklabels=True,
mirror='allticks', ticks='inside', ticklen=5, tickfont = dict(size=14),
title='')

annotateELarge = [ dict(showarrow=True, arrowsize=0.9, arrowwidth=6, arrowhead=5, standoff=14, startstandoff=4,
ax=pos[arrow[0]][0], ay=pos[arrow[0]][1], axref='x', ayref='y',
x=pos[arrow[1]][0], y=pos[arrow[1]][1], xref='x', yref='y'
) for arrow in elarge]
annotateESmall = [ dict(showarrow=True, arrowsize=1.5, arrowwidth=2, arrowhead=5, opacity=0.5, standoff=14, startstandoff=4,
ax=pos[arrow[0]][0], ay=pos[arrow[0]][1], axref='x', ayref='y',
x=pos[arrow[1]][0], y=pos[arrow[1]][1], xref='x', yref='y'
) for arrow in esmall]

layout=dict(width=800, height=600,
showlegend=False,
xaxis=Xaxis,
yaxis=Yaxis,
hovermode='closest',
plot_bgcolor='#E5ECF6',
annotations= annotateELarge + annotateESmall, #arrows
)

plotly_fig = dict(data=[nodes], layout=layout)


#Dash page stub
external_stylesheets = ['https://codepen.io/chriddyp/pen/bWLwgP.css']
app = dash.Dash(__name__, external_stylesheets=external_stylesheets)
app.layout = html.Div(children=[
dcc.Graph(id='network-graph', figure=plotly_fig)
])

if __name__ == '__main__':
app.run_server(debug=True)

关于python - 通过 Matplotlib 使用 Dash 绘制有向图,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57482878/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com