python基于Node2Vec实现节点分类及其可视化示例详解

作者:实力 时间:2022-04-16 06:49:33 

简介

Node2vec是一种用于图嵌入(Graph Embedding)的方法,可用于节点分类、社区发现和连接预测等任务。

实现过程 

加载数据集

首先,让我们加载所需的Python库并执行以下代码以加载Cora数据集:

import networkx as nx
import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
%matplotlib inline
from sklearn.manifold import TSNE
from node2vec import Node2Vec
# 加载Cora数据集
cora = pd.read_csv('cora/cora.content', sep='\t', header=None)
cited_in = pd.read_csv('cora/cora.cites', sep='\t', header=None,
                      names=['target', 'source'])
nodes, features = cora.iloc[:, :-1], cora.iloc[:, -1]

其中 cora.content 包含了所有节点特征信息,一共具有2708个节点和1433个特征;而 cora.cites 通过引文映射分别针对所述每个节点建立一个节点间的有向边关系,共有5429个边。接下来,我们需要将节点特征和引用信息合并,构建图结构。

# 定义函数:构造基于Cora数据集的图结构
def create_graph(nodes, features, cited_in):
   nodes.index = nodes.index.map(str)
   graph = nx.from_pandas_edgelist(cited_in,
                                   source='source',
                                   target='target')
   for index, row in nodes.iterrows():
       node_id = str(row[0])
       features = row.drop(labels=[0])
       node_attrs = {f'attr_{i}': float(x) for i, x in enumerate(features)}
       if graph.has_node(node_id) == True:
           temp = graph.nodes[node_id]
           temp.update(node_attrs)
           graph.add_nodes_from([(node_id, temp)])
       else:
           graph.add_nodes_from([(node_id, node_attrs)])
   return graph
# 构建图
graph = create_graph(nodes, features, cited_in)

该函数将 cora.content 中的节点特征与 cora.cites 的有向边整合,并在图上标记它们。现在我们已经构建了一个图形视图,可以按想法可视化。

使用Node2vec嵌入数据

为了使用节点的特征进行分类,我们需要从网络中提取某些信息,以便将其传递给分类器作为输入。 节点2矢量方法的一个示例就是将提取的信息转换为至少每个节点一个维度的向量表达式。

Node2Vec模型由代表每个节点的向量组成,使用起始节点和目标节点的随机游走样本来学习它们。 节点2Vec模型定义随机游走过程中节点间的转移概率。

我们将使用 node2vec 库来生成图形的嵌入表示,并采用神经网络进行节点分类。

# 定义函数:创建基于Cora数据集的嵌入
def create_embeddings(graph):
   # 初始化node2vec实例,指定相关超参数
   n2v = Node2Vec(graph, dimensions=64, walk_length=30,
                  num_walks=200, p=1, q=1, weight_key='attr_weight')
   # 基于指定参数训练得到嵌入向量表达式
   model = n2v.fit(window=10, min_count=1, batch_words=4)
   # 获得所有图中节点的嵌入向量
   embeddings = pd.DataFrame(model.wv.vectors)
   ids = list(map(str, model.wv.index2word))
   # 将原有的特征和id与新获取到的嵌入向量按行合并
   lookup_table = nodes.set_index(0).join(embeddings.set_index(embeddings.index))
   return np.array(lookup_table.dropna().iloc[:, -64:]), np.array(list(range(1, lookup_table.shape[0] + 1)))
# 创建嵌入向量
cora_embeddings, cora_labels = create_embeddings(graph)  

通过以上代码,我们可以获得每个节点的64维节点嵌入表达。

训练分类器

接下来我们将指定一些分类器并在Cora数据集上训练它们,以期根据嵌入进行准确的节点分类操作。

from sklearn import svm, model_selection, metrics
# 使用支持向量机作为示范的分类器
svm_model = svm.SVC(kernel='rbf', C=1, gamma=0.01)
# 进行交叉验证和分类训练
scores = model_selection.cross_val_score(
   svm_model, cora_embeddings, cora_labels, cv=5)
print(scores.mean())

使用支持向量机作为分类器,进一步问题是分类器本身也要进行调参等相关操作,以期获取更好的性能。此处采取了5折交叉验证的方式对其性能进行评估输出。

可视化节点嵌入

对于人类而言,64维特征表达并不容易理解,因此我们需要将其降维以便可视化。 在这里我们使用 t-SNE,它专门用于降低高维数据的复杂度。 通过输出只包含 2个元素的概率分布向量,它生成一个二维图,其中相似节点紧密地放在一起。

# 定义函数:可视化Nodes2Vec的结果
def visualize_results(embeddings, labels):
   # 使用t-SNE对数据进行降维并绘图
   tsne = TSNE(n_components=2, verbose=1, perplexity=40, n_iter=300)
   tsne_results = tsne.fit_transform(embeddings)
   plt.figure(figsize=(10, 5))
   plt.scatter(tsne_results[:,0], tsne_results[:,1], c=labels)
   plt.colorbar()
   plt.show()
# 可视化结果
visualize_results(cora_embeddings, cora_labels)

Node2Vec生成的嵌入向量将被输入到t-SNE中,其中t-SNE将64维向量表达进行了降维,并输出我们可以使用 matplotlib 库可视化的二维散点图。 我们可以在图形界面中检查大部分相关节点是否如预期那样紧密聚集。

来源:https://juejin.cn/post/7224410321670471735

标签:python,Node2Vec,节点分类,可视化
0
投稿

猜你喜欢

  • python 中pyqt5 树节点点击实现多窗口切换问题

    2021-07-28 06:19:39
  • 分享Python 的24个编程超好用技巧

    2021-05-21 16:51:55
  • 详解利用Pandas求解两个DataFrame的差集,交集,并集

    2023-10-21 06:14:51
  • Python import与from import使用和区别解读

    2021-06-22 08:51:02
  • pytorch中tensor张量数据类型的转化方式

    2022-03-19 20:07:24
  • 在Ubuntu 20.04中安装Pycharm 2020.1的图文教程

    2022-05-28 23:03:48
  • python异常触发及自定义异常类解析

    2023-05-02 18:17:01
  • python实现飞机大战

    2021-03-05 04:19:26
  • CSS布局之浮动(一)两列布局

    2008-08-18 21:24:00
  • django实现后台显示媒体文件

    2023-07-26 15:03:23
  • asp网站生成静态页面攻略

    2007-11-04 15:09:00
  • Go项目配置管理神器之viper的介绍与使用详解

    2023-09-17 01:05:52
  • javascript 函数调用的对象和方法

    2010-07-02 12:25:00
  • python 划分数据集为训练集和测试集的方法

    2023-01-10 12:18:36
  • Matlab中关于argmax、argmin函数的使用解读

    2023-06-27 20:36:53
  • 如何正确处理ajax 302跳转问题回博客首页

    2009-02-28 14:01:00
  • ASP的数据命名有什么规则吗?

    2009-10-28 18:23:00
  • python 实现识别图片上的数字

    2021-06-17 13:09:31
  • Python爬虫实例扒取2345天气预报

    2021-09-27 22:38:12
  • 三种数据库利用SQL语句进行高效果分页

    2008-11-28 14:52:00
  • asp之家 网络编程 m.aspxhome.com