- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在使用 Python Networkx 2.1 在具有加权边的无向图上计算介数中心性和当前流介数中心性。我关心的是 networkx 函数中参数“weight”的含义。请考虑以下示例给出的图表
G= nx.Graph()
G.add_path([1, 2,4])
G.add_path([1, 3,4])
G[1][2]['weight'] = 20
G[1][3]['weight'] = 1
G[2][4]['weight'] = 1
G[3][4]['weight'] = 1
for u,v,d in G.edges(data=True):
if 'weight' in d:
if d['weight'] != 0:
d['reciprocal'] = 1/d['weight']
在我的例子中,边缘权重是关系的强度,因此是积极的东西。这个想法是,具有较高权重的边应该对介数有更大的贡献。考虑到这个想法,我说计算节点加权介数中心性和加权电流介数中心性的正确公式如下是否正确?
b = nx.betweenness_centrality(G, weight= 'reciprocal', normalized=False)
Out[46]: {1: 1.0, 2: 1.0, 3: 0.0, 4: 0.0}
f = nx.current_flow_betweenness_centrality(G, normalized= False, weight= 'weight', solver='lu')
Out[48]:
{1: 1.3114754098360655,
2: 1.3114754098360657,
3: 0.6885245901639343,
4: 0.6885245901639347}
请注意,在第一个公式中,我使用了边缘权重的倒数,因为我觉得这些被算法解释为距离,所以有些“不好”。另一方面,在第二个公式中,我使用了原始权重,因为在电流介数算法中,这似乎更重视节点 1 和 2,就像介于两者之间。因此这里的权重似乎是“正”的。
我想知道我是否做错了什么。事实上,在较大的图表上,如果我使用相同的权重参数而不是倒数,则两个度量的相关性更高。这两种算法如何处理权重?
最佳答案
这可能对你现在没有太大帮助,但对于其他有同样问题的人......
查看源代码表明,如果提供权重,Dijkstra 算法用于计算最短路径。 Dijkstra 算法通常将权重视为距离(即“坏”),此实现也不异常(exception)。因此,取边缘权重的倒数是正确的方法。我不确定你所说的“在更大的图表上,这两个指标更相关”是什么意思。这将取决于您的大图彼此之间的相似程度。
关于python - networkx - weight in betwenness 和 current flow betweenness 的含义,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50497186/
这个问题在这里已经有了答案: Towards the "true" definition of JAVA_HOME (5 个答案) 关闭 4 年前。 为什么 ActiveMQ 提供者需要设置 JAV
这个问题在这里已经有了答案: What is a lambda expression in C++11? (10 个答案) 关闭 8 年前。 这是来自 boosts asio 的一个例子。这是什么意
这个问题在这里已经有了答案: What does the double colon (::) mean in CSS? (3 个答案) 关闭 7 年前。 我经常看到这种用法。特别是伪类。“::”在
嗨,另一个愚蠢的简单问题。我注意到在Apple框架中的某些typedef中使用符号"<<"谁能告诉我这是什么意思?: enum { UIViewAutoresizingNone
someObject.$() 是什么意思? 我正在浏览 sapui5 工具包中的 tilecontainer-dbg 文件,发现了这个: var oDomRef = this.$(); or some
这个问题已经有答案了: How to interpret function parameters in software and language documentation? (4 个回答) 已关闭
我遇到过这个语法。任何人都可以解释一下 getArg1ListInfo:()=>(object.freeze(arg1)) 的含义 function foo (arg1,arg2) { let
对于子类,我有以下代码: class child1 : public parent { public: static parent* function1(void) { ret
这个问题在这里已经有了答案: What does "|=" mean? (pipe equal operator) (6 个答案) 关闭 1 年前。 我有一部分代码包含以下功能: void Keyb
以下在 C++ 中是什么意思? typedef PComplex RComplex [100]; 请注意,PComplex 是我代码中的用户定义类型。 谢谢 最佳答案 RComplex 是 PComp
在我的 Lisp 代码中,我有函数 (nfa-regex-compile),它创建一个包含初始状态、转换和最终状态的 cons 列表(表示自动机的节点)从作为参数给出的正则表达式开始。 在这种情况下,
以下文字摘自 Learning Spark 第 3 章 One issue to watch out for when passing functions is inadvertently seria
PHP 文档 block 中以下内容的含义是什么: #@+ zend框架代码中的一个例子: /**#@+ * @const string Version constant numbers */ c
由于 python 的一些版本控制问题,我必须使用自定义函数来比较 HMAC (SHA512)。为此,我找到了这个函数: def compare_digest(x, y): if not (i
取自this answer here : static const qi::rule node = '{' >> *node >> '}' | +~qi::char_("{}"); 请注意,声明了名称
我正在查看 chi 包的文档。我看到类似的东西: https://github.com/pressly/chi/blob/master/_examples/rest/main.go#L154 data
我想知道如果我采用值为 8 的 INT,这是否意味着我只能从 1 到 99999999 或从 1 到 4294967295 UNSIGNED? 最佳答案 文档似乎很清楚这一点: Numeric Typ
我想知道如果我采用值为 8 的 INT,这是否意味着我只能从 1 到 99999999 或从 1 到 4294967295 UNSIGNED? 最佳答案 文档似乎很清楚这一点: Numeric Typ
这个问题在这里已经有了答案: 关闭9年前。 Possible Duplicate: Does “/* (non-javadoc)” have a well-understood meaning? 以下
在 Prolog 代码中,可以使用“ headless ”Horn 子句将指令传递给编译器,这些子句与指向左侧的物质蕴涵 ':-' (⇐) 的左侧没有头部关系。例如,导入模块或声明 Unit Test
我是一名优秀的程序员,十分优秀!