我正在尝试将边缘列表转换为相邻矩阵。
下面是样本数据
#Sample Data
User<-c("1","1","2","3","4")
v1 <- c("b", "b", "a", "d", "c")
v2 <- c("c", "d", "c", "a", "a")
v3 <- c(0, 0, "d", 0, "b")
v4 <- c(0, 0, 0, 0, 0)
v5 <- c(0, 0, 0, 0, 0)
my_data<-data.frame(User, v1, v2, v3, v4, v5)
my_data
如果您运行此代码,您将获得以下输出,
User v1 v2 v3 v4 v5
1 b c 0 0 0
1 b d 0 0 0
2 a c d 0 0
3 d a 0 0 0
4 c a b 0 0
使用这些数据,我想创建一个如下所示的相邻矩阵:
a b c d
a 0 0 2 2
b 0 0 1 1
c 2 1 0 1
d 2 1 1 0
基本上,所需的输出显示了样本数据帧中每对出现在列 v1~v5 中的次数。
我尝试使用库中AdjacencyFromEdgelist
的函数dils
,还尝试使用 NA 创建矩阵外壳并通过循环遍历数据框来填充矩阵。
但是,我无法工作。