squ*_*bar 6 c++ r matrix armadillo rcpp
观察
对于中等大小的矩阵,从R到C++传递矩阵的开销对于arma::mat类型而言比对NumericMatrix类型要慢得多.喜欢长约250倍.这是一个最小的例子
#include <RcppArmadillo.h>
// [[Rcpp::depends(RcppArmadillo)]]
using namespace Rcpp;
using namespace arma;
// [[Rcpp::export]]
double test_nm( NumericMatrix X ) {
return 0.0 ;
}
// [[Rcpp::export]]
double test_arma( mat X ) {
return 0.0 ;
}
// [[Rcpp::export]]
double test_nm_conv( NumericMatrix X ) {
mat X_arma = as<mat>( X ) ;
return 0.0 ;
}
Run Code Online (Sandbox Code Playgroud)
然后,在R:
XX <- matrix( runif( 10000 ), 2000, 50 )
microbenchmark( test_nm( XX ), test_arma( XX ), ( XX ) )
Unit: microseconds
expr min lq mean median uq max neval
test_nm(XX) 5.541 16.154 16.0781 17.577 18.876 48.024 100
test_arma(XX) 1280.946 1337.706 1404.0824 1361.237 1389.476 3385.868 100
test_nm_conv(XX) 1277.417 1338.835 1393.4888 1358.128 1386.101 4355.533 100
Run Code Online (Sandbox Code Playgroud)
因此,将矩阵作为一种arma::mat类型传递的速度大约是250倍NumericMatrix.太疯狂了!所以...
出现的问题
mat 这么慢NumericMatrix?arma::mat在一个被调用很多次的函数中使用一个相当简单的矩阵代数.我目前正在使用arma各种类型,而且我的代码比我预期的要慢得多(这就是我最终如何制作上面的愚蠢示例).250x的速度惩罚是如此重要,我将要重写大部分代码以使用NumericMatrix整个类型.实际上,我最终可能会编写自己的矩阵乘法函数NumericMatrix并arma完全放弃类型.但在此之前,有没有更好的解决方案?(虽然我想另一种方式来阅读这个并不是arma::mat从R类型转换的速度很慢,但这种NumericMatrix类型的效率非常高!)
我相信这会创建一个新的Armadillo矩阵,然后复制数字矩阵的内容.
要将NumericMatrix转换为键入arma :: mat,您应该使用以下命令:
// [[Rcpp::export]]
double test_const_arma( const mat& X ) {
return 0.0 ;
}
Run Code Online (Sandbox Code Playgroud)
我的机器上的速度比较:
microbenchmark( test_const_arma( XX ), test_nm( XX ), test_arma( XX ), test_nm_conv( XX ))
## Unit: microseconds
## expr min lq mean median uq max neval
## test_const_arma(XX) 1.852 2.381 3.69014 2.7885 4.3490 11.994 100
## test_nm(XX) 1.925 2.455 3.47679 2.8535 3.5195 21.222 100
## test_arma(XX) 68.593 71.212 83.63055 73.4555 98.8070 278.981 100
## test_nm_conv(XX) 68.700 70.983 80.55983 73.1705 82.2665 183.484 100
Run Code Online (Sandbox Code Playgroud)