我有两个矩阵,一个是 10x1 双矩阵,可以扩展到任何用户预设的数字,例如。100。
查看(min_matrx)
V1
1 27
2 46
3 30
4 59
5 46
6 45
7 34
8 31
9 52
10 46
另一个矩阵如下所示,还有更多行未显示:
查看(main_matrx)
row.names sum_value
s17 45
s7469 213
s20984 24
s17309 214
s7432369 43
s221320984 12
s17556 34
s741269 11
s20132984 35
对于 main_matrx 中的每个行名,我想计算一个值大于 main_matrx 中 sum_value 的值出现在 min_matrx 中的次数。然后我想将它除以 min_matrx 中的行数,并将该值作为新列添加到 main_matrx 中。
例如,在s17的main_matrx的第1行中,min_matrx中出现超过45的值的次数=5次。
现在将 min_matrx=> 5/10 =0.5 的 5 除以 10 行将是我希望在 main_matrx 中作为 s17 的新列的值。然后对行名称中的所有 s_id 使用相同的公式。
到目前为止,我一直在摆弄:
for(s in 1:length(main_matrx)) {
new<-sum(main_matrx[s,]>min_CPRS_set)/length(min_matrx)
}
我尝试使用 apply() 但我仍然没有得到结果。
apply(main_matrx,1:length(main_matrx), function(x) sum(main_matrx>min_CPRS_set)/length(min_matrx)))
现在,我只是被卡住了,因为它不起作用。我还是 R 新手,所以我的代码不是特别有效。有什么建议么?