我试图在Rcpp中编写一个Sequential Monte Carlo函数,我遇到了以下问题:
我通过以下方式创建了一个向量:
NumericVector R_t(Part*Ttau);
Run Code Online (Sandbox Code Playgroud)
我想填充矢量的部分块.应该是这样的:
for (int i=0;i<Part;i++){
R_t[i]=runif(1,0,2);
}
Run Code Online (Sandbox Code Playgroud)
我第二次想拥有
for (int i=Part+1;i<2*Part;i++){
R_t[i]=runif(1,0,2);
}
Run Code Online (Sandbox Code Playgroud)
但它似乎没有用.我可以在每次迭代中用新的值替换旧值,但是每次迭代我都需要旧的值.当我尝试编译时,我收到以下错误:
cannot convert 'Rcpp::NUmericVector {aka Rcpp::Vector<14, Rcpp::PrserveStorage>}' to 'Rcpp::traits::storage_type<14>:: type {aka double}' in assignment
Run Code Online (Sandbox Code Playgroud)
使用尺寸为Part和Ttau的二维矩阵替换矢量会更容易吗?我想避免这最后一个选择.
很抱歉,如果这已经得到解答,但我没有找到任何接近这个的rcpp
您正在尝试将长度为一的向量分配给期望a的位置double,因此用于[0]访问第一个元素:runif(1,0,2)[0].但是,您也可以使用Rcpp Sugar构造替换循环,以避免一次重复生成一个随机值:
#include <Rcpp.h>
// [[Rcpp::export]]
Rcpp::NumericVector fill_vector(R_xlen_t n, R_xlen_t m) {
Rcpp::NumericVector res(n);
for (R_xlen_t i = 0; i < m; i++) {
res[i] = Rcpp::runif(1, 0, 2)[0];
}
return res;
}
// [[Rcpp::export]]
Rcpp::NumericVector fill_vector2(R_xlen_t n, R_xlen_t m) {
Rcpp::NumericVector res(n);
res[Rcpp::seq(0, m - 1)] = Rcpp::runif(m, 0, 2);
return res;
}
/***R
set.seed(123)
fill_vector(7, 4)
#[1] 0.5751550 1.5766103 0.8179538 1.7660348 0.0000000 0.0000000 0.0000000
set.seed(123)
fill_vector2(7, 4)
#[1] 0.5751550 1.5766103 0.8179538 1.7660348 0.0000000 0.0000000 0.0000000
set.seed(123)
c(runif(4, 0, 2), rep(0, 3))
#[1] 0.5751550 1.5766103 0.8179538 1.7660348 0.0000000 0.0000000 0.0000000
*/
Run Code Online (Sandbox Code Playgroud)