如何在一个矩阵中定位满足条件的元素以识别第二个矩阵中的元素

时间:2019-08-16 03:34:41

标签: r matrix indexing subset

我想确定一个矩阵中满足条件的元素的位置,然后将这些位置应用于另一个矩阵并找到这些元素的均值。

my_vector_1<-c(1,2,1,4,1,1,7,8,)
my_matrix_1<-matrix(data=my_vector_1, nrow=3, ncol=3)

my_vector_2<-c(2,4,6,8,10,11,12,13,14)
my_matrix_2<-matrix(data=my_vector_2, nrow=3, ncol=3)

首先在第一个矩阵中找到my_matrix_1==1的位置以找到...

[1,1]
[2,2]
[3,1]
[3,2]

然后找到第二个矩阵中位于上述位置的元素的均值...

7.25    #mean of 2, 10, 6, 11 in my_matrix_2

2 个答案:

答案 0 :(得分:0)

您可以将my_matrix_2的子集设为my_matrix_1并取值mean

mean(my_matrix_2[my_matrix_1  == 1])
#[1] 7.25

答案 1 :(得分:0)

我们可以使用arr.ind查找行/列的位置

ind <- which(my_matrix_1 == 1, arr.ind = TRUE)
ind
#     row col
#[1,]   1   1
#[2,]   3   1
#[3,]   2   2
#[4,]   3   2


mean(my_matrix_2[ind])
#7.25

另一种方法是

mean(my_matrix_2 * NA^(my_matrix_1 != 1), na.rm = TRUE)