我有以下Rcpp/RcppArmadillo函数,它计算矩阵中的相关距离
#include <RcppArmadillo.h>
using namespace Rcpp;
// [[Rcpp::export]]
arma::mat cordiss(NumericMatrix X){
int nX = X.nrow(), kX = X.ncol();
arma::mat XX(X.begin(), nX, kX, false);
arma::mat output = (1 - arma::cor(XX.t(), XX.t()))/2;
return output.t();
}
在使用Rcpp::sourceCpp获取它之后,我可以这样做:
d <- cordiss(matrix(rnorm(1000),ncol=10))
但是,我在对角线上得到了非零值(因为我猜测机器的精度?),而我确实需要将这些数字设置为零,以便进一步处理距离矩阵。这是矩阵型的问题吗?我如何解决这个问题,而不必在事后(在Armadillo或R中)将对角线“手动”设置为零,例如:
diag(d) <- 0
实际上,我想使用一个类似的函数来计算两个不同的矩阵之间的距离,对于这两个矩阵,我无法预测矩阵的列将在哪里相等,谢谢您的帮助!
发布于 2014-03-13 05:52:16
不可能保证零,因为使用非整数数字的算法的任何实现实际上都使用这些数字的http://en.wikipedia.org/wiki/Floating_point。
您最好的选择是手动将对角线设置为零,您可以通过.diag()在Armadillo中这样做。例如,output.diag().zeros()
https://stackoverflow.com/questions/22378246
复制相似问题