【发布时间】:2020-04-06 12:43:20
【问题描述】:
我希望将下面R 代码的输出写入.csv 文件。
N <- c(15L, 20L)
SD <- c(1, 2) ^ 2
phi = c(0.2, 0.4)
## generate all combos
all_combos <- expand.grid(N = N, SD = SD, phi = phi)
## create function
fx_arima <- function(n, SD, phi) {
(arima.sim(n = n,
model=list(ar=phi, order = c(1, 1, 0)),
start.innov = 4.1,
n.start = 1,
rand.gen = function(n) rnorm(n, mean = 0, sd = SD)))[-1]
}
## find arima for all combos using Map
Map(fx_arima, all_combos[["N"]], all_combos[["SD"]], all_combos[["phi"]])
## or :
set.seed(123L)
by(all_combos, all_combos["N"],
function(DF) {
res = mapply(fx_arima, DF[["N"]], DF[["SD"]], DF[["phi"]])
colnames(res) = paste("SD", DF[["SD"]], "phi", DF[["phi"]], sep = "_")
res
})
上面的R 代码模拟了ARIMA(1,1,0) 的变化值N <- c(15L, 20L), SD <- c(1, 2) ^ 2, phi = c(0.2, 0.4)。 N=15 打印在一个矩阵中,N=20 打印在另一个矩阵中,所有列都带有列名。我希望将每个矩阵写入datafram,然后写入将存储在我的工作目录中的 .csv 文件。
我期待这个
v1 v2 v3 v4
1 4 3 1
2 6 3 2
3 8 3 12
4 4 4 8
5 6 4 4
6 8 4 0
7 4 5 2
8 6 5 1
9 8 5 2
10 11 12 13
11 12 13 14
8 6 5 1
9 8 5 2
10 11 12 13
11 12 13 14
我尝试了How to write R output with unequal length into excel 中所做的操作,但无法得到它
【问题讨论】:
-
Map(fx_arima, all_combos[["N"]], all_combos[["SD"]], all_combos[["phi"]])返回一个长度为 8 的列表,你想在 csv 中怎么写?不同csv中的每个列表都有一列?还是一个组合的 csv?
标签: r export-to-csv write.table