我是 Rcpp 的新手。
我创建了一个 rcpp 函数,它接受一个包含 2 列的数据帧和一个向量作为输入,并返回一个向量。我的数据如下
set.seed(10)
min= sort(rnorm(1000,800,sd=0.1))
max= min+0.02
k=data.frame(min,max)
explist= sort(rnorm(100,800,sd=0.2))
Run Code Online (Sandbox Code Playgroud)
然后我调用cfilter.cpp
k$output <- cfilter(k,explist)
#include <Rcpp.h>
using namespace Rcpp;
// [[Rcpp::export]]
CharacterVector cfilter(DataFrame k, NumericVector explist) {
NumericVector col1 = k["min"];
NumericVector col2 = k["max"];
NumericVector exp = explist ;
int n = col1.size();
int j = 0;
CharacterVector out(n);
for (int i=0; i<n ; i++){
out[i]=NA_STRING;
while(exp[j]<= col2[i]){
if( exp[j]>= col1[i] && exp[j]<= col2[i] ){
out[i]="Y";
break;
}
else if(exp[j]>col2[i]){
break;
}
else {
j++ ;
}
}
}
return out;
}
Run Code Online (Sandbox Code Playgroud)
我调用它 16171 次,它运行得很好。然后突然,在循环 16172 中,它因错误而停止:
> myfile$output<- cfilter(k,explist2)
Error in .Call(<pointer: (nil)>, k, explist) :
NULL value passed as symbol address
Run Code Online (Sandbox Code Playgroud)
我检查了 k 和 explist 中的 NA 值,但没有任何值,输入没有任何问题。我不知道如何解决此问题以及导致此错误的原因。
预先感谢您的任何回复
小智 1
我遇到了同样的问题。我不是 Rcpp 专家,也不是 C++ 专家,也不是后端编码专家。每次我想调用该函数时,我都通过重新获取我的 cpp 文件来避免这个问题。因此,例如,如果以下是您的 for 循环:
for(i in 1:SampleSize){
out[[I]]<-cfilter(k,explist)
}
Run Code Online (Sandbox Code Playgroud)
做类似的事情:
for(i in 1:SampleSize){
sourceCpp("cfilter.cpp")
out[[i]]<-cfilter(k,explist)
}
Run Code Online (Sandbox Code Playgroud)
再说一遍,我不知道为什么这对我有用,但它确实有效。根据我对C++的浅薄了解,这可能与内存分配有关,每次获取时,都会释放内存,因此不存在错误分配。但我认为这是一个非常疯狂的猜测。最好的
| 归档时间: |
|
| 查看次数: |
2577 次 |
| 最近记录: |