@ch20026103/anysis 0.0.3-alpha → 0.0.6-alpha

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (72) hide show
  1. package/dist/cjs/analyze/Month/index.d.ts +1 -1
  2. package/dist/cjs/analyze/Month/index.test.d.ts +1 -0
  3. package/dist/cjs/analyze/Month/index.test.js +22 -0
  4. package/dist/cjs/analyze/Regression/simpleRegressoinModel.d.ts +1 -1
  5. package/dist/cjs/analyze/Slope/slope.test.js +6 -0
  6. package/dist/cjs/analyze/TimeSeries/R/index.d.ts +1 -1
  7. package/dist/cjs/index.d.ts +3 -0
  8. package/dist/cjs/index.js +7 -1
  9. package/dist/cjs/stockSkills/boll.d.ts +58 -0
  10. package/dist/cjs/stockSkills/boll.js +101 -0
  11. package/dist/cjs/stockSkills/boll.test.d.ts +1 -0
  12. package/dist/cjs/stockSkills/boll.test.js +36 -0
  13. package/dist/cjs/stockSkills/ema.d.ts +9 -0
  14. package/dist/cjs/stockSkills/ema.js +41 -0
  15. package/dist/cjs/stockSkills/ema.test.d.ts +1 -0
  16. package/dist/cjs/stockSkills/ema.test.js +11 -0
  17. package/dist/cjs/stockSkills/gold.d.ts +4 -4
  18. package/dist/cjs/stockSkills/kd.d.ts +41 -14
  19. package/dist/cjs/stockSkills/kd.js +60 -6
  20. package/dist/cjs/stockSkills/kd.test.js +34 -2
  21. package/dist/cjs/stockSkills/ma.d.ts +49 -30
  22. package/dist/cjs/stockSkills/ma.js +37 -44
  23. package/dist/cjs/stockSkills/ma.test.js +15 -20
  24. package/dist/cjs/stockSkills/macd.d.ts +62 -16
  25. package/dist/cjs/stockSkills/macd.js +92 -5
  26. package/dist/cjs/stockSkills/macd.test.js +26 -0
  27. package/dist/cjs/stockSkills/obv.d.ts +44 -0
  28. package/dist/cjs/stockSkills/obv.js +89 -0
  29. package/dist/cjs/stockSkills/obv.test.d.ts +1 -0
  30. package/dist/cjs/stockSkills/obv.test.js +20 -0
  31. package/dist/cjs/stockSkills/rsi.d.ts +8 -8
  32. package/dist/cjs/stockSkills/rsi.js +2 -2
  33. package/dist/cjs/stockSkills/utils/getWeekLine.d.ts +2 -2
  34. package/dist/cjs/stockSkills/williams.d.ts +8 -8
  35. package/dist/cjs/stockSkills/williams.js +2 -2
  36. package/dist/esm/analyze/Month/index.d.ts +1 -1
  37. package/dist/esm/analyze/Month/index.test.d.ts +1 -0
  38. package/dist/esm/analyze/Month/index.test.js +20 -0
  39. package/dist/esm/analyze/Regression/simpleRegressoinModel.d.ts +1 -1
  40. package/dist/esm/analyze/Slope/slope.test.js +6 -0
  41. package/dist/esm/analyze/TimeSeries/R/index.d.ts +1 -1
  42. package/dist/esm/index.d.ts +3 -0
  43. package/dist/esm/index.js +3 -0
  44. package/dist/esm/stockSkills/boll.d.ts +58 -0
  45. package/dist/esm/stockSkills/boll.js +99 -0
  46. package/dist/esm/stockSkills/boll.test.d.ts +1 -0
  47. package/dist/esm/stockSkills/boll.test.js +34 -0
  48. package/dist/esm/stockSkills/ema.d.ts +9 -0
  49. package/dist/esm/stockSkills/ema.js +39 -0
  50. package/dist/esm/stockSkills/ema.test.d.ts +1 -0
  51. package/dist/esm/stockSkills/ema.test.js +9 -0
  52. package/dist/esm/stockSkills/gold.d.ts +4 -4
  53. package/dist/esm/stockSkills/kd.d.ts +41 -14
  54. package/dist/esm/stockSkills/kd.js +60 -6
  55. package/dist/esm/stockSkills/kd.test.js +34 -2
  56. package/dist/esm/stockSkills/ma.d.ts +49 -30
  57. package/dist/esm/stockSkills/ma.js +37 -44
  58. package/dist/esm/stockSkills/ma.test.js +15 -20
  59. package/dist/esm/stockSkills/macd.d.ts +62 -16
  60. package/dist/esm/stockSkills/macd.js +92 -5
  61. package/dist/esm/stockSkills/macd.test.js +26 -0
  62. package/dist/esm/stockSkills/obv.d.ts +44 -0
  63. package/dist/esm/stockSkills/obv.js +87 -0
  64. package/dist/esm/stockSkills/obv.test.d.ts +1 -0
  65. package/dist/esm/stockSkills/obv.test.js +18 -0
  66. package/dist/esm/stockSkills/rsi.d.ts +8 -8
  67. package/dist/esm/stockSkills/rsi.js +2 -2
  68. package/dist/esm/stockSkills/utils/getWeekLine.d.ts +2 -2
  69. package/dist/esm/stockSkills/williams.d.ts +8 -8
  70. package/dist/esm/stockSkills/williams.js +2 -2
  71. package/dist/umd/index.js +458 -96
  72. package/package.json +15 -17
@@ -0,0 +1,89 @@
1
+ "use strict";
2
+ var __assign = (this && this.__assign) || function () {
3
+ __assign = Object.assign || function(t) {
4
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
5
+ s = arguments[i];
6
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
7
+ t[p] = s[p];
8
+ }
9
+ return t;
10
+ };
11
+ return __assign.apply(this, arguments);
12
+ };
13
+ var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
14
+ if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
15
+ if (ar || !(i in from)) {
16
+ if (!ar) ar = Array.prototype.slice.call(from, 0, i);
17
+ ar[i] = from[i];
18
+ }
19
+ }
20
+ return to.concat(ar || Array.prototype.slice.call(from));
21
+ };
22
+ Object.defineProperty(exports, "__esModule", { value: true });
23
+ var Obv = /** @class */ (function () {
24
+ function Obv() {
25
+ }
26
+ Object.defineProperty(Obv.prototype, "init", {
27
+ enumerable: false,
28
+ configurable: true,
29
+ writable: true,
30
+ value: function (data) {
31
+ return {
32
+ dataset: [data],
33
+ obv: data.v,
34
+ preClose: data.c,
35
+ };
36
+ }
37
+ });
38
+ Object.defineProperty(Obv.prototype, "next", {
39
+ enumerable: false,
40
+ configurable: true,
41
+ writable: true,
42
+ value: function (data, preList) {
43
+ var currentVolume = data.v;
44
+ var currentClose = data.c;
45
+ // obv
46
+ var obv = preList.obv;
47
+ if (currentClose > preList.preClose) {
48
+ obv += currentVolume;
49
+ }
50
+ else if (currentClose < preList.preClose) {
51
+ obv -= currentVolume;
52
+ }
53
+ return {
54
+ dataset: __spreadArray(__spreadArray([], preList.dataset, true), [data], false),
55
+ obv: obv,
56
+ preClose: currentClose,
57
+ };
58
+ }
59
+ });
60
+ Object.defineProperty(Obv.prototype, "getObv", {
61
+ enumerable: false,
62
+ configurable: true,
63
+ writable: true,
64
+ value: function (list) {
65
+ var res = [];
66
+ var obv = 0;
67
+ for (var i = 0; i < list.length; i++) {
68
+ var currentVolume = list[i].v;
69
+ var currentClose = list[i].c;
70
+ if (i > 0) {
71
+ // obv
72
+ if (currentClose > list[i - 1].c) {
73
+ obv += currentVolume;
74
+ }
75
+ else if (currentClose < list[i - 1].c) {
76
+ obv -= currentVolume;
77
+ }
78
+ }
79
+ else {
80
+ obv = currentVolume;
81
+ }
82
+ res[i] = __assign(__assign({}, list[i]), { obv: obv });
83
+ }
84
+ return res;
85
+ }
86
+ });
87
+ return Obv;
88
+ }());
89
+ exports.default = Obv;
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ var obv_1 = require("./obv");
4
+ var test_data_test_1 = require("./test_data.test");
5
+ describe("test obv methods", function () {
6
+ it("test init", function () {
7
+ var obv = new obv_1.default();
8
+ var init = obv.init(test_data_test_1.data_9904[0]);
9
+ var res = init;
10
+ for (var i = 1; i < test_data_test_1.data_9904.length; i++) {
11
+ var item = test_data_test_1.data_9904[i];
12
+ res = obv.next(item, res);
13
+ }
14
+ expect(res.obv).toEqual(504538);
15
+ });
16
+ it("test getObv()", function () {
17
+ var kd = new obv_1.default();
18
+ expect(kd.getObv(test_data_test_1.data_9904)[test_data_test_1.data_9904.length - 1].obv).toEqual(504538);
19
+ });
20
+ });
@@ -1,18 +1,18 @@
1
- declare type ListType = {
1
+ type ListType = {
2
2
  c: number;
3
3
  }[];
4
- declare type ResRsi6Type = {
4
+ type ResRsi6Type = {
5
5
  c: number;
6
- rsi6?: number;
6
+ rsi6: number | null;
7
7
  }[];
8
- declare type ResRsi12Type = {
8
+ type ResRsi12Type = {
9
9
  c: number;
10
- rsi12?: number;
10
+ rsi12: number | null;
11
11
  }[];
12
- declare type ResAllRsiType = {
12
+ type ResAllRsiType = {
13
13
  c: number;
14
- rsi6?: number;
15
- rsi12?: number;
14
+ rsi6: number | null;
15
+ rsi12: number | null;
16
16
  }[];
17
17
  interface RsiType {
18
18
  getRsi6: (list: ListType) => ResRsi6Type;
@@ -36,7 +36,7 @@ var Rsi = /** @class */ (function () {
36
36
  var res = [];
37
37
  // 前5筆
38
38
  for (var i = 0; i < 5; i++) {
39
- res[i] = __assign(__assign({}, list[i]), { rsi6: undefined });
39
+ res[i] = __assign(__assign({}, list[i]), { rsi6: null });
40
40
  }
41
41
  // 第6筆Rsi
42
42
  var beforeUpAvg = this.getStartUpAvg(list, 6);
@@ -70,7 +70,7 @@ var Rsi = /** @class */ (function () {
70
70
  var res = [];
71
71
  // 前11筆
72
72
  for (var i = 0; i < 11; i++) {
73
- res[i] = __assign(__assign({}, list[i]), { rsi12: undefined });
73
+ res[i] = __assign(__assign({}, list[i]), { rsi12: null });
74
74
  }
75
75
  // 第12筆Rsi
76
76
  var beforeUpAvg = this.getStartUpAvg(list, 12);
@@ -1,11 +1,11 @@
1
- declare type ListType = {
1
+ type ListType = {
2
2
  h: number;
3
3
  t: number;
4
4
  o: number;
5
5
  c: number;
6
6
  l: number;
7
7
  }[];
8
- export declare type ResType = {
8
+ export type ResType = {
9
9
  h: number;
10
10
  t: number;
11
11
  o: number;
@@ -1,20 +1,20 @@
1
- declare type ListType = {
1
+ type ListType = {
2
2
  h: number;
3
3
  l: number;
4
4
  c: number;
5
5
  }[];
6
- declare type ResWilliams9Type = {
6
+ type ResWilliams9Type = {
7
7
  c: number;
8
- williams9?: number;
8
+ williams9: number | null;
9
9
  }[];
10
- declare type ResWilliams18Type = {
10
+ type ResWilliams18Type = {
11
11
  c: number;
12
- williams18?: number;
12
+ williams18: number | null;
13
13
  }[];
14
- declare type ResAllWilliamsType = {
14
+ type ResAllWilliamsType = {
15
15
  c: number;
16
- williams18?: number;
17
- williams9?: number;
16
+ williams18: number | null;
17
+ williams9: number | null;
18
18
  }[];
19
19
  interface WilliamsType {
20
20
  getWilliams9: (list: ListType) => ResWilliams9Type;
@@ -36,7 +36,7 @@ var Williams = /** @class */ (function () {
36
36
  var res = [];
37
37
  for (var i = 0; i < list.length; i++) {
38
38
  if (i < 9)
39
- res[i] = __assign(__assign({}, list[i]), { williams9: undefined });
39
+ res[i] = __assign(__assign({}, list[i]), { williams9: null });
40
40
  else {
41
41
  var maxList = list.slice(i - 8, i).map(function (item) { return item["h"]; });
42
42
  var minList = list.slice(i - 8, i).map(function (item) { return item["l"]; });
@@ -58,7 +58,7 @@ var Williams = /** @class */ (function () {
58
58
  var res = [];
59
59
  for (var i = 0; i < list.length; i++) {
60
60
  if (i < 18)
61
- res[i] = __assign(__assign({}, list[i]), { williams9: undefined });
61
+ res[i] = __assign(__assign({}, list[i]), { williams18: null });
62
62
  else {
63
63
  var maxList = list.slice(i - 17, i).map(function (item) { return item["h"]; });
64
64
  var minList = list.slice(i - 17, i).map(function (item) { return item["l"]; });
@@ -1,4 +1,4 @@
1
- export declare type setStartMonthInYearType = {
1
+ export type setStartMonthInYearType = {
2
2
  January: unknown;
3
3
  February: unknown;
4
4
  March: unknown;
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,20 @@
1
+ import { setStartMonthInYear } from "./index";
2
+ describe("test setStartMonthInYear", function () {
3
+ it("test 3", function () {
4
+ var res = setStartMonthInYear(3);
5
+ expect(res).toEqual([
6
+ "March",
7
+ "April",
8
+ "May",
9
+ "June",
10
+ "July",
11
+ "August",
12
+ "September",
13
+ "October",
14
+ "November",
15
+ "December",
16
+ "January",
17
+ "February",
18
+ ]);
19
+ });
20
+ });
@@ -1,4 +1,4 @@
1
- declare type RegressionResponseType = {
1
+ type RegressionResponseType = {
2
2
  description: string;
3
3
  predictModel: (xValue: number) => number;
4
4
  explained: string;
@@ -24,4 +24,10 @@ describe("test Slope methods", function () {
24
24
  var slope = Slope(x, y);
25
25
  expect(slope).toEqual(0);
26
26
  });
27
+ it("test 1,4,6,8,10,12", function () {
28
+ var x = [1, 2, 3, 4, 5, 6];
29
+ var y = [1, 4, 6, 8, 10, 12];
30
+ var slope = Slope(x, y);
31
+ expect(slope).toEqual(2.142857142857143);
32
+ });
27
33
  });
@@ -1,6 +1,6 @@
1
1
  export declare function movingAverages(arr: number[], periods: number): number[];
2
2
  export declare function weightMovingAverages(arr: number[], periods: number[]): number[];
3
- declare type ExponentialSmoothingOptions = {
3
+ type ExponentialSmoothingOptions = {
4
4
  initialForecast: number;
5
5
  };
6
6
  export declare function exponentialSmoothing(arr: number[], alpha: number, options?: Partial<ExponentialSmoothingOptions>): number[];
@@ -7,8 +7,11 @@ export { default as Kd } from "./stockSkills/kd.js";
7
7
  export { default as Ma } from "./stockSkills/ma.js";
8
8
  export { default as Macd } from "./stockSkills/macd.js";
9
9
  export { default as Rsi } from "./stockSkills/rsi.js";
10
+ export { default as Obv } from "./stockSkills/obv.js";
11
+ export { default as Ema } from "./stockSkills/ema.js";
10
12
  export { default as dateFormat } from "./stockSkills/utils/dateFormat.js";
11
13
  export { default as getWeekLine } from "./stockSkills/utils/getWeekLine.js";
12
14
  export { default as Williams } from "./stockSkills/williams.js";
15
+ export { default as Boll } from "./stockSkills/boll.js";
13
16
  export { add } from "./test/add.js";
14
17
  export { minus } from "./test/minus.js";
package/dist/esm/index.js CHANGED
@@ -12,8 +12,11 @@ export { default as Kd } from "./stockSkills/kd.js";
12
12
  export { default as Ma } from "./stockSkills/ma.js";
13
13
  export { default as Macd } from "./stockSkills/macd.js";
14
14
  export { default as Rsi } from "./stockSkills/rsi.js";
15
+ export { default as Obv } from "./stockSkills/obv.js";
16
+ export { default as Ema } from "./stockSkills/ema.js";
15
17
  export { default as dateFormat } from "./stockSkills/utils/dateFormat.js";
16
18
  export { default as getWeekLine } from "./stockSkills/utils/getWeekLine.js";
17
19
  export { default as Williams } from "./stockSkills/williams.js";
20
+ export { default as Boll } from "./stockSkills/boll.js";
18
21
  export { add } from "./test/add.js";
19
22
  export { minus } from "./test/minus.js";
@@ -0,0 +1,58 @@
1
+ type ItemType = {
2
+ c: number;
3
+ };
4
+ type ListType = ItemType[];
5
+ type ResBoll = {
6
+ c: number;
7
+ bollMa: number | null;
8
+ bollUb: number | null;
9
+ bollLb: number | null;
10
+ }[];
11
+ interface BollType {
12
+ init: (data: ItemType) => {
13
+ dataset: ListType;
14
+ bollMa: number | null;
15
+ bollUb: number | null;
16
+ bollLb: number | null;
17
+ };
18
+ next: (data: ItemType, preList: {
19
+ dataset: ListType;
20
+ bollMa: number | null;
21
+ bollUb: number | null;
22
+ bollLb: number | null;
23
+ }, type: number) => {
24
+ dataset: ListType;
25
+ bollMa: number | null;
26
+ bollUb: number | null;
27
+ bollLb: number | null;
28
+ };
29
+ getBoll: (list: ListType, type: number) => ResBoll;
30
+ }
31
+ export default class Boll implements BollType {
32
+ init(data: ItemType): {
33
+ dataset: ListType;
34
+ bollMa: number | null;
35
+ bollUb: number | null;
36
+ bollLb: number | null;
37
+ };
38
+ next(data: ItemType, preList: {
39
+ dataset: ListType;
40
+ bollMa: number | null;
41
+ bollUb: number | null;
42
+ bollLb: number | null;
43
+ }, type: number): {
44
+ dataset: ListType;
45
+ type: number;
46
+ bollMa: null;
47
+ bollUb: null;
48
+ bollLb: null;
49
+ } | {
50
+ dataset: ListType;
51
+ type: number;
52
+ bollMa: number;
53
+ bollUb: number;
54
+ bollLb: number;
55
+ };
56
+ getBoll(list: ListType, type: number): ResBoll;
57
+ }
58
+ export {};
@@ -0,0 +1,99 @@
1
+ var __assign = (this && this.__assign) || function () {
2
+ __assign = Object.assign || function(t) {
3
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
4
+ s = arguments[i];
5
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
6
+ t[p] = s[p];
7
+ }
8
+ return t;
9
+ };
10
+ return __assign.apply(this, arguments);
11
+ };
12
+ var Boll = /** @class */ (function () {
13
+ function Boll() {
14
+ }
15
+ Object.defineProperty(Boll.prototype, "init", {
16
+ enumerable: false,
17
+ configurable: true,
18
+ writable: true,
19
+ value: function (data) {
20
+ return {
21
+ dataset: [data],
22
+ bollMa: null,
23
+ bollUb: null,
24
+ bollLb: null,
25
+ };
26
+ }
27
+ });
28
+ Object.defineProperty(Boll.prototype, "next", {
29
+ enumerable: false,
30
+ configurable: true,
31
+ writable: true,
32
+ value: function (data, preList, type) {
33
+ preList.dataset.push(data);
34
+ if (preList.dataset.length < type) {
35
+ return {
36
+ dataset: preList.dataset,
37
+ type: type,
38
+ bollMa: null,
39
+ bollUb: null,
40
+ bollLb: null,
41
+ };
42
+ }
43
+ else {
44
+ if (preList.dataset.length > type) {
45
+ preList.dataset.shift();
46
+ }
47
+ var sum = preList.dataset.reduce(function (pre, current) { return pre + current.c; }, 0);
48
+ var bollMa_1 = Math.round((sum / type) * 100) / 100;
49
+ var difference = preList.dataset.reduce(function (pre, current) {
50
+ return bollMa_1 !== null ? pre + Math.pow(current.c - bollMa_1, 2) : pre;
51
+ }, 0);
52
+ var std = Math.round(Math.sqrt(difference / type) * 100) / 100;
53
+ return {
54
+ dataset: preList.dataset,
55
+ type: type,
56
+ bollMa: bollMa_1,
57
+ bollUb: bollMa_1 + 2 * std,
58
+ bollLb: bollMa_1 - 2 * std,
59
+ };
60
+ }
61
+ }
62
+ });
63
+ Object.defineProperty(Boll.prototype, "getBoll", {
64
+ enumerable: false,
65
+ configurable: true,
66
+ writable: true,
67
+ value: function (list, type) {
68
+ var res = [];
69
+ var _loop_1 = function (i) {
70
+ if (i < type)
71
+ res[i] = __assign(__assign({}, list[i]), { bollMa: null, bollUb: null, bollLb: null });
72
+ else {
73
+ // bollMa
74
+ var sumMa = list
75
+ .slice(i - (type - 1), i + 1)
76
+ .reduce(function (pre, current) { return pre + current.c; }, 0);
77
+ console.log("sumMa", sumMa);
78
+ var bollMa_2 = Math.round((sumMa / type) * 100) / 100;
79
+ // 標準差
80
+ var difference = res
81
+ .slice(i - (type - 1), i + 1)
82
+ .reduce(function (pre, current) {
83
+ return bollMa_2 !== null
84
+ ? pre + Math.pow(current.c - bollMa_2, 2)
85
+ : pre;
86
+ }, 0);
87
+ var std = Math.round(Math.sqrt(difference / type) * 100) / 100;
88
+ res[i] = __assign(__assign({}, list[i]), { bollMa: bollMa_2, bollUb: bollMa_2 + 2 * std, bollLb: bollMa_2 - 2 * std });
89
+ }
90
+ };
91
+ for (var i = 0; i < list.length; i++) {
92
+ _loop_1(i);
93
+ }
94
+ return res;
95
+ }
96
+ });
97
+ return Boll;
98
+ }());
99
+ export default Boll;
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,34 @@
1
+ import Boll from "./boll";
2
+ import data from "./test_data.test";
3
+ describe("test boll methods", function () {
4
+ it("test init & next", function () {
5
+ var index = data.length - 1;
6
+ var boll = new Boll();
7
+ var init = boll.init(data[0]);
8
+ var res = init;
9
+ for (var i = 1; i <= index; i++) {
10
+ var item = data[i];
11
+ res = boll.next(item, res, 25);
12
+ }
13
+ expect({
14
+ bollMa: res.bollMa,
15
+ bollLb: res.bollLb,
16
+ bollUb: res.bollUb,
17
+ }).toEqual({ bollMa: 142.66, bollLb: 126.69999999999999, bollUb: 158.62 });
18
+ });
19
+ it("test getBoll()", function () {
20
+ var boll = new Boll();
21
+ var res = boll.getBoll(data, 25);
22
+ expect(res[data.length - 1]).toEqual({
23
+ c: 142,
24
+ o: 138,
25
+ t: 20211214,
26
+ v: 16841,
27
+ h: 143,
28
+ l: 138,
29
+ bollMa: 142.66,
30
+ bollLb: 126.69999999999999,
31
+ bollUb: 158.62,
32
+ });
33
+ });
34
+ });
@@ -0,0 +1,9 @@
1
+ interface EmaType {
2
+ getStartEma: (list: number[], period: number) => number;
3
+ getEma: (list: number[], period: number) => (number | null)[];
4
+ }
5
+ export default class Ema implements EmaType {
6
+ getStartEma(list: number[], period: number): number;
7
+ getEma(list: number[], period: number): (number | null)[];
8
+ }
9
+ export {};
@@ -0,0 +1,39 @@
1
+ var Ema = /** @class */ (function () {
2
+ function Ema() {
3
+ }
4
+ Object.defineProperty(Ema.prototype, "getStartEma", {
5
+ enumerable: false,
6
+ configurable: true,
7
+ writable: true,
8
+ value: function (list, period) {
9
+ if (list.length < period)
10
+ throw new Error("list.length < period");
11
+ var sum = 0;
12
+ for (var i = 0; i < period; i++) {
13
+ sum += list[i];
14
+ }
15
+ var initialEMA = sum / period;
16
+ return initialEMA;
17
+ }
18
+ });
19
+ Object.defineProperty(Ema.prototype, "getEma", {
20
+ enumerable: false,
21
+ configurable: true,
22
+ writable: true,
23
+ value: function (list, period) {
24
+ var res = [];
25
+ var ema = this.getStartEma(list.slice(0, period), period);
26
+ for (var i = 0; i < list.length; i++) {
27
+ if (i < period) {
28
+ res.push(null);
29
+ continue;
30
+ }
31
+ ema = (list[i] * 2 + (period - 1) * ema) / (period + 1);
32
+ res.push(ema);
33
+ }
34
+ return res;
35
+ }
36
+ });
37
+ return Ema;
38
+ }());
39
+ export default Ema;
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,9 @@
1
+ import Ema from "./ema";
2
+ import data from "./test_data.test";
3
+ describe("test ema methods", function () {
4
+ it("test getEma5()", function () {
5
+ var ema = new Ema();
6
+ var res = ema.getEma(data.map(function (item) { return item.c; }), 5);
7
+ expect(res[data.length - 1]).toEqual(141.83482746491333);
8
+ });
9
+ });
@@ -1,4 +1,4 @@
1
- declare type ResGoldType = {
1
+ type ResGoldType = {
2
2
  highestPointDate: number;
3
3
  lowestPointDate: number;
4
4
  lowestPoint: number;
@@ -9,14 +9,14 @@ declare type ResGoldType = {
9
9
  weak: number;
10
10
  superWeak: number;
11
11
  };
12
- declare type ListType = {
12
+ type ListType = {
13
13
  h: number;
14
14
  t: number;
15
15
  o: number;
16
16
  c: number;
17
17
  l: number;
18
18
  }[];
19
- declare type ResHightestType = {
19
+ type ResHightestType = {
20
20
  [key: string]: {
21
21
  h: number;
22
22
  t: number;
@@ -25,7 +25,7 @@ declare type ResHightestType = {
25
25
  l: number;
26
26
  };
27
27
  };
28
- declare type ResLowestType = {
28
+ type ResLowestType = {
29
29
  [key: string]: {
30
30
  h: number;
31
31
  t: number;