- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
一切似乎都在我的包中工作,但我想检查制作它的步骤是否正确以及使用“Map”的内存使用情况。 (这是一个简单的示例,介于内联示例和 fastLm()
示例之间。)
这是一个内联函数,它取矩阵每一列的最大值:
library(Rcpp);
library(inline);
library(RcppEigen);
maxOverColCpp <- '
using Eigen::Map;
using Eigen::MatrixXd;
// Map the double matrix AA from R
const Map<MatrixXd> A(as<Map<MatrixXd> >(AA));
// evaluate and columnwise maximum entry of A
const MatrixXd Amax(A.colwise().maxCoeff());
return wrap(Amax);
'
rcppeigen_max_over_columns <- cxxfunction(signature(AA = "matrix"), maxOverColCpp, plugin = "RcppEigen")
然后为了更改函数以将其包含在现有的 R 包中,我将代码重写如下,将其保存在新的 src
文件夹中的 rcppeigen_max_over_columns.cpp
中一个现有的 R 包:
// we only include RcppEigen.h which pulls Rcpp.h in for us
#include <RcppEigen.h>
// via the depends attribute we tell Rcpp to create hooks for
// RcppEigen so that the build process will know what to do
//
// [[Rcpp::depends(RcppEigen)]]
// via the exports attribute we tell Rcpp to make this function
// available from R
//
// [[Rcpp::export]]
Eigen::MatrixXd rcppeigen_max_over_columns(const Eigen::MatrixXd & A){
Eigen::MatrixXd Amax = A.colwise().maxCoeff();
return Amax;
}
(事实上,它有点长,因为我还需要包括查找最大行数。)
然后:
使用以下行修改了描述文件:
导入:Rcpp (>= 0.11.3)、RcppEigen (>= 0.3.2.2.0)
链接到:Rcpp、RcppEigen
使用以下行修改了 NAMESPACE 文件:
使用动态库(玩具包)
导入(RcppEigen)
importFrom(Rcpp, evalCpp)
在 R 终端中,键入以下内容,我认为它与 R 和 C++ 结合:
Rcpp::compileAttributes(pkgdir="toyRpackage", verbose=getOption("verbose"))
然后对于常规包,我进行了R CMD check
和R CMD build
。
第一个问题是,将 RcppEigen 函数包含到现有 R 包中的过程是否正确? (我完全忽略了任何 Makevars
文件或任何 .h
文件——我真的不知道它们做了什么......也不太理解对NAMESPACE 文件。我试图复制 RcppEigen.package.skeleteon()
设置,但我正在将我的函数添加到现有包中。所以最好知道它是否可以,以防我错过以后可能会出现问题。)
第二个问题是我是否需要在 rcppeigen_max_over_columns.cpp
中的某处使用“映射”,以便矩阵在从 R 传递到 C++ 时不会被复制?
我知道这是一个初学者问题,但我在理解 .cpp 文件中的语法时遇到了一些困难,因为我不懂任何 C++。我想也许这个问题可能会帮助其他人也在尝试向他们的包中添加一个简单的功能。 :)
此外,如果您对使用 RcppEigen 而不是 RcppArmadillo 有任何强烈的感觉,请告诉我。我读了http://thread.gmane.org/gmane.comp.lang.r.rcpp/3522这很有用。对于我采用 max over columns 的示例,RcppEigen 似乎快得多,不知道为什么。
最佳答案
First question is whether this process for including an RcppEigen function into an existing R package is correct? (I completely ignored any Makevars files or any .h files -- I don't really know what they do... Also don't really understand the changes to the NAMESPACE file. I tried to copy the RcppEigen.package.skeleteon() set-up but I am adding my function to an existing package. So it would be good to know if it's okay in case I missed something that could be a problem later.)
对于具有相对简单的 C++ 代码的基本 R 包,您不需要包含头文件或自定义 Makevars/Makefile 或类似的东西。如果您构建更复杂的东西,您可能需要一个 Makefile/Makevars 来帮助处理构建过程,并且可能希望使用头文件将接口(interface)与实现分开——但为此您必须深入研究并挑选一些 C++ 书籍,因为有很多东西要学。
换句话说——你所做的一切都很好。对于简单的情况,可以只使用 src/
目录中的 .cpp
文件(并让 Rcpp
、属性和它的其他兄弟包处理剩下的)
Second question is whether I need a "Map" somewhere in rcppeigen_max_over_columns.cpp so that the matrix isn't copied when it's passed from R to C++?
好吧,当将 R 对象传输到(非 Rcpp
)类时,数据几乎总是会被复制,除非您专门使用可以重用底层数据的构造函数。我不知道 Eigen 是否有一个可以重复使用内存的构造函数,但我建议除非你知道它很重要,否则不要担心它(因为复制一系列数据是通常相当快)
关于c++ - RcppEigen - 从内联到包中的 .cpp 函数和 "Map",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27490659/
通过终端,您可以使用命令 - “SetFile -a B 文件名” 以编程方式,我认为我应该通过[[NSFileManager defaultManager] createDirectoryAtPat
嗨,正在尝试书中的一些示例:Practical Graph mining with R对于子图挖掘: library(subgraphMining) library(igraph) graph1 =
代码中的相同问题: class Foo { int getIntProperty () { ... } CustomObject getObjectProperty () { ... }
所以这可能是一个愚蠢的问题,但它已经困扰我一段时间了。 使用 React,我创建了两个组件(Buttons.js 和 Message.js),每个组件都有一个导出。但是,现在我希望将这两个组件用作 n
从今天早上开始,我发现我无法再从某个范围安装任何 NPM 包(或任何具有依赖项的包)。例如,如果我输入 npm i webpack 我会收到以下错误... npm ERR! code E401 npm
我在这里搜索过,Angular 2, @ngtools/webpack, AOT ,但对我不起作用。我运行了 npm install 命令。我正在做的是创建一个新的 Angular 2 项目。当我运行
情况: 我有一个 Swift 包,将其命名为 lib。 lib 位于其自己的存储库中。在lib的仓库中,有一堆本地包;也就是说,这些包是在 lib 中定义的,使用本地路径依赖格式 .package(p
我想在工作中学习和使用nodejs,但是在使用 de npm 命令安装模块/包时遇到网络问题。我是否可以使用我的家用计算机构建完整的 Node js 包,然后将其安装在另一台计算机(我的工作场所计算机
我需要将一些 .tar.bz2 格式的非 Python 包转换为 Anaconda/miniConda .egg 文件并安装它们。为此,我需要一个适用于 Windows 的 bld.bat 文件。互联
我需要共享库文件 libthrift-0.9.3.so 作为其他包的依赖项。我在构建 thrift-0.9.3 包时看到编译问题(我确实从 https://thrift.apache.org/down
我尝试在 R 版本 3.5.0 中安装“arcgisbinding”包。但是我失败了,得到以下错误和警告。 Installing package into ‘C:/Users/Lenovo/Docum
我尝试在 R 版本 3.5.0 中安装“arcgisbinding”包。但是我失败了,得到以下错误和警告。 Installing package into ‘C:/Users/Lenovo/Docum
我试图在 flutter 中测试这个应用程序,但我无法运行该应用程序,因为出现此错误“名称‘Page’在库‘package:burn_off/widgets/page.dart’和‘package’中
试图理解和学习如何编写包...用我一直使用的东西进行测试,记录... 您能帮我理解为什么“日志”变量不起作用...并且屏幕上没有日志记录吗? 谢谢! 主要文件: #!/opt/local/bin/py
我尝试运行此使用 Google 云的代码。 import signal import sys from google.cloud import language, exceptions # creat
我想知道是否有人找到了一个很好的 R 包来分析眼动追踪数据? 我遇到了 eyetrackR,但据我所知,没有可用的英文支持文档: http://read.psych.uni-potsdam.de/pm
我正在 R 上制作一个包。我有两个函数共享一个变量(全局)。 如何将其导入到包中? 例如, m<-0 f<-function() { m <- m+1 } g<-function() { m <- m
我用 C 为 Lua 编写了很多模块。每个模块都包含一个 Lua 用户数据类型,我像这样加载和使用它们: A = require("A") B = require("B") a = A.new(3,{
我正在尝试在 R 中的 Ubuntu 上安装 xlsx 包,以便使用允许在 R 中插入链接然后将它们导出到 Excel 的功能。 话虽如此,我根本无法安装该软件包。 显然它必须与 rJava 一起使用
我想在 Haskell 中做一些蒙特卡洛分析。我希望能够编写这样的代码: do n <- poisson lambda xs <- replicateM n $ normal mu sigma
我是一名优秀的程序员,十分优秀!