特征向量中心性

特征向量中心性的基本思想是,一个节点的中心性是相邻节点中心性的函数。也就是说,与你连接的人越重要,你也就越重要。

特征向量中心性和点度中心性不同,一个点度中心性高即拥有很多连接的节点,但特征向量中心性不一定高,因为所有的连接者有可能特征向量中心性很低。同理,特征向量中心性高并不意味着它的点度中心性高,它拥有很少但很重要的连接者也可以拥有高特征向量中心性。

考虑下面的图,以及相应的5x5的邻接矩阵(Adjacency Matrix),A。
特征向量中心性_第1张图片
A = [ 0 1 1 1 0 1 0 1 0 0 1 1 0 1 0 1 0 1 0 1 0 0 0 1 0 ] A=\left[\begin{array}{ccccc} 0 & 1 & 1 & 1 & 0 \\ 1 & 0 & 1 & 0 & 0 \\ 1 & 1 & 0 & 1 & 0 \\ 1 & 0 & 1 & 0 & 1 \\ 0 & 0 & 0 & 1 & 0 \end{array}\right] A=0111010100110101010100010
现在考虑x,一个5x1的向量,向量的值对应图中的每个点。在这种情况下,我们计算的是每个点的点度中心性(degree centrality),即以点的连接数来衡量中心性的高低。

矩阵A乘以这个向量的结果是一个5x1的向量:
A × x = ( 0 1 1 1 0 1 0 1 0 0 1 1 0 1 0 1 0 1 0 1 0 0 0 1 0 ) ( 3 2 3 3 1 ) = ( 0 × 3 + 1 × 2 + 1 × 3 + 1 × 3 + 0 × 1 1 × 3 + 0 × 2 + 1 × 3 + 0 × 3 + 0 × 1 1 × 3 + 1 × 2 + 0 × 3 + 1 × 3 + 0 × 1 1 × 3 + 0 × 2 + 1 × 3 + 0 × 3 + 1 × 1 0 × 3 + 0 × 2 + 1 × 3 + 0 × 3 + 0 × 1 ) = [ 8 6 8 7 3 ] \mathbf{A} \times \mathbf{x}=\left(\begin{array}{cccc} 0 & 1 & 1 & 1 & 0 \\ 1 & 0&1 & 0 & 0 \\ 1 & 1 & 0&1 & 0 \\ 1 & 0 & 1 & 0&1 \\ 0 & 0 & 0 & 1&0 \end{array}\right)\left(\begin{array}{l} 3 \\ 2 \\ 3 \\ 3 \\ 1 \end{array}\right)=\left(\begin{array}{l} 0 \times 3+1 \times 2+1 \times 3+1 \times 3+0 \times 1 \\ 1 \times 3+0 \times 2+1 \times 3+0 \times 3+0 \times 1 \\ 1 \times 3+1 \times 2+0 \times 3+1 \times 3+0 \times 1 \\ 1 \times 3+0 \times 2+1 \times 3+0 \times 3+1 \times 1 \\ 0 \times 3+0 \times 2+1 \times 3+0 \times 3+0 \times 1 \end{array}\right)=\left[\begin{array}{c} 8 \\ 6 \\ 8 \\ 7 \\ 3 \end{array}\right] A×x=011101010011010101010001032331=0×3+1×2+1×3+1×3+0×11×3+0×2+1×3+0×3+0×11×3+1×2+0×3+1×3+0×11×3+0×2+1×3+0×3+1×10×3+0×2+1×3+0×3+0×1=86873
结果向量的第一个元素是用矩阵A的第一行去“获取”每一个与第一个点有连接的点的值(连接数,点度中心性),也就是第2个、第3个和第4个点的值,然后将它们加起来。

换句话说,邻接矩阵做的事情是将相邻节点的求和值重新分配给每个点。这样做的结果就是“扩散了”点度中心性。你的朋友的朋友越多,你的特征向量中心性就越高。

特征向量中心性_第2张图片
我们继续用矩阵A乘以结果向量。如何理解呢?

实际上,我们允许这一中心性数值再次沿着图的边界“扩散”。我们会观察到两个方向上的扩散(点既给予也收获相邻节点)。我们猜测,这一过程最后会达到一个平衡,特定点收获的数量会和它给予相邻节点的数量取得平衡。既然我们仅仅是累加,数值会越来越大,但我们最终会到达一个点,各个节点在整体中的比例会保持稳定。

A × X = [ 0 1 1 1 0 1 0 1 0 0 1 1 0 1 0 1 0 1 0 1 0 0 0 1 0 ] [ x 1 x 2 x 3 x 4 x 5 ] = [ 0 ⋅ x 1 + 1 ⋅ x 2 + 1 ⋅ x 3 + 1 ⋅ x 4 + 0 ⋅ x 5 1 ⋅ x 1 + 0 ⋅ x 2 + 1 ⋅ x 3 + 0 ⋅ x 4 + 0 ⋅ x 5 1 ⋅ x 1 + 1 ⋅ x 2 + 0 ⋅ x 3 + 1 ⋅ x 4 + 0 ⋅ x 5 1 ⋅ x 1 + 0 ⋅ x 2 + 1 ⋅ x 3 + 0 ⋅ x 4 + 1 ⋅ x 5 0 ⋅ x 1 + 0 ⋅ x 2 + 0 ⋅ x 3 + 1 ⋅ x 4 + 0 ⋅ x 5 ] A \times X=\left[\begin{array}{ccccc} 0 & 1 & 1 & 1 & 0 \\ 1 & 0 & 1 & 0 & 0 \\ 1 & 1 & 0 & 1 & 0 \\ 1 & 0 & 1 & 0 & 1 \\ 0 & 0 & 0 & 1 & 0 \end{array}\right]\left[\begin{array}{l} x_{1} \\ x_{2} \\ x_{3} \\ x_{4} \\ x_{5} \end{array}\right]=\left[\begin{array}{l} 0 \cdot x_{1}+1 \cdot x_{2}+1 \cdot x_{3}+1 \cdot x_{4}+0 \cdot x_{5} \\ 1 \cdot x_{1}+0 \cdot x_{2}+1 \cdot x_{3}+0 \cdot x_{4}+0 \cdot x_{5} \\ 1 \cdot x_{1}+1 \cdot x_{2}+0 \cdot x_{3}+1 \cdot x_{4}+0 \cdot x_{5} \\ 1 \cdot x_{1}+0 \cdot x_{2}+1 \cdot x_{3}+0 \cdot x_{4}+1 \cdot x_{5} \\ 0 \cdot x_{1}+0 \cdot x_{2}+0 \cdot x_{3}+1 \cdot x_{4}+0 \cdot x_{5} \end{array}\right] A×X=0111010100110101010100010x1x2x3x4x5=0x1+1x2+1x3+1x4+0x51x1+0x2+1x3+0x4+0x51x1+1x2+0x3+1x4+0x51x1+0x2+1x3+0x4+1x50x1+0x2+0x3+1x4+0x5

我们认为,图中的点存在一个数值集合,对于它,用矩阵A去乘不会改变向量各个数值的相对大小。也就是说,它的数值会变大,但乘以的是同一个因子。用数学符号表示就是:
M x = λ x M × [ x 1 x 2 x 3 . . . x n ] = [ λ x 1 λ x 2 λ x 3 . . . λ x n ] Mx = \lambda x \\ M \times \left[\begin{array}{ccccc} x_1 \\ x_2 \\ x_3 \\ ... \\ x_n \end{array}\right]=\left[\begin{array}{ccccc} \lambda x_1 \\ \lambda x_2 \\ \lambda x_3 \\ ... \\ \lambda x_n \end{array}\right] Mx=λxM×x1x2x3...xn=λx1λx2λx3...λxn

满足这一属性的向量就是矩阵M的特征向量。特征向量的元素就是图中每个点的特征向量中心性。

x i x_i xi v i v_i vi的特征向量中心性度量,则:
E C ( i ) = x i = c ∑ j = i n a i j x j EC(i) = x_i=c\sum_{j=i}^{n}a_{ij}x_j EC(i)=xi=cj=inaijxj
其中c表示一个比例常数,记 x = [ x 1 , x 2 , . . . , x n ] T x=[x_1,x_2,...,x_n]^T x=[x1,x2,...,xn]T,经过多次迭代达到稳态时,可写成如下形式:
x = c A x x = cAx x=cAx
其中c为一个比例常数, a i j a_{ij} aij当且仅当i与j相连,否则为0。
这里的x是矩阵A的特征值 c − 1 c^{-1} c1对应的特征向量,也可以表示成如下形式:
A x = λ x Ax=\lambda x Ax=λx
特征向量中心性的计算需要读者具备矩阵乘法和特征向量的知识,但不影响这里大家对特征向量中心性思想的理解,不再赘述。

你可能感兴趣的:(GNN,GNN)