【问题标题】:remove NA from NumericVector in RCpp从 RCpp 中的 NumericVector 中删除 NA
【发布时间】:2014-04-19 17:10:41
【问题描述】:

我是 Rcpp 的新手(也是 C++ 的新手)。我在这里使用示例代码https://gist.github.com/kevinushey/4561281 编写了一个代码来计算矩阵的行/列最大值/混合,如下所示:

#include <Rcpp.h>
using namespace Rcpp;

template <class T>
inline double do_max(T& x) {
  return max(x);
}

template <class T>
inline double do_min(T& x) {
  return min(x);
}

NumericVector colMaxsCpp(NumericMatrix& x) {
  int nRows = x.nrow();
  NumericVector out = no_init(nRows);

  for (int i=0; i<nRows;i++) {
    NumericMatrix::Row tmp = x(i,_);
    out[i]=do_max(tmp);
  }

  return out;
}

NumericVector colMinsCpp(NumericMatrix& x) {
  int nRows = x.nrow();
  NumericVector out = no_init(nRows);

  for (int i=0; i<nRows;i++) {
    NumericMatrix::Row tmp = x(i,_);
    out[i]=do_min(tmp);
  }

  return out;
}

NumericVector rowMaxsCpp(NumericMatrix& x) {
  int nCols = x.ncol();
  NumericVector out = no_init(nCols);

  for (int i=0; i<nCols;i++) {
    NumericMatrix::Column tmp = x(_,i);
    out[i]=do_max(tmp);
  }

  return out;
}

NumericVector rowMinsCpp(NumericMatrix& x) {
  int nCols = x.ncol();
  NumericVector out = no_init(nCols);

  for (int i=0; i<nCols;i++) {
    NumericMatrix::Column tmp = x(_,i);
    out[i]=do_min(tmp);
  }

  return out;
}

// [[Rcpp::export]]
NumericVector Max(NumericMatrix x, int dim) {
  if (dim==1) {
    return rowMaxsCpp(x);
  } else if (dim==2) {
    return colMaxsCpp(x);
  }
}

// [[Rcpp::export]]
NumericVector Min(NumericMatrix x, int dim) {
  if (dim==1) {
    return rowMinsCpp(x);
  } else if (dim==2) {
    return colMinsCpp(x);
  }
}

我想修改代码以处理do_mindo_max 函数中的NAdo_mindo_max 函数使用类的 template

我在网上看到有关 NA_REALNA_INTEGER 的信息,但这些是特定于类的。

(a) 是否有任何通用的NA 可用于类的template(例如上面的示例)?

(b) 另外,是否有任何可用的函数可以让我将变量x 子集化为仅使用非NA 元素,例如相当于max(x[!is.na(x)])min(x[!is.na(x)]) 中的R

(c) 最后,上面的代码被编写来处理数字matrix,但即使提供了整数matrix,它似乎也可以工作(尽管输出转换为numeric)。为什么会这样?

【问题讨论】:

  • 有一个糖函数na_omit
  • @Roland,太好了,谢谢。我尝试用max(na_omit(x)) 替换max(x),但它没有编译。您能告诉我如何将它与max(x) 一起使用吗?
  • 您使用的是哪个版本的 Rcpp?如果我这样做,你的代码编译得很好。
  • @Roland,使用Rcpp 0.11.1。实际上,代码已经编译,但是出现了“Line 70 controlreach end of non-void function”之类的错误
  • 该警告是正常的,g++ 低于足够的警告级别。你需要插入一个无条件的 return a la NumericVector NeverReached(1); return NeverReached; 来抑制它。

标签: r rcpp


【解决方案1】:

快速的:

a) 是的,有,但我不确定它们是矢量化的。但是添加了一些模板化的 NA 特征。

b) 是的,例如在

R> cppFunction('double mymax(NumericVector x) { \
                   IntegerVector x2 = wrap(na_omit(x)); \
                   return max(x2);}')
R> mymax(c(1L, 2L, NA, 4L))
[1] 4
R> 

c) 整数总是以副本为代价“转换”为 Numeric。

@Roland 已经暗示过na_omit。在 b) 中,我需要以某种方式帮助 wrap() 生成中间 SEXP 对象。

【讨论】:

  • 我可以毫无问题地编译和使用cppFunction('double mymax(NumericVector x) {return max(na_omit(x));}')
  • @Roland,实际上,我的错,代码确实编译了,但它给了我两个警告。德克在上面的评论中给了我警告的答案
猜你喜欢
  • 2013-10-28
  • 1970-01-01
  • 2023-03-04
  • 2023-04-02
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多