@datagrok-libraries/statistics 0.1.3 → 0.1.6
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/.eslintrc.json +28 -28
- package/README.md +2 -2
- package/package.json +36 -32
- package/src/correlation-coefficient.d.ts +15 -0
- package/src/correlation-coefficient.d.ts.map +1 -0
- package/src/correlation-coefficient.js +100 -0
- package/src/multiple-tests.d.ts +34 -34
- package/src/multiple-tests.d.ts.map +1 -1
- package/src/multiple-tests.js +202 -206
- package/src/tests.d.ts +11 -10
- package/src/tests.d.ts.map +1 -1
- package/src/tests.js +77 -77
- package/tsconfig.json +71 -71
- package/src/multiple-tests.ts +0 -234
- package/src/tests.ts +0 -101
package/src/multiple-tests.js
CHANGED
|
@@ -1,206 +1,202 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
'
|
|
5
|
-
'
|
|
6
|
-
'
|
|
7
|
-
'
|
|
8
|
-
'
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
*
|
|
13
|
-
*
|
|
14
|
-
* @
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
const
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
*
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
*
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
*
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
*
|
|
89
|
-
*
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
*
|
|
100
|
-
*
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
}
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
*
|
|
125
|
-
*
|
|
126
|
-
*
|
|
127
|
-
*
|
|
128
|
-
*
|
|
129
|
-
*
|
|
130
|
-
*
|
|
131
|
-
*
|
|
132
|
-
* (
|
|
133
|
-
*
|
|
134
|
-
*
|
|
135
|
-
*
|
|
136
|
-
*
|
|
137
|
-
*
|
|
138
|
-
* pvalues
|
|
139
|
-
* @
|
|
140
|
-
*
|
|
141
|
-
*
|
|
142
|
-
*
|
|
143
|
-
*
|
|
144
|
-
*
|
|
145
|
-
*
|
|
146
|
-
*
|
|
147
|
-
*
|
|
148
|
-
*
|
|
149
|
-
*
|
|
150
|
-
*
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
pvalsSortind =
|
|
163
|
-
pvalsSorted =
|
|
164
|
-
}
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
}
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
;
|
|
172
|
-
}
|
|
173
|
-
else
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
return [reject_, pvalsCorrected_];
|
|
203
|
-
}
|
|
204
|
-
return [reject, pvalsCorrected];
|
|
205
|
-
}
|
|
206
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibXVsdGlwbGUtdGVzdHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJtdWx0aXBsZS10ZXN0cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSx5REFBeUQ7QUFDekQsTUFBTSxXQUFXLEdBQStCO0lBQzlDLEdBQUcsRUFBRSxDQUFDLENBQVMsRUFBRSxDQUFTLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUN0QyxHQUFHLEVBQUUsQ0FBQyxDQUFTLEVBQUUsQ0FBUyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDdEMsR0FBRyxFQUFFLENBQUMsQ0FBUyxFQUFFLENBQVMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ3RDLEdBQUcsRUFBRSxDQUFDLENBQVMsRUFBRSxDQUFTLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUN0QyxLQUFLLEVBQUUsQ0FBQyxDQUFTLEVBQUUsQ0FBUyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ2hELEtBQUssRUFBRSxDQUFDLENBQVMsRUFBRSxDQUFTLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7Q0FDakQsQ0FBQztBQUVGOzs7OztHQUtHO0FBQ0gsU0FBUyxRQUFRLENBQUMsTUFBb0I7SUFDcEMsTUFBTSxDQUFDLEdBQUcsS0FBSyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUU3QixNQUFNLE9BQU8sR0FBRyxDQUFDLEdBQWEsRUFBRSxFQUFFLENBQUMsR0FBRztTQUNuQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMs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RUFBRSxlQUFlLENBQUMsQ0FBQztLQUNuQztJQUNELE9BQU8sQ0FBQyxNQUFNLEVBQUUsY0FBYyxDQUFDLENBQUM7QUFDbEMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKiBAdHlwZSB7Kn0gQSBkaWN0aW9uYXJ5IG9mIGJhc2ljIGJpbmFyeSBvcGVyYXRpb25zLiAqL1xyXG5jb25zdCBfb3BlcmF0aW9uczoge1tuYW1lOiBzdHJpbmddOiBGdW5jdGlvbn0gPSB7XHJcbiAgJysnOiAoYTogbnVtYmVyLCBiOiBudW1iZXIpID0+IChhICsgYiksXHJcbiAgJy0nOiAoYTogbnVtYmVyLCBiOiBudW1iZXIpID0+IChhIC0gYiksXHJcbiAgJyonOiAoYTogbnVtYmVyLCBiOiBudW1iZXIpID0+IChhICogYiksXHJcbiAgJy8nOiAoYTogbnVtYmVyLCBiOiBudW1iZXIpID0+IChhIC8gYiksXHJcbiAgJ21pbic6IChhOiBudW1iZXIsIGI6IG51bWJlcikgPT4gKGEgPCBiID8gYSA6IGIpLFxyXG4gICdtYXgnOiAoYTogbnVtYmVyLCBiOiBudW1iZXIpID0+IChhID4gYiA/IGEgOiBiKSxcclxufTtcclxuXHJcbi8qKlxyXG4gKiBSZXR1cm5zIHRoZSBpbmRpY2VzIHRoYXQgd291bGQgc29ydCBhbiBhcnJheS5cclxuICpcclxuICogQHBhcmFtIHtGbG9hdDMyQXJyYXl9IHZhbHVlcyBBcnJheSB0byBzb3J0LlxyXG4gKiBAcmV0dXJuIHtJbnQzMkFycmF5fSBBcnJheSBvZiBpbmRpY2VzIHRoYXQgc29ydCB2YWx1ZXMgYWxvbmcgdGhlIGZpcnN0IGF4aXMuXHJcbiAqL1xyXG5mdW5jdGlvbiBfYXJnc29ydCh2YWx1ZXM6IEZsb2F0MzJBcnJheSk6IEludDMyQXJyYXkge1xyXG4gIGNvbnN0IHYgPSBBcnJheS5mcm9tKHZhbHVlcyk7XHJcblxyXG4gIGNvbnN0IGFyZ3NvcnQgPSAoYXJyOiBudW1iZXJbXSkgPT4gYXJyXHJcbiAgICAubWFwKCh2LCBpKSA9PiBbdiwgaV0pIC8vIERlY29yYXRlIHdpdGggaW5kZXhcclxuICAgIC5zb3J0KChhLCBiKSA9PiAoYVswXSA9PSBiWzBdID8gMCA6IChhWzBdID4gYlswXSA/IDEgOiAtMSkpKVxyXG4gICAgLm1hcCgodiwgXykgPT4gdlsxXSk7IC8vIFVuZGVjb3JhdGVcclxuXHJcbiAgY29uc3QgZm9yZGVyID0gYXJnc29ydCh2KTtcclxuXHJcbiAgcmV0dXJuIEludDMyQXJyYXkuZnJvbShmb3JkZXIpO1xyXG59XHJcblxyXG5cclxuLyoqXHJcbiAqIFRha2UgZWxlbWVudHMgZnJvbSBhbiBhcnJheS5cclxuICpcclxuICogQHBhcmFtIHtJbnQzMkFycmF5fSBvcmRlciBUaGUgaW5kaWNlcyBvZiB0aGUgdmFsdWVzIHRvIGV4dHJhY3QuXHJcbiAqIEBwYXJhbSB7RmxvYXQzMkFycmF5fSB2YWx1ZXMgVGhlIHNvdXJjZSBhcnJheS5cclxuICogQHJldHVybiB7RmxvYXQzMkFycmF5fSBUaGUgcmV0dXJuZWQgYXJyYXkgaGFzIHRoZSBzYW1lIHR5cGUgYXMgdmFsdWVzLlxyXG4gKi9cclxuZnVuY3Rpb24gX3Rha2Uob3JkZXI6IEludDMyQXJyYXksIHZhbHVlczogRmxvYXQzMkFycmF5KTogRmxvYXQzMkFycmF5IHtcclxuICAvLyBUT0RPOiBJbXBsZW1lbnQgYSBnZW5lcmFsIGZ1bmN0aW9uIGZvciBUeXBlZEFycmF5LlxyXG4gIHJldHVybiBGbG9hdDMyQXJyYXkuZnJvbSh2YWx1ZXMpLm1hcCgoXywgaSkgPT4gdmFsdWVzW29yZGVyW2ldXSk7XHJcbn1cclxuXHJcbi8qKlxyXG4gKiBBc3NpZ24gZWxlbWVudHMgb2YgYW4gYXJyYXkgZm9sbG93aW5nIHRoZSBvcmRlciBnaXZlbiAoZmxvYXRpbmctcG9pbnQgdmVyc2lvbikuXHJcbiAqXHJcbiAqIEBwYXJhbSB7RmxvYXQzMkFycmF5fSB2YWx1ZXMgVGhlIHNvdXJjZSBhcnJheS5cclxuICogQHBhcmFtIHtJbnQzMkFycmF5fSBvcmRlciBUaGUgb3JkZXIgZ2l2ZW4uXHJcbiAqIEByZXR1cm4ge0Zsb2F0MzJBcnJheX0gVGhlIHJldHVybmVkIGFycmF5IGhhcyB0aGUgc2FtZSB0eXBlIGFzIHZhbHVlcy5cclxuICovXHJcbmZ1bmN0aW9uIF9naXZlKHZhbHVlczogRmxvYXQzMkFycmF5LCBvcmRlcjogSW50MzJBcnJheSk6IEZsb2F0MzJBcnJheSB7XHJcbiAgY29uc3QgdiA9IEZsb2F0MzJBcnJheS5mcm9tKHZhbHVlcyk7XHJcblxyXG4gIGZvciAobGV0IGkgPSAwOyBpIDwgb3JkZXIubGVuZ3RoOyArK2kpIHtcclxuICAgIHZbb3JkZXJbaV1dID0gdmFsdWVzW2ldO1xyXG4gIH1cclxuICByZXR1cm4gdjtcclxufVxyXG5cclxuLyoqXHJcbiAqIEFzc2lnbiBlbGVtZW50cyBvZiBhbiBhcnJheSBmb2xsb3dpbmcgdGhlIG9yZGVyIGdpdmVuIChib29sZWFuIHZlcnNpb24pLlxyXG4gKlxyXG4gKiBAcGFyYW0ge0FycmF5PGJvb2xlYW4+fSB2YWx1ZXMgVGhlIHNvdXJjZSBhcnJheS5cclxuICogQHBhcmFtIHtJbnQzMkFycmF5fSBvcmRlciBUaGUgb3JkZXIgZ2l2ZW4uXHJcbiAqIEByZXR1cm4ge0FycmF5PGJvb2xlYW4+fSBUaGUgcmV0dXJuZWQgYXJyYXkgaGFzIHRoZSBzYW1lIHR5cGUgYXMgdmFsdWVzLlxyXG4gKi9cclxuZnVuY3Rpb24gX2dpdmViKHZhbHVlczogQXJyYXk8Ym9vbGVhbj4sIG9yZGVyOiBJbnQzMkFycmF5KTogQXJyYXk8Ym9vbGVhbj4ge1xyXG4gIGNvbnN0IHYgPSBBcnJheS5mcm9tKHZhbHVlcyk7XHJcblxyXG4gIGZvciAobGV0IGkgPSAwOyBpIDwgb3JkZXIubGVuZ3RoOyArK2kpIHtcclxuICAgIHZbb3JkZXJbaV1dID0gdmFsdWVzW2ldO1xyXG4gIH1cclxuICByZXR1cm4gdjtcclxufVxyXG5cclxuLyoqXHJcbiAqIE5vIGZyaWxscyBlbXBpcmljYWwgY2RmIHVzZWQgaW4gZmRyY29ycmVjdGlvbi5cclxuICpcclxuICogQHBhcmFtIHtGbG9hdDMyQXJyYXl9IHggVGhlIHNvdXJjZSBhcnJheSB0byB0YWtlIGEgZGltZW5zaW9uIGZyb20uXHJcbiAqIEByZXR1cm4ge0Zsb2F0MzJBcnJheX0gRW1waXJpY2FsIGNkZi5cclxuICovXHJcbmZ1bmN0aW9uIF9lY2RmKHg6IEZsb2F0MzJBcnJheSk6IEZsb2F0MzJBcnJheSB7XHJcbiAgY29uc3Qgbm9icyA9IHgubGVuZ3RoO1xyXG4gIHJldHVybiBGbG9hdDMyQXJyYXkuZnJvbSh4KS5tYXAoKF8sIGkpID0+IChpKzEpL25vYnMpO1xyXG59XHJcblxyXG4vKipcclxuICogY20gPSBucC5zdW0oMS4vbnAuYXJhbmdlKDEsIGxlbihwdmFsc19zb3J0ZWQpKzEpKVxyXG4gKlxyXG4gKiBAcGFyYW0ge251bWJlcn0gbiBUaGUgbnVtYmVyIGdpdmVuLlxyXG4gKiBAcmV0dXJuIHtudW1iZXJ9IGNtIHZhbHVlLlxyXG4gKi9cclxuZnVuY3Rpb24gX2NtKG46IG51bWJlcik6IG51bWJlciB7XHJcbiAgbGV0IHN1bSA9IDA7XHJcbiAgZm9yIChsZXQgaSA9IDA7IGkgPCBuOyArK2kpIHtcclxuICAgIHN1bSArPSAxIC8gKGkrMSk7XHJcbiAgfVxyXG4gIHJldHVybiBzdW07XHJcbn1cclxuXHJcbi8qKlxyXG4gKiBCYXNpYyBvcGVyYXRpb24gdW5kZXIgYSB2ZWN0b3IgYW5kIGEgc2NhbGFyLlxyXG4gKlxyXG4gKiBAcGFyYW0ge0Zsb2F0MzJBcnJheX0gdmFsdWVzIFRoZSBzb3VyY2UgdmVjdG9yLlxyXG4gKiBAcGFyYW0ge251bWJlcn0gc2NhbGUgVGhlIHNjYWxhci5cclxuICogQHBhcmFtIHtzdHJpbmd9IFtvcD0nKiddIFRoZSBvcGVyYXRpb24gdG8gcGVyZm9ybS5cclxuICogQHJldHVybiB7RmxvYXQzMkFycmF5fSBOZXcgdmVjdG9yIGFzIGEgcmVzdWx0IG9mIHRoZSBvcGVyYXRpb24uXHJcbiAqL1xyXG5mdW5jdGlvbiBfZmFjdG9yKHZhbHVlczogRmxvYXQzMkFycmF5LCBzY2FsZTogbnVtYmVyLCBvcCA9ICcqJyk6IEZsb2F0MzJBcnJheSB7XHJcbiAgcmV0dXJuIEZsb2F0MzJBcnJheS5mcm9tKHZhbHVlcykubWFwKCh2LCBfKSA9PiBfb3BlcmF0aW9uc1tvcF0odiwgc2NhbGUpKTtcclxufVxyXG5cclxuLyoqXHJcbiAqIEJhc2ljIG9wZXJhdGlvbiB1bmRlciB0d28gdmVjdG9ycy5cclxuICpcclxuICogQHBhcmFtIHtGbG9hdDMyQXJyYXl9IHZhbHVlcyBUaGUgZmlyc3QgdmVjdG9yLlxyXG4gKiBAcGFyYW0ge0Zsb2F0MzJBcnJheX0gc2NhbGUgVGhlIHNlY29uZCB2ZWN0b3IuXHJcbiAqIEBwYXJhbSB7c3RyaW5nfSBbb3A9JyonXSBUaGUgb3BlcmF0aW9uIHRvIHBlcmZvcm0uXHJcbiAqIEByZXR1cm4ge0Zsb2F0MzJBcnJheX0gTmV3IHZlY3RvciBhcyBhIHJlc3VsdCBvZiB0aGUgb3BlcmF0aW9uLlxyXG4gKi9cclxuZnVuY3Rpb24gX3ZmYWN0b3IodmFsdWVzOiBGbG9hdDMyQXJyYXksIHNjYWxlOiBGbG9hdDMyQXJyYXksIG9wID0gJyonKTogRmxvYXQzMkFycmF5IHtcclxuICByZXR1cm4gRmxvYXQzMkFycmF5LmZyb20odmFsdWVzKS5tYXAoKHYsIGkpID0+IF9vcGVyYXRpb25zW29wXSh2LCBzY2FsZVtpXSkpO1xyXG59XHJcblxyXG4vKipcclxuICogQWNjdW11bGF0ZSB0aGUgcmVzdWx0IG9mIGFwcGx5aW5nIHRoZSBtaW4gb3BlcmF0b3IgdG8gYWxsIGVsZW1lbnRzLlxyXG4gKlxyXG4gKiBAcGFyYW0ge0Zsb2F0MzJBcnJheX0gdmFsdWVzIFRoZSBhcnJheSB0byBhY3Qgb24uXHJcbiAqIEByZXR1cm4ge0Zsb2F0MzJBcnJheX0gVGhlIGFjY3VtdWxhdGVkIHZhbHVlcy5cclxuICovXHJcbmZ1bmN0aW9uIF9taW5pbXVtQWNjdW11bGF0ZSh2YWx1ZXM6IEZsb2F0MzJBcnJheSk6IEZsb2F0MzJBcnJheSB7XHJcbiAgY29uc3Qgbkl0ZW1zID0gdmFsdWVzLmxlbmd0aDtcclxuICBjb25zdCByID0gRmxvYXQzMkFycmF5LmZyb20odmFsdWVzKTtcclxuXHJcbiAgZm9yIChsZXQgaSA9IDA7IGkgPCBuSXRlbXM7ICsraSkge1xyXG4gICAgcltpXSA9IHZhbHVlcy5zbGljZSgwLCBpKzEpLnJlZHVjZSgoYSwgYiwgXywgX18pID0+IChfb3BlcmF0aW9uc1snbWluJ10oYSwgYikpKTtcclxuICB9XHJcbiAgcmV0dXJuIHI7XHJcbn1cclxuXHJcbi8qKlxyXG4gKiBwdmFsdWUgY29ycmVjdGlvbiBmb3IgZmFsc2UgZGlzY292ZXJ5IHJhdGVcclxuICpcclxuICogQGV4cG9ydFxyXG4gKiBAcGFyYW0ge0Zsb2F0MzJBcnJheX0gcHZhbHMgU2V0IG9mIHAtdmFsdWVzIG9mIHRoZSBpbmRpdmlkdWFsIHRlc3RzLlxyXG4gKiBAcGFyYW0ge251bWJlcn0gW2FscGhhPTAuMDVdIEZhbWlseS13aXNlIGVycm9yIHJhdGUuIERlZmF1bHRzIHRvIDAuMDUuXHJcbiAqIEBwYXJhbSB7c3RyaW5nfSBbbWV0aG9kPSduJ10geydpJywgJ2luZGVwJywgJ3AnLCAncG9zY29ycicsICduJywgJ25lZ2NvcnInfSwgb3B0aW9uYWxcclxuICogV2hpY2ggbWV0aG9kIHRvIHVzZSBmb3IgRkRSIGNvcnJlY3Rpb24uXHJcbiAqIGBgeydpJywgJ2luZGVwJywgJ3AnLCAncG9zY29ycid9YGAgYWxsIHJlZmVyIHRvIGBgZmRyX2JoYGBcclxuICogKEJlbmphbWluaS9Ib2NoYmVyZyBmb3IgaW5kZXBlbmRlbnQgb3IgcG9zaXRpdmVseVxyXG4gKiBjb3JyZWxhdGVkIHRlc3RzKS4gYGB7J24nLCAnbmVnY29ycid9YGAgYm90aCByZWZlciB0byBgYGZkcl9ieWBgXHJcbiAqIChCZW5qYW1pbmkvWWVrdXRpZWxpIGZvciBnZW5lcmFsIG9yIG5lZ2F0aXZlbHkgY29ycmVsYXRlZCB0ZXN0cykuXHJcbiAqIERlZmF1bHRzIHRvICduJy5cclxuICogQHBhcmFtIHtib29sZWFufSBbaXNTb3J0ZWQ9ZmFsc2VdIElmIEZhbHNlIChkZWZhdWx0KSwgdGhlIHBfdmFsdWVzIHdpbGwgYmUgc29ydGVkLCBidXQgdGhlIGNvcnJlY3RlZFxyXG4gKiBwdmFsdWVzIGFyZSBpbiB0aGUgb3JpZ2luYWwgb3JkZXIuIElmIFRydWUsIHRoZW4gaXQgYXNzdW1lZCB0aGF0IHRoZVxyXG4gKiBwdmFsdWVzIGFyZSBhbHJlYWR5IHNvcnRlZCBpbiBhc2NlbmRpbmcgb3JkZXIuXHJcbiAqIEByZXR1cm4ge1tBcnJheTxib29sZWFuPiwgRmxvYXQzMkFycmF5XX0gcmVqZWN0ZWQgOiBuZGFycmF5LCBib29sXHJcbiAqIFRydWUgaWYgYSBoeXBvdGhlc2lzIGlzIHJlamVjdGVkLCBGYWxzZSBpZiBub3RcclxuICogcHZhbHVlLWNvcnJlY3RlZCA6IG5kYXJyYXlcclxuICogcHZhbHVlcyBhZGp1c3RlZCBmb3IgbXVsdGlwbGUgaHlwb3RoZXNpcyB0ZXN0aW5nIHRvIGxpbWl0IEZEUlxyXG4gKiBAc2VlXHJcbiAqIElmIHRoZXJlIGlzIHByaW9yIGluZm9ybWF0aW9uIG9uIHRoZSBmcmFjdGlvbiBvZiB0cnVlIGh5cG90aGVzaXMsIHRoZW4gYWxwaGFcclxuICogc2hvdWxkIGJlIHNldCB0byBgYGFscGhhICogbS9tXzBgYCB3aGVyZSBtIGlzIHRoZSBudW1iZXIgb2YgdGVzdHMsXHJcbiAqIGdpdmVuIGJ5IHRoZSBwLXZhbHVlcywgYW5kIG1fMCBpcyBhbiBlc3RpbWF0ZSBvZiB0aGUgdHJ1ZSBoeXBvdGhlc2lzLlxyXG4gKiAoc2VlIEJlbmphbWluaSwgS3JpZWdlciBhbmQgWWVrdXRlbGkpXHJcbiAqXHJcbiAqIFRoZSB0d28tc3RlcCBtZXRob2Qgb2YgQmVuamFtaW5pLCBLcmllZ2VyIGFuZCBZZWt1dGllbCB0aGF0IGVzdGltYXRlcyB0aGUgbnVtYmVyXHJcbiAqIG9mIGZhbHNlIGh5cG90aGVzZXMgd2lsbCBiZSBhdmFpbGFibGUgKHNvb24pLlxyXG4gKlxyXG4gKiBCb3RoIG1ldGhvZHMgZXhwb3NlZCB2aWEgdGhpcyBmdW5jdGlvbiAoQmVuamFtaW5pL0hvY2hiZXJnLCBCZW5qYW1pbmkvWWVrdXRpZWxpKVxyXG4gKiBhcmUgYWxzbyBhdmFpbGFibGUgaW4gdGhlIGZ1bmN0aW9uIGBgbXVsdGlwbGV0ZXN0c2BgLCBhcyBgYG1ldGhvZD1cImZkcl9iaFwiYGAgYW5kXHJcbiAqIGBgbWV0aG9kPVwiZmRyX2J5XCJgYCwgcmVzcGVjdGl2ZWx5LlxyXG4gKi9cclxuZXhwb3J0IGZ1bmN0aW9uIGZkcmNvcnJlY3Rpb24oXHJcbiAgcHZhbHM6IEZsb2F0MzJBcnJheSxcclxuICBhbHBoYTogbnVtYmVyID0gMC4wNSxcclxuICBtZXRob2Q6IHN0cmluZyA9J24nLFxyXG4gIGlzU29ydGVkOiBib29sZWFuID0gZmFsc2UpOiBbQXJyYXk8Ym9vbGVhbj4sIEZsb2F0MzJBcnJheV1cclxuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGJyYWNlLXN0eWxlXHJcbntcclxuICBjb25zdCBuSXRlbXMgPSBwdmFscy5sZW5ndGg7XHJcbiAgbGV0IHB2YWxzU29ydGVkOiBGbG9hdDMyQXJyYXk7XHJcbiAgbGV0IHB2YWxzU29ydGluZDogSW50MzJBcnJheTtcclxuICBsZXQgY20gPSAwO1xyXG5cclxuICBpZiAoIWlzU29ydGVkKSB7XHJcbiAgICBwdmFsc1NvcnRpbmQgPSBfYXJnc29ydChwdmFscyk7XHJcbiAgICBwdmFsc1NvcnRlZCA9IF90YWtlKHB2YWxzU29ydGluZCwgcHZhbHMpO1xyXG4gIH0gZWxzZSB7XHJcbiAgICBwdmFsc1NvcnRpbmQgPSBuZXcgSW50MzJBcnJheShuSXRlbXMpLmZpbGwoMCkubWFwKChfLCBpKSA9PiAoaSkpO1xyXG4gICAgcHZhbHNTb3J0ZWQgPSBwdmFsczsgLy8gYWxpYXNcclxuICB9XHJcblxyXG4gIGxldCBlY2RmZmFjdG9yID0gX2VjZGYocHZhbHNTb3J0ZWQpO1xyXG5cclxuICBpZiAoWydpJywgJ2luZGVwJywgJ3AnLCAncG9zY29yciddLmluY2x1ZGVzKG1ldGhvZCkpIHtcclxuICAgIDtcclxuICB9IGVsc2UgaWYgKFsnbicsICduZWdjb3JyJ10uaW5jbHVkZXMobWV0aG9kKSkge1xyXG4gICAgY20gPSBfY20obkl0ZW1zKTtcclxuICAgIGVjZGZmYWN0b3IgPSBfZmFjdG9yKGVjZGZmYWN0b3IsIGNtLCAnLycpO1xyXG4gIH0gZWxzZSB7XHJcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ29ubHkgaW5kZXAgYW5kIG5lZ2NvcnIgaW1wbGVtZW50ZWQnKTtcclxuICB9XHJcblxyXG4gIGNvbnN0IHJlamVjdDogYm9vbGVhbltdID0gbmV3IEFycmF5KG5JdGVtcykuZmlsbChmYWxzZSk7XHJcbiAgbGV0IHJlamVjdG1heCA9IC0xO1xyXG5cclxuICBmb3IgKGxldCBpID0gMDsgaSA8IG5JdGVtczsgKytpKSB7XHJcbiAgICBpZiAocHZhbHNTb3J0ZWRbaV0gPD0gZWNkZmZhY3RvcltpXSphbHBoYSkge1xyXG4gICAgICByZWplY3RtYXggPSBpO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgaWYgKHJlamVjdG1heCA+PSAwKSB7XHJcbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IHJlamVjdG1heDsgKytpKSB7XHJcbiAgICAgIHJlamVjdFtpXSA9IHRydWU7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBsZXQgcHZhbHNDb3JyZWN0ZWQgPSBfdmZhY3RvcihwdmFsc1NvcnRlZCwgZWNkZmZhY3RvciwgJy8nKTtcclxuICBwdmFsc0NvcnJlY3RlZCA9IF9taW5pbXVtQWNjdW11bGF0ZShwdmFsc0NvcnJlY3RlZC5yZXZlcnNlKCkpLnJldmVyc2UoKTtcclxuXHJcbiAgZm9yIChsZXQgaSA9IDA7IGkgPCBuSXRlbXM7ICsraSkge1xyXG4gICAgaWYgKHB2YWxzQ29ycmVjdGVkW2ldID4gMSkge1xyXG4gICAgICBwdmFsc0NvcnJlY3RlZFtpXSA9IDE7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBpZiAoIWlzU29ydGVkKSB7XHJcbiAgICBjb25zdCBwdmFsc0NvcnJlY3RlZF8gPSBfZ2l2ZShwdmFsc0NvcnJlY3RlZCwgcHZhbHNTb3J0aW5kKTtcclxuICAgIGNvbnN0IHJlamVjdF8gPSBfZ2l2ZWIocmVqZWN0LCBwdmFsc1NvcnRpbmQpO1xyXG4gICAgcmV0dXJuIFtyZWplY3RfLCBwdmFsc0NvcnJlY3RlZF9dO1xyXG4gIH1cclxuICByZXR1cm4gW3JlamVjdCwgcHZhbHNDb3JyZWN0ZWRdO1xyXG59XHJcbiJdfQ==
|
|
1
|
+
import { ArrayUtils } from '@datagrok-libraries/utils/src/array-utils';
|
|
2
|
+
/** @type {*} A dictionary of basic binary operations. */
|
|
3
|
+
const _operations = {
|
|
4
|
+
'+': (a, b) => (a + b),
|
|
5
|
+
'-': (a, b) => (a - b),
|
|
6
|
+
'*': (a, b) => (a * b),
|
|
7
|
+
'/': (a, b) => (a / b),
|
|
8
|
+
'min': (a, b) => (a < b ? a : b),
|
|
9
|
+
'max': (a, b) => (a > b ? a : b),
|
|
10
|
+
};
|
|
11
|
+
/**
|
|
12
|
+
* Returns the indices that would sort an array.
|
|
13
|
+
*
|
|
14
|
+
* @param {Float32Array} values Array to sort.
|
|
15
|
+
* @return {Int32Array} Array of indices that sort values along the first axis.
|
|
16
|
+
*/
|
|
17
|
+
function _argsort(values) {
|
|
18
|
+
const array = Array.from(values);
|
|
19
|
+
return Int32Array.from(ArrayUtils.argSort(array));
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Take elements from an array.
|
|
23
|
+
*
|
|
24
|
+
* @param {Int32Array} order The indices of the values to extract.
|
|
25
|
+
* @param {Float32Array} values The source array.
|
|
26
|
+
* @return {Float32Array} The returned array has the same type as values.
|
|
27
|
+
*/
|
|
28
|
+
function _take(order, values) {
|
|
29
|
+
// TODO: Implement a general function for TypedArray.
|
|
30
|
+
return Float32Array.from(values).map((_, i) => values[order[i]]);
|
|
31
|
+
}
|
|
32
|
+
/**
|
|
33
|
+
* Assign elements of an array following the order given (floating-point version).
|
|
34
|
+
*
|
|
35
|
+
* @param {Float32Array} values The source array.
|
|
36
|
+
* @param {Int32Array} order The order given.
|
|
37
|
+
* @return {Float32Array} The returned array has the same type as values.
|
|
38
|
+
*/
|
|
39
|
+
function _give(values, order) {
|
|
40
|
+
const v = Float32Array.from(values);
|
|
41
|
+
for (let i = 0; i < order.length; ++i) {
|
|
42
|
+
v[order[i]] = values[i];
|
|
43
|
+
}
|
|
44
|
+
return v;
|
|
45
|
+
}
|
|
46
|
+
/**
|
|
47
|
+
* Assign elements of an array following the order given (boolean version).
|
|
48
|
+
*
|
|
49
|
+
* @param {Array<boolean>} values The source array.
|
|
50
|
+
* @param {Int32Array} order The order given.
|
|
51
|
+
* @return {Array<boolean>} The returned array has the same type as values.
|
|
52
|
+
*/
|
|
53
|
+
function _giveb(values, order) {
|
|
54
|
+
const v = Array.from(values);
|
|
55
|
+
for (let i = 0; i < order.length; ++i) {
|
|
56
|
+
v[order[i]] = values[i];
|
|
57
|
+
}
|
|
58
|
+
return v;
|
|
59
|
+
}
|
|
60
|
+
/**
|
|
61
|
+
* No frills empirical cdf used in fdrcorrection.
|
|
62
|
+
*
|
|
63
|
+
* @param {Float32Array} x The source array to take a dimension from.
|
|
64
|
+
* @return {Float32Array} Empirical cdf.
|
|
65
|
+
*/
|
|
66
|
+
function _ecdf(x) {
|
|
67
|
+
const nobs = x.length;
|
|
68
|
+
return Float32Array.from(x).map((_, i) => (i + 1) / nobs);
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* cm = np.sum(1./np.arange(1, len(pvals_sorted)+1))
|
|
72
|
+
*
|
|
73
|
+
* @param {number} n The number given.
|
|
74
|
+
* @return {number} cm value.
|
|
75
|
+
*/
|
|
76
|
+
function _cm(n) {
|
|
77
|
+
let sum = 0;
|
|
78
|
+
for (let i = 0; i < n; ++i) {
|
|
79
|
+
sum += 1 / (i + 1);
|
|
80
|
+
}
|
|
81
|
+
return sum;
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* Basic operation under a vector and a scalar.
|
|
85
|
+
*
|
|
86
|
+
* @param {Float32Array} values The source vector.
|
|
87
|
+
* @param {number} scale The scalar.
|
|
88
|
+
* @param {string} [op='*'] The operation to perform.
|
|
89
|
+
* @return {Float32Array} New vector as a result of the operation.
|
|
90
|
+
*/
|
|
91
|
+
function _factor(values, scale, op = '*') {
|
|
92
|
+
return Float32Array.from(values).map((v, _) => _operations[op](v, scale));
|
|
93
|
+
}
|
|
94
|
+
/**
|
|
95
|
+
* Basic operation under two vectors.
|
|
96
|
+
*
|
|
97
|
+
* @param {Float32Array} values The first vector.
|
|
98
|
+
* @param {Float32Array} scale The second vector.
|
|
99
|
+
* @param {string} [op='*'] The operation to perform.
|
|
100
|
+
* @return {Float32Array} New vector as a result of the operation.
|
|
101
|
+
*/
|
|
102
|
+
function _vfactor(values, scale, op = '*') {
|
|
103
|
+
return Float32Array.from(values).map((v, i) => _operations[op](v, scale[i]));
|
|
104
|
+
}
|
|
105
|
+
/**
|
|
106
|
+
* Accumulate the result of applying the min operator to all elements.
|
|
107
|
+
*
|
|
108
|
+
* @param {Float32Array} values The array to act on.
|
|
109
|
+
* @return {Float32Array} The accumulated values.
|
|
110
|
+
*/
|
|
111
|
+
function _minimumAccumulate(values) {
|
|
112
|
+
const nItems = values.length;
|
|
113
|
+
const r = Float32Array.from(values);
|
|
114
|
+
for (let i = 0; i < nItems; ++i) {
|
|
115
|
+
r[i] = values.slice(0, i + 1).reduce((a, b, _, __) => (_operations['min'](a, b)));
|
|
116
|
+
}
|
|
117
|
+
return r;
|
|
118
|
+
}
|
|
119
|
+
/**
|
|
120
|
+
* pvalue correction for false discovery rate
|
|
121
|
+
*
|
|
122
|
+
* @export
|
|
123
|
+
* @param {Float32Array} pvals Set of p-values of the individual tests.
|
|
124
|
+
* @param {number} [alpha=0.05] Family-wise error rate. Defaults to 0.05.
|
|
125
|
+
* @param {string} [method='n'] {'i', 'indep', 'p', 'poscorr', 'n', 'negcorr'}, optional
|
|
126
|
+
* Which method to use for FDR correction.
|
|
127
|
+
* ``{'i', 'indep', 'p', 'poscorr'}`` all refer to ``fdr_bh``
|
|
128
|
+
* (Benjamini/Hochberg for independent or positively
|
|
129
|
+
* correlated tests). ``{'n', 'negcorr'}`` both refer to ``fdr_by``
|
|
130
|
+
* (Benjamini/Yekutieli for general or negatively correlated tests).
|
|
131
|
+
* Defaults to 'n'.
|
|
132
|
+
* @param {boolean} [isSorted=false] If False (default), the p_values will be sorted, but the corrected
|
|
133
|
+
* pvalues are in the original order. If True, then it assumed that the
|
|
134
|
+
* pvalues are already sorted in ascending order.
|
|
135
|
+
* @return {[Array<boolean>, Float32Array]} rejected : ndarray, bool
|
|
136
|
+
* True if a hypothesis is rejected, False if not
|
|
137
|
+
* pvalue-corrected : ndarray
|
|
138
|
+
* pvalues adjusted for multiple hypothesis testing to limit FDR
|
|
139
|
+
* @see
|
|
140
|
+
* If there is prior information on the fraction of true hypothesis, then alpha
|
|
141
|
+
* should be set to ``alpha * m/m_0`` where m is the number of tests,
|
|
142
|
+
* given by the p-values, and m_0 is an estimate of the true hypothesis.
|
|
143
|
+
* (see Benjamini, Krieger and Yekuteli)
|
|
144
|
+
*
|
|
145
|
+
* The two-step method of Benjamini, Krieger and Yekutiel that estimates the number
|
|
146
|
+
* of false hypotheses will be available (soon).
|
|
147
|
+
*
|
|
148
|
+
* Both methods exposed via this function (Benjamini/Hochberg, Benjamini/Yekutieli)
|
|
149
|
+
* are also available in the function ``multipletests``, as ``method="fdr_bh"`` and
|
|
150
|
+
* ``method="fdr_by"``, respectively.
|
|
151
|
+
*/
|
|
152
|
+
export function fdrcorrection(pvals, alpha = 0.05, method = 'n', isSorted = false) {
|
|
153
|
+
const nItems = pvals.length;
|
|
154
|
+
let pvalsSorted;
|
|
155
|
+
let pvalsSortind;
|
|
156
|
+
let cm = 0;
|
|
157
|
+
if (!isSorted) {
|
|
158
|
+
pvalsSortind = _argsort(pvals);
|
|
159
|
+
pvalsSorted = _take(pvalsSortind, pvals);
|
|
160
|
+
}
|
|
161
|
+
else {
|
|
162
|
+
pvalsSortind = new Int32Array(nItems).fill(0).map((_, i) => (i));
|
|
163
|
+
pvalsSorted = pvals; // alias
|
|
164
|
+
}
|
|
165
|
+
let ecdffactor = _ecdf(pvalsSorted);
|
|
166
|
+
if (['i', 'indep', 'p', 'poscorr'].includes(method)) {
|
|
167
|
+
;
|
|
168
|
+
}
|
|
169
|
+
else if (['n', 'negcorr'].includes(method)) {
|
|
170
|
+
cm = _cm(nItems);
|
|
171
|
+
ecdffactor = _factor(ecdffactor, cm, '/');
|
|
172
|
+
}
|
|
173
|
+
else {
|
|
174
|
+
throw new Error('only indep and negcorr implemented');
|
|
175
|
+
}
|
|
176
|
+
const reject = new Array(nItems).fill(false);
|
|
177
|
+
let rejectmax = -1;
|
|
178
|
+
for (let i = 0; i < nItems; ++i) {
|
|
179
|
+
if (pvalsSorted[i] <= ecdffactor[i] * alpha) {
|
|
180
|
+
rejectmax = i;
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
if (rejectmax >= 0) {
|
|
184
|
+
for (let i = 0; i < rejectmax; ++i) {
|
|
185
|
+
reject[i] = true;
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
let pvalsCorrected = _vfactor(pvalsSorted, ecdffactor, '/');
|
|
189
|
+
pvalsCorrected = _minimumAccumulate(pvalsCorrected.reverse()).reverse();
|
|
190
|
+
for (let i = 0; i < nItems; ++i) {
|
|
191
|
+
if (pvalsCorrected[i] > 1) {
|
|
192
|
+
pvalsCorrected[i] = 1;
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
if (!isSorted) {
|
|
196
|
+
const pvalsCorrected_ = _give(pvalsCorrected, pvalsSortind);
|
|
197
|
+
const reject_ = _giveb(reject, pvalsSortind);
|
|
198
|
+
return [reject_, pvalsCorrected_];
|
|
199
|
+
}
|
|
200
|
+
return [reject, pvalsCorrected];
|
|
201
|
+
}
|
|
202
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibXVsdGlwbGUtdGVzdHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJtdWx0aXBsZS10ZXN0cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0sMkNBQTJDLENBQUM7QUFFckUseURBQXlEO0FBQ3pELE1BQU0sV0FBVyxHQUErQjtJQUM5QyxHQUFHLEVBQUUsQ0FBQyxDQUFTLEVBQUUsQ0FBUyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDdEMsR0FBRyxFQUFFLENBQUMsQ0FBUyxFQUFFLENBQVMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ3RDLEdBQUcsRUFBRSxDQUFDLENBQVMsRUFBRSxDQUFTLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUN0QyxHQUFHLEVBQUUsQ0FBQyxDQUFTLEVBQUUsQ0FBUyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDdEMsS0FBSyxFQUFFLENBQUMsQ0FBUyxFQUFFLENBQVMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNoRCxLQUFLLEVBQUUsQ0FBQyxDQUFTLEVBQUUsQ0FBUyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0NBQ2pELENBQUM7QUFFRjs7Ozs7R0FLRztBQUNILFNBQVMsUUFBUSxDQUFDLE1BQW9CO0lBQ3BDLE1BQU0sS0FBSyxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDakMsT0FBTyxVQUFVLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FB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USxDQUFDLFdBQVcsRUFBRSxVQUFVLEVBQUUsR0FBRyxDQUFDLENBQUM7SUFDNUQsY0FBYyxHQUFHLGtCQUFrQixDQUFDLGNBQWMsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDLE9BQU8sRUFBRSxDQUFDO0lBRXhFLEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxNQUFNLEVBQUUsRUFBRSxDQUFDLEVBQUU7UUFDL0IsSUFBSSxjQUFjLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxFQUFFO1lBQ3pCLGNBQWMsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUM7U0FDdkI7S0FDRjtJQUVELElBQUksQ0FBQyxRQUFRLEVBQUU7UUFDYixNQUFNLGVBQWUsR0FBRyxLQUFLLENBQUMsY0FBYyxFQUFFLFlBQVksQ0FBQyxDQUFDO1FBQzVELE1BQU0sT0FBTyxHQUFHLE1BQU0sQ0FBQyxNQUFNLEVBQUUsWUFBWSxDQUFDLENBQUM7UUFDN0MsT0FBTyxDQUFDLE9BQU8sRUFBRSxlQUFlLENBQUMsQ0FBQztLQUNuQztJQUNELE9BQU8sQ0FBQyxNQUFNLEVBQUUsY0FBYyxDQUFDLENBQUM7QUFDbEMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7QXJyYXlVdGlsc30gZnJvbSAnQGRhdGFncm9rLWxpYnJhcmllcy91dGlscy9zcmMvYXJyYXktdXRpbHMnO1xuXG4vKiogQHR5cGUgeyp9IEEgZGljdGlvbmFyeSBvZiBiYXNpYyBiaW5hcnkgb3BlcmF0aW9ucy4gKi9cbmNvbnN0IF9vcGVyYXRpb25zOiB7W25hbWU6IHN0cmluZ106IEZ1bmN0aW9ufSA9IHtcbiAgJysnOiAoYTogbnVtYmVyLCBiOiBudW1iZXIpID0+IChhICsgYiksXG4gICctJzogKGE6IG51bWJlciwgYjogbnVtYmVyKSA9PiAoYSAtIGIpLFxuICAnKic6IChhOiBudW1iZXIsIGI6IG51bWJlcikgPT4gKGEgKiBiKSxcbiAgJy8nOiAoYTogbnVtYmVyLCBiOiBudW1iZXIpID0+IChhIC8gYiksXG4gICdtaW4nOiAoYTogbnVtYmVyLCBiOiBudW1iZXIpID0+IChhIDwgYiA/IGEgOiBiKSxcbiAgJ21heCc6IChhOiBudW1iZXIsIGI6IG51bWJlcikgPT4gKGEgPiBiID8gYSA6IGIpLFxufTtcblxuLyoqXG4gKiBSZXR1cm5zIHRoZSBpbmRpY2VzIHRoYXQgd291bGQgc29ydCBhbiBhcnJheS5cbiAqXG4gKiBAcGFyYW0ge0Zsb2F0MzJBcnJheX0gdmFsdWVzIEFycmF5IHRvIHNvcnQuXG4gKiBAcmV0dXJuIHtJbnQzMkFycmF5fSBBcnJheSBvZiBpbmRpY2VzIHRoYXQgc29ydCB2YWx1ZXMgYWxvbmcgdGhlIGZpcnN0IGF4aXMuXG4gKi9cbmZ1bmN0aW9uIF9hcmdzb3J0KHZhbHVlczogRmxvYXQzMkFycmF5KTogSW50MzJBcnJheSB7XG4gIGNvbnN0IGFycmF5ID0gQXJyYXkuZnJvbSh2YWx1ZXMpO1xuICByZXR1cm4gSW50MzJBcnJheS5mcm9tKEFycmF5VXRpbHMuYXJnU29ydChhcnJheSkpO1xufVxuXG4vKipcbiAqIFRha2UgZWxlbWVudHMgZnJvbSBhbiBhcnJheS5cbiAqXG4gKiBAcGFyYW0ge0ludDMyQXJyYXl9IG9yZGVyIFRoZSBpbmRpY2VzIG9mIHRoZSB2YWx1ZXMgdG8gZXh0cmFjdC5cbiAqIEBwYXJhbSB7RmxvYXQzMkFycmF5fSB2YWx1ZXMgVGhlIHNvdXJjZSBhcnJheS5cbiAqIEByZXR1cm4ge0Zsb2F0MzJBcnJheX0gVGhlIHJldHVybmVkIGFycmF5IGhhcyB0aGUgc2FtZSB0eXBlIGFzIHZhbHVlcy5cbiAqL1xuZnVuY3Rpb24gX3Rha2Uob3JkZXI6IEludDMyQXJyYXksIHZhbHVlczogRmxvYXQzMkFycmF5KTogRmxvYXQzMkFycmF5IHtcbiAgLy8gVE9ETzogSW1wbGVtZW50IGEgZ2VuZXJhbCBmdW5jdGlvbiBmb3IgVHlwZWRBcnJheS5cbiAgcmV0dXJuIEZsb2F0MzJBcnJheS5mcm9tKHZhbHVlcykubWFwKChfLCBpKSA9PiB2YWx1ZXNbb3JkZXJbaV1dKTtcbn1cblxuLyoqXG4gKiBBc3NpZ24gZWxlbWVudHMgb2YgYW4gYXJyYXkgZm9sbG93aW5nIHRoZSBvcmRlciBnaXZlbiAoZmxvYXRpbmctcG9pbnQgdmVyc2lvbikuXG4gKlxuICogQHBhcmFtIHtGbG9hdDMyQXJyYXl9IHZhbHVlcyBUaGUgc291cmNlIGFycmF5LlxuICogQHBhcmFtIHtJbnQzMkFycmF5fSBvcmRlciBUaGUgb3JkZXIgZ2l2ZW4uXG4gKiBAcmV0dXJuIHtGbG9hdDMyQXJyYXl9IFRoZSByZXR1cm5lZCBhcnJheSBoYXMgdGhlIHNhbWUgdHlwZSBhcyB2YWx1ZXMuXG4gKi9cbmZ1bmN0aW9uIF9naXZlKHZhbHVlczogRmxvYXQzMkFycmF5LCBvcmRlcjogSW50MzJBcnJheSk6IEZsb2F0MzJBcnJheSB7XG4gIGNvbnN0IHYgPSBGbG9hdDMyQXJyYXkuZnJvbSh2YWx1ZXMpO1xuXG4gIGZvciAobGV0IGkgPSAwOyBpIDwgb3JkZXIubGVuZ3RoOyArK2kpIHtcbiAgICB2W29yZGVyW2ldXSA9IHZhbHVlc1tpXTtcbiAgfVxuICByZXR1cm4gdjtcbn1cblxuLyoqXG4gKiBBc3NpZ24gZWxlbWVudHMgb2YgYW4gYXJyYXkgZm9sbG93aW5nIHRoZSBvcmRlciBnaXZlbiAoYm9vbGVhbiB2ZXJzaW9uKS5cbiAqXG4gKiBAcGFyYW0ge0FycmF5PGJvb2xlYW4+fSB2YWx1ZXMgVGhlIHNvdXJjZSBhcnJheS5cbiAqIEBwYXJhbSB7SW50MzJBcnJheX0gb3JkZXIgVGhlIG9yZGVyIGdpdmVuLlxuICogQHJldHVybiB7QXJyYXk8Ym9vbGVhbj59IFRoZSByZXR1cm5lZCBhcnJheSBoYXMgdGhlIHNhbWUgdHlwZSBhcyB2YWx1ZXMuXG4gKi9cbmZ1bmN0aW9uIF9naXZlYih2YWx1ZXM6IEFycmF5PGJvb2xlYW4+LCBvcmRlcjogSW50MzJBcnJheSk6IEFycmF5PGJvb2xlYW4+IHtcbiAgY29uc3QgdiA9IEFycmF5LmZyb20odmFsdWVzKTtcblxuICBmb3IgKGxldCBpID0gMDsgaSA8IG9yZGVyLmxlbmd0aDsgKytpKSB7XG4gICAgdltvcmRlcltpXV0gPSB2YWx1ZXNbaV07XG4gIH1cbiAgcmV0dXJuIHY7XG59XG5cbi8qKlxuICogTm8gZnJpbGxzIGVtcGlyaWNhbCBjZGYgdXNlZCBpbiBmZHJjb3JyZWN0aW9uLlxuICpcbiAqIEBwYXJhbSB7RmxvYXQzMkFycmF5fSB4IFRoZSBzb3VyY2UgYXJyYXkgdG8gdGFrZSBhIGRpbWVuc2lvbiBmcm9tLlxuICogQHJldHVybiB7RmxvYXQzMkFycmF5fSBFbXBpcmljYWwgY2RmLlxuICovXG5mdW5jdGlvbiBfZWNkZih4OiBGbG9hdDMyQXJyYXkpOiBGbG9hdDMyQXJyYXkge1xuICBjb25zdCBub2JzID0geC5sZW5ndGg7XG4gIHJldHVybiBGbG9hdDMyQXJyYXkuZnJvbSh4KS5tYXAoKF8sIGkpID0+IChpKzEpL25vYnMpO1xufVxuXG4vKipcbiAqIGNtID0gbnAuc3VtKDEuL25wLmFyYW5nZSgxLCBsZW4ocHZhbHNfc29ydGVkKSsxKSlcbiAqXG4gKiBAcGFyYW0ge251bWJlcn0gbiBUaGUgbnVtYmVyIGdpdmVuLlxuICogQHJldHVybiB7bnVtYmVyfSBjbSB2YWx1ZS5cbiAqL1xuZnVuY3Rpb24gX2NtKG46IG51bWJlcik6IG51bWJlciB7XG4gIGxldCBzdW0gPSAwO1xuICBmb3IgKGxldCBpID0gMDsgaSA8IG47ICsraSkge1xuICAgIHN1bSArPSAxIC8gKGkrMSk7XG4gIH1cbiAgcmV0dXJuIHN1bTtcbn1cblxuLyoqXG4gKiBCYXNpYyBvcGVyYXRpb24gdW5kZXIgYSB2ZWN0b3IgYW5kIGEgc2NhbGFyLlxuICpcbiAqIEBwYXJhbSB7RmxvYXQzMkFycmF5fSB2YWx1ZXMgVGhlIHNvdXJjZSB2ZWN0b3IuXG4gKiBAcGFyYW0ge251bWJlcn0gc2NhbGUgVGhlIHNjYWxhci5cbiAqIEBwYXJhbSB7c3RyaW5nfSBbb3A9JyonXSBUaGUgb3BlcmF0aW9uIHRvIHBlcmZvcm0uXG4gKiBAcmV0dXJuIHtGbG9hdDMyQXJyYXl9IE5ldyB2ZWN0b3IgYXMgYSByZXN1bHQgb2YgdGhlIG9wZXJhdGlvbi5cbiAqL1xuZnVuY3Rpb24gX2ZhY3Rvcih2YWx1ZXM6IEZsb2F0MzJBcnJheSwgc2NhbGU6IG51bWJlciwgb3AgPSAnKicpOiBGbG9hdDMyQXJyYXkge1xuICByZXR1cm4gRmxvYXQzMkFycmF5LmZyb20odmFsdWVzKS5tYXAoKHYsIF8pID0+IF9vcGVyYXRpb25zW29wXSh2LCBzY2FsZSkpO1xufVxuXG4vKipcbiAqIEJhc2ljIG9wZXJhdGlvbiB1bmRlciB0d28gdmVjdG9ycy5cbiAqXG4gKiBAcGFyYW0ge0Zsb2F0MzJBcnJheX0gdmFsdWVzIFRoZSBmaXJzdCB2ZWN0b3IuXG4gKiBAcGFyYW0ge0Zsb2F0MzJBcnJheX0gc2NhbGUgVGhlIHNlY29uZCB2ZWN0b3IuXG4gKiBAcGFyYW0ge3N0cmluZ30gW29wPScqJ10gVGhlIG9wZXJhdGlvbiB0byBwZXJmb3JtLlxuICogQHJldHVybiB7RmxvYXQzMkFycmF5fSBOZXcgdmVjdG9yIGFzIGEgcmVzdWx0IG9mIHRoZSBvcGVyYXRpb24uXG4gKi9cbmZ1bmN0aW9uIF92ZmFjdG9yKHZhbHVlczogRmxvYXQzMkFycmF5LCBzY2FsZTogRmxvYXQzMkFycmF5LCBvcCA9ICcqJyk6IEZsb2F0MzJBcnJheSB7XG4gIHJldHVybiBGbG9hdDMyQXJyYXkuZnJvbSh2YWx1ZXMpLm1hcCgodiwgaSkgPT4gX29wZXJhdGlvbnNbb3BdKHYsIHNjYWxlW2ldKSk7XG59XG5cbi8qKlxuICogQWNjdW11bGF0ZSB0aGUgcmVzdWx0IG9mIGFwcGx5aW5nIHRoZSBtaW4gb3BlcmF0b3IgdG8gYWxsIGVsZW1lbnRzLlxuICpcbiAqIEBwYXJhbSB7RmxvYXQzMkFycmF5fSB2YWx1ZXMgVGhlIGFycmF5IHRvIGFjdCBvbi5cbiAqIEByZXR1cm4ge0Zsb2F0MzJBcnJheX0gVGhlIGFjY3VtdWxhdGVkIHZhbHVlcy5cbiAqL1xuZnVuY3Rpb24gX21pbmltdW1BY2N1bXVsYXRlKHZhbHVlczogRmxvYXQzMkFycmF5KTogRmxvYXQzMkFycmF5IHtcbiAgY29uc3Qgbkl0ZW1zID0gdmFsdWVzLmxlbmd0aDtcbiAgY29uc3QgciA9IEZsb2F0MzJBcnJheS5mcm9tKHZhbHVlcyk7XG5cbiAgZm9yIChsZXQgaSA9IDA7IGkgPCBuSXRlbXM7ICsraSkge1xuICAgIHJbaV0gPSB2YWx1ZXMuc2xpY2UoMCwgaSsxKS5yZWR1Y2UoKGEsIGIsIF8sIF9fKSA9PiAoX29wZXJhdGlvbnNbJ21pbiddKGEsIGIpKSk7XG4gIH1cbiAgcmV0dXJuIHI7XG59XG5cbi8qKlxuICogcHZhbHVlIGNvcnJlY3Rpb24gZm9yIGZhbHNlIGRpc2NvdmVyeSByYXRlXG4gKlxuICogQGV4cG9ydFxuICogQHBhcmFtIHtGbG9hdDMyQXJyYXl9IHB2YWxzIFNldCBvZiBwLXZhbHVlcyBvZiB0aGUgaW5kaXZpZHVhbCB0ZXN0cy5cbiAqIEBwYXJhbSB7bnVtYmVyfSBbYWxwaGE9MC4wNV0gRmFtaWx5LXdpc2UgZXJyb3IgcmF0ZS4gRGVmYXVsdHMgdG8gMC4wNS5cbiAqIEBwYXJhbSB7c3RyaW5nfSBbbWV0aG9kPSduJ10geydpJywgJ2luZGVwJywgJ3AnLCAncG9zY29ycicsICduJywgJ25lZ2NvcnInfSwgb3B0aW9uYWxcbiAqIFdoaWNoIG1ldGhvZCB0byB1c2UgZm9yIEZEUiBjb3JyZWN0aW9uLlxuICogYGB7J2knLCAnaW5kZXAnLCAncCcsICdwb3Njb3JyJ31gYCBhbGwgcmVmZXIgdG8gYGBmZHJfYmhgYFxuICogKEJlbmphbWluaS9Ib2NoYmVyZyBmb3IgaW5kZXBlbmRlbnQgb3IgcG9zaXRpdmVseVxuICogY29ycmVsYXRlZCB0ZXN0cykuIGBgeyduJywgJ25lZ2NvcnInfWBgIGJvdGggcmVmZXIgdG8gYGBmZHJfYnlgYFxuICogKEJlbmphbWluaS9ZZWt1dGllbGkgZm9yIGdlbmVyYWwgb3IgbmVnYXRpdmVseSBjb3JyZWxhdGVkIHRlc3RzKS5cbiAqIERlZmF1bHRzIHRvICduJy5cbiAqIEBwYXJhbSB7Ym9vbGVhbn0gW2lzU29ydGVkPWZhbHNlXSBJZiBGYWxzZSAoZGVmYXVsdCksIHRoZSBwX3ZhbHVlcyB3aWxsIGJlIHNvcnRlZCwgYnV0IHRoZSBjb3JyZWN0ZWRcbiAqIHB2YWx1ZXMgYXJlIGluIHRoZSBvcmlnaW5hbCBvcmRlci4gSWYgVHJ1ZSwgdGhlbiBpdCBhc3N1bWVkIHRoYXQgdGhlXG4gKiBwdmFsdWVzIGFyZSBhbHJlYWR5IHNvcnRlZCBpbiBhc2NlbmRpbmcgb3JkZXIuXG4gKiBAcmV0dXJuIHtbQXJyYXk8Ym9vbGVhbj4sIEZsb2F0MzJBcnJheV19IHJlamVjdGVkIDogbmRhcnJheSwgYm9vbFxuICogVHJ1ZSBpZiBhIGh5cG90aGVzaXMgaXMgcmVqZWN0ZWQsIEZhbHNlIGlmIG5vdFxuICogcHZhbHVlLWNvcnJlY3RlZCA6IG5kYXJyYXlcbiAqIHB2YWx1ZXMgYWRqdXN0ZWQgZm9yIG11bHRpcGxlIGh5cG90aGVzaXMgdGVzdGluZyB0byBsaW1pdCBGRFJcbiAqIEBzZWVcbiAqIElmIHRoZXJlIGlzIHByaW9yIGluZm9ybWF0aW9uIG9uIHRoZSBmcmFjdGlvbiBvZiB0cnVlIGh5cG90aGVzaXMsIHRoZW4gYWxwaGFcbiAqIHNob3VsZCBiZSBzZXQgdG8gYGBhbHBoYSAqIG0vbV8wYGAgd2hlcmUgbSBpcyB0aGUgbnVtYmVyIG9mIHRlc3RzLFxuICogZ2l2ZW4gYnkgdGhlIHAtdmFsdWVzLCBhbmQgbV8wIGlzIGFuIGVzdGltYXRlIG9mIHRoZSB0cnVlIGh5cG90aGVzaXMuXG4gKiAoc2VlIEJlbmphbWluaSwgS3JpZWdlciBhbmQgWWVrdXRlbGkpXG4gKlxuICogVGhlIHR3by1zdGVwIG1ldGhvZCBvZiBCZW5qYW1pbmksIEtyaWVnZXIgYW5kIFlla3V0aWVsIHRoYXQgZXN0aW1hdGVzIHRoZSBudW1iZXJcbiAqIG9mIGZhbHNlIGh5cG90aGVzZXMgd2lsbCBiZSBhdmFpbGFibGUgKHNvb24pLlxuICpcbiAqIEJvdGggbWV0aG9kcyBleHBvc2VkIHZpYSB0aGlzIGZ1bmN0aW9uIChCZW5qYW1pbmkvSG9jaGJlcmcsIEJlbmphbWluaS9ZZWt1dGllbGkpXG4gKiBhcmUgYWxzbyBhdmFpbGFibGUgaW4gdGhlIGZ1bmN0aW9uIGBgbXVsdGlwbGV0ZXN0c2BgLCBhcyBgYG1ldGhvZD1cImZkcl9iaFwiYGAgYW5kXG4gKiBgYG1ldGhvZD1cImZkcl9ieVwiYGAsIHJlc3BlY3RpdmVseS5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGZkcmNvcnJlY3Rpb24oXG4gIHB2YWxzOiBGbG9hdDMyQXJyYXksXG4gIGFscGhhOiBudW1iZXIgPSAwLjA1LFxuICBtZXRob2Q6IHN0cmluZyA9J24nLFxuICBpc1NvcnRlZDogYm9vbGVhbiA9IGZhbHNlKTogW0FycmF5PGJvb2xlYW4+LCBGbG9hdDMyQXJyYXldXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgYnJhY2Utc3R5bGVcbntcbiAgY29uc3Qgbkl0ZW1zID0gcHZhbHMubGVuZ3RoO1xuICBsZXQgcHZhbHNTb3J0ZWQ6IEZsb2F0MzJBcnJheTtcbiAgbGV0IHB2YWxzU29ydGluZDogSW50MzJBcnJheTtcbiAgbGV0IGNtID0gMDtcblxuICBpZiAoIWlzU29ydGVkKSB7XG4gICAgcHZhbHNTb3J0aW5kID0gX2FyZ3NvcnQocHZhbHMpO1xuICAgIHB2YWxzU29ydGVkID0gX3Rha2UocHZhbHNTb3J0aW5kLCBwdmFscyk7XG4gIH0gZWxzZSB7XG4gICAgcHZhbHNTb3J0aW5kID0gbmV3IEludDMyQXJyYXkobkl0ZW1zKS5maWxsKDApLm1hcCgoXywgaSkgPT4gKGkpKTtcbiAgICBwdmFsc1NvcnRlZCA9IHB2YWxzOyAvLyBhbGlhc1xuICB9XG5cbiAgbGV0IGVjZGZmYWN0b3IgPSBfZWNkZihwdmFsc1NvcnRlZCk7XG5cbiAgaWYgKFsnaScsICdpbmRlcCcsICdwJywgJ3Bvc2NvcnInXS5pbmNsdWRlcyhtZXRob2QpKSB7XG4gICAgO1xuICB9IGVsc2UgaWYgKFsnbicsICduZWdjb3JyJ10uaW5jbHVkZXMobWV0aG9kKSkge1xuICAgIGNtID0gX2NtKG5JdGVtcyk7XG4gICAgZWNkZmZhY3RvciA9IF9mYWN0b3IoZWNkZmZhY3RvciwgY20sICcvJyk7XG4gIH0gZWxzZSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdvbmx5IGluZGVwIGFuZCBuZWdjb3JyIGltcGxlbWVudGVkJyk7XG4gIH1cblxuICBjb25zdCByZWplY3Q6IGJvb2xlYW5bXSA9IG5ldyBBcnJheShuSXRlbXMpLmZpbGwoZmFsc2UpO1xuICBsZXQgcmVqZWN0bWF4ID0gLTE7XG5cbiAgZm9yIChsZXQgaSA9IDA7IGkgPCBuSXRlbXM7ICsraSkge1xuICAgIGlmIChwdmFsc1NvcnRlZFtpXSA8PSBlY2RmZmFjdG9yW2ldKmFscGhhKSB7XG4gICAgICByZWplY3RtYXggPSBpO1xuICAgIH1cbiAgfVxuXG4gIGlmIChyZWplY3RtYXggPj0gMCkge1xuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgcmVqZWN0bWF4OyArK2kpIHtcbiAgICAgIHJlamVjdFtpXSA9IHRydWU7XG4gICAgfVxuICB9XG5cbiAgbGV0IHB2YWxzQ29ycmVjdGVkID0gX3ZmYWN0b3IocHZhbHNTb3J0ZWQsIGVjZGZmYWN0b3IsICcvJyk7XG4gIHB2YWxzQ29ycmVjdGVkID0gX21pbmltdW1BY2N1bXVsYXRlKHB2YWxzQ29ycmVjdGVkLnJldmVyc2UoKSkucmV2ZXJzZSgpO1xuXG4gIGZvciAobGV0IGkgPSAwOyBpIDwgbkl0ZW1zOyArK2kpIHtcbiAgICBpZiAocHZhbHNDb3JyZWN0ZWRbaV0gPiAxKSB7XG4gICAgICBwdmFsc0NvcnJlY3RlZFtpXSA9IDE7XG4gICAgfVxuICB9XG5cbiAgaWYgKCFpc1NvcnRlZCkge1xuICAgIGNvbnN0IHB2YWxzQ29ycmVjdGVkXyA9IF9naXZlKHB2YWxzQ29ycmVjdGVkLCBwdmFsc1NvcnRpbmQpO1xuICAgIGNvbnN0IHJlamVjdF8gPSBfZ2l2ZWIocmVqZWN0LCBwdmFsc1NvcnRpbmQpO1xuICAgIHJldHVybiBbcmVqZWN0XywgcHZhbHNDb3JyZWN0ZWRfXTtcbiAgfVxuICByZXR1cm4gW3JlamVjdCwgcHZhbHNDb3JyZWN0ZWRdO1xufVxuIl19
|
package/src/tests.d.ts
CHANGED
|
@@ -1,11 +1,12 @@
|
|
|
1
|
-
declare type testStats = {
|
|
2
|
-
'p-value': number;
|
|
3
|
-
'Mean difference'?: number;
|
|
4
|
-
'Median difference'?: number;
|
|
5
|
-
'p-value more': number;
|
|
6
|
-
'p-value less': number;
|
|
7
|
-
};
|
|
8
|
-
|
|
9
|
-
export declare function
|
|
10
|
-
export
|
|
1
|
+
declare type testStats = {
|
|
2
|
+
'p-value': number;
|
|
3
|
+
'Mean difference'?: number;
|
|
4
|
+
'Median difference'?: number;
|
|
5
|
+
'p-value more': number;
|
|
6
|
+
'p-value less': number;
|
|
7
|
+
};
|
|
8
|
+
declare type Population = number[] | Float32Array | Int32Array;
|
|
9
|
+
export declare function tTest(arr1: Population, arr2: Population, devKnown?: boolean, devEqual?: boolean): testStats;
|
|
10
|
+
export declare function uTest(x: number[], y: number[], continuity?: boolean): testStats;
|
|
11
|
+
export {};
|
|
11
12
|
//# sourceMappingURL=tests.d.ts.map
|
package/src/tests.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tests.d.ts","sourceRoot":"","sources":["tests.ts"],"names":[],"mappings":"AAGA,aAAK,SAAS,GAAG;IACf,SAAS,EAAE,MAAM,CAAC;IAClB,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAC7B,cAAc,EAAE,MAAM,CAAC;IACvB,cAAc,EAAE,MAAM,CAAC;CACxB,CAAC;AAEF,wBAAgB,KAAK,CAAC,IAAI,EAAE,
|
|
1
|
+
{"version":3,"file":"tests.d.ts","sourceRoot":"","sources":["tests.ts"],"names":[],"mappings":"AAGA,aAAK,SAAS,GAAG;IACf,SAAS,EAAE,MAAM,CAAC;IAClB,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAC7B,cAAc,EAAE,MAAM,CAAC;IACvB,cAAc,EAAE,MAAM,CAAC;CACxB,CAAC;AAEF,aAAK,UAAU,GAAG,MAAM,EAAE,GAAG,YAAY,GAAG,UAAU,CAAC;AAEvD,wBAAgB,KAAK,CAAC,IAAI,EAAE,UAAU,EAAE,IAAI,EAAE,UAAU,EAAE,QAAQ,UAAM,EAAE,QAAQ,UAAM,GAAG,SAAS,CA8CnG;AAED,wBAAgB,KAAK,CAAC,CAAC,EAAE,MAAM,EAAE,EAAE,CAAC,EAAE,MAAM,EAAE,EAAE,UAAU,UAAK,GAAG,SAAS,CA+B1E"}
|