Я учусь знакомиться с пакетом Rcpp, и у меня есть фрейм данных R df со столбцами списка, сгенерированными в два этапа:
df<- data.frame(w= 1:3, x=3:5, y=6:8, z = I(list(1:2, 1:3, 1:4)))
df <- as.data.frame(do.call(cbind, lapply(df[1:3], function(x) Map("*",
df$z, x))))
>df
w x y
1, 2 3, 6 6, 12
2, 4, 6 4, 8, 12 7, 14, 21
3, 6, 9, 12 5, 10, 15, 20 8, 16, 24, 32
Я работаю с набором данных из почти 2 миллионов строк. Чтобы сэкономить много времени для удаления, я хочу получить прямой доступ к фрейму данных и выполнить следующую операцию непосредственно с расположением Rcpp, чтобы сгенерировать фрейм данных df1 .
df1 <- as.data.frame (4*sin(df*pi))
Основываясь на информации с этого сайта, я структурировал свой код, который, как я ожидал, смог бы работать, следующим образом:
library(Rcpp)
cppFunction('NumericVector transfo(Rcpp::DataFrame x) {
int nrow = x.nrow(), ncol = x.ncol();
NumericVector out(nrow*ncol);
int pi;
int vol = 4;
for (int j = 0; j < ncol; j++) {
for (int i = 0; i < nrow; i++) {
out[i, j] = sin(x[i,j]*pi)*vol;
}
}
return out;
}')
Но с transfo(df)
:
Я получаю ошибку:
Expecting a single value: [extent=3].
Буду благодарен за любые подсказки о том, откуда возникла моя ошибка.