metaapi.cloud-sdk
Version:
SDK for MetaApi, a professional cloud forex API which includes MetaTrader REST API and MetaTrader websocket API. Supports both MetaTrader 5 (MT5) and MetaTrader 4 (MT4). CopyFactory copy trading API included. (https://metaapi.cloud)
253 lines (252 loc) • 32.1 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
Object.defineProperty(exports, "default", {
enumerable: true,
get: function() {
return Reservoir;
}
});
let Reservoir = class Reservoir {
checkStatisticsOnRestore(statistics) {
if (statistics.count === 0) {
statistics = {
count: 0,
sum: 0,
max: undefined,
min: undefined,
average: undefined,
sumOfSquares: 0,
msdev: undefined,
stddev: undefined
};
} else if (statistics.count < 2) {
statistics.msdev = undefined;
statistics.stddev = undefined;
}
return statistics;
}
/**
* Add element to Reservoir
* @param {Number} data to add
*/ pushMeasurement(data) {
if (isFinite(data)) {
this._updateQueue();
this._updateIntermediaryRecord(data);
this._updateStatisticsOnAdd(data);
}
}
/**
* return Reservoir statistics
* @return {Object} Reservoir statistics
*/ getStatistics() {
this._updateQueue();
return this.statistics;
}
toPlainObject() {
this._updateQueue(true);
return {
array: this.array,
size: this.size,
_interval: this._interval,
_queueEndTime: this._queueEndTime,
_fisrtQueueIndex: this._fisrtQueueIndex,
_intermediaryRecord: this._intermediaryRecord,
statistics: this.statistics
};
}
_updateQueue() {
let intervalsCount = this._takeTimeIntervalsCount();
let emptyElementsCount = this._takeEmptyElementsAddCount();
if (emptyElementsCount > 0) {
this._addRecord(emptyElementsCount);
this._queueEndTime += intervalsCount * this._interval;
}
}
_takeEmptyElementsAddCount() {
let emptyElementsCount = this._takeTimeIntervalsCount();
if (emptyElementsCount > this.size) {
emptyElementsCount = this.size;
}
return emptyElementsCount;
}
_takeTimeIntervalsCount() {
let timeNow = Date.now();
let timeDiff = timeNow - this._queueEndTime;
let timeIntervalsCount = Math.floor(timeDiff / this._interval);
return timeIntervalsCount;
}
_updateRunningStatisticsOnRemove(removeCount) {
let removeElementIndex = this._fisrtQueueIndex + 1;
for(let i = 0; i < removeCount; i++){
if (removeElementIndex >= this.size) {
removeElementIndex = 0;
}
this._updateStatisticsOnRemove(this.array[removeElementIndex], removeElementIndex);
this.array[removeElementIndex] = {
count: 0,
sum: 0,
max: undefined,
min: undefined,
average: 0,
sumOfSquares: 0
};
removeElementIndex++;
}
removeElementIndex--;
if (removeElementIndex < 0) {
removeElementIndex = this.size - 1;
}
return removeElementIndex;
}
_updateStatisticsOnRemove(removeElement, removeElementIndex) {
if (removeElement !== undefined && removeElement !== null) {
this.statistics.count -= removeElement.count;
this.statistics.sumOfSquares -= removeElement.sumOfSquares;
this.statistics.sum -= removeElement.sum;
this._updateStatisticsMinAndMaxOnRemove(removeElement, removeElementIndex);
if (this.statistics.count > 0) {
this.statistics.average = this.statistics.sum / this.statistics.count;
if (this.statistics.count > 1) {
let difOfSums = this._calculateDifferenceOfSums(this.statistics.sumOfSquares, this.statistics.sum, this.statistics.count);
this.statistics.msdev = parseFloat(Math.sqrt(difOfSums / this.statistics.count));
this.statistics.stddev = parseFloat(Math.sqrt(difOfSums / (this.statistics.count - 1)));
} else {
this.statistics.stddev = undefined;
this.statistics.msdev = undefined;
}
} else {
this.statistics.average = undefined;
this.statistics.stddev = undefined;
this.statistics.msdev = undefined;
}
}
}
_updateStatisticsMinAndMaxOnRemove(removeElement, removeElementIndex) {
if (removeElement.max !== undefined && removeElement.max === this.statistics.max) {
this.statistics.max = this._findMax(removeElementIndex);
}
if (removeElement.min !== undefined && removeElement.min === this.statistics.min) {
this.statistics.min = this._findMin(removeElementIndex);
}
}
_updateStatisticsOnAdd(el) {
if (el !== undefined && el !== null) {
this.statistics.count += 1;
this.statistics.sum += el;
this._updateStatisticsMinAndMaxOnAdd(el);
this.statistics.sumOfSquares += Math.pow(el, 2);
if (this.statistics.count > 0) {
this.statistics.average = this.statistics.sum / this.statistics.count;
let difOfSums = this._calculateDifferenceOfSums(this.statistics.sumOfSquares, this.statistics.sum, this.statistics.count);
if (this.statistics.count > 1) {
this.statistics.msdev = parseFloat(Math.sqrt(difOfSums / this.statistics.count));
this.statistics.stddev = parseFloat(Math.sqrt(difOfSums / (this.statistics.count - 1)));
} else {
this.statistics.msdev = undefined;
this.statistics.stddev = undefined;
}
}
}
}
_updateStatisticsMinAndMaxOnAdd(el) {
if (this.statistics.max < el || this.statistics.max === undefined || this.statistics.max === null) {
this.statistics.max = el;
}
if (this.statistics.min > el || this.statistics.min === undefined || this.statistics.min === null) {
this.statistics.min = el;
}
}
_addRecord(emptyElementsCount) {
if (this._intermediaryRecord !== undefined) {
this.array[this._fisrtQueueIndex] = this._intermediaryRecord;
this._intermediaryRecord = undefined;
}
let curIndexInArray = this._updateRunningStatisticsOnRemove(emptyElementsCount);
this._fisrtQueueIndex = curIndexInArray;
}
_calculateDifferenceOfSums(sum1, sum2, count) {
let dif = sum1 - Math.pow(sum2, 2) / count;
return dif;
}
_updateIntermediaryRecord(el) {
if (this._intermediaryRecord === undefined) {
this._intermediaryRecord = {
count: 1,
sum: el,
max: el,
min: el,
average: el,
sumOfSquares: Math.pow(el, 2)
};
} else {
if (this._intermediaryRecord.max < el) {
this._intermediaryRecord.max = el;
}
if (this._intermediaryRecord.min > el) {
this._intermediaryRecord.min = el;
}
this._intermediaryRecord.count += 1;
this._intermediaryRecord.sum += el;
this._intermediaryRecord.sumOfSquares += Math.pow(el, 2);
}
}
_findMin(index) {
let min = Infinity;
this.array.forEach((el, i)=>{
if (el !== null && el !== undefined && el.min !== undefined && el.min < min && i !== index) {
min = el.min;
}
});
if (min === Infinity) {
return this._intermediaryRecord !== undefined ? this._intermediaryRecord.min : undefined;
}
return min;
}
_findMax(index) {
let max = -Infinity;
this.array.forEach((el, i)=>{
if (el !== null && el !== undefined && el.max !== undefined && el.max > max && i !== index) {
max = el.max;
}
});
if (max === -Infinity) {
return this._intermediaryRecord !== undefined ? this._intermediaryRecord.max : undefined;
}
return max;
}
/**
* Constructs Reservoir
* @param {number} size Reservoir size
* @param {number} observationIntervalInMS Reservoir observation Interval In ms
*/ constructor(size, observationIntervalInMS, object){
if (!object) {
this.array = [];
this.size = size;
this._interval = observationIntervalInMS / size;
this._queueEndTime = Date.now();
this._fisrtQueueIndex = 0;
this._intermediaryRecord = undefined;
this.statistics = {
count: 0,
sum: 0,
max: undefined,
min: undefined,
average: 0,
sumOfSquares: 0,
msdev: 0,
stddev: 0
};
} else {
this.array = object.array;
this.size = object.size;
this._interval = object._interval;
this._queueEndTime = object._queueEndTime;
this._fisrtQueueIndex = object._fisrtQueueIndex;
this._intermediaryRecord = object._intermediaryRecord;
this.statistics = this.checkStatisticsOnRestore(object.statistics);
}
}
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["<anon>"],"sourcesContent":["'use strict';\n\n/**\n * FIFO-like reservoir of a fixed size capable\n * calculating running sums, min/max, average, msdev and stddev\n * msdev and stddev calculation by Naive algorithm\n * (Mean square deviation) msdev = sqrt((∑{i = from 1 to n}(Xi)^2 -(∑{i = from 1 to n}Xi)^2 / N) / N)\n * (Standard deviation) stddev = sqrt((∑{i = from 1 to n}(Xi)^2 -(∑{i = from 1 to n}Xi)^2 / N) / N - 1)\n * link: https://goo.gl/MAEGP2\n */\nexport default class Reservoir {\n\n  /**\n   * Constructs Reservoir\n   * @param {number} size Reservoir size\n   * @param {number} observationIntervalInMS Reservoir observation Interval In ms\n   */\n  constructor(size, observationIntervalInMS, object) {\n    if (!object) {\n      this.array = [];\n      this.size = size;\n      this._interval = (observationIntervalInMS / size);\n      this._queueEndTime = Date.now();\n      this._fisrtQueueIndex = 0;\n      this._intermediaryRecord = undefined;\n      this.statistics = {\n        count: 0,\n        sum: 0,\n        max: undefined,\n        min: undefined,\n        average: 0,\n        sumOfSquares: 0,\n        msdev: 0,\n        stddev: 0\n      };\n    } else {\n      this.array = object.array;\n      this.size = object.size;\n      this._interval = object._interval;\n      this._queueEndTime = object._queueEndTime;\n      this._fisrtQueueIndex = object._fisrtQueueIndex;\n      this._intermediaryRecord = object._intermediaryRecord;\n      this.statistics = this.checkStatisticsOnRestore(object.statistics);\n    }\n  }\n\n  checkStatisticsOnRestore(statistics) {\n    if (statistics.count === 0) {\n      statistics = {\n        count: 0,\n        sum: 0,\n        max: undefined,\n        min: undefined,\n        average: undefined,\n        sumOfSquares: 0,\n        msdev: undefined,\n        stddev: undefined\n      };\n    } else if (statistics.count < 2) {\n      statistics.msdev = undefined;\n      statistics.stddev = undefined;\n    }\n    return statistics;\n  }\n\n  /**\n   * Add element to Reservoir\n   * @param {Number} data to add\n   */\n  pushMeasurement(data) {\n    if (isFinite(data)) {\n      this._updateQueue();\n      this._updateIntermediaryRecord(data);\n      this._updateStatisticsOnAdd(data);\n    }\n  }\n\n  /**\n   * return Reservoir statistics\n   * @return {Object} Reservoir statistics\n   */\n  getStatistics() {\n    this._updateQueue();\n    return this.statistics;\n  }\n\n  toPlainObject() {\n    this._updateQueue(true);\n    return {\n      array: this.array,\n      size: this.size,\n      _interval: this._interval,\n      _queueEndTime: this._queueEndTime,\n      _fisrtQueueIndex: this._fisrtQueueIndex,\n      _intermediaryRecord: this._intermediaryRecord,\n      statistics: this.statistics\n    };\n  }\n\n  _updateQueue() {\n    let intervalsCount = this._takeTimeIntervalsCount();\n    let emptyElementsCount = this._takeEmptyElementsAddCount();\n    if (emptyElementsCount > 0) {\n      this._addRecord(emptyElementsCount);\n      this._queueEndTime += intervalsCount * this._interval;\n    }\n  }\n\n  _takeEmptyElementsAddCount() {\n    let emptyElementsCount = this._takeTimeIntervalsCount();\n    if (emptyElementsCount > this.size) {\n      emptyElementsCount = this.size;\n    }\n    return emptyElementsCount;\n  }\n\n  _takeTimeIntervalsCount() {\n    let timeNow = Date.now();\n    let timeDiff = timeNow - this._queueEndTime;\n    let timeIntervalsCount = Math.floor(timeDiff / this._interval);\n    return timeIntervalsCount;\n  }\n\n  _updateRunningStatisticsOnRemove(removeCount) {\n    let removeElementIndex = this._fisrtQueueIndex + 1;\n    for (let i = 0; i < removeCount; i++) {\n      if (removeElementIndex >= this.size) {\n        removeElementIndex = 0;\n      }\n\n      this._updateStatisticsOnRemove(this.array[removeElementIndex], removeElementIndex);\n      this.array[removeElementIndex] = {\n        count: 0,\n        sum: 0,\n        max: undefined,\n        min: undefined,\n        average: 0,\n        sumOfSquares: 0\n      };\n      removeElementIndex++;\n    }\n    removeElementIndex--;\n    if (removeElementIndex < 0) {\n      removeElementIndex = this.size - 1;\n    }\n    return removeElementIndex;\n  }\n\n  _updateStatisticsOnRemove(removeElement, removeElementIndex) {\n    if (removeElement !== undefined && removeElement !== null) {\n      this.statistics.count -= removeElement.count;\n      this.statistics.sumOfSquares -= removeElement.sumOfSquares;\n      this.statistics.sum -= removeElement.sum;\n      this._updateStatisticsMinAndMaxOnRemove(removeElement, removeElementIndex);\n      if (this.statistics.count > 0) {\n        this.statistics.average = this.statistics.sum / this.statistics.count;\n        if (this.statistics.count > 1) {\n          let difOfSums = this._calculateDifferenceOfSums(this.statistics.sumOfSquares,\n            this.statistics.sum, this.statistics.count);\n          this.statistics.msdev = parseFloat(Math.sqrt(difOfSums / this.statistics.count));\n          this.statistics.stddev = parseFloat(Math.sqrt(difOfSums / (this.statistics.count - 1)));\n        } else {\n          this.statistics.stddev = undefined;\n          this.statistics.msdev = undefined;\n        }\n      } else {\n        this.statistics.average = undefined;\n        this.statistics.stddev = undefined;\n        this.statistics.msdev = undefined;\n      }\n    }\n  }\n\n  _updateStatisticsMinAndMaxOnRemove(removeElement, removeElementIndex) {\n    if (removeElement.max !== undefined && removeElement.max === this.statistics.max) {\n      this.statistics.max = this._findMax(removeElementIndex);\n    }\n\n    if (removeElement.min !== undefined && removeElement.min === this.statistics.min) {\n      this.statistics.min = this._findMin(removeElementIndex);\n    }\n  }\n\n  _updateStatisticsOnAdd(el) {\n    if (el !== undefined && el !== null) {\n      this.statistics.count += 1;\n      this.statistics.sum += el;\n      this._updateStatisticsMinAndMaxOnAdd(el);\n      this.statistics.sumOfSquares += Math.pow(el, 2);\n      if (this.statistics.count > 0) {\n        this.statistics.average = this.statistics.sum / this.statistics.count;\n        let difOfSums = this._calculateDifferenceOfSums(this.statistics.sumOfSquares,\n          this.statistics.sum, this.statistics.count);\n        if (this.statistics.count > 1) {\n          this.statistics.msdev = parseFloat(Math.sqrt(difOfSums / this.statistics.count));\n          this.statistics.stddev = parseFloat(Math.sqrt(difOfSums / (this.statistics.count - 1)));\n        } else {\n          this.statistics.msdev = undefined;\n          this.statistics.stddev = undefined;\n        }\n      }\n    }\n  }\n\n  _updateStatisticsMinAndMaxOnAdd(el) {\n    if (this.statistics.max < el || this.statistics.max === undefined || this.statistics.max === null) {\n      this.statistics.max = el;\n    }\n    if (this.statistics.min > el || this.statistics.min === undefined || this.statistics.min === null) {\n      this.statistics.min = el;\n    }\n  }\n\n  _addRecord(emptyElementsCount) {\n    if (this._intermediaryRecord !== undefined) {\n      this.array[this._fisrtQueueIndex] = this._intermediaryRecord;\n      this._intermediaryRecord = undefined;\n    }\n    let curIndexInArray = this._updateRunningStatisticsOnRemove(emptyElementsCount);\n    this._fisrtQueueIndex = curIndexInArray;\n  }\n\n  _calculateDifferenceOfSums(sum1, sum2, count) {\n    let dif = sum1 - Math.pow(sum2, 2) / count;\n    return dif;\n  }\n\n  _updateIntermediaryRecord(el) {\n    if (this._intermediaryRecord === undefined) {\n      this._intermediaryRecord = {\n        count: 1,\n        sum: el,\n        max: el,\n        min: el,\n        average: el,\n        sumOfSquares: Math.pow(el, 2)\n      };\n    } else {\n      if (this._intermediaryRecord.max < el) {\n        this._intermediaryRecord.max = el;\n      }\n      if (this._intermediaryRecord.min > el) {\n        this._intermediaryRecord.min = el;\n      }\n      this._intermediaryRecord.count += 1;\n      this._intermediaryRecord.sum += el;\n      this._intermediaryRecord.sumOfSquares += Math.pow(el, 2);\n    }\n  }\n\n  _findMin(index) {\n    let min = Infinity;\n    this.array.forEach((el, i) => {\n      if (el !== null && el !== undefined && el.min !== undefined && el.min < min && i !== index) {\n        min = el.min;\n      }\n    });\n    if (min === Infinity) {\n      return (this._intermediaryRecord !== undefined) ? this._intermediaryRecord.min : undefined;\n    }\n    return min;\n  }\n\n  _findMax(index) {\n    let max = -Infinity;\n\n    this.array.forEach((el, i) => {\n      if (el !== null && el !== undefined && el.max !== undefined && el.max > max && i !== index) {\n        max = el.max;\n      }\n    });\n    if (max === -Infinity) {\n      return (this._intermediaryRecord !== undefined) ? this._intermediaryRecord.max : undefined;\n    }\n    return max;\n  }\n}\n"],"names":["Reservoir","checkStatisticsOnRestore","statistics","count","sum","max","undefined","min","average","sumOfSquares","msdev","stddev","pushMeasurement","data","isFinite","_updateQueue","_updateIntermediaryRecord","_updateStatisticsOnAdd","getStatistics","toPlainObject","array","size","_interval","_queueEndTime","_fisrtQueueIndex","_intermediaryRecord","intervalsCount","_takeTimeIntervalsCount","emptyElementsCount","_takeEmptyElementsAddCount","_addRecord","timeNow","Date","now","timeDiff","timeIntervalsCount","Math","floor","_updateRunningStatisticsOnRemove","removeCount","removeElementIndex","i","_updateStatisticsOnRemove","removeElement","_updateStatisticsMinAndMaxOnRemove","difOfSums","_calculateDifferenceOfSums","parseFloat","sqrt","_findMax","_findMin","el","_updateStatisticsMinAndMaxOnAdd","pow","curIndexInArray","sum1","sum2","dif","index","Infinity","forEach","constructor","observationIntervalInMS","object"],"mappings":"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"}