通过引用修改单独函数中的Rcpp :: List的子节

时间:2018-08-24 14:17:07

标签: c++ r rcpp

我希望能够通过一个函数来修改Rcpp::List的子部分。由于Rcpp::List是指向某些R数据的指针,因此我认为可以执行以下操作:

void modifyList(Rcpp::List l) {
  l["x"] = "x";
}

// [[Rcpp::export]]
Rcpp::List rcppTest() {
  Rcpp::List res;
  res["a"] = Rcpp::List::create();
  modifyList(res["a"]);
  return res;
}

我期望将元素“ x”的值为“ x”的列表作为rcppTest的返回值。返回的列表为空。

如果我改用签名modifyList(Rcpp::List& l),则会出现编译错误

rcppTest.cpp:17:6: note: candidate function not viable: no known conversion from 'Rcpp::Vector<19, PreserveStorage>::NameProxy' (aka 'generic_name_proxy<19, PreserveStorage>') to 'Rcpp::List &' (aka 'Vector<19> &') for 1st argument

如何通过函数修改Rcpp::List的子部分?

2 个答案:

答案 0 :(得分:3)

简而言之,无法通过引用修改列表。在这种情况下,您必须 返回@ {RalfStubner从注释中指出的Rcpp::List

例如

#include<Rcpp.h>

// Specified return type of List
Rcpp::List modifyList(Rcpp::List l) {
  l["x"] = "x";
  return l;
}

// [[Rcpp::export]]
Rcpp::List rcppTest() {
  Rcpp::List res;
  res["a"] = Rcpp::List::create();

  // Store result back into "a"
  res["a"] = modifyList(res["a"]);

  return res;
}

测试:

rcppTest()
# $a
# $a$x
# [1] "x"

答案 1 :(得分:0)

这有效:

// [[Rcpp::export]]
void modifyList(List& l, std::string i) {
  l[i]= "x";
}

// [[Rcpp::export]]
Rcpp::List rcppTest() {
  Rcpp::List res;
  res["a"] = Rcpp::List::create();
  modifyList(res,"a");
  return res;
}

并给出:

> rcppTest()
$`a`
[1] "x"

问题是您正在尝试:

error: invalid initialization of non-const reference of type 'Rcpp::List& {aka Rcpp::Vector<19>&}'