我有看起来类似于这两个邻接矩阵的数据:
data1999 <- data.frame(node1=c("A", "A", "B", "D", "B", "C", "D"),
node2=c("A", "A", "D", "B", "B", "C", "D"),
link=c(1, 1, 1, 1, 1, 1, 1),
stringsAsFactors = FALSE)
adj.m1999 <- reshape2::acast(data1999, node1 ~ node2)
> adj.m1999
A B C D
A 2 0 0 0
B 0 1 0 1
C 0 0 1 0
D 0 1 0 1
data2000 <- data.frame(node1=c("A", "A", "B", "C", "D", "C", "D"),
node2=c("A", "A", "B", "C", "D", "D", "C"),
link=c(1, 1, 1, 1, 1, 1, 1),
stringsAsFactors = FALSE)
adj.m2000 <- reshape2::acast(data2000, node1 ~ node2)
> adj.m2000
A B C D
A 2 0 0 0
B 0 1 0 0
C 0 0 1 1
D 0 0 1 1
请注意,在 1999 年,节点 D 和 B 有一个链接。
请注意,在 2000 年,节点 D 和 C 有一个链接。
基于这些信息,我想构建一个新的邻接矩阵(包含我的 2000 数据的所有节点),其中 BD 和 DB 的值为 1,而其余的值为 0:
> result
A B C D
A 0 0 0 0
B 0 0 1 0
C 0 1 0 0
D 0 0 0 0
在我的真实数据中,1999 年的数据可能有 2000 年不会返回的额外节点,反之亦然。
有任何想法吗?