@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.
- package/dist/cjs/analyze/Month/index.d.ts +1 -1
- package/dist/cjs/analyze/Month/index.test.d.ts +1 -0
- package/dist/cjs/analyze/Month/index.test.js +22 -0
- package/dist/cjs/analyze/Regression/simpleRegressoinModel.d.ts +1 -1
- package/dist/cjs/analyze/Slope/slope.test.js +6 -0
- package/dist/cjs/analyze/TimeSeries/R/index.d.ts +1 -1
- package/dist/cjs/index.d.ts +3 -0
- package/dist/cjs/index.js +7 -1
- package/dist/cjs/stockSkills/boll.d.ts +58 -0
- package/dist/cjs/stockSkills/boll.js +101 -0
- package/dist/cjs/stockSkills/boll.test.d.ts +1 -0
- package/dist/cjs/stockSkills/boll.test.js +36 -0
- package/dist/cjs/stockSkills/ema.d.ts +9 -0
- package/dist/cjs/stockSkills/ema.js +41 -0
- package/dist/cjs/stockSkills/ema.test.d.ts +1 -0
- package/dist/cjs/stockSkills/ema.test.js +11 -0
- package/dist/cjs/stockSkills/gold.d.ts +4 -4
- package/dist/cjs/stockSkills/kd.d.ts +41 -14
- package/dist/cjs/stockSkills/kd.js +60 -6
- package/dist/cjs/stockSkills/kd.test.js +34 -2
- package/dist/cjs/stockSkills/ma.d.ts +49 -30
- package/dist/cjs/stockSkills/ma.js +37 -44
- package/dist/cjs/stockSkills/ma.test.js +15 -20
- package/dist/cjs/stockSkills/macd.d.ts +62 -16
- package/dist/cjs/stockSkills/macd.js +92 -5
- package/dist/cjs/stockSkills/macd.test.js +26 -0
- package/dist/cjs/stockSkills/obv.d.ts +44 -0
- package/dist/cjs/stockSkills/obv.js +89 -0
- package/dist/cjs/stockSkills/obv.test.d.ts +1 -0
- package/dist/cjs/stockSkills/obv.test.js +20 -0
- package/dist/cjs/stockSkills/rsi.d.ts +8 -8
- package/dist/cjs/stockSkills/rsi.js +2 -2
- package/dist/cjs/stockSkills/utils/getWeekLine.d.ts +2 -2
- package/dist/cjs/stockSkills/williams.d.ts +8 -8
- package/dist/cjs/stockSkills/williams.js +2 -2
- package/dist/esm/analyze/Month/index.d.ts +1 -1
- package/dist/esm/analyze/Month/index.test.d.ts +1 -0
- package/dist/esm/analyze/Month/index.test.js +20 -0
- package/dist/esm/analyze/Regression/simpleRegressoinModel.d.ts +1 -1
- package/dist/esm/analyze/Slope/slope.test.js +6 -0
- package/dist/esm/analyze/TimeSeries/R/index.d.ts +1 -1
- package/dist/esm/index.d.ts +3 -0
- package/dist/esm/index.js +3 -0
- package/dist/esm/stockSkills/boll.d.ts +58 -0
- package/dist/esm/stockSkills/boll.js +99 -0
- package/dist/esm/stockSkills/boll.test.d.ts +1 -0
- package/dist/esm/stockSkills/boll.test.js +34 -0
- package/dist/esm/stockSkills/ema.d.ts +9 -0
- package/dist/esm/stockSkills/ema.js +39 -0
- package/dist/esm/stockSkills/ema.test.d.ts +1 -0
- package/dist/esm/stockSkills/ema.test.js +9 -0
- package/dist/esm/stockSkills/gold.d.ts +4 -4
- package/dist/esm/stockSkills/kd.d.ts +41 -14
- package/dist/esm/stockSkills/kd.js +60 -6
- package/dist/esm/stockSkills/kd.test.js +34 -2
- package/dist/esm/stockSkills/ma.d.ts +49 -30
- package/dist/esm/stockSkills/ma.js +37 -44
- package/dist/esm/stockSkills/ma.test.js +15 -20
- package/dist/esm/stockSkills/macd.d.ts +62 -16
- package/dist/esm/stockSkills/macd.js +92 -5
- package/dist/esm/stockSkills/macd.test.js +26 -0
- package/dist/esm/stockSkills/obv.d.ts +44 -0
- package/dist/esm/stockSkills/obv.js +87 -0
- package/dist/esm/stockSkills/obv.test.d.ts +1 -0
- package/dist/esm/stockSkills/obv.test.js +18 -0
- package/dist/esm/stockSkills/rsi.d.ts +8 -8
- package/dist/esm/stockSkills/rsi.js +2 -2
- package/dist/esm/stockSkills/utils/getWeekLine.d.ts +2 -2
- package/dist/esm/stockSkills/williams.d.ts +8 -8
- package/dist/esm/stockSkills/williams.js +2 -2
- package/dist/umd/index.js +458 -96
- 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
|
-
|
|
1
|
+
type ListType = {
|
|
2
2
|
c: number;
|
|
3
3
|
}[];
|
|
4
|
-
|
|
4
|
+
type ResRsi6Type = {
|
|
5
5
|
c: number;
|
|
6
|
-
rsi6
|
|
6
|
+
rsi6: number | null;
|
|
7
7
|
}[];
|
|
8
|
-
|
|
8
|
+
type ResRsi12Type = {
|
|
9
9
|
c: number;
|
|
10
|
-
rsi12
|
|
10
|
+
rsi12: number | null;
|
|
11
11
|
}[];
|
|
12
|
-
|
|
12
|
+
type ResAllRsiType = {
|
|
13
13
|
c: number;
|
|
14
|
-
rsi6
|
|
15
|
-
rsi12
|
|
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:
|
|
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:
|
|
73
|
+
res[i] = __assign(__assign({}, list[i]), { rsi12: null });
|
|
74
74
|
}
|
|
75
75
|
// 第12筆Rsi
|
|
76
76
|
var beforeUpAvg = this.getStartUpAvg(list, 12);
|
|
@@ -1,20 +1,20 @@
|
|
|
1
|
-
|
|
1
|
+
type ListType = {
|
|
2
2
|
h: number;
|
|
3
3
|
l: number;
|
|
4
4
|
c: number;
|
|
5
5
|
}[];
|
|
6
|
-
|
|
6
|
+
type ResWilliams9Type = {
|
|
7
7
|
c: number;
|
|
8
|
-
williams9
|
|
8
|
+
williams9: number | null;
|
|
9
9
|
}[];
|
|
10
|
-
|
|
10
|
+
type ResWilliams18Type = {
|
|
11
11
|
c: number;
|
|
12
|
-
williams18
|
|
12
|
+
williams18: number | null;
|
|
13
13
|
}[];
|
|
14
|
-
|
|
14
|
+
type ResAllWilliamsType = {
|
|
15
15
|
c: number;
|
|
16
|
-
williams18
|
|
17
|
-
williams9
|
|
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:
|
|
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]), {
|
|
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"]; });
|
|
@@ -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
|
+
});
|
|
@@ -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
|
-
|
|
3
|
+
type ExponentialSmoothingOptions = {
|
|
4
4
|
initialForecast: number;
|
|
5
5
|
};
|
|
6
6
|
export declare function exponentialSmoothing(arr: number[], alpha: number, options?: Partial<ExponentialSmoothingOptions>): number[];
|
package/dist/esm/index.d.ts
CHANGED
|
@@ -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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
28
|
+
type ResLowestType = {
|
|
29
29
|
[key: string]: {
|
|
30
30
|
h: number;
|
|
31
31
|
t: number;
|