图形工具 - 'NestedBlockState' 对象没有属性 'get_nonempty_B'

graph-tool - 'NestedBlockState' object has no attribute 'get_nonempty_B'

我正在尝试从图形工具说明书中复制一段代码,以在使用层次分区时找到图形中组数的边际概率。然而,我收到一条错误消息,告诉我 'NestedBlockState' object has no attribute 'get_nonempty_B' 所以大概是我在某个地方犯了一个错误。有人知道我错在哪里吗?

import graph_tool.all as gt
import cPickle as pickle

g = gt.load_graph('graph_no_multi_reac_type.gt')
gt.remove_parallel_edges(g)

state = gt.minimize_nested_blockmodel_dl(g, deg_corr=True)

state = state.copy(sampling=True)
with open('state_mcmc.pkl','wb') as state_pkl:
    pickle.dump(state,state_pkl,-1)

print 'equilibrating Markov chain'
gt.mcmc_equilibrate(state, wait=1000, mcmc_args=dict(niter=10))

h = np.zeros(g.num_vertices() + 1)

def collect_num_groups(s):
    B = s.get_nonempty_B()
    h[B] += 1

print 'colleting marginals'
gt.mcmc_equilibrate(state, force_niter=10000, mcmc_args=dict(niter=10),
                callback=collect_num_groups)
with open('state_ncnc.pkl','wb') as state_pkl:
    pickle.dump(state,state_pkl,-1)

with open('hist.pkl','wb') as h_pkl:
    pickle.dump(h,h_pkl,-1)

我得到的错误如下所示:

Traceback (most recent call last):
  File "num_groups_marg_prob.py", line 42, in <module>
        gt.mcmc_equilibrate(state, force_niter=10000, mcmc_args=dict(niter=10),
  File "/usr/lib/python2.7/dist-packages/graph_tool/inference/mcmc.py", line 172, in mcmc_equilibrate
        extra = callback(state)
  File "num_groups_marg_prob.py", line 35, in collect_num_groups
        def collect_num_groups(s):
AttributeError: 'NestedBlockState' object has no attribute 'get_nonempty_B' 

引用 graph-tool 邮件列表的回答:

》报错信息很清楚,这个属性属于BlockState,不是 嵌套块状态。您想要做的是:

s.levels[0].get_nonempty_B()

http://main-discussion-list-for-the-graph-tool-project.982480.n3.nabble.com/self-state-couple-state-state-state-entropy-args-Python-argument-types-did-not-match-C-signature-td4026975.html