如何在R中使用apply函数内的行号

问题描述 投票:0回答:1

我想按如下方式处理数据帧,其中我想获得2个向量的总和并将其作为行向量附加到数据帧。 2个向量是考虑行和列向量的行向量,其在具有固定长度的考虑行的正下方开始。

 data
  A b1 b2 b3
  1 2  2  2
  2 3  3  3  
  3 4  4  4
  4 5  5  5
  5 6  6  6

 output (expected)
  A b1 b2 b3
  1 4  5  6
  2 6  7  8
  3 8  9  -
  4 10 -  -
  5 -  -  -

在该示例中,如果考虑第一行,则两个向量

 row vector r- [2 2 2]
 column vector c - [2,3,4]

在获得列向量的转置后,我可以添加两个向量并将其附加到新的数据帧。必须对所有行执行此过程。

最简单的方法是循环,但在R循环中效率不高,而是可以使用apply函数。但是在这种情况下,要做到这一点需要知道当前行号是什么。

有没有办法在R中有效地做到这一点

r
1个回答
0
投票

1)rollapply我们可以使用rollapply来形成A的子向量矩阵,然后将其与初始的零列添加到m。请注意,我们使用NA值填充A,以便rollapply的结果是合适的形状。

library(zoo)

m <- cbind(A = 1:5, b1 = 2:6, b2 = 2:6, b3 = 2:6)  # input matrix

nc1 <- ncol(m) - 1
A <- c(m[, 1], rep(NA, nc1))
cbind(0, rollapply(A[-1], nc1, c)) + m

赠送:

     A b1 b2 b3
[1,] 1  4  5  6
[2,] 2  6  7  8
[3,] 3  8  9 NA
[4,] 4 10 NA NA
[5,] 5 NA NA NA

2)base此解决方案类似,但不使用任何包。前两行与(1)中的相同。

nc1 <- ncol(m) - 1
A <- c(m[, 1], rep(NA, nc1))
cbind(0, embed(A[-1], nc1)[, seq(nc1, 1)]) + m

赠送:

     A b1 b2 b3
[1,] 1  4  5  6
[2,] 2  6  7  8
[3,] 3  8  9 NA
[4,] 4 10 NA NA
[5,] 5 NA NA NA
© www.soinside.com 2019 - 2024. All rights reserved.