@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
|
@@ -1,17 +1,5 @@
|
|
|
1
|
-
|
|
2
|
-
h: number;
|
|
3
|
-
t: number;
|
|
4
|
-
o: number;
|
|
5
|
-
c: number;
|
|
6
|
-
l: number;
|
|
7
|
-
}[];
|
|
1
|
+
import { StockListType, StockType } from "../types";
|
|
8
2
|
export type ResType = {
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
c: number;
|
|
13
|
-
l: number;
|
|
14
|
-
detail?: ListType;
|
|
15
|
-
};
|
|
16
|
-
export default function getWeekLine(list: ListType, detail: boolean): ResType[];
|
|
17
|
-
export {};
|
|
3
|
+
detail?: StockListType;
|
|
4
|
+
} & StockType;
|
|
5
|
+
export default function getWeekLine(list: StockListType, detail: boolean): ResType[];
|
|
@@ -36,6 +36,7 @@ function getWeekLine(list, detail) {
|
|
|
36
36
|
t: collectWeekData[collectWeekData.length - 1]["t"],
|
|
37
37
|
h: Math.max.apply(Math, collectWeekData.map(function (item) { return item.h; })),
|
|
38
38
|
l: Math.min.apply(Math, collectWeekData.map(function (item) { return item.l; })),
|
|
39
|
+
v: collectWeekData.reduce(function (pre, current) { return pre + current.v; }, 0),
|
|
39
40
|
};
|
|
40
41
|
res.push(addDetail(obj, collectWeekData, detail));
|
|
41
42
|
collectWeekData = [];
|
|
@@ -49,6 +50,7 @@ function getWeekLine(list, detail) {
|
|
|
49
50
|
t: collectWeekData[collectWeekData.length - 1]["t"],
|
|
50
51
|
h: Math.max.apply(Math, collectWeekData.map(function (item) { return item.h; })),
|
|
51
52
|
l: Math.min.apply(Math, collectWeekData.map(function (item) { return item.l; })),
|
|
53
|
+
v: collectWeekData.reduce(function (pre, current) { return pre + current.v; }, 0),
|
|
52
54
|
};
|
|
53
55
|
res.push(addDetail(obj, collectWeekData, detail));
|
|
54
56
|
}
|
|
@@ -64,6 +66,7 @@ function getWeekLine(list, detail) {
|
|
|
64
66
|
t: collectWeekData[collectWeekData.length - 1]["t"],
|
|
65
67
|
h: Math.max.apply(Math, collectWeekData.map(function (item) { return item.h; })),
|
|
66
68
|
l: Math.min.apply(Math, collectWeekData.map(function (item) { return item.l; })),
|
|
69
|
+
v: collectWeekData.reduce(function (pre, current) { return pre + current.v; }, 0),
|
|
67
70
|
};
|
|
68
71
|
res.push(addDetail(obj, collectWeekData, detail));
|
|
69
72
|
}
|
|
@@ -1,36 +1,21 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
import { StockListType, StockType } from "./types";
|
|
2
|
+
export type VmaResType = {
|
|
3
|
+
dataset: StockListType;
|
|
4
|
+
vma: number;
|
|
5
|
+
type: number;
|
|
4
6
|
};
|
|
5
|
-
type ListType = DataType[];
|
|
6
7
|
interface VmaType {
|
|
7
|
-
init: (data:
|
|
8
|
-
|
|
9
|
-
vma: number;
|
|
10
|
-
type: number;
|
|
11
|
-
};
|
|
12
|
-
next: (data: DataType, preList: {
|
|
13
|
-
dataset: ListType;
|
|
14
|
-
vma: number;
|
|
15
|
-
type: number;
|
|
16
|
-
}, type: number) => {
|
|
17
|
-
dataset: ListType;
|
|
18
|
-
vma: number;
|
|
19
|
-
type: number;
|
|
20
|
-
};
|
|
8
|
+
init: (data: StockType, type: number) => VmaResType;
|
|
9
|
+
next: (data: StockType, preList: VmaResType, type: number) => VmaResType;
|
|
21
10
|
}
|
|
22
11
|
export default class Vma implements VmaType {
|
|
23
|
-
init(data:
|
|
24
|
-
dataset:
|
|
12
|
+
init(data: StockType, type: number): {
|
|
13
|
+
dataset: StockType[];
|
|
25
14
|
vma: number;
|
|
26
15
|
type: number;
|
|
27
16
|
};
|
|
28
|
-
next(data:
|
|
29
|
-
dataset:
|
|
30
|
-
vma: number;
|
|
31
|
-
type: number;
|
|
32
|
-
}, type: number): {
|
|
33
|
-
dataset: ListType;
|
|
17
|
+
next(data: StockType, preList: VmaResType, type: number): {
|
|
18
|
+
dataset: StockListType;
|
|
34
19
|
vma: number;
|
|
35
20
|
type: number;
|
|
36
21
|
};
|
|
@@ -1,9 +1,4 @@
|
|
|
1
|
-
|
|
2
|
-
h: number;
|
|
3
|
-
l: number;
|
|
4
|
-
c: number;
|
|
5
|
-
};
|
|
6
|
-
type ListType = DataType[];
|
|
1
|
+
import { StockListType, StockType } from "./types";
|
|
7
2
|
type ResWilliams9Type = {
|
|
8
3
|
c: number;
|
|
9
4
|
williams9: number | null;
|
|
@@ -17,42 +12,35 @@ type ResAllWilliamsType = {
|
|
|
17
12
|
williams18: number | null;
|
|
18
13
|
williams9: number | null;
|
|
19
14
|
}[];
|
|
15
|
+
export type WilliamsResType = {
|
|
16
|
+
dataset: StockListType;
|
|
17
|
+
williams: number;
|
|
18
|
+
type: number;
|
|
19
|
+
};
|
|
20
20
|
interface WilliamsType {
|
|
21
|
-
init: (data:
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
type: number;
|
|
25
|
-
};
|
|
26
|
-
next: (data: DataType, preList: {
|
|
27
|
-
dataset: ListType;
|
|
21
|
+
init: (data: StockType, type: number) => WilliamsResType;
|
|
22
|
+
next: (data: StockType, preList: {
|
|
23
|
+
dataset: StockListType;
|
|
28
24
|
williams: number;
|
|
29
25
|
type: number;
|
|
30
|
-
}, type: number) =>
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
};
|
|
35
|
-
getWilliams9: (list: ListType) => ResWilliams9Type;
|
|
36
|
-
getWilliams18: (list: ListType) => ResWilliams18Type;
|
|
37
|
-
getAllWillams(list: ListType): ResAllWilliamsType;
|
|
26
|
+
}, type: number) => WilliamsResType;
|
|
27
|
+
getWilliams9: (list: StockListType) => ResWilliams9Type;
|
|
28
|
+
getWilliams18: (list: StockListType) => ResWilliams18Type;
|
|
29
|
+
getAllWillams(list: StockListType): ResAllWilliamsType;
|
|
38
30
|
}
|
|
39
31
|
export default class Williams implements WilliamsType {
|
|
40
|
-
init(data:
|
|
41
|
-
dataset:
|
|
32
|
+
init(data: StockType, type: number): {
|
|
33
|
+
dataset: StockType[];
|
|
42
34
|
williams: number;
|
|
43
35
|
type: number;
|
|
44
36
|
};
|
|
45
|
-
next(data:
|
|
46
|
-
dataset:
|
|
47
|
-
williams: number;
|
|
48
|
-
type: number;
|
|
49
|
-
}, type: number): {
|
|
50
|
-
dataset: ListType;
|
|
37
|
+
next(data: StockType, preList: WilliamsResType, type: number): {
|
|
38
|
+
dataset: StockListType;
|
|
51
39
|
williams: number;
|
|
52
40
|
type: number;
|
|
53
41
|
};
|
|
54
|
-
getAllWillams(list:
|
|
55
|
-
getWilliams9(list:
|
|
56
|
-
getWilliams18(list:
|
|
42
|
+
getAllWillams(list: StockListType): ResAllWilliamsType;
|
|
43
|
+
getWilliams9(list: StockListType): ResWilliams9Type;
|
|
44
|
+
getWilliams18(list: StockListType): ResWilliams18Type;
|
|
57
45
|
}
|
|
58
46
|
export {};
|
|
@@ -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 {};
|
|
@@ -19,9 +19,9 @@ var Boll = /** @class */ (function () {
|
|
|
19
19
|
value: function (data) {
|
|
20
20
|
return {
|
|
21
21
|
dataset: [data],
|
|
22
|
-
bollMa:
|
|
23
|
-
bollUb:
|
|
24
|
-
bollLb:
|
|
22
|
+
bollMa: 0,
|
|
23
|
+
bollUb: 0,
|
|
24
|
+
bollLb: 0,
|
|
25
25
|
};
|
|
26
26
|
}
|
|
27
27
|
});
|
|
@@ -35,9 +35,9 @@ var Boll = /** @class */ (function () {
|
|
|
35
35
|
return {
|
|
36
36
|
dataset: preList.dataset,
|
|
37
37
|
type: type,
|
|
38
|
-
bollMa:
|
|
39
|
-
bollUb:
|
|
40
|
-
bollLb:
|
|
38
|
+
bollMa: 0,
|
|
39
|
+
bollUb: 0,
|
|
40
|
+
bollLb: 0,
|
|
41
41
|
};
|
|
42
42
|
}
|
|
43
43
|
else {
|
|
@@ -47,7 +47,7 @@ var Boll = /** @class */ (function () {
|
|
|
47
47
|
var sum = preList.dataset.reduce(function (pre, current) { return pre + current.c; }, 0);
|
|
48
48
|
var bollMa_1 = Math.round((sum / type) * 100) / 100;
|
|
49
49
|
var difference = preList.dataset.reduce(function (pre, current) {
|
|
50
|
-
return bollMa_1 !==
|
|
50
|
+
return bollMa_1 !== 0 ? pre + Math.pow(current.c - bollMa_1, 2) : pre;
|
|
51
51
|
}, 0);
|
|
52
52
|
var std = Math.round(Math.sqrt(difference / type) * 100) / 100;
|
|
53
53
|
return {
|
|
@@ -68,7 +68,7 @@ var Boll = /** @class */ (function () {
|
|
|
68
68
|
var res = [];
|
|
69
69
|
var _loop_1 = function (i) {
|
|
70
70
|
if (i < type)
|
|
71
|
-
res[i] = __assign(__assign({}, list[i]), { bollMa:
|
|
71
|
+
res[i] = __assign(__assign({}, list[i]), { bollMa: 0, bollUb: 0, bollLb: 0 });
|
|
72
72
|
else {
|
|
73
73
|
// bollMa
|
|
74
74
|
var sumMa = list
|
|
@@ -79,9 +79,7 @@ var Boll = /** @class */ (function () {
|
|
|
79
79
|
var difference = res
|
|
80
80
|
.slice(i - (type - 1), i + 1)
|
|
81
81
|
.reduce(function (pre, current) {
|
|
82
|
-
return bollMa_2 !==
|
|
83
|
-
? pre + Math.pow(current.c - bollMa_2, 2)
|
|
84
|
-
: pre;
|
|
82
|
+
return bollMa_2 !== 0 ? pre + Math.pow(current.c - bollMa_2, 2) : pre;
|
|
85
83
|
}, 0);
|
|
86
84
|
var std = Math.round(Math.sqrt(difference / type) * 100) / 100;
|
|
87
85
|
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 {};
|
|
@@ -16,13 +16,14 @@ var Kd = /** @class */ (function () {
|
|
|
16
16
|
enumerable: false,
|
|
17
17
|
configurable: true,
|
|
18
18
|
writable: true,
|
|
19
|
-
value: function (data) {
|
|
19
|
+
value: function (data, type) {
|
|
20
20
|
return {
|
|
21
21
|
dataset: [data],
|
|
22
|
-
rsv:
|
|
23
|
-
k:
|
|
24
|
-
d:
|
|
25
|
-
"k-d":
|
|
22
|
+
rsv: 0,
|
|
23
|
+
k: 0,
|
|
24
|
+
d: 0,
|
|
25
|
+
"k-d": 0,
|
|
26
|
+
type: type,
|
|
26
27
|
};
|
|
27
28
|
}
|
|
28
29
|
});
|
|
@@ -35,10 +36,11 @@ var Kd = /** @class */ (function () {
|
|
|
35
36
|
if (preList.dataset.length < type) {
|
|
36
37
|
return {
|
|
37
38
|
dataset: preList.dataset,
|
|
38
|
-
rsv:
|
|
39
|
-
k:
|
|
40
|
-
d:
|
|
41
|
-
"k-d":
|
|
39
|
+
rsv: 0,
|
|
40
|
+
k: 0,
|
|
41
|
+
d: 0,
|
|
42
|
+
"k-d": 0,
|
|
43
|
+
type: type,
|
|
42
44
|
};
|
|
43
45
|
}
|
|
44
46
|
else {
|
|
@@ -62,6 +64,7 @@ var Kd = /** @class */ (function () {
|
|
|
62
64
|
k: k,
|
|
63
65
|
d: d,
|
|
64
66
|
"k-d": k_d,
|
|
67
|
+
type: type,
|
|
65
68
|
};
|
|
66
69
|
}
|
|
67
70
|
}
|
|
@@ -74,7 +77,7 @@ var Kd = /** @class */ (function () {
|
|
|
74
77
|
var res = [];
|
|
75
78
|
for (var i = 0; i < list.length; i++) {
|
|
76
79
|
if (i < 8)
|
|
77
|
-
res[i] = __assign(__assign({}, list[i]), { rsv:
|
|
80
|
+
res[i] = __assign(__assign({}, list[i]), { rsv: 0 });
|
|
78
81
|
else {
|
|
79
82
|
var low = Math.min.apply(Math, list.slice(i - 8, i + 1).map(function (item) { return item.l; }));
|
|
80
83
|
var hight = Math.max.apply(Math, list.slice(i - 8, i + 1).map(function (item) { return item.h; }));
|
|
@@ -97,7 +100,7 @@ var Kd = /** @class */ (function () {
|
|
|
97
100
|
var yesterdayD = 50;
|
|
98
101
|
for (var i = 0; i < list.length; i++) {
|
|
99
102
|
if (i < 8)
|
|
100
|
-
res[i] = __assign(__assign({}, list[i]), { rsv:
|
|
103
|
+
res[i] = __assign(__assign({}, list[i]), { rsv: 0, k: 0, d: 0, "k-d": 0 });
|
|
101
104
|
else {
|
|
102
105
|
var low = Math.min.apply(Math, list.slice(i - 8, i + 1).map(function (item) { return item.l; }));
|
|
103
106
|
var hight = Math.max.apply(Math, list.slice(i - 8, i + 1).map(function (item) { return item.h; }));
|
|
@@ -5,7 +5,7 @@ describe("test kd methods", function () {
|
|
|
5
5
|
var index = data.length - 1;
|
|
6
6
|
var kd = new Kd();
|
|
7
7
|
var realData = kd.getKD(data)[index];
|
|
8
|
-
var init = kd.init(data[0]);
|
|
8
|
+
var init = kd.init(data[0], 9);
|
|
9
9
|
var res = init;
|
|
10
10
|
for (var i = 1; i <= index; i++) {
|
|
11
11
|
var item = data[i];
|