使用 Rcpp 模块公开 C++ 类

Posted

技术标签:

【中文标题】使用 Rcpp 模块公开 C++ 类【英文标题】:Using Rcpp Modules to expose C++ classes 【发布时间】:2017-10-13 20:06:12 【问题描述】:

我正在尝试使用 Rcpp 模块将 C++ 类公开给 R。我尝试创建一个简单的示例来了解其工作原理。我有两个类 Bar 和 Foo 存储在它们自己的 cpp 文件中,在包的 src 文件夹中。 Bar.cpp 的代码如下:

#include "Bar.h"
#include "Foo.h"
#include <Rcpp.h>
using namespace Rcpp;

Bar::Bar()x = 0;;

int Bar::getX()return x;

void Bar::setX(int num)x = num;

int Bar::sumXY()
  Foo f = Foo();
  f.setY(5);
  return x + f.getY();


RCPP_MODULE(bar_mod)
  class_<Bar>("Bar")
  .constructor()
  .method("getX", &Bar::getX)
  .method("setX", &Bar::setX)
  .method("sumXY", &Bar::sumXY)
  ;

其头文件的代码如下。

class Bar
public:
  Bar();
  int getX();
  void setX(int num);
  int sumXY();
private:
  int x;
;

Foo.cpp 的代码如下。

#include "Foo.h"
#include <Rcpp.h>
using namespace Rcpp;

Foo::Foo()
  y = 0;


int Foo::getY()return y;

void Foo::setY(int num)y = num;

RCPP_MODULE(foo_module)
  class_<Foo>("Foo")
  .constructor()
  .method("getY", &Foo::getY)
  .method("setY", &Foo::setY)
  ;

其头文件的代码如下。

class Foo
public:
  Foo();
  int getY();
  void setY(int num);
private:
  int y;
;

Bar.cpp 文件包含两个头文件(Bar.h 和 Foo.h)。 Bar 中的 setXY() 方法创建一个 Foo 对象并调用其方法(因此它使用自己文件之外的类和方法)。

我想在 R 中从这两个类创建对象,并调用它们的方法。我正在尝试使用以下代码在 R 中加载这些模块:

require(Rcpp)
loadModule("foo_mod", TRUE)
loadModule("bar_mod", TRUE)

foo_mod <- Module("foo_mod")
bar_mod <- Module("bar_mod")

foo <- new (Foo)
bar <- new (Bar)

但是,我收到以下错误:

.getClassesFromCache(Class) 中的错误:找不到对象“Foo”

我做错了什么?

【问题讨论】:

【参考方案1】:

我认为你可能只是对你的命名草率。尝试在宏 RCPP_MODULE 和加载器中更一致地使用标识符,即我会使用

RCPP_MODULE(bar)   // not bar_mod
//...
RCPP_MODULE(foo)   // not foo_modules

然后通过

加载(在包中,这很重要)
loadModule("foo", TRUE)
loadModule("bar", TRUE)

之后你可以做(​​一旦你加载了包,这也是必须的)

z <- new(foo)

参见我的RcppAnnoy 包。

【讨论】:

以上是关于使用 Rcpp 模块公开 C++ 类的主要内容,如果未能解决你的问题,请参考以下文章

如何使用 swig C++ 命名空间作为 python 模块公开

Rcpp Armadilllo 中的模板类 arma::Col

使用 Rcpp 在 C++ 函数的 R 中使用 for 循环的内存问题

如何在 C++ 中通过 Rcpp 使用 Boost 库

rcpp报错,在mac上学习Rcpp和C++

将 C++ 函数用作由导出的 Rcpp 函数调用的另一个 C++ 函数的参数