在 R 中滚动 window 模式更新

Rolling window pattern update in R

我想在矩阵上应用滚动 window 模式更新。假设我有一个零和一个矩阵,如下所示:

mat <- matrix(c(0,1,1,0,1,1,0,0,1,1,1,0,1,0,0,0),nrow=4)

0   1   1   1
1   1   1   0
1   0   1   0
0   0   0   0

我想一次扫描矩阵的每一行 2 个值,并根据这组规则创建一个标签矩阵:

0   0   - then label as A
0   1   - then label as B
1   0   - then label as B
1   1   - then label as C

上述矩阵的期望输出是: (出现 NA 值是因为第一个值之前没有值)

NA  B   C   C
NA  C   C   B
NA  B   B   B
NA  A   A   A

我正在尝试在 R 中实现它。有没有办法使用其中一种应用方法来做到这一点?或者是否有一种快速方法将此数据存储为 data.frame 并使用 dplyrdata.table 等包进行处理?目前,我将其作为 for 循环处理(当然,非常非常慢)。

这里的rolling操作作用于pairwise组合,所以你可以直接定义函数:

f <- function(x,y) LETTERS[1:3][x+y+1L]

然后将其应用于适当的对:

nc  <- ncol(m)
res <- matrix(,length(m)/nc,nc)

res[,-1] <- f(m[,-nc], m[,-1])

#      [,1] [,2] [,3] [,4]
# [1,] NA   "B"  "C"  "C" 
# [2,] NA   "C"  "C"  "B" 
# [3,] NA   "B"  "B"  "B" 
# [4,] NA   "A"  "A"  "A"