4

私は以下のように2つの二重配列を持っています

double[] x = { 2.5, 0.5, 2.2, 1.9, 3.1, 2.3, 2.0, 1.0, 1.5, 1.1 };
double[] y = { 2.4, 0.7, 2.9, 2.2, 3.0, 2.7, 1.6, 1.1, 1.6, 0.9 };

効率的なjava-matrix-library(EJML)ライブラリを使用して、それらの間の共分散をどのように見つけますか?どんなコードスニペットでも大歓迎です。ありがとう!

4

1 に答える 1

2

SimpleMatrix でそれを行う 1 つの方法を次に示しますが、コードはテストしていません。

double[] x = { 2.5, 0.5, 2.2, 1.9, 3.1, 2.3, 2.0, 1.0, 1.5, 1.1 };
double[] y = { 2.4, 0.7, 2.9, 2.2, 3.0, 2.7, 1.6, 1.1, 1.6, 0.9 };

SimpleMatrix a = new SimpleMatrix(x.length,1,true,x);
SimpleMatrix b = new SimpleMatrix(x.length,1,true,x);

double meanA = a.elementSum()/x.length;
double meanB = a.elementSum()/y.length;

// X = X - mean(A)
CommonOps.add(a.getMatrix(),-meanA);
CommonOps.add(b.getMatrix(),-meanB);

// compute the covariance
double c11 = a.transpose().mult(a).get(0,0)/x.length;
double c12 = a.transpose().mult(b).get(0,0)/x.length;
double c22 = b.transpose().mult(b).get(0,0)/x.length;

SimpleMatrix covariance = new SimpleMatrix(2,2,true,c11,c12,c12,c22);
于 2011-05-23T19:09:02.733 に答える