@ch20026103/anysis 0.0.14-alpha → 0.0.16-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/demo/main.js +19 -12
- package/dist/cjs/stockSkills/boll.d.ts +25 -50
- package/dist/cjs/stockSkills/boll.js +9 -11
- package/dist/cjs/stockSkills/ema.d.ts +11 -33
- package/dist/cjs/stockSkills/gold.d.ts +12 -32
- package/dist/cjs/stockSkills/kd.d.ts +29 -72
- package/dist/cjs/stockSkills/kd.js +14 -11
- package/dist/cjs/stockSkills/kd.test.js +1 -1
- package/dist/cjs/stockSkills/ma.d.ts +39 -60
- package/dist/cjs/stockSkills/ma.js +16 -7
- package/dist/cjs/stockSkills/macd.d.ts +32 -63
- package/dist/cjs/stockSkills/macd.js +21 -24
- package/dist/cjs/stockSkills/obv.d.ts +16 -49
- package/dist/cjs/stockSkills/obv.js +3 -1
- package/dist/cjs/stockSkills/rsi.d.ts +12 -31
- package/dist/cjs/stockSkills/rsi.js +79 -101
- package/dist/cjs/stockSkills/rsi.test.js +9 -20
- package/dist/cjs/stockSkills/types.d.ts +10 -0
- package/dist/cjs/stockSkills/types.js +2 -0
- package/dist/cjs/stockSkills/utils/getWeekLine.d.ts +4 -16
- package/dist/cjs/stockSkills/utils/getWeekLine.js +3 -0
- package/dist/cjs/stockSkills/utils/getWeekLine.test.js +1 -0
- package/dist/cjs/stockSkills/vma.d.ts +11 -26
- package/dist/cjs/stockSkills/williams.d.ts +20 -32
- package/dist/esm/stockSkills/boll.d.ts +25 -50
- package/dist/esm/stockSkills/boll.js +9 -11
- package/dist/esm/stockSkills/ema.d.ts +11 -33
- package/dist/esm/stockSkills/gold.d.ts +12 -32
- package/dist/esm/stockSkills/kd.d.ts +29 -72
- package/dist/esm/stockSkills/kd.js +14 -11
- package/dist/esm/stockSkills/kd.test.js +1 -1
- package/dist/esm/stockSkills/ma.d.ts +39 -60
- package/dist/esm/stockSkills/ma.js +16 -7
- package/dist/esm/stockSkills/macd.d.ts +32 -63
- package/dist/esm/stockSkills/macd.js +21 -24
- package/dist/esm/stockSkills/obv.d.ts +16 -49
- package/dist/esm/stockSkills/obv.js +3 -1
- package/dist/esm/stockSkills/rsi.d.ts +12 -31
- package/dist/esm/stockSkills/rsi.js +79 -101
- package/dist/esm/stockSkills/rsi.test.js +9 -20
- package/dist/esm/stockSkills/types.d.ts +10 -0
- package/dist/esm/stockSkills/types.js +1 -0
- package/dist/esm/stockSkills/utils/getWeekLine.d.ts +4 -16
- package/dist/esm/stockSkills/utils/getWeekLine.js +3 -0
- package/dist/esm/stockSkills/utils/getWeekLine.test.js +1 -0
- package/dist/esm/stockSkills/vma.d.ts +11 -26
- package/dist/esm/stockSkills/williams.d.ts +20 -32
- package/dist/umd/index.js +145 -155
- package/package.json +17 -15
package/demo/main.js
CHANGED
|
@@ -1,12 +1,13 @@
|
|
|
1
1
|
/* eslint @typescript-eslint/no-var-requires: "off" */
|
|
2
2
|
const axios = require("axios");
|
|
3
3
|
const {
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
4
|
+
Obv,
|
|
5
|
+
findPeaksByGradient,
|
|
6
|
+
findTroughByGradient,
|
|
7
7
|
} = require("../dist/cjs/index.js");
|
|
8
8
|
|
|
9
|
-
|
|
9
|
+
// 使用示例
|
|
10
|
+
const obv = new Obv();
|
|
10
11
|
function DemoDay(stockId) {
|
|
11
12
|
axios
|
|
12
13
|
.get(
|
|
@@ -16,13 +17,19 @@ function DemoDay(stockId) {
|
|
|
16
17
|
res = res.data.replace(/^\(|\);$/g, "");
|
|
17
18
|
let parse = JSON.parse(res);
|
|
18
19
|
let data = parse.ta;
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
const
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
20
|
+
let obvData = obv.getObv(data);
|
|
21
|
+
obvData = obvData.map((item) => item.obv);
|
|
22
|
+
const peak = findPeaksByGradient(obvData, 1);
|
|
23
|
+
const peakIndex =peak[peak.length-1]
|
|
24
|
+
const peak2Index =peak[peak.length-2]
|
|
25
|
+
console.log(data[peakIndex].t, data[peakIndex].c);
|
|
26
|
+
console.log(data[peak2Index].t, data[peak2Index].c);
|
|
27
|
+
|
|
28
|
+
const trough = findTroughByGradient(obvData, 1);
|
|
29
|
+
const troughIndex =trough[trough.length-1]
|
|
30
|
+
const trough2Index =trough[trough.length-2]
|
|
31
|
+
console.log(data[troughIndex].t, data[troughIndex].c);
|
|
32
|
+
console.log(data[trough2Index].t, data[trough2Index].c);
|
|
26
33
|
})
|
|
27
34
|
.catch((error) => {
|
|
28
35
|
console.error(error);
|
|
@@ -32,4 +39,4 @@ function DemoDay(stockId) {
|
|
|
32
39
|
});
|
|
33
40
|
}
|
|
34
41
|
|
|
35
|
-
DemoDay("
|
|
42
|
+
DemoDay("2385");
|
|
@@ -1,59 +1,34 @@
|
|
|
1
|
-
|
|
2
|
-
c: number;
|
|
3
|
-
[key: string]: unknown;
|
|
4
|
-
};
|
|
5
|
-
type ListType = ItemType[];
|
|
1
|
+
import { StockListType, StockType } from "./types";
|
|
6
2
|
export type BollResType = {
|
|
7
|
-
|
|
8
|
-
bollMa: number
|
|
9
|
-
bollUb: number
|
|
10
|
-
bollLb: number
|
|
11
|
-
}
|
|
12
|
-
interface
|
|
13
|
-
init: (data:
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
bollMa: number | null;
|
|
22
|
-
bollUb: number | null;
|
|
23
|
-
bollLb: number | null;
|
|
24
|
-
}, type: number) => {
|
|
25
|
-
dataset: ListType;
|
|
26
|
-
bollMa: number | null;
|
|
27
|
-
bollUb: number | null;
|
|
28
|
-
bollLb: number | null;
|
|
29
|
-
};
|
|
30
|
-
getBoll: (list: ListType, type: number) => BollResType;
|
|
3
|
+
dataset: StockListType;
|
|
4
|
+
bollMa: number;
|
|
5
|
+
bollUb: number;
|
|
6
|
+
bollLb: number;
|
|
7
|
+
};
|
|
8
|
+
interface BollClassType {
|
|
9
|
+
init: (data: StockType) => BollResType;
|
|
10
|
+
next: (data: StockType, preList: BollResType, type: number) => BollResType;
|
|
11
|
+
getBoll: (list: StockListType, type: number) => {
|
|
12
|
+
[key: string]: unknown;
|
|
13
|
+
bollMa: number;
|
|
14
|
+
bollUb: number;
|
|
15
|
+
bollLb: number;
|
|
16
|
+
}[];
|
|
31
17
|
}
|
|
32
|
-
export default class Boll implements
|
|
33
|
-
init(data:
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
bollUb: number | null;
|
|
37
|
-
bollLb: number | null;
|
|
38
|
-
};
|
|
39
|
-
next(data: ItemType, preList: {
|
|
40
|
-
dataset: ListType;
|
|
41
|
-
bollMa: number | null;
|
|
42
|
-
bollUb: number | null;
|
|
43
|
-
bollLb: number | null;
|
|
44
|
-
}, type: number): {
|
|
45
|
-
dataset: ListType;
|
|
46
|
-
type: number;
|
|
47
|
-
bollMa: null;
|
|
48
|
-
bollUb: null;
|
|
49
|
-
bollLb: null;
|
|
50
|
-
} | {
|
|
51
|
-
dataset: ListType;
|
|
18
|
+
export default class Boll implements BollClassType {
|
|
19
|
+
init(data: StockType): BollResType;
|
|
20
|
+
next(data: StockType, preList: BollResType, type: number): {
|
|
21
|
+
dataset: StockListType;
|
|
52
22
|
type: number;
|
|
53
23
|
bollMa: number;
|
|
54
24
|
bollUb: number;
|
|
55
25
|
bollLb: number;
|
|
56
26
|
};
|
|
57
|
-
getBoll(list:
|
|
27
|
+
getBoll(list: StockListType, type: number): {
|
|
28
|
+
[key: string]: unknown;
|
|
29
|
+
bollMa: number;
|
|
30
|
+
bollUb: number;
|
|
31
|
+
bollLb: number;
|
|
32
|
+
}[];
|
|
58
33
|
}
|
|
59
34
|
export {};
|
|
@@ -21,9 +21,9 @@ var Boll = /** @class */ (function () {
|
|
|
21
21
|
value: function (data) {
|
|
22
22
|
return {
|
|
23
23
|
dataset: [data],
|
|
24
|
-
bollMa:
|
|
25
|
-
bollUb:
|
|
26
|
-
bollLb:
|
|
24
|
+
bollMa: 0,
|
|
25
|
+
bollUb: 0,
|
|
26
|
+
bollLb: 0,
|
|
27
27
|
};
|
|
28
28
|
}
|
|
29
29
|
});
|
|
@@ -37,9 +37,9 @@ var Boll = /** @class */ (function () {
|
|
|
37
37
|
return {
|
|
38
38
|
dataset: preList.dataset,
|
|
39
39
|
type: type,
|
|
40
|
-
bollMa:
|
|
41
|
-
bollUb:
|
|
42
|
-
bollLb:
|
|
40
|
+
bollMa: 0,
|
|
41
|
+
bollUb: 0,
|
|
42
|
+
bollLb: 0,
|
|
43
43
|
};
|
|
44
44
|
}
|
|
45
45
|
else {
|
|
@@ -49,7 +49,7 @@ var Boll = /** @class */ (function () {
|
|
|
49
49
|
var sum = preList.dataset.reduce(function (pre, current) { return pre + current.c; }, 0);
|
|
50
50
|
var bollMa_1 = Math.round((sum / type) * 100) / 100;
|
|
51
51
|
var difference = preList.dataset.reduce(function (pre, current) {
|
|
52
|
-
return bollMa_1 !==
|
|
52
|
+
return bollMa_1 !== 0 ? pre + Math.pow(current.c - bollMa_1, 2) : pre;
|
|
53
53
|
}, 0);
|
|
54
54
|
var std = Math.round(Math.sqrt(difference / type) * 100) / 100;
|
|
55
55
|
return {
|
|
@@ -70,7 +70,7 @@ var Boll = /** @class */ (function () {
|
|
|
70
70
|
var res = [];
|
|
71
71
|
var _loop_1 = function (i) {
|
|
72
72
|
if (i < type)
|
|
73
|
-
res[i] = __assign(__assign({}, list[i]), { bollMa:
|
|
73
|
+
res[i] = __assign(__assign({}, list[i]), { bollMa: 0, bollUb: 0, bollLb: 0 });
|
|
74
74
|
else {
|
|
75
75
|
// bollMa
|
|
76
76
|
var sumMa = list
|
|
@@ -81,9 +81,7 @@ var Boll = /** @class */ (function () {
|
|
|
81
81
|
var difference = res
|
|
82
82
|
.slice(i - (type - 1), i + 1)
|
|
83
83
|
.reduce(function (pre, current) {
|
|
84
|
-
return bollMa_2 !==
|
|
85
|
-
? pre + Math.pow(current.c - bollMa_2, 2)
|
|
86
|
-
: pre;
|
|
84
|
+
return bollMa_2 !== 0 ? pre + Math.pow(current.c - bollMa_2, 2) : pre;
|
|
87
85
|
}, 0);
|
|
88
86
|
var std = Math.round(Math.sqrt(difference / type) * 100) / 100;
|
|
89
87
|
res[i] = __assign(__assign({}, list[i]), { bollMa: bollMa_2, bollUb: bollMa_2 + 2 * std, bollLb: bollMa_2 - 2 * std });
|
|
@@ -1,40 +1,18 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
import { StockListType, StockType } from "./types";
|
|
2
|
+
export type EmaResType = {
|
|
3
|
+
dataset: StockListType;
|
|
4
|
+
ema: number;
|
|
5
|
+
type: number;
|
|
4
6
|
};
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
dataset: ListType;
|
|
9
|
-
ema: number;
|
|
10
|
-
type: number;
|
|
11
|
-
};
|
|
12
|
-
next: (data: ItemType, preList: {
|
|
13
|
-
dataset: ListType;
|
|
14
|
-
ema: number;
|
|
15
|
-
type: number;
|
|
16
|
-
}, type: number) => {
|
|
17
|
-
dataset: ListType;
|
|
18
|
-
ema: number;
|
|
19
|
-
type: number;
|
|
20
|
-
};
|
|
7
|
+
interface EmaClassType {
|
|
8
|
+
init: (data: StockType, type: number) => EmaResType;
|
|
9
|
+
next: (data: StockType, preList: EmaResType, type: number) => EmaResType;
|
|
21
10
|
getStartEma: (list: number[], period: number) => number;
|
|
22
11
|
getEma: (list: number[], period: number) => (number | null)[];
|
|
23
12
|
}
|
|
24
|
-
export default class Ema implements
|
|
25
|
-
init(data:
|
|
26
|
-
|
|
27
|
-
ema: number;
|
|
28
|
-
type: number;
|
|
29
|
-
};
|
|
30
|
-
next(data: ItemType, preList: {
|
|
31
|
-
dataset: ListType;
|
|
32
|
-
ema: number;
|
|
33
|
-
}, type: number): {
|
|
34
|
-
dataset: ListType;
|
|
35
|
-
ema: number;
|
|
36
|
-
type: number;
|
|
37
|
-
};
|
|
13
|
+
export default class Ema implements EmaClassType {
|
|
14
|
+
init(data: StockType, type: number): EmaResType;
|
|
15
|
+
next(data: StockType, preList: EmaResType, type: number): EmaResType;
|
|
38
16
|
getStartEma(list: number[], period: number): number;
|
|
39
17
|
getEma(list: number[], period: number): (number | null)[];
|
|
40
18
|
}
|
|
@@ -1,3 +1,5 @@
|
|
|
1
|
+
import { StockListType } from "./types";
|
|
2
|
+
import { StockType } from "./types";
|
|
1
3
|
export type GetGoldResType = {
|
|
2
4
|
lowestPoint: number;
|
|
3
5
|
highestPoint: number;
|
|
@@ -7,42 +9,20 @@ export type GetGoldResType = {
|
|
|
7
9
|
weak: number;
|
|
8
10
|
superWeak: number;
|
|
9
11
|
};
|
|
10
|
-
type
|
|
11
|
-
|
|
12
|
-
t: number;
|
|
13
|
-
o: number;
|
|
14
|
-
c: number;
|
|
15
|
-
l: number;
|
|
16
|
-
[key: string]: unknown;
|
|
17
|
-
}[];
|
|
18
|
-
type FindHightestResType = {
|
|
19
|
-
[key: string]: {
|
|
20
|
-
h: number;
|
|
21
|
-
t: number;
|
|
22
|
-
o: number;
|
|
23
|
-
c: number;
|
|
24
|
-
l: number;
|
|
25
|
-
[key: string]: unknown;
|
|
26
|
-
};
|
|
12
|
+
export type FindHightestResType = {
|
|
13
|
+
[key: string]: StockType;
|
|
27
14
|
};
|
|
28
|
-
type FindLowestResType = {
|
|
29
|
-
[key: string]:
|
|
30
|
-
h: number;
|
|
31
|
-
t: number;
|
|
32
|
-
o: number;
|
|
33
|
-
c: number;
|
|
34
|
-
l: number;
|
|
35
|
-
[key: string]: unknown;
|
|
36
|
-
};
|
|
15
|
+
export type FindLowestResType = {
|
|
16
|
+
[key: string]: StockType;
|
|
37
17
|
};
|
|
38
|
-
interface
|
|
39
|
-
findHighPoint: (list:
|
|
40
|
-
findLowPoint: (list:
|
|
18
|
+
interface GoldClassType {
|
|
19
|
+
findHighPoint: (list: StockListType) => FindHightestResType;
|
|
20
|
+
findLowPoint: (list: StockListType) => FindLowestResType;
|
|
41
21
|
getGold: (highestPoint: number, lowestPoint: number) => GetGoldResType;
|
|
42
22
|
}
|
|
43
|
-
export default class Gold implements
|
|
44
|
-
findHighPoint(list:
|
|
45
|
-
findLowPoint(list:
|
|
23
|
+
export default class Gold implements GoldClassType {
|
|
24
|
+
findHighPoint(list: StockListType): FindHightestResType;
|
|
25
|
+
findLowPoint(list: StockListType): FindLowestResType;
|
|
46
26
|
getGold(highestPoint: number, lowestPoint: number): GetGoldResType;
|
|
47
27
|
}
|
|
48
28
|
export {};
|
|
@@ -1,78 +1,35 @@
|
|
|
1
|
-
|
|
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[];
|
|
1
|
+
import { StockListType, StockType } from "./types";
|
|
11
2
|
type ResRSV = {
|
|
12
3
|
c: number;
|
|
13
|
-
rsv: number
|
|
14
|
-
|
|
4
|
+
rsv: number;
|
|
5
|
+
[key: string]: unknown;
|
|
6
|
+
};
|
|
15
7
|
type ResKD = {
|
|
16
8
|
c: number;
|
|
17
|
-
rsv: number
|
|
18
|
-
k: number
|
|
19
|
-
d: number
|
|
20
|
-
"k-d": number
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
} | {
|
|
43
|
-
dataset: ListType;
|
|
44
|
-
rsv: number;
|
|
45
|
-
k: number;
|
|
46
|
-
d: number;
|
|
47
|
-
"k-d": number;
|
|
48
|
-
};
|
|
49
|
-
getRSV(list: ListType): ({
|
|
50
|
-
rsv: null;
|
|
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: null;
|
|
62
|
-
k: null;
|
|
63
|
-
d: null;
|
|
64
|
-
"k-d": null;
|
|
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
|
-
})[];
|
|
9
|
+
rsv: number;
|
|
10
|
+
k: number;
|
|
11
|
+
d: number;
|
|
12
|
+
"k-d": number;
|
|
13
|
+
[key: string]: unknown;
|
|
14
|
+
};
|
|
15
|
+
export type KdResType = {
|
|
16
|
+
dataset: StockListType;
|
|
17
|
+
rsv: number;
|
|
18
|
+
k: number;
|
|
19
|
+
d: number;
|
|
20
|
+
"k-d": number;
|
|
21
|
+
type: number;
|
|
22
|
+
};
|
|
23
|
+
interface KdClassType {
|
|
24
|
+
init: (data: StockType, type: number) => KdResType;
|
|
25
|
+
next: (data: StockType, preList: KdResType, type: number) => KdResType;
|
|
26
|
+
getRSV: (list: StockListType) => ResRSV[];
|
|
27
|
+
getKD: (list: StockListType) => ResKD[];
|
|
28
|
+
}
|
|
29
|
+
export default class Kd implements KdClassType {
|
|
30
|
+
init(data: StockType, type: number): KdResType;
|
|
31
|
+
next(data: StockType, preList: KdResType, type: number): KdResType;
|
|
32
|
+
getRSV(list: StockListType): ResRSV[];
|
|
33
|
+
getKD(list: StockListType): ResKD[];
|
|
77
34
|
}
|
|
78
35
|
export {};
|
|
@@ -18,13 +18,14 @@ var Kd = /** @class */ (function () {
|
|
|
18
18
|
enumerable: false,
|
|
19
19
|
configurable: true,
|
|
20
20
|
writable: true,
|
|
21
|
-
value: function (data) {
|
|
21
|
+
value: function (data, type) {
|
|
22
22
|
return {
|
|
23
23
|
dataset: [data],
|
|
24
|
-
rsv:
|
|
25
|
-
k:
|
|
26
|
-
d:
|
|
27
|
-
"k-d":
|
|
24
|
+
rsv: 0,
|
|
25
|
+
k: 0,
|
|
26
|
+
d: 0,
|
|
27
|
+
"k-d": 0,
|
|
28
|
+
type: type,
|
|
28
29
|
};
|
|
29
30
|
}
|
|
30
31
|
});
|
|
@@ -37,10 +38,11 @@ var Kd = /** @class */ (function () {
|
|
|
37
38
|
if (preList.dataset.length < type) {
|
|
38
39
|
return {
|
|
39
40
|
dataset: preList.dataset,
|
|
40
|
-
rsv:
|
|
41
|
-
k:
|
|
42
|
-
d:
|
|
43
|
-
"k-d":
|
|
41
|
+
rsv: 0,
|
|
42
|
+
k: 0,
|
|
43
|
+
d: 0,
|
|
44
|
+
"k-d": 0,
|
|
45
|
+
type: type,
|
|
44
46
|
};
|
|
45
47
|
}
|
|
46
48
|
else {
|
|
@@ -64,6 +66,7 @@ var Kd = /** @class */ (function () {
|
|
|
64
66
|
k: k,
|
|
65
67
|
d: d,
|
|
66
68
|
"k-d": k_d,
|
|
69
|
+
type: type,
|
|
67
70
|
};
|
|
68
71
|
}
|
|
69
72
|
}
|
|
@@ -76,7 +79,7 @@ var Kd = /** @class */ (function () {
|
|
|
76
79
|
var res = [];
|
|
77
80
|
for (var i = 0; i < list.length; i++) {
|
|
78
81
|
if (i < 8)
|
|
79
|
-
res[i] = __assign(__assign({}, list[i]), { rsv:
|
|
82
|
+
res[i] = __assign(__assign({}, list[i]), { rsv: 0 });
|
|
80
83
|
else {
|
|
81
84
|
var low = Math.min.apply(Math, list.slice(i - 8, i + 1).map(function (item) { return item.l; }));
|
|
82
85
|
var hight = Math.max.apply(Math, list.slice(i - 8, i + 1).map(function (item) { return item.h; }));
|
|
@@ -99,7 +102,7 @@ var Kd = /** @class */ (function () {
|
|
|
99
102
|
var yesterdayD = 50;
|
|
100
103
|
for (var i = 0; i < list.length; i++) {
|
|
101
104
|
if (i < 8)
|
|
102
|
-
res[i] = __assign(__assign({}, list[i]), { rsv:
|
|
105
|
+
res[i] = __assign(__assign({}, list[i]), { rsv: 0, k: 0, d: 0, "k-d": 0 });
|
|
103
106
|
else {
|
|
104
107
|
var low = Math.min.apply(Math, list.slice(i - 8, i + 1).map(function (item) { return item.l; }));
|
|
105
108
|
var hight = Math.max.apply(Math, list.slice(i - 8, i + 1).map(function (item) { return item.h; }));
|
|
@@ -7,7 +7,7 @@ describe("test kd methods", function () {
|
|
|
7
7
|
var index = test_data_test_1.data_9904.length - 1;
|
|
8
8
|
var kd = new kd_1.default();
|
|
9
9
|
var realData = kd.getKD(test_data_test_1.data_9904)[index];
|
|
10
|
-
var init = kd.init(test_data_test_1.data_9904[0]);
|
|
10
|
+
var init = kd.init(test_data_test_1.data_9904[0], 9);
|
|
11
11
|
var res = init;
|
|
12
12
|
for (var i = 1; i <= index; i++) {
|
|
13
13
|
var item = test_data_test_1.data_9904[i];
|
|
@@ -1,76 +1,55 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
import { StockListType, StockType } from "./types";
|
|
2
|
+
export type MaResType = {
|
|
3
|
+
dataset: StockListType;
|
|
4
|
+
ma: number;
|
|
5
|
+
type: number;
|
|
6
|
+
exclusionValue: {
|
|
7
|
+
"d+1": number;
|
|
8
|
+
d: number;
|
|
9
|
+
"d-1": number;
|
|
10
|
+
};
|
|
4
11
|
};
|
|
5
|
-
type ListType = DataType[];
|
|
6
12
|
type ResMa5 = {
|
|
7
13
|
c: number;
|
|
8
|
-
ma5: number
|
|
14
|
+
ma5: number;
|
|
9
15
|
}[];
|
|
10
16
|
type ResMa10 = {
|
|
11
17
|
c: number;
|
|
12
|
-
ma10: number
|
|
18
|
+
ma10: number;
|
|
13
19
|
}[];
|
|
14
20
|
type ResMa20 = {
|
|
15
21
|
c: number;
|
|
16
|
-
ma20: number
|
|
22
|
+
ma20: number;
|
|
17
23
|
}[];
|
|
18
24
|
type ResMa60 = {
|
|
19
25
|
c: number;
|
|
20
|
-
ma60: number
|
|
26
|
+
ma60: number;
|
|
21
27
|
}[];
|
|
22
28
|
type ResMa = {
|
|
23
29
|
c: number;
|
|
24
|
-
ma: number
|
|
30
|
+
ma: number;
|
|
25
31
|
}[];
|
|
26
32
|
type ResAllMa = {
|
|
27
33
|
c: number;
|
|
28
|
-
ma5: number
|
|
29
|
-
ma10: number
|
|
30
|
-
ma20: number
|
|
31
|
-
ma25: number
|
|
32
|
-
ma60: number
|
|
34
|
+
ma5: number;
|
|
35
|
+
ma10: number;
|
|
36
|
+
ma20: number;
|
|
37
|
+
ma25: number;
|
|
38
|
+
ma60: number;
|
|
33
39
|
}[];
|
|
34
40
|
interface MaType {
|
|
35
|
-
init: (data:
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
};
|
|
44
|
-
};
|
|
45
|
-
next: (data: DataType, preList: {
|
|
46
|
-
dataset: ListType;
|
|
47
|
-
ma: number;
|
|
48
|
-
type: number;
|
|
49
|
-
exclusionValue: {
|
|
50
|
-
"d+1": number;
|
|
51
|
-
d: number;
|
|
52
|
-
"d-1": number;
|
|
53
|
-
};
|
|
54
|
-
}, type: number) => {
|
|
55
|
-
dataset: ListType;
|
|
56
|
-
ma: number;
|
|
57
|
-
type: number;
|
|
58
|
-
exclusionValue: {
|
|
59
|
-
"d+1": number;
|
|
60
|
-
d: number;
|
|
61
|
-
"d-1": number;
|
|
62
|
-
};
|
|
63
|
-
};
|
|
64
|
-
getAllMa: (list: ListType) => ResAllMa;
|
|
65
|
-
getMa5: (list: ListType) => ResMa5;
|
|
66
|
-
getMa10: (list: ListType) => ResMa10;
|
|
67
|
-
getMa20: (list: ListType) => ResMa20;
|
|
68
|
-
getMa60: (list: ListType) => ResMa60;
|
|
69
|
-
getMa: (list: ListType, self: number) => ResMa;
|
|
41
|
+
init: (data: StockType, type: number) => MaResType;
|
|
42
|
+
next: (data: StockType, preList: MaResType, type: number) => MaResType;
|
|
43
|
+
getAllMa: (list: StockListType) => ResAllMa;
|
|
44
|
+
getMa5: (list: StockListType) => ResMa5;
|
|
45
|
+
getMa10: (list: StockListType) => ResMa10;
|
|
46
|
+
getMa20: (list: StockListType) => ResMa20;
|
|
47
|
+
getMa60: (list: StockListType) => ResMa60;
|
|
48
|
+
getMa: (list: StockListType, self: number) => ResMa;
|
|
70
49
|
}
|
|
71
50
|
export default class Ma implements MaType {
|
|
72
|
-
init(data:
|
|
73
|
-
dataset:
|
|
51
|
+
init(data: StockType, type: number): {
|
|
52
|
+
dataset: StockType[];
|
|
74
53
|
ma: number;
|
|
75
54
|
type: number;
|
|
76
55
|
exclusionValue: {
|
|
@@ -79,12 +58,12 @@ export default class Ma implements MaType {
|
|
|
79
58
|
"d-1": number;
|
|
80
59
|
};
|
|
81
60
|
};
|
|
82
|
-
next(data:
|
|
83
|
-
dataset:
|
|
61
|
+
next(data: StockType, preList: {
|
|
62
|
+
dataset: StockListType;
|
|
84
63
|
ma: number;
|
|
85
64
|
type: number;
|
|
86
65
|
}, type: number): {
|
|
87
|
-
dataset:
|
|
66
|
+
dataset: StockListType;
|
|
88
67
|
ma: number;
|
|
89
68
|
type: number;
|
|
90
69
|
exclusionValue: {
|
|
@@ -93,11 +72,11 @@ export default class Ma implements MaType {
|
|
|
93
72
|
"d-1": number;
|
|
94
73
|
};
|
|
95
74
|
};
|
|
96
|
-
getAllMa(list:
|
|
97
|
-
getMa5(list:
|
|
98
|
-
getMa10(list:
|
|
99
|
-
getMa20(list:
|
|
100
|
-
getMa60(list:
|
|
101
|
-
getMa(list:
|
|
75
|
+
getAllMa(list: StockListType): ResAllMa;
|
|
76
|
+
getMa5(list: StockListType): ResMa5;
|
|
77
|
+
getMa10(list: StockListType): ResMa10;
|
|
78
|
+
getMa20(list: StockListType): ResMa20;
|
|
79
|
+
getMa60(list: StockListType): ResMa60;
|
|
80
|
+
getMa(list: StockListType, self: number): ResMa;
|
|
102
81
|
}
|
|
103
82
|
export {};
|