@ch20026103/anysis 0.0.2 → 0.0.5-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/index.d.ts +1 -0
  6. package/dist/cjs/analyze/Slope/index.js +13 -0
  7. package/dist/cjs/analyze/Slope/slope.test.d.ts +1 -0
  8. package/dist/cjs/analyze/Slope/slope.test.js +35 -0
  9. package/dist/cjs/analyze/TimeSeries/R/index.d.ts +1 -1
  10. package/dist/cjs/index.d.ts +9 -5
  11. package/dist/cjs/index.js +23 -15
  12. package/dist/cjs/stockSkills/ema.d.ts +9 -0
  13. package/dist/cjs/stockSkills/ema.js +41 -0
  14. package/dist/cjs/stockSkills/ema.test.d.ts +1 -0
  15. package/dist/cjs/stockSkills/ema.test.js +11 -0
  16. package/dist/cjs/stockSkills/gold.d.ts +4 -4
  17. package/dist/cjs/stockSkills/kd.d.ts +78 -0
  18. package/dist/cjs/stockSkills/kd.js +125 -0
  19. package/dist/cjs/stockSkills/kd.test.d.ts +1 -0
  20. package/dist/cjs/stockSkills/kd.test.js +65 -0
  21. package/dist/cjs/stockSkills/ma.d.ts +49 -7
  22. package/dist/cjs/stockSkills/ma.js +69 -1
  23. package/dist/cjs/stockSkills/ma.test.js +41 -4
  24. package/dist/cjs/stockSkills/macd.d.ts +52 -6
  25. package/dist/cjs/stockSkills/macd.js +87 -0
  26. package/dist/cjs/stockSkills/macd.test.js +24 -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 +4 -4
  32. package/dist/cjs/stockSkills/test_data.test.d.ts +8 -0
  33. package/dist/cjs/stockSkills/test_data.test.js +626 -0
  34. package/dist/cjs/stockSkills/utils/getWeekLine.d.ts +2 -2
  35. package/dist/cjs/stockSkills/williams.d.ts +4 -4
  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/index.d.ts +1 -0
  41. package/dist/esm/analyze/Slope/index.js +10 -0
  42. package/dist/esm/analyze/Slope/slope.test.d.ts +1 -0
  43. package/dist/esm/analyze/Slope/slope.test.js +33 -0
  44. package/dist/esm/analyze/TimeSeries/R/index.d.ts +1 -1
  45. package/dist/esm/index.d.ts +9 -5
  46. package/dist/esm/index.js +9 -5
  47. package/dist/esm/stockSkills/ema.d.ts +9 -0
  48. package/dist/esm/stockSkills/ema.js +39 -0
  49. package/dist/esm/stockSkills/ema.test.d.ts +1 -0
  50. package/dist/esm/stockSkills/ema.test.js +9 -0
  51. package/dist/esm/stockSkills/gold.d.ts +4 -4
  52. package/dist/esm/stockSkills/kd.d.ts +78 -0
  53. package/dist/esm/stockSkills/kd.js +123 -0
  54. package/dist/esm/stockSkills/kd.test.d.ts +1 -0
  55. package/dist/esm/stockSkills/kd.test.js +63 -0
  56. package/dist/esm/stockSkills/ma.d.ts +49 -7
  57. package/dist/esm/stockSkills/ma.js +69 -1
  58. package/dist/esm/stockSkills/ma.test.js +41 -4
  59. package/dist/esm/stockSkills/macd.d.ts +52 -6
  60. package/dist/esm/stockSkills/macd.js +87 -0
  61. package/dist/esm/stockSkills/macd.test.js +24 -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 +4 -4
  67. package/dist/esm/stockSkills/test_data.test.d.ts +8 -0
  68. package/dist/esm/stockSkills/test_data.test.js +625 -0
  69. package/dist/esm/stockSkills/utils/getWeekLine.d.ts +2 -2
  70. package/dist/esm/stockSkills/williams.d.ts +4 -4
  71. package/dist/umd/index.js +901 -482
  72. package/package.json +15 -17
@@ -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,22 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ var index_1 = require("./index");
4
+ describe("test setStartMonthInYear", function () {
5
+ it("test 3", function () {
6
+ var res = (0, index_1.setStartMonthInYear)(3);
7
+ expect(res).toEqual([
8
+ "March",
9
+ "April",
10
+ "May",
11
+ "June",
12
+ "July",
13
+ "August",
14
+ "September",
15
+ "October",
16
+ "November",
17
+ "December",
18
+ "January",
19
+ "February",
20
+ ]);
21
+ });
22
+ });
@@ -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;
@@ -0,0 +1 @@
1
+ export default function Slope(x: number[], y: number[]): number;
@@ -0,0 +1,13 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ function Slope(x, y) {
4
+ // 計算 x 和 y 的平均值
5
+ var x_mean = x.reduce(function (acc, cur) { return acc + cur; }) / x.length;
6
+ var y_mean = y.reduce(function (acc, cur) { return acc + cur; }) / y.length;
7
+ // 計算斜率
8
+ var numerator = x.reduce(function (acc, cur, i) { return acc + (cur - x_mean) * (y[i] - y_mean); }, 0);
9
+ var denominator = x.reduce(function (acc, cur) { return acc + Math.pow((cur - x_mean), 2); }, 0);
10
+ var slope = numerator / denominator;
11
+ return slope;
12
+ }
13
+ exports.default = Slope;
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,35 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ var index_1 = require("./index");
4
+ describe("test Slope methods", function () {
5
+ it("test 123456", function () {
6
+ var x = [1, 2, 3, 4, 5, 6];
7
+ var y = [1, 2, 3, 4, 5, 6];
8
+ var slope = (0, index_1.default)(x, y);
9
+ expect(slope).toEqual(1);
10
+ });
11
+ it("test -123456", function () {
12
+ var x = [1, 2, 3, 4, 5, 6];
13
+ var y = [-1, -2, -3, -4, -5, -6];
14
+ var slope = (0, index_1.default)(x, y);
15
+ expect(slope).toEqual(-1);
16
+ });
17
+ it("test 654321", function () {
18
+ var x = [1, 2, 3, 4, 5, 6];
19
+ var y = [6, 5, 4, 3, 2, 1];
20
+ var slope = (0, index_1.default)(x, y);
21
+ expect(slope).toEqual(-1);
22
+ });
23
+ it("test 222222", function () {
24
+ var x = [1, 2, 3, 4, 5, 6];
25
+ var y = [2, 2, 2, 2, 2, 2];
26
+ var slope = (0, index_1.default)(x, y);
27
+ expect(slope).toEqual(0);
28
+ });
29
+ it("test 1,4,6,8,10,12", function () {
30
+ var x = [1, 2, 3, 4, 5, 6];
31
+ var y = [1, 4, 6, 8, 10, 12];
32
+ var slope = (0, index_1.default)(x, y);
33
+ expect(slope).toEqual(2.142857142857143);
34
+ });
35
+ });
@@ -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[];
@@ -1,12 +1,16 @@
1
1
  export { default as simpleRegressionModel } from "./analyze/Regression/simpleRegressoinModel.js";
2
- export { movingAverages, weightMovingAverages, exponentialSmoothing, } from "./analyze/TimeSeries/R/index.js";
2
+ export { default as slope } from "./analyze/Slope/index.js";
3
+ export { exponentialSmoothing, movingAverages, weightMovingAverages, } from "./analyze/TimeSeries/R/index.js";
3
4
  export { calcSeasonalIndicesNoTrend } from "./analyze/TimeSeries/RS/index.js";
4
- export { add } from "./test/add.js";
5
- export { minus } from "./test/minus.js";
5
+ export { default as Gold } from "./stockSkills/gold.js";
6
+ export { default as Kd } from "./stockSkills/kd.js";
6
7
  export { default as Ma } from "./stockSkills/ma.js";
7
8
  export { default as Macd } from "./stockSkills/macd.js";
8
9
  export { default as Rsi } from "./stockSkills/rsi.js";
9
- export { default as Williams } from "./stockSkills/williams.js";
10
- export { default as Gold } from "./stockSkills/gold.js";
10
+ export { default as Obv } from "./stockSkills/obv.js";
11
+ export { default as Ema } from "./stockSkills/ema.js";
11
12
  export { default as dateFormat } from "./stockSkills/utils/dateFormat.js";
12
13
  export { default as getWeekLine } from "./stockSkills/utils/getWeekLine.js";
14
+ export { default as Williams } from "./stockSkills/williams.js";
15
+ export { add } from "./test/add.js";
16
+ export { minus } from "./test/minus.js";
package/dist/cjs/index.js CHANGED
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getWeekLine = exports.dateFormat = exports.Gold = exports.Williams = exports.Rsi = exports.Macd = exports.Ma = exports.minus = exports.add = exports.calcSeasonalIndicesNoTrend = exports.exponentialSmoothing = exports.weightMovingAverages = exports.movingAverages = exports.simpleRegressionModel = void 0;
3
+ exports.minus = exports.add = exports.Williams = exports.getWeekLine = exports.dateFormat = exports.Ema = exports.Obv = exports.Rsi = exports.Macd = exports.Ma = exports.Kd = exports.Gold = exports.calcSeasonalIndicesNoTrend = exports.weightMovingAverages = exports.movingAverages = exports.exponentialSmoothing = exports.slope = exports.simpleRegressionModel = void 0;
4
4
  /*
5
5
  請注意,在 src/index.ts 中,我的導入包含文件擴展名(.js)。
6
6
  如果需要支持 Node.js 和構建工具(ex: webpack),則不需要這樣做。 **因為commonJs默認js副檔名**
@@ -8,27 +8,35 @@ exports.getWeekLine = exports.dateFormat = exports.Gold = exports.Williams = exp
8
8
  */
9
9
  var simpleRegressoinModel_js_1 = require("./analyze/Regression/simpleRegressoinModel.js");
10
10
  Object.defineProperty(exports, "simpleRegressionModel", { enumerable: true, get: function () { return simpleRegressoinModel_js_1.default; } });
11
- var index_js_1 = require("./analyze/TimeSeries/R/index.js");
12
- Object.defineProperty(exports, "movingAverages", { enumerable: true, get: function () { return index_js_1.movingAverages; } });
13
- Object.defineProperty(exports, "weightMovingAverages", { enumerable: true, get: function () { return index_js_1.weightMovingAverages; } });
14
- Object.defineProperty(exports, "exponentialSmoothing", { enumerable: true, get: function () { return index_js_1.exponentialSmoothing; } });
15
- var index_js_2 = require("./analyze/TimeSeries/RS/index.js");
16
- Object.defineProperty(exports, "calcSeasonalIndicesNoTrend", { enumerable: true, get: function () { return index_js_2.calcSeasonalIndicesNoTrend; } });
17
- var add_js_1 = require("./test/add.js");
18
- Object.defineProperty(exports, "add", { enumerable: true, get: function () { return add_js_1.add; } });
19
- var minus_js_1 = require("./test/minus.js");
20
- Object.defineProperty(exports, "minus", { enumerable: true, get: function () { return minus_js_1.minus; } });
11
+ var index_js_1 = require("./analyze/Slope/index.js");
12
+ Object.defineProperty(exports, "slope", { enumerable: true, get: function () { return index_js_1.default; } });
13
+ var index_js_2 = require("./analyze/TimeSeries/R/index.js");
14
+ Object.defineProperty(exports, "exponentialSmoothing", { enumerable: true, get: function () { return index_js_2.exponentialSmoothing; } });
15
+ Object.defineProperty(exports, "movingAverages", { enumerable: true, get: function () { return index_js_2.movingAverages; } });
16
+ Object.defineProperty(exports, "weightMovingAverages", { enumerable: true, get: function () { return index_js_2.weightMovingAverages; } });
17
+ var index_js_3 = require("./analyze/TimeSeries/RS/index.js");
18
+ Object.defineProperty(exports, "calcSeasonalIndicesNoTrend", { enumerable: true, get: function () { return index_js_3.calcSeasonalIndicesNoTrend; } });
19
+ var gold_js_1 = require("./stockSkills/gold.js");
20
+ Object.defineProperty(exports, "Gold", { enumerable: true, get: function () { return gold_js_1.default; } });
21
+ var kd_js_1 = require("./stockSkills/kd.js");
22
+ Object.defineProperty(exports, "Kd", { enumerable: true, get: function () { return kd_js_1.default; } });
21
23
  var ma_js_1 = require("./stockSkills/ma.js");
22
24
  Object.defineProperty(exports, "Ma", { enumerable: true, get: function () { return ma_js_1.default; } });
23
25
  var macd_js_1 = require("./stockSkills/macd.js");
24
26
  Object.defineProperty(exports, "Macd", { enumerable: true, get: function () { return macd_js_1.default; } });
25
27
  var rsi_js_1 = require("./stockSkills/rsi.js");
26
28
  Object.defineProperty(exports, "Rsi", { enumerable: true, get: function () { return rsi_js_1.default; } });
27
- var williams_js_1 = require("./stockSkills/williams.js");
28
- Object.defineProperty(exports, "Williams", { enumerable: true, get: function () { return williams_js_1.default; } });
29
- var gold_js_1 = require("./stockSkills/gold.js");
30
- Object.defineProperty(exports, "Gold", { enumerable: true, get: function () { return gold_js_1.default; } });
29
+ var obv_js_1 = require("./stockSkills/obv.js");
30
+ Object.defineProperty(exports, "Obv", { enumerable: true, get: function () { return obv_js_1.default; } });
31
+ var ema_js_1 = require("./stockSkills/ema.js");
32
+ Object.defineProperty(exports, "Ema", { enumerable: true, get: function () { return ema_js_1.default; } });
31
33
  var dateFormat_js_1 = require("./stockSkills/utils/dateFormat.js");
32
34
  Object.defineProperty(exports, "dateFormat", { enumerable: true, get: function () { return dateFormat_js_1.default; } });
33
35
  var getWeekLine_js_1 = require("./stockSkills/utils/getWeekLine.js");
34
36
  Object.defineProperty(exports, "getWeekLine", { enumerable: true, get: function () { return getWeekLine_js_1.default; } });
37
+ var williams_js_1 = require("./stockSkills/williams.js");
38
+ Object.defineProperty(exports, "Williams", { enumerable: true, get: function () { return williams_js_1.default; } });
39
+ var add_js_1 = require("./test/add.js");
40
+ Object.defineProperty(exports, "add", { enumerable: true, get: function () { return add_js_1.add; } });
41
+ var minus_js_1 = require("./test/minus.js");
42
+ Object.defineProperty(exports, "minus", { enumerable: true, get: function () { return minus_js_1.minus; } });
@@ -0,0 +1,9 @@
1
+ interface EmaType {
2
+ getStartEma: (list: number[], period: number) => number;
3
+ getEma: (list: number[], period: number) => (number | undefined)[];
4
+ }
5
+ export default class Ema implements EmaType {
6
+ getStartEma(list: number[], period: number): number;
7
+ getEma(list: number[], period: number): (number | undefined)[];
8
+ }
9
+ export {};
@@ -0,0 +1,41 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ var Ema = /** @class */ (function () {
4
+ function Ema() {
5
+ }
6
+ Object.defineProperty(Ema.prototype, "getStartEma", {
7
+ enumerable: false,
8
+ configurable: true,
9
+ writable: true,
10
+ value: function (list, period) {
11
+ if (list.length < period)
12
+ throw new Error("list.length < period");
13
+ var sum = 0;
14
+ for (var i = 0; i < period; i++) {
15
+ sum += list[i];
16
+ }
17
+ var initialEMA = sum / period;
18
+ return initialEMA;
19
+ }
20
+ });
21
+ Object.defineProperty(Ema.prototype, "getEma", {
22
+ enumerable: false,
23
+ configurable: true,
24
+ writable: true,
25
+ value: function (list, period) {
26
+ var res = [];
27
+ var ema = this.getStartEma(list.slice(0, period), period);
28
+ for (var i = 0; i < list.length; i++) {
29
+ if (i < period) {
30
+ res.push(undefined);
31
+ continue;
32
+ }
33
+ ema = (list[i] * 2 + (period - 1) * ema) / (period + 1);
34
+ res.push(ema);
35
+ }
36
+ return res;
37
+ }
38
+ });
39
+ return Ema;
40
+ }());
41
+ exports.default = Ema;
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,11 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ var ema_1 = require("./ema");
4
+ var test_data_test_1 = require("./test_data.test");
5
+ describe("test ema methods", function () {
6
+ it("test getEma5()", function () {
7
+ var ema = new ema_1.default();
8
+ var res = ema.getEma(test_data_test_1.default.map(function (item) { return item.c; }), 5);
9
+ expect(res[test_data_test_1.default.length - 1]).toEqual(141.83482746491333);
10
+ });
11
+ });
@@ -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;
@@ -0,0 +1,78 @@
1
+ interface KdType {
2
+ getRSV: (list: ListType) => ResRSV;
3
+ getKD: (list: ListType) => ResKD;
4
+ }
5
+ type DataType = {
6
+ c: number;
7
+ h: number;
8
+ l: number;
9
+ };
10
+ type ListType = DataType[];
11
+ type ResRSV = {
12
+ c: number;
13
+ rsv?: number;
14
+ }[];
15
+ type ResKD = {
16
+ c: number;
17
+ rsv?: number;
18
+ k?: number;
19
+ d?: number;
20
+ "k-d"?: number;
21
+ }[];
22
+ export default class Kd implements KdType {
23
+ init(data: DataType): {
24
+ dataset: ListType;
25
+ rsv?: number;
26
+ k?: number;
27
+ d?: number;
28
+ "k-d"?: number;
29
+ };
30
+ next(data: DataType, preList: {
31
+ dataset: ListType;
32
+ rsv?: number;
33
+ k?: number;
34
+ d?: number;
35
+ "k-d"?: number;
36
+ }, type: number): {
37
+ dataset: ListType;
38
+ rsv: undefined;
39
+ k: undefined;
40
+ d: undefined;
41
+ "k-d": undefined;
42
+ } | {
43
+ dataset: ListType;
44
+ rsv: number;
45
+ k: number;
46
+ d: number;
47
+ "k-d": number;
48
+ };
49
+ getRSV(list: ListType): ({
50
+ rsv: undefined;
51
+ c: number;
52
+ h: number;
53
+ l: number;
54
+ } | {
55
+ rsv: number;
56
+ c: number;
57
+ h: number;
58
+ l: number;
59
+ })[];
60
+ getKD(list: ListType): ({
61
+ rsv: undefined;
62
+ k: undefined;
63
+ d: undefined;
64
+ "k-d": undefined;
65
+ c: number;
66
+ h: number;
67
+ l: number;
68
+ } | {
69
+ rsv: number;
70
+ k: number;
71
+ d: number;
72
+ "k-d": number;
73
+ c: number;
74
+ h: number;
75
+ l: number;
76
+ })[];
77
+ }
78
+ export {};
@@ -0,0 +1,125 @@
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
+ Object.defineProperty(exports, "__esModule", { value: true });
14
+ var Kd = /** @class */ (function () {
15
+ function Kd() {
16
+ }
17
+ Object.defineProperty(Kd.prototype, "init", {
18
+ enumerable: false,
19
+ configurable: true,
20
+ writable: true,
21
+ value: function (data) {
22
+ return {
23
+ dataset: [data],
24
+ rsv: undefined,
25
+ k: undefined,
26
+ d: undefined,
27
+ "k-d": undefined,
28
+ };
29
+ }
30
+ });
31
+ Object.defineProperty(Kd.prototype, "next", {
32
+ enumerable: false,
33
+ configurable: true,
34
+ writable: true,
35
+ value: function (data, preList, type) {
36
+ preList.dataset.push(data);
37
+ if (preList.dataset.length < type) {
38
+ return {
39
+ dataset: preList.dataset,
40
+ rsv: undefined,
41
+ k: undefined,
42
+ d: undefined,
43
+ "k-d": undefined,
44
+ };
45
+ }
46
+ else {
47
+ if (preList.dataset.length > type) {
48
+ preList.dataset.shift();
49
+ }
50
+ var low = Math.min.apply(Math, preList.dataset.map(function (item) { return item.l; }));
51
+ var hight = Math.max.apply(Math, preList.dataset.map(function (item) { return item.h; }));
52
+ var close_1 = data.c;
53
+ var rsv = ((close_1 - low) / (hight - low)) * 100;
54
+ rsv = Math.round(rsv * 100) / 100;
55
+ var k = (2 / 3) * (preList.k ? preList.k : 50) + (1 / 3) * rsv;
56
+ var d = (2 / 3) * (preList.d ? preList.d : 50) + (1 / 3) * k;
57
+ var k_d = k - d;
58
+ k = Math.round(k * 100) / 100;
59
+ d = Math.round(d * 100) / 100;
60
+ k_d = Math.round(k_d * 100) / 100;
61
+ return {
62
+ dataset: preList.dataset,
63
+ rsv: rsv,
64
+ k: k,
65
+ d: d,
66
+ "k-d": k_d,
67
+ };
68
+ }
69
+ }
70
+ });
71
+ Object.defineProperty(Kd.prototype, "getRSV", {
72
+ enumerable: false,
73
+ configurable: true,
74
+ writable: true,
75
+ value: function (list) {
76
+ var res = [];
77
+ for (var i = 0; i < list.length; i++) {
78
+ if (i < 8)
79
+ res[i] = __assign(__assign({}, list[i]), { rsv: undefined });
80
+ else {
81
+ var low = Math.min.apply(Math, list.slice(i - 8, i + 1).map(function (item) { return item.l; }));
82
+ var hight = Math.max.apply(Math, list.slice(i - 8, i + 1).map(function (item) { return item.h; }));
83
+ var close_2 = list[i].c;
84
+ var rsv = ((close_2 - low) / (hight - low)) * 100;
85
+ rsv = Math.round(rsv * 100) / 100;
86
+ res[i] = __assign(__assign({}, list[i]), { rsv: rsv });
87
+ }
88
+ }
89
+ return res;
90
+ }
91
+ });
92
+ Object.defineProperty(Kd.prototype, "getKD", {
93
+ enumerable: false,
94
+ configurable: true,
95
+ writable: true,
96
+ value: function (list) {
97
+ var res = [];
98
+ var yesterdayK = 50;
99
+ var yesterdayD = 50;
100
+ for (var i = 0; i < list.length; i++) {
101
+ if (i < 8)
102
+ res[i] = __assign(__assign({}, list[i]), { rsv: undefined, k: undefined, d: undefined, "k-d": undefined });
103
+ else {
104
+ var low = Math.min.apply(Math, list.slice(i - 8, i + 1).map(function (item) { return item.l; }));
105
+ var hight = Math.max.apply(Math, list.slice(i - 8, i + 1).map(function (item) { return item.h; }));
106
+ var close_3 = list[i].c;
107
+ var rsv = ((close_3 - low) / (hight - low)) * 100;
108
+ rsv = Math.round(rsv * 100) / 100;
109
+ var k = (2 / 3) * yesterdayK + (1 / 3) * rsv;
110
+ var d = (2 / 3) * yesterdayD + (1 / 3) * k;
111
+ var k_d = k - d;
112
+ k = Math.round(k * 100) / 100;
113
+ d = Math.round(d * 100) / 100;
114
+ k_d = Math.round(k_d * 100) / 100;
115
+ res[i] = __assign(__assign({}, list[i]), { rsv: rsv, k: k, d: d, "k-d": k_d });
116
+ yesterdayK = k;
117
+ yesterdayD = d;
118
+ }
119
+ }
120
+ return res;
121
+ }
122
+ });
123
+ return Kd;
124
+ }());
125
+ exports.default = Kd;
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,65 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ var kd_1 = require("./kd");
4
+ var test_data_test_1 = require("./test_data.test");
5
+ describe("test kd methods", function () {
6
+ it("test init", function () {
7
+ var index = test_data_test_1.data_9904.length - 1;
8
+ var kd = new kd_1.default();
9
+ var realData = kd.getKD(test_data_test_1.data_9904)[index];
10
+ var init = kd.init(test_data_test_1.data_9904[0]);
11
+ var res = init;
12
+ for (var i = 1; i <= index; i++) {
13
+ var item = test_data_test_1.data_9904[i];
14
+ res = kd.next(item, res, 9);
15
+ }
16
+ expect({
17
+ dataset: {
18
+ c: realData.c,
19
+ h: realData.h,
20
+ l: realData.l,
21
+ },
22
+ rsv: realData.rsv,
23
+ "k-d": realData["k-d"],
24
+ k: realData.k,
25
+ d: realData.d,
26
+ }).toEqual({
27
+ dataset: {
28
+ c: res.dataset[res.dataset.length - 1].c,
29
+ h: res.dataset[res.dataset.length - 1].h,
30
+ l: res.dataset[res.dataset.length - 1].l,
31
+ },
32
+ rsv: res.rsv,
33
+ "k-d": res["k-d"],
34
+ k: res.k,
35
+ d: res.d,
36
+ });
37
+ });
38
+ it("test getRSV()", function () {
39
+ var kd = new kd_1.default();
40
+ expect(kd.getRSV(test_data_test_1.data_9904)[test_data_test_1.data_9904.length - 1]).toEqual({
41
+ o: 26.4,
42
+ l: 34.3,
43
+ h: 34.8,
44
+ c: 34.65,
45
+ v: 12765,
46
+ t: 20230216,
47
+ rsv: 90.63,
48
+ });
49
+ });
50
+ it("test getKD()", function () {
51
+ var kd = new kd_1.default();
52
+ expect(kd.getKD(test_data_test_1.data_9904)[test_data_test_1.data_9904.length - 1]).toEqual({
53
+ o: 26.4,
54
+ l: 34.3,
55
+ h: 34.8,
56
+ c: 34.65,
57
+ v: 12765,
58
+ t: 20230216,
59
+ rsv: 90.63,
60
+ k: 64.41,
61
+ d: 45.25,
62
+ "k-d": 19.16,
63
+ });
64
+ });
65
+ });
@@ -1,45 +1,87 @@
1
- declare type ListType = {
1
+ type DataType = {
2
2
  c: number;
3
- }[];
4
- declare type ResMa5 = {
3
+ };
4
+ type ListType = DataType[];
5
+ type ResMa5 = {
5
6
  c: number;
6
7
  ma5?: number;
7
8
  }[];
8
- declare type ResMa10 = {
9
+ type ResMa10 = {
9
10
  c: number;
10
11
  ma10?: number;
11
12
  }[];
12
- declare type ResMa20 = {
13
+ type ResMa20 = {
13
14
  c: number;
14
15
  ma20?: number;
15
16
  }[];
16
- declare type ResBoll = {
17
+ type ResMa60 = {
18
+ c: number;
19
+ ma60?: number;
20
+ }[];
21
+ type ResMaSelf = {
22
+ c: number;
23
+ maSelf?: number;
24
+ }[];
25
+ type ResBoll = {
17
26
  c: number;
18
27
  ma25?: number;
19
28
  bollUb?: number;
20
29
  bollLb?: number;
21
30
  }[];
22
- declare type ResAllMa = {
31
+ type ResAllMa = {
23
32
  c: number;
24
33
  ma5?: number;
25
34
  ma10?: number;
26
35
  ma20?: number;
27
36
  ma25?: number;
37
+ ma60?: number;
28
38
  bollUb?: number;
29
39
  bollLb?: number;
30
40
  }[];
31
41
  interface MaType {
42
+ init: (data: DataType, type: number) => {
43
+ dataset: ListType;
44
+ ma: number;
45
+ type: number;
46
+ };
47
+ next: (data: DataType, preList: {
48
+ dataset: ListType;
49
+ ma: number;
50
+ type: number;
51
+ }, type: number) => {
52
+ dataset: ListType;
53
+ ma: number;
54
+ type: number;
55
+ };
32
56
  getAllMa: (list: ListType) => ResAllMa;
33
57
  getMa5: (list: ListType) => ResMa5;
34
58
  getMa10: (list: ListType) => ResMa10;
35
59
  getMa20: (list: ListType) => ResMa20;
60
+ getMa60: (list: ListType) => ResMa60;
61
+ getMaSelf: (list: ListType, self: number) => ResMaSelf;
36
62
  getBoll: (list: ListType) => ResBoll;
37
63
  }
38
64
  export default class Ma implements MaType {
65
+ init(data: DataType, type: number): {
66
+ dataset: DataType[];
67
+ ma: number;
68
+ type: number;
69
+ };
70
+ next(data: DataType, preList: {
71
+ dataset: ListType;
72
+ ma: number;
73
+ type: number;
74
+ }, type: number): {
75
+ dataset: ListType;
76
+ ma: number;
77
+ type: number;
78
+ };
39
79
  getAllMa(list: ListType): ResAllMa;
40
80
  getMa5(list: ListType): ResMa5;
41
81
  getMa10(list: ListType): ResMa10;
42
82
  getMa20(list: ListType): ResMa20;
83
+ getMa60(list: ListType): ResMa60;
84
+ getMaSelf(list: ListType, self: number): ResMaSelf;
43
85
  getBoll(list: ListType): ResBoll;
44
86
  }
45
87
  export {};