use of org.apache.ignite.ml.math.Vector in project ignite by apache.
the class EigenDecompositionTest method assertEigenvalues.
/** */
private void assertEigenvalues(EigenDecomposition decomposition, double[] expRealEigenValues) {
Vector real = decomposition.getRealEigenValues();
Vector imag = decomposition.getImagEigenvalues();
assertEquals("Real values size differs from expected.", expRealEigenValues.length, real.size());
assertEquals("Imag values size differs from expected.", expRealEigenValues.length, imag.size());
for (int idx = 0; idx < expRealEigenValues.length; idx++) {
assertEquals("Real eigen value differs from expected at " + idx, expRealEigenValues[idx], real.get(idx), 0d);
assertEquals("Imag eigen value differs from expected at " + idx, 0d, imag.get(idx), 0d);
}
}
use of org.apache.ignite.ml.math.Vector in project ignite by apache.
the class AbstractVector method minus.
/** {@inheritDoc} */
@Override
public Vector minus(Vector vec) {
checkCardinality(vec);
Vector cp = copy();
return cp.map(vec, Functions.MINUS);
}
use of org.apache.ignite.ml.math.Vector in project ignite by apache.
the class AbstractMatrix method foldColumns.
/** {@inheritDoc} */
@Override
public Vector foldColumns(IgniteFunction<Vector, Double> fun) {
int cols = columnSize();
Vector vec = likeVector(cols);
for (int i = 0; i < cols; i++) vec.setX(i, fun.apply(viewColumn(i)));
return vec;
}
use of org.apache.ignite.ml.math.Vector in project ignite by apache.
the class VectorExample method main.
/**
* Executes example.
*
* @param args Command line arguments, none required.
*/
public static void main(String[] args) {
System.out.println();
System.out.println(">>> Basic Vector API usage example started.");
System.out.println("\n>>> Creating perpendicular vectors.");
double[] data1 = new double[] { 1, 0, 3, 0, 5, 0 };
double[] data2 = new double[] { 0, 2, 0, 4, 0, 6 };
Vector v1 = new DenseLocalOnHeapVector(data1);
Vector v2 = new DenseLocalOnHeapVector(data2);
System.out.println(">>> First vector: " + Arrays.toString(data1));
System.out.println(">>> Second vector: " + Arrays.toString(data2));
double dotProduct = v1.dot(v2);
boolean dotProductIsAsExp = dotProduct == 0;
System.out.println("\n>>> Dot product of vectors: [" + dotProduct + "], it is 0 as expected: [" + dotProductIsAsExp + "].");
Vector hypotenuse = v1.plus(v2);
System.out.println("\n>>> Hypotenuse (sum of vectors): " + Arrays.toString(hypotenuse.getStorage().data()));
double lenSquared1 = v1.getLengthSquared();
double lenSquared2 = v2.getLengthSquared();
double lenSquaredHypotenuse = hypotenuse.getLengthSquared();
boolean lenSquaredHypotenuseIsAsExp = lenSquaredHypotenuse == lenSquared1 + lenSquared2;
System.out.println(">>> Squared length of first vector: [" + lenSquared1 + "].");
System.out.println(">>> Squared length of second vector: [" + lenSquared2 + "].");
System.out.println(">>> Squared length of hypotenuse: [" + lenSquaredHypotenuse + "], equals sum of squared lengths of two original vectors as expected: [" + lenSquaredHypotenuseIsAsExp + "].");
System.out.println("\n>>> Basic Vector API usage example completed.");
}
use of org.apache.ignite.ml.math.Vector in project ignite by apache.
the class SparseVectorExample method main.
/**
* Executes example.
*
* @param args Command line arguments, none required.
*/
public static void main(String[] args) {
System.out.println();
System.out.println(">>> Sparse vector API usage example started.");
System.out.println("\n>>> Creating perpendicular sparse vectors.");
double[] data1 = new double[] { 1, 0, 3, 0, 5, 0 };
double[] data2 = new double[] { 0, 2, 0, 4, 0, 6 };
Vector v1 = new SparseLocalVector(data1.length, RANDOM_ACCESS_MODE);
Vector v2 = new SparseLocalVector(data2.length, RANDOM_ACCESS_MODE);
v1.assign(data1);
v2.assign(data2);
System.out.println(">>> First vector: " + Arrays.toString(data1));
System.out.println(">>> Second vector: " + Arrays.toString(data2));
double dotProduct = v1.dot(v2);
boolean dotProductIsAsExp = dotProduct == 0;
System.out.println("\n>>> Dot product of vectors: [" + dotProduct + "], it is 0 as expected: [" + dotProductIsAsExp + "].");
Vector hypotenuse = v1.plus(v2);
System.out.println("\n>>> Hypotenuse (sum of vectors): " + Arrays.toString(hypotenuse.getStorage().data()));
double lenSquared1 = v1.getLengthSquared();
double lenSquared2 = v2.getLengthSquared();
double lenSquaredHypotenuse = hypotenuse.getLengthSquared();
boolean lenSquaredHypotenuseIsAsExp = lenSquaredHypotenuse == lenSquared1 + lenSquared2;
System.out.println(">>> Squared length of first vector: [" + lenSquared1 + "].");
System.out.println(">>> Squared length of second vector: [" + lenSquared2 + "].");
System.out.println(">>> Squared length of hypotenuse: [" + lenSquaredHypotenuse + "], equals sum of squared lengths of two original vectors as expected: [" + lenSquaredHypotenuseIsAsExp + "].");
System.out.println("\n>>> Sparse vector API usage example completed.");
}
Aggregations