示例#1
0
文件: community.py 项目: wtgme/ohsn
def plot_communty(dbname, colname, name, commline):
    G = nt.load_network(dbname, colname)
    GC = nt.get_gaint_comp(G)

    id_map = pickle.load(open("data/" + name + "-id.pick", "r"))
    nodelist = list()

    fr = open("data/" + name + "-fc_best.groups", "r")
    line = ""
    while commline not in line:
        line = fr.readline()
    print line
    print "----------------------------"
    for line in fr.readlines():
        if "GROUP" in line:
            break
        else:
            nodelist.append(id_map[int(line.strip())])
    print "node size:", str(len(nodelist))
    # plot.network_top(GC.subgraph(nodelist))
    pickle.dump(nodelist, open("data/" + name + "uid.pick", "w"))
    return GC.subgraph(nodelist)
示例#2
0
文件: community.py 项目: wtgme/ohsn
def count_freque():
    db = dbt.db_connect_no_auth("fed")
    bnet = db["bnet"]
    for i in xrange(5):
        print bnet.count({"type": i})


if __name__ == "__main__":

    # snap_comm('fed', 'bnet', 'fedtime')
    # count_freque()

    # purn_net('yg')
    # out_net_commudet('fed', 'bnet', 'fedtime')

    # rdcom = plot_communty('rd', 'scnet', 'rd2l', 'GROUP[ 74 ][ 2691 ]')
    rdcom = plot_communty("rd", "tnet", "rdtime", "GROUP[ 1539 ][ 4641 ]")
    # ygcom = plot_communty('yg', 'scnet', 'yg3l', 'GROUP[ 33 ][ 3883 ]')
    ygcom = plot_communty("yg", "tnet", "ygtime", "GROUP[ 2360 ][ 1966 ]")
    fed = nt.load_network("fed", "snet")
    nt.net_statis(rdcom)
    nt.net_statis(ygcom)
    nt.net_statis(fed)
    rddseq = sorted(nx.degree(rdcom).values(), reverse=True)
    ygdseq = sorted(nx.degree(ygcom).values(), reverse=True)
    eddseq = sorted(nx.degree(fed).values(), reverse=True)
    plot.plot_pdf_mul_data(
        [rddseq, ygdseq, eddseq], ["--bo", "--r^", "--ks"], "Degree", ["Random", "Young", "ED"], False
    )