【发布时间】:2020-05-11 06:07:10
【问题描述】:
我正在尝试为每次n 尝试绘制可变数量的样本。在这个例子中n = 8 因为length(n.obs) == 8。绘制完所有样本后,我想将它们组合成matrix。
这是我的第一次尝试:
set.seed(1234)
n.obs <- c(2,1,2,2,2,2,2,2)
my.samples <- sapply(1:8, function(x) sample(1:4, size=n.obs[x], prob=c(0.1,0.2,0.3,0.4), replace=TRUE))
my.samples
这种方法会产生一个list。
class(my.samples)
#[1] "list"
我使用以下方法确定输出 matrix 中所需的列数:
max.len <- max(sapply(my.samples, length))
max.len
#[1] 2
输出matrix 可以使用:
corrected.list <- lapply(my.samples, function(x) {c(x, rep(NA, max.len - length(x)))})
output.matrix <- do.call(rbind, corrected.list)
output.matrix[is.na(output.matrix)] <- 0
output.matrix
# [,1] [,2]
#[1,] 4 3
#[2,] 3 0
#[3,] 3 2
#[4,] 3 4
#[5,] 4 3
#[6,] 3 3
#[7,] 3 4
#[8,] 1 4
当n.obs 包含多个值并且n.obs > 1 中至少包含一个element 时,上述方法似乎可以正常工作。但是,我希望代码足够灵活以处理以下每个n.obs:
上面的sapply 语句返回一个2 x 8 matrix 和下面的n.obs。
set.seed(1234)
n.obs <- c(2,2,2,2,2,2,2,2)
上面的sapply 语句返回一个integer 和下面的n.obs。
set.seed(3333)
n.obs <- c(1,1,1,1,1,1,1,1)
上面的sapply 语句返回一个list 和下面的n.obs。
n.obs <- c(0,0,0,0,0,0,0,0)
以下是上述三个n.obs 的示例期望结果:
desired.output <- matrix(c(4, 3,
3, 3,
2, 3,
4, 4,
3, 3,
3, 3,
4, 1,
4, 2), ncol = 2, byrow = TRUE)
desired.output <- matrix(c(2,
3,
4,
2,
3,
4,
4,
1), ncol = 1, byrow = TRUE)
desired.output <- matrix(c(0,
0,
0,
0,
0,
0,
0,
0), ncol = 1, byrow = TRUE)
无论n.obs 用作输入,我如何概括代码以便它始终返回一个有八行的matrix?一种方法是使用一系列if 语句来处理有问题的情况,但我认为可能有更简单和更有效的解决方案。
【问题讨论】: