dygraphs
Version:
dygraphs is a fast, flexible open source JavaScript charting library.
102 lines (96 loc) • 12.4 kB
JavaScript
/**
* @license
* Copyright 2013 David Eberlein (david.eberlein@ch.sauter-bc.com)
* MIT-licenced: https://opensource.org/licenses/MIT
*/
/**
* @fileoverview DataHandler implementation for the errorBars option.
* @author David Eberlein (david.eberlein@ch.sauter-bc.com)
*/
/*global Dygraph:false */
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _bars = _interopRequireDefault(require("./bars"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
/**
* @constructor
* @extends BarsHandler
*/
var ErrorBarsHandler = function ErrorBarsHandler() {};
ErrorBarsHandler.prototype = new _bars["default"]();
/** @inheritDoc */
ErrorBarsHandler.prototype.extractSeries = function (rawData, i, options) {
// TODO(danvk): pre-allocate series here.
var series = [];
var x, y, variance, point;
var seriesLabel = options.get("labels")[i];
var logScale = options.getForSeries("logscale", seriesLabel);
var sigma = options.getForSeries("sigma", seriesLabel);
for (var j = 0; j < rawData.length; j++) {
x = rawData[j][0];
point = rawData[j][i];
if (logScale && point !== null) {
// On the log scale, points less than zero do not exist.
// This will create a gap in the chart.
if (point[0] <= 0 || point[0] - sigma * point[1] <= 0) {
point = null;
}
}
// Extract to the unified data format.
if (point !== null) {
y = point[0];
if (y !== null && !isNaN(y)) {
variance = sigma * point[1];
// preserve original error value in extras for further
// filtering
series.push([x, y, [y - variance, y + variance, point[1]]]);
} else {
series.push([x, y, [y, y, y]]);
}
} else {
series.push([x, null, [null, null, null]]);
}
}
return series;
};
/** @inheritDoc */
ErrorBarsHandler.prototype.rollingAverage = function (originalData, rollPeriod, options, i) {
rollPeriod = Math.min(rollPeriod, originalData.length);
var rollingData = [];
var seriesLabel = options.get("labels")[i];
var sigma = options.getForSeries("sigma", seriesLabel);
var i, j, y, v, sum, num_ok, stddev, variance, value;
// Calculate the rolling average for the first rollPeriod - 1 points
// where there is not enough data to roll over the full number of points
for (i = 0; i < originalData.length; i++) {
sum = 0;
variance = 0;
num_ok = 0;
for (j = Math.max(0, i - rollPeriod + 1); j < i + 1; j++) {
y = originalData[j][1];
if (y === null || isNaN(y)) continue;
num_ok++;
sum += y;
variance += Math.pow(originalData[j][2][2], 2);
}
if (num_ok) {
stddev = Math.sqrt(variance) / num_ok;
value = sum / num_ok;
rollingData[i] = [originalData[i][0], value, [value - sigma * stddev, value + sigma * stddev]];
} else {
// This explicitly preserves NaNs to aid with "independent
// series".
// See testRollingAveragePreservesNaNs.
v = rollPeriod == 1 ? originalData[i][1] : null;
rollingData[i] = [originalData[i][0], v, [v, v]];
}
}
return rollingData;
};
var _default = ErrorBarsHandler;
exports["default"] = _default;
module.exports = exports.default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJFcnJvckJhcnNIYW5kbGVyIiwicHJvdG90eXBlIiwiQmFyc0hhbmRsZXIiLCJleHRyYWN0U2VyaWVzIiwicmF3RGF0YSIsImkiLCJvcHRpb25zIiwic2VyaWVzIiwieCIsInkiLCJ2YXJpYW5jZSIsInBvaW50Iiwic2VyaWVzTGFiZWwiLCJnZXQiLCJsb2dTY2FsZSIsImdldEZvclNlcmllcyIsInNpZ21hIiwiaiIsImxlbmd0aCIsImlzTmFOIiwicHVzaCIsInJvbGxpbmdBdmVyYWdlIiwib3JpZ2luYWxEYXRhIiwicm9sbFBlcmlvZCIsIk1hdGgiLCJtaW4iLCJyb2xsaW5nRGF0YSIsInYiLCJzdW0iLCJudW1fb2siLCJzdGRkZXYiLCJ2YWx1ZSIsIm1heCIsInBvdyIsInNxcnQiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvZGF0YWhhbmRsZXIvYmFycy1lcnJvci5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgMjAxMyBEYXZpZCBFYmVybGVpbiAoZGF2aWQuZWJlcmxlaW5AY2guc2F1dGVyLWJjLmNvbSlcbiAqIE1JVC1saWNlbmNlZDogaHR0cHM6Ly9vcGVuc291cmNlLm9yZy9saWNlbnNlcy9NSVRcbiAqL1xuXG4vKipcbiAqIEBmaWxlb3ZlcnZpZXcgRGF0YUhhbmRsZXIgaW1wbGVtZW50YXRpb24gZm9yIHRoZSBlcnJvckJhcnMgb3B0aW9uLlxuICogQGF1dGhvciBEYXZpZCBFYmVybGVpbiAoZGF2aWQuZWJlcmxlaW5AY2guc2F1dGVyLWJjLmNvbSlcbiAqL1xuXG4vKmdsb2JhbCBEeWdyYXBoOmZhbHNlICovXG5cInVzZSBzdHJpY3RcIjtcblxuaW1wb3J0IEJhcnNIYW5kbGVyIGZyb20gJy4vYmFycyc7XG5cbi8qKlxuICogQGNvbnN0cnVjdG9yXG4gKiBAZXh0ZW5kcyBCYXJzSGFuZGxlclxuICovXG52YXIgRXJyb3JCYXJzSGFuZGxlciA9IGZ1bmN0aW9uKCkge1xufTtcblxuRXJyb3JCYXJzSGFuZGxlci5wcm90b3R5cGUgPSBuZXcgQmFyc0hhbmRsZXIoKTtcblxuLyoqIEBpbmhlcml0RG9jICovXG5FcnJvckJhcnNIYW5kbGVyLnByb3RvdHlwZS5leHRyYWN0U2VyaWVzID0gZnVuY3Rpb24ocmF3RGF0YSwgaSwgb3B0aW9ucykge1xuICAvLyBUT0RPKGRhbnZrKTogcHJlLWFsbG9jYXRlIHNlcmllcyBoZXJlLlxuICB2YXIgc2VyaWVzID0gW107XG4gIHZhciB4LCB5LCB2YXJpYW5jZSwgcG9pbnQ7XG4gIGNvbnN0IHNlcmllc0xhYmVsID0gb3B0aW9ucy5nZXQoXCJsYWJlbHNcIilbaV07XG4gIGNvbnN0IGxvZ1NjYWxlID0gb3B0aW9ucy5nZXRGb3JTZXJpZXMoXCJsb2dzY2FsZVwiLCBzZXJpZXNMYWJlbCk7XG4gIGNvbnN0IHNpZ21hID0gb3B0aW9ucy5nZXRGb3JTZXJpZXMoXCJzaWdtYVwiLCBzZXJpZXNMYWJlbCk7XG4gIGZvciAoIHZhciBqID0gMDsgaiA8IHJhd0RhdGEubGVuZ3RoOyBqKyspIHtcbiAgICB4ID0gcmF3RGF0YVtqXVswXTtcbiAgICBwb2ludCA9IHJhd0RhdGFbal1baV07XG4gICAgaWYgKGxvZ1NjYWxlICYmIHBvaW50ICE9PSBudWxsKSB7XG4gICAgICAvLyBPbiB0aGUgbG9nIHNjYWxlLCBwb2ludHMgbGVzcyB0aGFuIHplcm8gZG8gbm90IGV4aXN0LlxuICAgICAgLy8gVGhpcyB3aWxsIGNyZWF0ZSBhIGdhcCBpbiB0aGUgY2hhcnQuXG4gICAgICBpZiAocG9pbnRbMF0gPD0gMCB8fCBwb2ludFswXSAtIHNpZ21hICogcG9pbnRbMV0gPD0gMCkge1xuICAgICAgICBwb2ludCA9IG51bGw7XG4gICAgICB9XG4gICAgfVxuICAgIC8vIEV4dHJhY3QgdG8gdGhlIHVuaWZpZWQgZGF0YSBmb3JtYXQuXG4gICAgaWYgKHBvaW50ICE9PSBudWxsKSB7XG4gICAgICB5ID0gcG9pbnRbMF07XG4gICAgICBpZiAoeSAhPT0gbnVsbCAmJiAhaXNOYU4oeSkpIHtcbiAgICAgICAgdmFyaWFuY2UgPSBzaWdtYSAqIHBvaW50WzFdO1xuICAgICAgICAvLyBwcmVzZXJ2ZSBvcmlnaW5hbCBlcnJvciB2YWx1ZSBpbiBleHRyYXMgZm9yIGZ1cnRoZXJcbiAgICAgICAgLy8gZmlsdGVyaW5nXG4gICAgICAgIHNlcmllcy5wdXNoKFsgeCwgeSwgWyB5IC0gdmFyaWFuY2UsIHkgKyB2YXJpYW5jZSwgcG9pbnRbMV0gXSBdKTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHNlcmllcy5wdXNoKFsgeCwgeSwgWyB5LCB5LCB5IF0gXSk7XG4gICAgICB9XG4gICAgfSBlbHNlIHtcbiAgICAgIHNlcmllcy5wdXNoKFsgeCwgbnVsbCwgWyBudWxsLCBudWxsLCBudWxsIF0gXSk7XG4gICAgfVxuICB9XG4gIHJldHVybiBzZXJpZXM7XG59O1xuXG4vKiogQGluaGVyaXREb2MgKi9cbkVycm9yQmFyc0hhbmRsZXIucHJvdG90eXBlLnJvbGxpbmdBdmVyYWdlID1cbiAgICBmdW5jdGlvbihvcmlnaW5hbERhdGEsIHJvbGxQZXJpb2QsIG9wdGlvbnMsIGkpIHtcbiAgcm9sbFBlcmlvZCA9IE1hdGgubWluKHJvbGxQZXJpb2QsIG9yaWdpbmFsRGF0YS5sZW5ndGgpO1xuICB2YXIgcm9sbGluZ0RhdGEgPSBbXTtcbiAgY29uc3Qgc2VyaWVzTGFiZWwgPSBvcHRpb25zLmdldChcImxhYmVsc1wiKVtpXTtcbiAgY29uc3Qgc2lnbWEgPSBvcHRpb25zLmdldEZvclNlcmllcyhcInNpZ21hXCIsIHNlcmllc0xhYmVsKTtcblxuICB2YXIgaSwgaiwgeSwgdiwgc3VtLCBudW1fb2ssIHN0ZGRldiwgdmFyaWFuY2UsIHZhbHVlO1xuXG4gIC8vIENhbGN1bGF0ZSB0aGUgcm9sbGluZyBhdmVyYWdlIGZvciB0aGUgZmlyc3Qgcm9sbFBlcmlvZCAtIDEgcG9pbnRzXG4gIC8vIHdoZXJlIHRoZXJlIGlzIG5vdCBlbm91Z2ggZGF0YSB0byByb2xsIG92ZXIgdGhlIGZ1bGwgbnVtYmVyIG9mIHBvaW50c1xuICBmb3IgKGkgPSAwOyBpIDwgb3JpZ2luYWxEYXRhLmxlbmd0aDsgaSsrKSB7XG4gICAgc3VtID0gMDtcbiAgICB2YXJpYW5jZSA9IDA7XG4gICAgbnVtX29rID0gMDtcbiAgICBmb3IgKGogPSBNYXRoLm1heCgwLCBpIC0gcm9sbFBlcmlvZCArIDEpOyBqIDwgaSArIDE7IGorKykge1xuICAgICAgeSA9IG9yaWdpbmFsRGF0YVtqXVsxXTtcbiAgICAgIGlmICh5ID09PSBudWxsIHx8IGlzTmFOKHkpKVxuICAgICAgICBjb250aW51ZTtcbiAgICAgIG51bV9vaysrO1xuICAgICAgc3VtICs9IHk7XG4gICAgICB2YXJpYW5jZSArPSBNYXRoLnBvdyhvcmlnaW5hbERhdGFbal1bMl1bMl0sIDIpO1xuICAgIH1cbiAgICBpZiAobnVtX29rKSB7XG4gICAgICBzdGRkZXYgPSBNYXRoLnNxcnQodmFyaWFuY2UpIC8gbnVtX29rO1xuICAgICAgdmFsdWUgPSBzdW0gLyBudW1fb2s7XG4gICAgICByb2xsaW5nRGF0YVtpXSA9IFsgb3JpZ2luYWxEYXRhW2ldWzBdLCB2YWx1ZSxcbiAgICAgICAgICBbdmFsdWUgLSBzaWdtYSAqIHN0ZGRldiwgdmFsdWUgKyBzaWdtYSAqIHN0ZGRldl0gXTtcbiAgICB9IGVsc2Uge1xuICAgICAgLy8gVGhpcyBleHBsaWNpdGx5IHByZXNlcnZlcyBOYU5zIHRvIGFpZCB3aXRoIFwiaW5kZXBlbmRlbnRcbiAgICAgIC8vIHNlcmllc1wiLlxuICAgICAgLy8gU2VlIHRlc3RSb2xsaW5nQXZlcmFnZVByZXNlcnZlc05hTnMuXG4gICAgICB2ID0gKHJvbGxQZXJpb2QgPT0gMSkgPyBvcmlnaW5hbERhdGFbaV1bMV0gOiBudWxsO1xuICAgICAgcm9sbGluZ0RhdGFbaV0gPSBbIG9yaWdpbmFsRGF0YVtpXVswXSwgdiwgWyB2LCB2IF0gXTtcbiAgICB9XG4gIH1cblxuICByZXR1cm4gcm9sbGluZ0RhdGE7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBFcnJvckJhcnNIYW5kbGVyO1xuIl0sIm1h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