2016-08-03 18:00:07 -04:00
|
|
|
/**
|
|
|
|
* @license
|
|
|
|
* Copyright Google Inc. All Rights Reserved.
|
|
|
|
*
|
|
|
|
* Use of this source code is governed by an MIT-style license that can be
|
|
|
|
* found in the LICENSE file at https://angular.io/license
|
|
|
|
*/
|
2015-02-11 13:13:49 -05:00
|
|
|
|
2017-03-02 15:12:46 -05:00
|
|
|
import {describe, expect, it} from '@angular/core/testing/src/testing_internal';
|
2016-08-26 19:34:08 -04:00
|
|
|
import {Statistic} from '../src/statistic';
|
2015-02-11 13:13:49 -05:00
|
|
|
|
2017-12-16 17:42:55 -05:00
|
|
|
{
|
2015-02-11 13:13:49 -05:00
|
|
|
describe('statistic', () => {
|
|
|
|
it('should calculate the mean', () => {
|
|
|
|
expect(Statistic.calculateMean([])).toBeNaN();
|
2015-05-27 17:57:54 -04:00
|
|
|
expect(Statistic.calculateMean([1, 2, 3])).toBe(2.0);
|
2015-02-11 13:13:49 -05:00
|
|
|
});
|
|
|
|
|
|
|
|
it('should calculate the standard deviation', () => {
|
|
|
|
expect(Statistic.calculateStandardDeviation([], NaN)).toBeNaN();
|
|
|
|
expect(Statistic.calculateStandardDeviation([1], 1)).toBe(0.0);
|
|
|
|
expect(Statistic.calculateStandardDeviation([2, 4, 4, 4, 5, 5, 7, 9], 5)).toBe(2.0);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should calculate the coefficient of variation', () => {
|
|
|
|
expect(Statistic.calculateCoefficientOfVariation([], NaN)).toBeNaN();
|
|
|
|
expect(Statistic.calculateCoefficientOfVariation([1], 1)).toBe(0.0);
|
|
|
|
expect(Statistic.calculateCoefficientOfVariation([2, 4, 4, 4, 5, 5, 7, 9], 5)).toBe(40.0);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should calculate the regression slope', () => {
|
|
|
|
expect(Statistic.calculateRegressionSlope([], NaN, [], NaN)).toBeNaN();
|
|
|
|
expect(Statistic.calculateRegressionSlope([1], 1, [2], 2)).toBeNaN();
|
2015-05-27 17:57:54 -04:00
|
|
|
expect(Statistic.calculateRegressionSlope([1, 2], 1.5, [2, 4], 3)).toBe(2.0);
|
2015-02-11 13:13:49 -05:00
|
|
|
});
|
|
|
|
});
|
2016-04-28 20:50:03 -04:00
|
|
|
}
|