UNPKG

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
"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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"}