UNPKG

qminer

Version:

A C++ based data analytics platform for processing large-scale real-time streams containing structured and unstructured data

490 lines (442 loc) 20.6 kB
/** * Copyright (c) 2015, Jozef Stefan Institute, Quintelligence d.o.o. and contributors * All rights reserved. * * This source code is licensed under the FreeBSD license found in the * LICENSE file in the root directory of this source tree. */ // JavaScript source code var la = require('../../index.js').la; var analytics = require('../../index.js').analytics; var assert = require("../../src/nodejs/scripts/assert.js"); //Unit test for SVR describe("SVR test", function () { describe("Constructor test", function () { it("It should return a default constructor", function () { var SVR = new analytics.SVR(); var SVRjSon = SVR.getParams(); assert.strictEqual(SVRjSon.c, 1); assert.strictEqual(SVRjSon.eps, 1e-3); assert.strictEqual(SVRjSon.batchSize, 1000); assert.strictEqual(SVRjSon.maxIterations, 10000); assert.strictEqual(SVRjSon.maxTime, 1); assert.eqtol(SVRjSon.minDiff, 1e-6); assert.strictEqual(SVRjSon.verbose, false); }); it("It should return a SVR created by Json", function () { var SVR = new analytics.SVR({ c: 5, eps: 5, batchSize: 5, maxIterations: 5, maxTime: 1, minDiff: 1e-10, verbose: true }); var SVRjSon = SVR.getParams(); assert.strictEqual(SVRjSon.c, 5); assert.strictEqual(SVRjSon.eps, 5); assert.strictEqual(SVRjSon.batchSize, 5); assert.strictEqual(SVRjSon.maxIterations, 5); assert.strictEqual(SVRjSon.maxTime, 1); assert.eqtol(SVRjSon.minDiff, 1e-10); assert.strictEqual(SVRjSon.verbose, true); }); it("It should return a SVR created by Json, not all key values are given", function () { var SVR = new analytics.SVR({ c: 5, batchSize: 5, maxTime: 1, verbose: true }); var SVRjSon = SVR.getParams(); assert.strictEqual(SVRjSon.c, 5); assert.strictEqual(SVRjSon.eps, 1e-3); assert.strictEqual(SVRjSon.batchSize, 5); assert.strictEqual(SVRjSon.maxIterations, 10000); assert.strictEqual(SVRjSon.maxTime, 1); assert.eqtol(SVRjSon.minDiff, 1e-6); assert.strictEqual(SVRjSon.verbose, true); }); it("It should return a SVR created by an empty Json", function () { var SVR = new analytics.SVR({}); var SVRjSon = SVR.getParams(); assert.strictEqual(SVRjSon.c, 1); assert.strictEqual(SVRjSon.eps, 1e-3); assert.strictEqual(SVRjSon.batchSize, 1000); assert.strictEqual(SVRjSon.maxIterations, 10000); assert.strictEqual(SVRjSon.maxTime, 1); assert.eqtol(SVRjSon.minDiff, 1e-6); assert.strictEqual(SVRjSon.verbose, false); }); it("It should return a SVR created by Json, with added key values", function () { var SVR = new analytics.SVR({ alpha: 5, beta: 10, s: 3, batchSize: 10000, verbose: true }); var SVRjSon = SVR.getParams(); assert.strictEqual(SVRjSon.c, 1); assert.strictEqual(SVRjSon.eps, 1e-3); assert.strictEqual(SVRjSon.batchSize, 10000); assert.strictEqual(SVRjSon.maxIterations, 10000); assert.strictEqual(SVRjSon.maxTime, 1); assert.eqtol(SVRjSon.minDiff, 1e-6); assert.strictEqual(SVRjSon.verbose, true); }); }); describe("GetParams tests", function () { it("should return the parameters of the default SVR model as Json", function () { var SVR = new analytics.SVR(); var SVRjSon = SVR.getParams(); assert.strictEqual(SVRjSon.c, 1); assert.strictEqual(SVRjSon.eps, 1e-3); assert.strictEqual(SVRjSon.batchSize, 1000); assert.strictEqual(SVRjSon.maxIterations, 10000); assert.strictEqual(SVRjSon.maxTime, 1); assert.eqtol(SVRjSon.minDiff, 1e-6); assert.strictEqual(SVRjSon.verbose, false); }) it("should return the parameters of the default SVR model as Json, without some key values", function () { var SVR = new analytics.SVR({ c: 3, eps: 2, maxTime: 1 }); var SVRjSon = SVR.getParams(); assert.strictEqual(SVRjSon.c, 3); assert.strictEqual(SVRjSon.eps, 2); assert.strictEqual(SVRjSon.batchSize, 1000); assert.strictEqual(SVRjSon.maxIterations, 10000); assert.strictEqual(SVRjSon.maxTime, 1); assert.eqtol(SVRjSon.minDiff, 1e-6); assert.strictEqual(SVRjSon.verbose, false); }) it("should return the parameters of the default SVR model as Json, with added key values", function () { var SVR = new analytics.SVR({ alpha: 3, beta: 3, z: 3 }); var SVRjSon = SVR.getParams(); assert.strictEqual(SVRjSon.c, 1); assert.strictEqual(SVRjSon.eps, 1e-3); assert.strictEqual(SVRjSon.batchSize, 1000); assert.strictEqual(SVRjSon.maxIterations, 10000); assert.strictEqual(SVRjSon.maxTime, 1); assert.eqtol(SVRjSon.minDiff, 1e-6); assert.strictEqual(SVRjSon.verbose, false); }) }); describe("SetParams tests", function () { it("should return the existing SVR with the changed values", function () { var SVR = new analytics.SVR(); SVR.setParams({ eps: 3, maxTime: 2 }); var SVRjSon = SVR.getParams(); assert.strictEqual(SVRjSon.c, 1); assert.strictEqual(SVRjSon.eps, 3); assert.strictEqual(SVRjSon.batchSize, 1000); assert.strictEqual(SVRjSon.maxIterations, 10000); assert.strictEqual(SVRjSon.maxTime, 2); assert.eqtol(SVRjSon.minDiff, 1e-6); assert.strictEqual(SVRjSon.verbose, false); }) it("should return the existing SVR with the changed, added values", function () { var SVR = new analytics.SVR(); SVR.setParams({ eps: 3, maxTime: 2, alpha: 5, z: 10 }); var SVRjSon = SVR.getParams(); assert.strictEqual(SVRjSon.c, 1); assert.strictEqual(SVRjSon.eps, 3); assert.strictEqual(SVRjSon.batchSize, 1000); assert.strictEqual(SVRjSon.maxIterations, 10000); assert.strictEqual(SVRjSon.maxTime, 2); assert.eqtol(SVRjSon.minDiff, 1e-6); assert.strictEqual(SVRjSon.verbose, false); }) it("should throw an exception if the argument is not Json", function () { var SVR = new analytics.SVR(); assert.throws(function () { SVR.setParams(1); }); }) it("should throw an exception if there is no given argument", function () { var SVR = new analytics.SVR(); assert.throws(function () { SVR.setParams(); }); }) it('should throw an exception if algorithm has changed', function () { var matrix = new la.Matrix([[1, -1], [0, 0]]); var vec = new la.Vector([1, -1]); var SVR = new analytics.SVR(); assert.throws(function () { SVR.setParams({ algorithm: "LIBSVM", kernel: "RBF" }); }); }) }); describe("Weights tests", function () { it("should return an empty vector", function () { var SVR = new analytics.SVR(); var Vec = SVR.weights; assert.strictEqual(Vec.length, 0); }) it("should return an empty vector even if the parameters have been changed", function () { var SVR = new analytics.SVR(); SVR.setParams({ j: 3, maxTime: 2 }); var Vec = SVR.weights; assert.strictEqual(Vec.length, 0); }) }); describe("getModel tests", function () { it("should return parameters of the model", function () { var SVR = new analytics.SVR(); var Model = SVR.getModel(); assert.strictEqual(Model.weights.length, 0); }) it("should ignore extra parameters given to the function", function () { var SVR = new analytics.SVR(); var Model = SVR.getModel(1); assert.strictEqual(Model.weights.length, 0); }) }); describe("Fit Tests", function () { it("should not throw an exception for correct values", function () { var matrix = new la.Matrix([[1, -1], [1, -1]]); var vector = new la.Vector([1, 1]); var SVR = new analytics.SVR(); assert.doesNotThrow(function () { SVR.fit(matrix, vector); }); }) //degenerated example it("should return a fitted model for the degenerated example", function () { var matrix = new la.Matrix([[1, -1], [1, -1]]); var vector = new la.Vector([1, 1]); var SVR = new analytics.SVR(); SVR.fit(matrix, vector); var model = SVR.getModel(); assert.eqtol(model.weights[0], 0, 1e-2); assert.eqtol(model.weights[1], 0, 1e-2); }) //the tolerance in the test is equal to epsilon in SVR it("should return a fitted model", function () { var matrix = new la.Matrix([[1, -1], [1, 1]]); var vector = new la.Vector([1, 1]); var SVR = new analytics.SVR({c: 10}); SVR.fit(matrix, vector); var model = SVR.getModel(); assert.eqtol(model.weights[0], 0, 1e-1); assert.eqtol(model.weights[1], 1, 1e-1); }) it('should make a model from one-dimensional vectors', function () { var matrix = new la.Matrix([[1, -1]]); var vector = new la.Vector([1, -1]); var SVR = new analytics.SVR({ c: 10 }); SVR.fit(matrix, vector); var weights = SVR.weights; assert.eqtol(weights[0], 1, 3e-1); }) it('should throw an exception if the number of matrix cols and the vector length aren\'t equal', function () { var matrix = new la.Matrix([[1, -1, 2], [1, -2, 3]]); var vector = new la.Vector([1, -1]); var SVR = new analytics.SVR({ c: 10 }); assert.throws(function () { SVR.fit(matrix, vector); }); }) it('should forget the previous model', function () { var matrix = new la.Matrix([[1, -1], [1, 1]]); var vector = new la.Vector([1, 1]); var SVR = new analytics.SVR({ c: 100 }); SVR.fit(matrix, vector); var weights = SVR.weights; assert.eqtol(weights[0], 0, 1e-1); assert.eqtol(weights[1], 1, 1e-1); var matrix2 = new la.Matrix([[1, -1]]); var vec2 = new la.Vector([1, -1]); SVR.fit(matrix2, vec2); weights = SVR.weights; // temporary fix, since assert.eqtol(weights[0], 1, 1e-1); sometimes throws errors assert.eqtol(weights[0], 1, 2e-1); }) // test for setParams it('should not change the model', function () { var matrix = new la.Matrix([[1, -1], [1, 1]]); var vector = new la.Vector([1, 1]); var SVR = new analytics.SVR({ c: 10 }); SVR.fit(matrix, vector); var model = SVR.getModel(); assert.eqtol(model.weights[0], 0, 1e-1); assert.eqtol(model.weights[1], 1, 1e-1); // changing the parameters SVR.setParams({ c: 100, maxTime: 12000 }); var weights = SVR.weights; assert.eqtol(weights[0], 0, 1e-1); assert.eqtol(weights[1], 1, 1e-1); }) }); describe('Predict Tests', function () { it('should not throw an exception for giving the correct values', function () { var matrix = new la.Matrix([[1, -1], [1, 1]]); var vector = new la.Vector([1, 1]); var SVR = new analytics.SVR({ c: 10 }); SVR.fit(matrix, vector); var vec2 = new la.Vector([2, 3]); assert.doesNotThrow(function () { SVR.predict(vec2); }); }) it('should return the prediction of the vector [2, 3]', function () { var matrix = new la.Matrix([[1, -1], [1, 1]]); var vector = new la.Vector([1, 1]); var SVR = new analytics.SVR({ c: 10 }); SVR.fit(matrix, vector); var vec2 = new la.Vector([2, 3]); var prediction = SVR.predict(vec2); assert.eqtol(prediction, 3, 5e-1); }) it('should throw an exception if the given vector is to long', function () { var matrix = new la.Matrix([[1, -1], [1, 1]]); var vector = new la.Vector([1, 1]); var SVR = new analytics.SVR({ c: 10 }); SVR.fit(matrix, vector); assert.throws(function () { SVR.predict(new la.Vector([1, 2, 3])); }); }) it('should throw an exception if the given vector is to short', function () { var matrix = new la.Matrix([[1, -1], [1, 1]]); var vector = new la.Vector([1, 1]); var SVR = new analytics.SVR({ c: 10 }); SVR.fit(matrix, vector); assert.throws(function () { SVR.predict(new la.Vector([1])); }); }) it('should throw an exception if the given vector is empty', function () { var matrix = new la.Matrix([[1, -1], [1, 1]]); var vector = new la.Vector([1, 1]); var SVR = new analytics.SVR({ c: 10 }); SVR.fit(matrix, vector); assert.throws(function () { SVR.predict(new la.Vector()); }); }) it('should return the prediction of the one-dimensional vector', function () { var matrix = new la.Matrix([[1, -1]]); var vector = new la.Vector([1, -1]); var SVR = new analytics.SVR({ c: 10 }); SVR.fit(matrix, vector); var vec2 = new la.Vector([3]); var prediction = SVR.predict(vec2); assert.eqtol(prediction, 3, 5e-1); }) // if fit is not previously used it('should throw an exception if the fit is not used', function () { var SVR = new analytics.SVR({ c: 10 }); var vector = new la.Vector([1, 1]); assert.throws(function () { SVR.predict(vector); }); }) it('should return the predictions for the matrix', function () { var matrix = new la.Matrix([[1, -1], [1, 1]]); var vector = new la.Vector([1, 1]); var SVR = new analytics.SVR({ c: 10 }); SVR.fit(matrix, vector); var mat2 = new la.Matrix([[2, -3, 5], [1, -4, 0.3]]); var prediction = SVR.predict(mat2); assert.eqtol(prediction[0], 1, 5e-1); assert.eqtol(prediction[1], -4, 5e-1); assert.eqtol(prediction[2], 0.3, 5e-1); }) it('should throw an exception if there are too many rows in the matrix', function () { var matrix = new la.Matrix([[1, -1], [1, 1]]); var vector = new la.Vector([1, 1]); var SVR = new analytics.SVR({ c: 10 }); SVR.fit(matrix, vector); var mat2 = new la.Matrix([[2, -3, 5], [1, -4, 0.3], [0, 0, 1]]); assert.throws(function () { SVR.predict(mat2); }); }) it('should throw an exception if there are too lesser rows in the matrix', function () { var matrix = new la.Matrix([[1, -1], [1, 1]]); var vector = new la.Vector([1, 1]); var SVR = new analytics.SVR({ c: 10 }); SVR.fit(matrix, vector); var mat2 = new la.Matrix([[2, -3, 5]]); assert.throws(function () { SVR.predict(mat2); }); }) }); describe('DecisionFunction Tests', function () { it('should not return an exception for the given correct values', function () { var matrix = new la.Matrix([[1, -1], [1, 1]]); var vector = new la.Vector([1, 1]); var SVR = new analytics.SVR({ c: 10 }); SVR.fit(matrix, vector); var vec2 = new la.Vector([2, 3]); assert.doesNotThrow(function () { SVR.decisionFunction(vec2); }) }) it('should return the distance from the model', function () { var matrix = new la.Matrix([[1, -1], [1, 1]]); var vector = new la.Vector([1, 1]); var SVR = new analytics.SVR({ c: 10 }); SVR.fit(matrix, vector); var vec2 = new la.Vector([2, 3]); var distance = SVR.decisionFunction(vec2); assert.eqtol(distance, 3, 5e-1); }) it('should return the distance of the one-dimensional vector from the model', function () { var matrix = new la.Matrix([[1, -1]]); var vector = new la.Vector([1, -1]); var SVR = new analytics.SVR({ c: 10 }); SVR.fit(matrix, vector); var vec2 = new la.Vector([0.5]); var distance = SVR.decisionFunction(vec2); assert.eqtol(distance, 0.5, 1e-1); }) it('should return the distance of the matrix from the model', function () { var matrix = new la.Matrix([[1, -1], [1, 1]]); var vector = new la.Vector([1, 1]); var SVR = new analytics.SVR({ c: 10 }); SVR.fit(matrix, vector); var matrix2 = new la.Matrix([[1, 2, 3], [-2, 3, -0.5]]); var distance = SVR.decisionFunction(matrix2); assert.eqtol(distance[0], -2, 5e-1); assert.eqtol(distance[1], 3, 5e-1); assert.eqtol(distance[2], -0.5, 5e-1); }) it('should throw an exception if the vector is too long', function () { var matrix = new la.Matrix([[1, -1], [1, 1]]); var vector = new la.Vector([1, 1]); var SVR = new analytics.SVR({ c: 10 }); SVR.fit(matrix, vector); var vec2 = new la.Vector([2, 3, 4]); assert.throws(function () { SVR.decisionFunction(vec2); }); }) it('should throw an exception if the vector is too short', function () { var matrix = new la.Matrix([[1, -1], [1, 1]]); var vector = new la.Vector([1, 1]); var SVR = new analytics.SVR({ c: 10 }); SVR.fit(matrix, vector); var vec2 = new la.Vector([2]); assert.throws(function () { SVR.decisionFunction(vec2); }); }) it('should throw an exception if the matrix has to many rows', function () { var matrix = new la.Matrix([[1, -1], [1, 1]]); var vector = new la.Vector([1, 1]); var SVR = new analytics.SVR({ c: 10 }); SVR.fit(matrix, vector); var matrix2 = new la.Matrix([[1, 2, 3], [2, 3, -4], [-1, 0, 0]]); assert.throws(function () { SVR.decisionFunction(matrix2); }) }) it('should throw an exception if the matrix has too lesser of rows', function () { var matrix = new la.Matrix([[1, -1], [1, 1]]); var vector = new la.Vector([1, 1]); var SVR = new analytics.SVR({ c: 10 }); SVR.fit(matrix, vector); var matrix2 = new la.Matrix([[1, 2, 3]]); assert.throws(function () { SVR.decisionFunction(matrix2); }); }) }); describe('Serialization Tests', function () { it('should serialize and deserialize', function () { var matrix = new la.Matrix([[1, -1], [0, 0]]); var vec = new la.Vector([1, -1]); var SVR = new analytics.SVR(); SVR.fit(matrix, vec); SVR.save(require('../../index.js').fs.openWrite('svc_test.bin')).close(); var SVR2 = new analytics.SVR(require('../../index.js').fs.openRead('svc_test.bin')); assert.deepEqual(SVR.getParams(), SVR2.getParams()); assert.eqtol(SVR.weights.minus(SVR2.weights).norm(), 0, 1e-8); }) }); })