- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我有以下函数,它在 NumericVector
上执行一个简单的循环并返回 int
类型的值。
Rcpp::cppFunction({'
int calc_streak( NumericVector x, int i1, int i2){
int cur_streak=1;
if (NumericVector::is_na(x[0])){
cur_streak = NumericVector::get_na();
} else {
cur_streak = 1;
}
for(int j = i1; j <= i2 ; ++j) {
if( x[ j ] == x[ j-1 ]){
cur_streak += 1;
} else if(NumericVector::is_na( x[ j ] )){
cur_streak = NumericVector::get_na();
} else {
cur_streak = 1;
}
}
return cur_streak;
}
"})
calc_streak(c(1,1,1,1),i1=0,i2=3)
# [1] 4
功能对我来说工作正常,但真正的问题是当我试图在其他输入类型上扩展此功能。我一直在搜索堆栈 here和 here ,但这些示例不适用于我的情况,或者我不知道如何正确使用示例。我尝试了几种处理未知输入类型的方法,但在我的案例中没有一个成功。下面三个例子
最简单的一个灵感来自 this - 创建了主函数,该函数根据参数 TYPEOF(x)
的类型运行先前定义的函数之一。 此函数返回integer
和numeric
的期望值。对于 character
session 崩溃
Rcpp::cppFunction('
#include <Rcpp.h>
using namespace Rcpp;
int streak_run_int(IntegerVector x, int i1, int i2){
int cur_streak=1;
if (IntegerVector::is_na(x[0])){
cur_streak = NumericVector::get_na();
} else {
cur_streak = 1;
}
for(int j = i1; j <= i2 ; ++j) {
if( x[ j ] == x[ j-1 ]){
cur_streak += 1;
} else if(IntegerVector::is_na( x[ j ] )){
cur_streak = NumericVector::get_na();
} else {
cur_streak = 1;
}
}
return cur_streak;
}
int streak_run_char(CharacterVector x, int i1, int i2){
int cur_streak=1;
if (CharacterVector::is_na(x[0])){
cur_streak = NumericVector::get_na();
} else {
cur_streak = 1;
}
for(int j = i1; j <= i2 ; ++j) {
if( x[ j ] == x[ j-1 ]){
cur_streak += 1;
} else if(CharacterVector::is_na( x[ j ] )){
cur_streak = NumericVector::get_na();
} else {
cur_streak = 1;
}
}
return cur_streak;
}
// [[Rcpp::export]]
int streak_run4(SEXP x, int i1, int i2) {
switch (TYPEOF(x)) {
case INTSXP: {
return streak_run_int(as<IntegerVector>(x), i1, i2);
}
case STRSXP: {
return streak_run_char(as<CharacterVector>(x), i1, i2);
}
default: { return 0; }
}
}
')
# expected results for int and real - for character session crashes
streak_run4( c(1,1,1,1),i1=0, i2=3)
streak_run4( as.integer(c(1,1,1,1)),i1=0, i2=3)
streak_run4( as.character(c(1,1,1,1)),i1=0, i2=3)
第二个函数的想法完全相同,但使用模板而不是定义多个函数。结果与上面相同 - character
输入 session 崩溃
Rcpp::cppFunction('
#include <Rcpp.h>
using namespace Rcpp;
namespace impl {
template <int RTYPE>
int streak_run_impl(const Vector<RTYPE>& x, int i1, int i2)
{
int cur_streak=1;
if (Vector<RTYPE>::is_na(x[0])){
cur_streak = NumericVector::get_na();
} else {
cur_streak = 1;
}
for(int j = i1; j <= i2 ; ++j) {
if( x[ j ] == x[ j-1 ]){
cur_streak += 1;
} else if(Vector<RTYPE>::is_na( x[ j ] )){
cur_streak = NumericVector::get_na();
} else {
cur_streak = 1;
}
}
return cur_streak;
}
}
// [[Rcpp::export]]
int streak_run3(SEXP x, int i1, int i2) {
switch (TYPEOF(x)) {
case INTSXP: {
return impl::streak_run_impl(as<IntegerVector>(x), i1, i2);
}
case REALSXP: {
return impl::streak_run_impl(as<NumericVector>(x), i1, i2);
}
case STRSXP: {
return impl::streak_run_impl(as<CharacterVector>(x), i1, i2);
}
case LGLSXP: {
return impl::streak_run_impl(as<LogicalVector>(x), i1, i2);
}
case CPLXSXP: {
return impl::streak_run_impl(as<ComplexVector>(x), i1, i2);
}
default: {
return 0;
}
}
}
')
streak_run3( c(1,1,1,1),i1=0, i2=3)
streak_run3( as.integer(c(1,1,1,1)),i1=0, i2=3)
streak_run3( as.character(c(1,1,1,1)),i1=0, i2=3)
另一个灵感来自 this article ,这次我什至无法编译 C++ 函数,同时出现错误 use of overloaded operator '==' is ambiguous
。无论如何,在检查了上述两个示例之后,我不希望有任何其他结果。
Rcpp::cppFunction('
#include <Rcpp.h>
using namespace Rcpp;
class streak_run2_impl {
private:
int i1;
int i2;
public:
streak_run2_impl(int i1, int i2) : i1(i1), i2(i2) {}
template <int RTYPE>
IntegerVector operator()(const Vector<RTYPE>& x)
{
int cur_streak=1;
if (Vector<RTYPE>::is_na(x[0])){
cur_streak = NumericVector::get_na();
} else {
cur_streak = 1;
}
for(int j = i1; j <= i2 ; ++j) {
if( x[ j ] == x[ j-1 ] ){
cur_streak += 1;
} else if(Vector<RTYPE>::is_na( x[ j ] )){
cur_streak = NumericVector::get_na();
} else {
cur_streak = 1;
}
}
return cur_streak;
}
};
// [[Rcpp::export]]
RObject streak_run2(RObject x, int i1 = 0, int i2=6){
RCPP_RETURN_VECTOR(streak_run2_impl(i1, i2), x);
}
')
所以我的问题是:如何正确定义此函数以获得任何 R 类输入 vector 的结果?
我很乐意提供任何建议。
最佳答案
首先,好帖子!不幸的是,您链接的上述资源均与您的问题无关,因为它是由于原型(prototype)函数中未发现的完全不同的错误所致。 为什么 原型(prototype)在调用时返回了一个有效值,这纯属运气。
正如@BenjaminChristoffersen 指出的那样,代码运行到 undefined behavior (UB)由于 out-of-bounds (OOB)发生错误。他的解决方案将有效地“解决”问题。
但是,要在将来自行诊断此问题,请从使用元素访问器 []
切换到 ()
,它会检查您请求的元素是否是范围内。例如j 是否在 0 到 n - 1 之间?
例如
if (Vector<RTYPE>::is_na( x( 0 ) )){
// ------------------------^---^
cur_streak = NumericVector::get_na();
} else {
cur_streak = 1;
}
for(int j = i1; j <= i2 ; ++j) {
if( x( j ) == x( j-1 )){
// ^---^-----^-----^
cur_streak += 1;
} else if(Vector<RTYPE>::is_na( x( j ) )){
// --------------------------- ^ ^
cur_streak = NumericVector::get_na();
} else {
cur_streak = 1;
}
}
运行相同的命令然后给出:
streak_run3( c(1,1,1,1),i1=0, i2=3)
输出:
Error in streak_run3(c(1, 1, 1, 1), i1 = 0, i2 = 3) :
Index out of bounds: [index=-1; extent=4].
输入:
streak_run3( as.integer(c(1,1,1,1)),i1=0, i2=3)
输出:
Error in streak_run3(as.integer(c(1, 1, 1, 1)), i1 = 0, i2 = 3) :
Index out of bounds: [index=-1; extent=4].
输入:
streak_run3( as.character(c(1,1,1,1)),i1=0, i2=3)
输出:
Error in streak_run3(as.character(c(1, 1, 1, 1)), i1 = 0, i2 = 3) :
Index out of bounds: [index=-1; extent=4].
关于c++ - 将 Rcpp 函数扩展到任何类型的输入 vector ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46515052/
我想将函数参数中的默认值设置为 Rcpp::Function 参数。 只是简单的赋值,Rcpp::Function func = mean , 不可能。它返回错误:no viable conversi
我正在处理需要逐元素矩阵乘法的代码。我试图在 Rcpp 中实现这一点,因为代码需要一些昂贵的循环。我对 Rcpp 还很陌生,可能会遗漏一些东西,但我无法使逐元素矩阵乘法工作。 // [[Rcpp::e
在 C++ 中,我们可以声明一个变量作为引用。 int a = 10; int& b = a; 如果我们设置 b=15 , a 也会改变。 我想在 Rcpp 中做类似的事情。 List X = obj
我正在阅读很棒的 Rcpp vignette关于使用 Rcpp 模块公开 C++ 类和函数。在这种情况下,是否可以创建一个 Rcpp 函数,该函数具有一个类型为 Uniform 的类作为参数之一,并且
我在 R 中有一个命名列表: l = list(a=1, b=2) 我想在 Rcpp 中使用这个列表,并迭代值和名称。理想情况下,它可能类似于(为简洁起见使用 C++11 格式): void prin
这个问题在这里已经有了答案: Rcpp - sourceCpp - undefined symbol (2 个答案) 关闭 4 年前。 我现有的 C 代码由三个文件组成:头文件(“.h”文件)、库文
我目前正在为类作业编写模拟退火算法(“解决”背包问题),并想在 Rcpp 中完成(我必须使用 R,而 Rcpp 更快)。 Rcpp 一直给我以下错误 invalid static_cast from
根据我的理解,在 Rcpp 和 C++ 之间转换 vector 会创建新 vector ,如下所示。我的理解对吗? 将 Rcpp vector 转换为 C++ vector 时,我们使用 Rcpp::
我想将参数的默认值设置为 NULL在Rcpp如果参数不是NULL,则函数并根据参数进行一些计算.这种代码的一个例子是 #include using namespace Rcpp; // [[Rcpp
任何人都可以解释以下行为吗? 当声明一个新的NumericMatrix时,y,作为原始矩阵,x,乘以一个标量,c,标量/矩阵乘法的顺序很重要。如果我将左侧的标量与右侧的矩阵相乘(例如 NumericM
有一种方法可以使用 NA 值初始化数值向量,例如。 NumericVector x(10,NumericVector::get_na()) 有没有类似的方法可以将矩阵初始化为 NA 值? 最佳答案 这
这可能是一个非常简单的问题,但我不知道哪里出了问题。 我有一个传递给 Rcpp 函数的列表,该列表的第一个元素是一个 data.frame。 我如何获取该 data.frame? bar = list
我正在尝试开发一个使用 Sundials 的 R 包用于求解微分方程的 C 库。为了不让用户安装库,我将库的源代码放在我的包中。 我已将库中的所有头文件放入 /inst/include/sundial
我正在研究一个同时使用 Rcpp::IntegerVector (行/列指针)和模板化 std::vector 的 Rcpp 稀疏矩阵类。基本原理是,在极大的稀疏矩阵中深度复制整数指针 vector
我想将一个R函数翻译成Rcpp,一个简单的测试代码如下,但我不知道如何处理默认设置为NULL的参数。 test t=R_NilValue, Rcpp
我想将一个R函数翻译成Rcpp,一个简单的测试代码如下,但我不知道如何处理默认设置为NULL的参数。 test t=R_NilValue, Rcpp
我想公开一个 C++ 类和一个将该类的对象作为 R 参数的函数。我必须遵循简化的示例。我使用创建了一个包 Rscript -e 'Rcpp::Rcpp.package.skeleton("soq")'
我想用 Rcpp 编写一个 C++ 函数,它使用 hypred 包中的 C 函数,它在 CRAN here 上. 我读了using C function from other package in R
[我在别处将其草拟为评论,但决定创建一个适当的问题...] 在 Rcpp 中使用数据帧时,就代码结构而言,目前被认为是“最佳实践”的是什么?从 R 到 C++ 代码的输入数据帧“传输”非常容易,但是如
我正在尝试使用 Rcpp::CharacterMatrix 并将每一行转换为 Rcpp::List 中它自己的元素。 但是,我为此编写的函数有一个奇怪的行为,即列表的每个条目都对应于矩阵的最后一行。为
我是一名优秀的程序员,十分优秀!