@simahfud/pine-to-kline 0.1.0 → 0.1.1
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/PineInterpreter.d.ts +19 -0
- package/dist/PineInterpreter.d.ts.map +1 -0
- package/dist/PineInterpreter.js +89 -0
- package/dist/PineInterpreter.js.map +1 -0
- package/dist/adapter/FigureMapper.d.ts +8 -0
- package/dist/adapter/FigureMapper.d.ts.map +1 -0
- package/dist/adapter/FigureMapper.js +22 -0
- package/dist/adapter/FigureMapper.js.map +1 -0
- package/dist/adapter/KlineAdapter.d.ts +11 -0
- package/dist/adapter/KlineAdapter.d.ts.map +1 -0
- package/dist/adapter/KlineAdapter.js +88 -0
- package/dist/adapter/KlineAdapter.js.map +1 -0
- package/dist/adapter/StyleMapper.d.ts +10 -0
- package/dist/adapter/StyleMapper.d.ts.map +1 -0
- package/dist/adapter/StyleMapper.js +28 -0
- package/dist/adapter/StyleMapper.js.map +1 -0
- package/dist/builtins/color/constants.d.ts +7 -0
- package/dist/builtins/color/constants.d.ts.map +1 -0
- package/dist/builtins/color/constants.js +25 -0
- package/dist/builtins/color/constants.js.map +1 -0
- package/dist/builtins/color/functions.d.ts +21 -0
- package/dist/builtins/color/functions.d.ts.map +1 -0
- package/dist/builtins/color/functions.js +52 -0
- package/dist/builtins/color/functions.js.map +1 -0
- package/dist/builtins/index.d.ts +15 -0
- package/dist/builtins/index.d.ts.map +1 -0
- package/dist/builtins/index.js +32 -0
- package/dist/builtins/index.js.map +1 -0
- package/dist/builtins/input/functions.d.ts +28 -0
- package/dist/builtins/input/functions.d.ts.map +1 -0
- package/dist/builtins/input/functions.js +114 -0
- package/dist/builtins/input/functions.js.map +1 -0
- package/dist/builtins/math/functions.d.ts +9 -0
- package/dist/builtins/math/functions.d.ts.map +1 -0
- package/dist/builtins/math/functions.js +57 -0
- package/dist/builtins/math/functions.js.map +1 -0
- package/dist/builtins/ta/crossover.d.ts +18 -0
- package/dist/builtins/ta/crossover.d.ts.map +1 -0
- package/dist/builtins/ta/crossover.js +59 -0
- package/dist/builtins/ta/crossover.js.map +1 -0
- package/dist/builtins/ta/index.d.ts +12 -0
- package/dist/builtins/ta/index.d.ts.map +1 -0
- package/dist/builtins/ta/index.js +61 -0
- package/dist/builtins/ta/index.js.map +1 -0
- package/dist/builtins/ta/momentum.d.ts +22 -0
- package/dist/builtins/ta/momentum.d.ts.map +1 -0
- package/dist/builtins/ta/momentum.js +81 -0
- package/dist/builtins/ta/momentum.js.map +1 -0
- package/dist/builtins/ta/moving-averages.d.ts +24 -0
- package/dist/builtins/ta/moving-averages.d.ts.map +1 -0
- package/dist/builtins/ta/moving-averages.js +108 -0
- package/dist/builtins/ta/moving-averages.js.map +1 -0
- package/dist/builtins/ta/utility.d.ts +28 -0
- package/dist/builtins/ta/utility.d.ts.map +1 -0
- package/dist/builtins/ta/utility.js +156 -0
- package/dist/builtins/ta/utility.js.map +1 -0
- package/dist/builtins/ta/volatility.d.ts +21 -0
- package/dist/builtins/ta/volatility.d.ts.map +1 -0
- package/dist/builtins/ta/volatility.js +71 -0
- package/dist/builtins/ta/volatility.js.map +1 -0
- package/dist/index.d.ts +21 -695
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +24 -0
- package/dist/index.js.map +1 -0
- package/dist/lexer/Lexer.d.ts +40 -0
- package/dist/lexer/Lexer.d.ts.map +1 -0
- package/dist/lexer/Lexer.js +383 -0
- package/dist/lexer/Lexer.js.map +1 -0
- package/dist/lexer/Token.d.ts +16 -0
- package/dist/lexer/Token.d.ts.map +1 -0
- package/dist/lexer/Token.js +26 -0
- package/dist/lexer/Token.js.map +1 -0
- package/dist/lexer/TokenType.d.ts +74 -0
- package/dist/lexer/TokenType.d.ts.map +1 -0
- package/dist/lexer/TokenType.js +111 -0
- package/dist/lexer/TokenType.js.map +1 -0
- package/dist/parser/Parser.d.ts +55 -0
- package/dist/parser/Parser.d.ts.map +1 -0
- package/dist/parser/Parser.js +569 -0
- package/dist/parser/Parser.js.map +1 -0
- package/dist/parser/nodes/index.d.ts +215 -0
- package/dist/parser/nodes/index.d.ts.map +1 -0
- package/dist/parser/nodes/index.js +7 -0
- package/dist/parser/nodes/index.js.map +1 -0
- package/dist/plugin/KlineChartProPlugin.d.ts +43 -0
- package/dist/plugin/KlineChartProPlugin.d.ts.map +1 -0
- package/dist/plugin/KlineChartProPlugin.js +44 -0
- package/dist/plugin/KlineChartProPlugin.js.map +1 -0
- package/dist/runtime/BarContext.d.ts +23 -0
- package/dist/runtime/BarContext.d.ts.map +1 -0
- package/dist/runtime/BarContext.js +41 -0
- package/dist/runtime/BarContext.js.map +1 -0
- package/dist/runtime/PineRuntime.d.ts +51 -0
- package/dist/runtime/PineRuntime.d.ts.map +1 -0
- package/dist/runtime/PineRuntime.js +471 -0
- package/dist/runtime/PineRuntime.js.map +1 -0
- package/dist/runtime/SeriesEmulator.d.ts +21 -0
- package/dist/runtime/SeriesEmulator.d.ts.map +1 -0
- package/dist/runtime/SeriesEmulator.js +32 -0
- package/dist/runtime/SeriesEmulator.js.map +1 -0
- package/dist/runtime/VarPersistence.d.ts +20 -0
- package/dist/runtime/VarPersistence.d.ts.map +1 -0
- package/dist/runtime/VarPersistence.js +28 -0
- package/dist/runtime/VarPersistence.js.map +1 -0
- package/dist/types.d.ts +97 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +6 -0
- package/dist/types.js.map +1 -0
- package/dist/utils/errors.d.ts +24 -0
- package/dist/utils/errors.d.ts.map +1 -0
- package/dist/utils/errors.js +46 -0
- package/dist/utils/errors.js.map +1 -0
- package/package.json +1 -1
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* pine-to-kline — TA Utility Functions
|
|
3
|
+
* Implements: highest, lowest, highestbars, lowestbars, barssince, valuewhen, pivothigh, pivotlow
|
|
4
|
+
* @license Apache-2.0
|
|
5
|
+
*/
|
|
6
|
+
/** ta.highest() — highest value in last `length` bars */
|
|
7
|
+
export declare function highest(source: number[], length: number): number[];
|
|
8
|
+
/** ta.lowest() — lowest value in last `length` bars */
|
|
9
|
+
export declare function lowest(source: number[], length: number): number[];
|
|
10
|
+
/** ta.highestbars() — number of bars since highest value */
|
|
11
|
+
export declare function highestbars(source: number[], length: number): number[];
|
|
12
|
+
/** ta.lowestbars() — number of bars since lowest value */
|
|
13
|
+
export declare function lowestbars(source: number[], length: number): number[];
|
|
14
|
+
/** ta.barssince(condition) — bars since condition was last true */
|
|
15
|
+
export declare function barssince(condition: boolean[]): number[];
|
|
16
|
+
/** ta.valuewhen(condition, source, occurrence) */
|
|
17
|
+
export declare function valuewhen(condition: boolean[], source: number[], occurrence?: number): number[];
|
|
18
|
+
/** ta.pivothigh() — pivot high detection */
|
|
19
|
+
export declare function pivothigh(source: number[], leftBars: number, rightBars: number): number[];
|
|
20
|
+
/** ta.pivotlow() — pivot low detection */
|
|
21
|
+
export declare function pivotlow(source: number[], leftBars: number, rightBars: number): number[];
|
|
22
|
+
/** ta.cum() — cumulative sum */
|
|
23
|
+
export declare function cum(source: number[]): number[];
|
|
24
|
+
/** ta.stdev() — standard deviation */
|
|
25
|
+
export declare function stdev(source: number[], length: number): number[];
|
|
26
|
+
/** ta.percentrank() — percent rank */
|
|
27
|
+
export declare function percentrank(source: number[], length: number): number[];
|
|
28
|
+
//# sourceMappingURL=utility.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utility.d.ts","sourceRoot":"","sources":["../../../src/builtins/ta/utility.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,yDAAyD;AACzD,wBAAgB,OAAO,CAAC,MAAM,EAAE,MAAM,EAAE,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,CASlE;AAED,uDAAuD;AACvD,wBAAgB,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,CASjE;AAED,4DAA4D;AAC5D,wBAAgB,WAAW,CAAC,MAAM,EAAE,MAAM,EAAE,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,CAUtE;AAED,0DAA0D;AAC1D,wBAAgB,UAAU,CAAC,MAAM,EAAE,MAAM,EAAE,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,CAUrE;AAED,mEAAmE;AACnE,wBAAgB,SAAS,CAAC,SAAS,EAAE,OAAO,EAAE,GAAG,MAAM,EAAE,CAMxD;AAED,kDAAkD;AAClD,wBAAgB,SAAS,CACvB,SAAS,EAAE,OAAO,EAAE,EACpB,MAAM,EAAE,MAAM,EAAE,EAChB,UAAU,SAAI,GACb,MAAM,EAAE,CAQV;AAED,4CAA4C;AAC5C,wBAAgB,SAAS,CACvB,MAAM,EAAE,MAAM,EAAE,EAChB,QAAQ,EAAE,MAAM,EAChB,SAAS,EAAE,MAAM,GAChB,MAAM,EAAE,CAWV;AAED,0CAA0C;AAC1C,wBAAgB,QAAQ,CACtB,MAAM,EAAE,MAAM,EAAE,EAChB,QAAQ,EAAE,MAAM,EAChB,SAAS,EAAE,MAAM,GAChB,MAAM,EAAE,CAWV;AAED,gCAAgC;AAChC,wBAAgB,GAAG,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,EAAE,CAM9C;AAED,sCAAsC;AACtC,wBAAgB,KAAK,CAAC,MAAM,EAAE,MAAM,EAAE,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,CAUhE;AAED,sCAAsC;AACtC,wBAAgB,WAAW,CAAC,MAAM,EAAE,MAAM,EAAE,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,CAStE"}
|
|
@@ -0,0 +1,156 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* pine-to-kline — TA Utility Functions
|
|
3
|
+
* Implements: highest, lowest, highestbars, lowestbars, barssince, valuewhen, pivothigh, pivotlow
|
|
4
|
+
* @license Apache-2.0
|
|
5
|
+
*/
|
|
6
|
+
/** ta.highest() — highest value in last `length` bars */
|
|
7
|
+
export function highest(source, length) {
|
|
8
|
+
return source.map((_, i) => {
|
|
9
|
+
if (i < length - 1)
|
|
10
|
+
return NaN;
|
|
11
|
+
let max = -Infinity;
|
|
12
|
+
for (let j = i - length + 1; j <= i; j++) {
|
|
13
|
+
if (source[j] > max)
|
|
14
|
+
max = source[j];
|
|
15
|
+
}
|
|
16
|
+
return max;
|
|
17
|
+
});
|
|
18
|
+
}
|
|
19
|
+
/** ta.lowest() — lowest value in last `length` bars */
|
|
20
|
+
export function lowest(source, length) {
|
|
21
|
+
return source.map((_, i) => {
|
|
22
|
+
if (i < length - 1)
|
|
23
|
+
return NaN;
|
|
24
|
+
let min = Infinity;
|
|
25
|
+
for (let j = i - length + 1; j <= i; j++) {
|
|
26
|
+
if (source[j] < min)
|
|
27
|
+
min = source[j];
|
|
28
|
+
}
|
|
29
|
+
return min;
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
/** ta.highestbars() — number of bars since highest value */
|
|
33
|
+
export function highestbars(source, length) {
|
|
34
|
+
return source.map((_, i) => {
|
|
35
|
+
if (i < length - 1)
|
|
36
|
+
return NaN;
|
|
37
|
+
let maxVal = -Infinity;
|
|
38
|
+
let maxIdx = i;
|
|
39
|
+
for (let j = i - length + 1; j <= i; j++) {
|
|
40
|
+
if (source[j] >= maxVal) {
|
|
41
|
+
maxVal = source[j];
|
|
42
|
+
maxIdx = j;
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
return -(i - maxIdx);
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
/** ta.lowestbars() — number of bars since lowest value */
|
|
49
|
+
export function lowestbars(source, length) {
|
|
50
|
+
return source.map((_, i) => {
|
|
51
|
+
if (i < length - 1)
|
|
52
|
+
return NaN;
|
|
53
|
+
let minVal = Infinity;
|
|
54
|
+
let minIdx = i;
|
|
55
|
+
for (let j = i - length + 1; j <= i; j++) {
|
|
56
|
+
if (source[j] <= minVal) {
|
|
57
|
+
minVal = source[j];
|
|
58
|
+
minIdx = j;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
return -(i - minIdx);
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
/** ta.barssince(condition) — bars since condition was last true */
|
|
65
|
+
export function barssince(condition) {
|
|
66
|
+
let count = NaN;
|
|
67
|
+
return condition.map((c) => {
|
|
68
|
+
if (c) {
|
|
69
|
+
count = 0;
|
|
70
|
+
}
|
|
71
|
+
else if (!isNaN(count)) {
|
|
72
|
+
count++;
|
|
73
|
+
}
|
|
74
|
+
return count;
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
/** ta.valuewhen(condition, source, occurrence) */
|
|
78
|
+
export function valuewhen(condition, source, occurrence = 0) {
|
|
79
|
+
const result = [];
|
|
80
|
+
const occurrences = [];
|
|
81
|
+
for (let i = 0; i < source.length; i++) {
|
|
82
|
+
if (condition[i])
|
|
83
|
+
occurrences.unshift(source[i]);
|
|
84
|
+
result.push(occurrences[occurrence] ?? NaN);
|
|
85
|
+
}
|
|
86
|
+
return result;
|
|
87
|
+
}
|
|
88
|
+
/** ta.pivothigh() — pivot high detection */
|
|
89
|
+
export function pivothigh(source, leftBars, rightBars) {
|
|
90
|
+
return source.map((v, i) => {
|
|
91
|
+
if (i < leftBars || i + rightBars >= source.length)
|
|
92
|
+
return NaN;
|
|
93
|
+
for (let j = i - leftBars; j < i; j++) {
|
|
94
|
+
if (source[j] > v)
|
|
95
|
+
return NaN;
|
|
96
|
+
}
|
|
97
|
+
for (let j = i + 1; j <= i + rightBars; j++) {
|
|
98
|
+
if (source[j] > v)
|
|
99
|
+
return NaN;
|
|
100
|
+
}
|
|
101
|
+
return v;
|
|
102
|
+
});
|
|
103
|
+
}
|
|
104
|
+
/** ta.pivotlow() — pivot low detection */
|
|
105
|
+
export function pivotlow(source, leftBars, rightBars) {
|
|
106
|
+
return source.map((v, i) => {
|
|
107
|
+
if (i < leftBars || i + rightBars >= source.length)
|
|
108
|
+
return NaN;
|
|
109
|
+
for (let j = i - leftBars; j < i; j++) {
|
|
110
|
+
if (source[j] < v)
|
|
111
|
+
return NaN;
|
|
112
|
+
}
|
|
113
|
+
for (let j = i + 1; j <= i + rightBars; j++) {
|
|
114
|
+
if (source[j] < v)
|
|
115
|
+
return NaN;
|
|
116
|
+
}
|
|
117
|
+
return v;
|
|
118
|
+
});
|
|
119
|
+
}
|
|
120
|
+
/** ta.cum() — cumulative sum */
|
|
121
|
+
export function cum(source) {
|
|
122
|
+
let sum = 0;
|
|
123
|
+
return source.map(v => {
|
|
124
|
+
sum += v;
|
|
125
|
+
return sum;
|
|
126
|
+
});
|
|
127
|
+
}
|
|
128
|
+
/** ta.stdev() — standard deviation */
|
|
129
|
+
export function stdev(source, length) {
|
|
130
|
+
return source.map((_, i) => {
|
|
131
|
+
if (i < length - 1)
|
|
132
|
+
return NaN;
|
|
133
|
+
let sum = 0;
|
|
134
|
+
for (let j = i - length + 1; j <= i; j++)
|
|
135
|
+
sum += source[j];
|
|
136
|
+
const mean = sum / length;
|
|
137
|
+
let sumSq = 0;
|
|
138
|
+
for (let j = i - length + 1; j <= i; j++)
|
|
139
|
+
sumSq += Math.pow(source[j] - mean, 2);
|
|
140
|
+
return Math.sqrt(sumSq / length);
|
|
141
|
+
});
|
|
142
|
+
}
|
|
143
|
+
/** ta.percentrank() — percent rank */
|
|
144
|
+
export function percentrank(source, length) {
|
|
145
|
+
return source.map((v, i) => {
|
|
146
|
+
if (i < length)
|
|
147
|
+
return NaN;
|
|
148
|
+
let count = 0;
|
|
149
|
+
for (let j = i - length; j < i; j++) {
|
|
150
|
+
if (source[j] <= v)
|
|
151
|
+
count++;
|
|
152
|
+
}
|
|
153
|
+
return (count / length) * 100;
|
|
154
|
+
});
|
|
155
|
+
}
|
|
156
|
+
//# sourceMappingURL=utility.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utility.js","sourceRoot":"","sources":["../../../src/builtins/ta/utility.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* pine-to-kline — Volatility Indicators
|
|
3
|
+
* Implements: atr, bb, kc, donchian
|
|
4
|
+
* @license Apache-2.0
|
|
5
|
+
*/
|
|
6
|
+
/** ta.atr() — Average True Range */
|
|
7
|
+
export declare function atr(high: number[], low: number[], close: number[], length: number): number[];
|
|
8
|
+
export interface BandsResult {
|
|
9
|
+
upper: number;
|
|
10
|
+
basis: number;
|
|
11
|
+
lower: number;
|
|
12
|
+
}
|
|
13
|
+
/** ta.bb() — Bollinger Bands */
|
|
14
|
+
export declare function bb(source: number[], length: number, mult?: number): BandsResult[];
|
|
15
|
+
/** ta.kc() — Keltner Channels */
|
|
16
|
+
export declare function kc(source: number[], high: number[], low: number[], close: number[], length: number, mult?: number): BandsResult[];
|
|
17
|
+
/** ta.donchian() — Donchian Channels */
|
|
18
|
+
export declare function donchian(high: number[], low: number[], length: number): BandsResult[];
|
|
19
|
+
/** ta.tr() — True Range (single series) */
|
|
20
|
+
export declare function tr(high: number[], low: number[], close: number[]): number[];
|
|
21
|
+
//# sourceMappingURL=volatility.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"volatility.d.ts","sourceRoot":"","sources":["../../../src/builtins/ta/volatility.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAIH,oCAAoC;AACpC,wBAAgB,GAAG,CACjB,IAAI,EAAE,MAAM,EAAE,EACd,GAAG,EAAE,MAAM,EAAE,EACb,KAAK,EAAE,MAAM,EAAE,EACf,MAAM,EAAE,MAAM,GACb,MAAM,EAAE,CAUV;AAED,MAAM,WAAW,WAAW;IAC1B,KAAK,EAAE,MAAM,CAAA;IACb,KAAK,EAAE,MAAM,CAAA;IACb,KAAK,EAAE,MAAM,CAAA;CACd;AAED,gCAAgC;AAChC,wBAAgB,EAAE,CAChB,MAAM,EAAE,MAAM,EAAE,EAChB,MAAM,EAAE,MAAM,EACd,IAAI,SAAM,GACT,WAAW,EAAE,CAef;AAED,iCAAiC;AACjC,wBAAgB,EAAE,CAChB,MAAM,EAAE,MAAM,EAAE,EAChB,IAAI,EAAE,MAAM,EAAE,EACd,GAAG,EAAE,MAAM,EAAE,EACb,KAAK,EAAE,MAAM,EAAE,EACf,MAAM,EAAE,MAAM,EACd,IAAI,SAAM,GACT,WAAW,EAAE,CAQf;AAED,wCAAwC;AACxC,wBAAgB,QAAQ,CACtB,IAAI,EAAE,MAAM,EAAE,EACd,GAAG,EAAE,MAAM,EAAE,EACb,MAAM,EAAE,MAAM,GACb,WAAW,EAAE,CAcf;AAED,2CAA2C;AAC3C,wBAAgB,EAAE,CAChB,IAAI,EAAE,MAAM,EAAE,EACd,GAAG,EAAE,MAAM,EAAE,EACb,KAAK,EAAE,MAAM,EAAE,GACd,MAAM,EAAE,CASV"}
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* pine-to-kline — Volatility Indicators
|
|
3
|
+
* Implements: atr, bb, kc, donchian
|
|
4
|
+
* @license Apache-2.0
|
|
5
|
+
*/
|
|
6
|
+
import { rma, ema, sma } from './moving-averages';
|
|
7
|
+
/** ta.atr() — Average True Range */
|
|
8
|
+
export function atr(high, low, close, length) {
|
|
9
|
+
const tr = high.map((h, i) => {
|
|
10
|
+
if (i === 0)
|
|
11
|
+
return h - low[i];
|
|
12
|
+
return Math.max(h - low[i], Math.abs(h - close[i - 1]), Math.abs(low[i] - close[i - 1]));
|
|
13
|
+
});
|
|
14
|
+
return rma(tr, length);
|
|
15
|
+
}
|
|
16
|
+
/** ta.bb() — Bollinger Bands */
|
|
17
|
+
export function bb(source, length, mult = 2.0) {
|
|
18
|
+
const mid = sma(source, length);
|
|
19
|
+
return source.map((_, i) => {
|
|
20
|
+
if (i < length - 1)
|
|
21
|
+
return { upper: NaN, basis: NaN, lower: NaN };
|
|
22
|
+
let sumSq = 0;
|
|
23
|
+
for (let j = i - length + 1; j <= i; j++) {
|
|
24
|
+
sumSq += Math.pow(source[j] - mid[i], 2);
|
|
25
|
+
}
|
|
26
|
+
const std = Math.sqrt(sumSq / length);
|
|
27
|
+
return {
|
|
28
|
+
upper: mid[i] + mult * std,
|
|
29
|
+
basis: mid[i],
|
|
30
|
+
lower: mid[i] - mult * std
|
|
31
|
+
};
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
/** ta.kc() — Keltner Channels */
|
|
35
|
+
export function kc(source, high, low, close, length, mult = 1.5) {
|
|
36
|
+
const mid = ema(source, length);
|
|
37
|
+
const atrVals = atr(high, low, close, length);
|
|
38
|
+
return source.map((_, i) => ({
|
|
39
|
+
upper: mid[i] + mult * atrVals[i],
|
|
40
|
+
basis: mid[i],
|
|
41
|
+
lower: mid[i] - mult * atrVals[i]
|
|
42
|
+
}));
|
|
43
|
+
}
|
|
44
|
+
/** ta.donchian() — Donchian Channels */
|
|
45
|
+
export function donchian(high, low, length) {
|
|
46
|
+
return high.map((_, i) => {
|
|
47
|
+
if (i < length - 1)
|
|
48
|
+
return { upper: NaN, basis: NaN, lower: NaN };
|
|
49
|
+
let highest = -Infinity, lowest = Infinity;
|
|
50
|
+
for (let j = i - length + 1; j <= i; j++) {
|
|
51
|
+
if (high[j] > highest)
|
|
52
|
+
highest = high[j];
|
|
53
|
+
if (low[j] < lowest)
|
|
54
|
+
lowest = low[j];
|
|
55
|
+
}
|
|
56
|
+
return {
|
|
57
|
+
upper: highest,
|
|
58
|
+
basis: (highest + lowest) / 2,
|
|
59
|
+
lower: lowest
|
|
60
|
+
};
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
/** ta.tr() — True Range (single series) */
|
|
64
|
+
export function tr(high, low, close) {
|
|
65
|
+
return high.map((h, i) => {
|
|
66
|
+
if (i === 0)
|
|
67
|
+
return h - low[i];
|
|
68
|
+
return Math.max(h - low[i], Math.abs(h - close[i - 1]), Math.abs(low[i] - close[i - 1]));
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
//# sourceMappingURL=volatility.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"volatility.js","sourceRoot":"","sources":["../../../src/builtins/ta/volatility.ts"],"names":[],"mappings":"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"}
|