“内部产品”未在此范围内声明

问题描述 投票:-2回答:1

嗨,我是rcpp的新手,它计算两个变量的内积,但是对于以下代码,出现错误“此范围内未声明inner_product”:

#include <math.h>
#include <RcppCommon.h>
#include <RcppArmadillo.h>
// [[Rcpp::depends(RcppArmadillo)]]

using namespace Rcpp;
// [[Rcpp::export]]
NumericVector polynomial_kernel(NumericVector x, NumericMatrix Y, double scale = 1, double offset = 
1, int d=1){

  int n = Y.nrow();
  NumericVector kernel(n);

  for (int j = 0; j < n; j++){
    NumericVector v = Y( j,_ );
    double crossProd =innerProduct(x,v);
    kernel[j]= pow((scale*crossProd+offset),2); 
  }
  return kernel;
}

[请帮助我解决此问题。

r rcpp rcpparmadillo
1个回答
0
投票

下面是实际编译的代码的更简单,经过修复的版本。它使用Armadillo类型来保持一致性,而不是调用不存在的“ inner_product”例程来通过乘法以标准方式计算两个向量的内积。

#include <RcppArmadillo.h>      // also pulls in Rcpp.h amd cmath

// [[Rcpp::depends(RcppArmadillo)]]

// [[Rcpp::export]]
arma::vec polynomial_kernel(arma::vec x, arma::mat Y,
                            double scale = 1, double offset = 1, int d=1) {

  int n = Y.n_rows;
  arma::vec kernel(n);

  for (int j = 0; j < n; j++){
    arma::rowvec v = Y.row(j);
    double crossProd = arma::as_scalar(v * x);
    kernel[j] = std::pow((scale*crossProd+offset),2);
  }
  return kernel;
}

您的示例不是minimallyc complete verifiable example,因此我无法向您显示您可以提供的任何数据。在某些编造的数据上,它似乎起作用:

R> set.seed(123)
R> polynomial_kernel(runif(4), matrix(rnorm(16),4))
         [,1]
[1,] 3.317483
[2,] 3.055690
[3,] 1.208345
[4,] 0.301834
R> 
© www.soinside.com 2019 - 2024. All rights reserved.