首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >生成随机图

生成随机图
EN

Stack Overflow用户
提问于 2011-04-24 14:28:53
回答 2查看 2.5K关注 0票数 0

我需要产生随机的单源/单汇流网络,的不同维度,以便我可以测量一些算法的性能,如福特-富尔克森和迪尼奇。

Kruskal算法是生成这样的图的一种方法吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-04-24 14:33:52

要创建通用流网络,只需创建一个adjancency矩阵即可。

adju =从节点u到节点v的容量

所以,你只需要随机地创建这个矩阵。

例如,如果n是你想要的顶点数(你也可以随机):

代码语言:javascript
复制
for u in 0..n-1:
    for v in 0..u-1:
      if (rand() % 2 and u != sink and v != source or u == source):
         adj[u][v] = rand()
         adj[v][u] = 0
      else:
         adj[u][v] = 0
         adj[v][u] = rand()
票数 1
EN

Stack Overflow用户

发布于 2021-08-18 14:53:37

希马德里斯的回答部分是正确的。我必须添加一些约束,以确保单源/单接收器得到满足。

对于单个源,只有一列必须是邻接矩阵的全部0,而对于单个接收器则必须是一行。

代码语言:javascript
复制
import numpy 

def random_dag(n):
    adj = np.zeros((n, n))
    sink = n-1
    source = 0
    for u in range(0, n):
        for v in range(u):
            if (u != sink and v != source or u == source):
                adj[u, v] = np.random.randint(0, 2)
                adj[v, u] = 0
            else:
                adj[u, v] = 0
                adj[v, u] = np.random.randint(0, 2)
    # Additional constraints to make sure single-source/single-sink
    # May be further randomized (but fixed my issues so far)
    for u in range(0, n):
        if sum(adj[u]) == 0:
            adj[u, -1] = 1
            adj[-1, u] = 0
        if sum(adj.T[u]) == 0:
            adj.T[u, 0] = 1
            adj.T[0, u] = 0
    return adj

您可以使用以下代码进行可视化:

代码语言:javascript
复制
import networkx
import matplotlib.plot as plt

def show_graph_with_labels(adjacency_matrix, mylabels):
    rows, cols = np.where(adjacency_matrix == 1)
    edges = zip(rows.tolist(), cols.tolist())
    gr = nx.DiGraph()
    gr.add_edges_from(edges)
    nx.draw(gr, node_size=500, labels=mylabels, with_labels=True)
    plt.show()


n = 4
show_graph_with_labels(random_dag(n), {i: i for i in range(n)})
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5771075

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档