我在C中编写了一个函数“foo”,我想从R程序中调用它.该函数接受矩阵作为输入并对其执行一些操作(例如,为每个元素添加1).虽然单个矢量很容易
.C("foo",n=as.integer(5),x=as.double(rnorm(5)))
用foo实现的
void foo(int *nin,double *x)
{
int n = nin[0];
int i;
for (i=0; i<n; i++)
x[i] = x[i] * x[i];
}
如何传入二维数组?如果我将“double * x”更改为“double ** x”,则会出现分段错误.任何指针赞赏.
解决方法
没有必要放弃.C这样的直接操作.请记住,R中的矩阵是矢量维度.同样在C中,因此传递矩阵及其尺寸,并将矩阵的元素作为适当的偏移量进入矢量.就像是
void cplus1(double *x,int *dim)
{
for (int j = 0; j < dim[1]; ++j)
for (int i = 0; i < dim[0]; ++i)
x[j * dim[0] + i] += 1;
}
所以使用内联作为一个很好的派对技巧
library(inline)
sig <- signature(x="numeric",dim="integer")
body <- "
for (int j = 0; j < dim[1]; ++j)
for (int i = 0; i < dim[0]; ++i)
x[j * dim[0] + i] += 1;
"
cfun <- cfunction(sig,body=body,language="C",convention=".C")
plus1 <- function(m) {
m[] = cfun(as.numeric(m),dim(m))$x
m
}