@sipemu/anofox-forecast 0.4.0
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/README.md +209 -0
- package/anofox_forecast_js.d.ts +657 -0
- package/anofox_forecast_js.js +2617 -0
- package/anofox_forecast_js_bg.wasm +0 -0
- package/anofox_forecast_js_bg.wasm.d.ts +185 -0
- package/package.json +35 -0
|
@@ -0,0 +1,2617 @@
|
|
|
1
|
+
let wasm;
|
|
2
|
+
|
|
3
|
+
function _assertClass(instance, klass) {
|
|
4
|
+
if (!(instance instanceof klass)) {
|
|
5
|
+
throw new Error(`expected instance of ${klass.name}`);
|
|
6
|
+
}
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
function getArrayF64FromWasm0(ptr, len) {
|
|
10
|
+
ptr = ptr >>> 0;
|
|
11
|
+
return getFloat64ArrayMemory0().subarray(ptr / 8, ptr / 8 + len);
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
let cachedFloat64ArrayMemory0 = null;
|
|
15
|
+
function getFloat64ArrayMemory0() {
|
|
16
|
+
if (cachedFloat64ArrayMemory0 === null || cachedFloat64ArrayMemory0.byteLength === 0) {
|
|
17
|
+
cachedFloat64ArrayMemory0 = new Float64Array(wasm.memory.buffer);
|
|
18
|
+
}
|
|
19
|
+
return cachedFloat64ArrayMemory0;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
function getStringFromWasm0(ptr, len) {
|
|
23
|
+
ptr = ptr >>> 0;
|
|
24
|
+
return decodeText(ptr, len);
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
let cachedUint32ArrayMemory0 = null;
|
|
28
|
+
function getUint32ArrayMemory0() {
|
|
29
|
+
if (cachedUint32ArrayMemory0 === null || cachedUint32ArrayMemory0.byteLength === 0) {
|
|
30
|
+
cachedUint32ArrayMemory0 = new Uint32Array(wasm.memory.buffer);
|
|
31
|
+
}
|
|
32
|
+
return cachedUint32ArrayMemory0;
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
let cachedUint8ArrayMemory0 = null;
|
|
36
|
+
function getUint8ArrayMemory0() {
|
|
37
|
+
if (cachedUint8ArrayMemory0 === null || cachedUint8ArrayMemory0.byteLength === 0) {
|
|
38
|
+
cachedUint8ArrayMemory0 = new Uint8Array(wasm.memory.buffer);
|
|
39
|
+
}
|
|
40
|
+
return cachedUint8ArrayMemory0;
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
function passArray32ToWasm0(arg, malloc) {
|
|
44
|
+
const ptr = malloc(arg.length * 4, 4) >>> 0;
|
|
45
|
+
getUint32ArrayMemory0().set(arg, ptr / 4);
|
|
46
|
+
WASM_VECTOR_LEN = arg.length;
|
|
47
|
+
return ptr;
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
function passArrayF64ToWasm0(arg, malloc) {
|
|
51
|
+
const ptr = malloc(arg.length * 8, 8) >>> 0;
|
|
52
|
+
getFloat64ArrayMemory0().set(arg, ptr / 8);
|
|
53
|
+
WASM_VECTOR_LEN = arg.length;
|
|
54
|
+
return ptr;
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
function passStringToWasm0(arg, malloc, realloc) {
|
|
58
|
+
if (realloc === undefined) {
|
|
59
|
+
const buf = cachedTextEncoder.encode(arg);
|
|
60
|
+
const ptr = malloc(buf.length, 1) >>> 0;
|
|
61
|
+
getUint8ArrayMemory0().subarray(ptr, ptr + buf.length).set(buf);
|
|
62
|
+
WASM_VECTOR_LEN = buf.length;
|
|
63
|
+
return ptr;
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
let len = arg.length;
|
|
67
|
+
let ptr = malloc(len, 1) >>> 0;
|
|
68
|
+
|
|
69
|
+
const mem = getUint8ArrayMemory0();
|
|
70
|
+
|
|
71
|
+
let offset = 0;
|
|
72
|
+
|
|
73
|
+
for (; offset < len; offset++) {
|
|
74
|
+
const code = arg.charCodeAt(offset);
|
|
75
|
+
if (code > 0x7F) break;
|
|
76
|
+
mem[ptr + offset] = code;
|
|
77
|
+
}
|
|
78
|
+
if (offset !== len) {
|
|
79
|
+
if (offset !== 0) {
|
|
80
|
+
arg = arg.slice(offset);
|
|
81
|
+
}
|
|
82
|
+
ptr = realloc(ptr, len, len = offset + arg.length * 3, 1) >>> 0;
|
|
83
|
+
const view = getUint8ArrayMemory0().subarray(ptr + offset, ptr + len);
|
|
84
|
+
const ret = cachedTextEncoder.encodeInto(arg, view);
|
|
85
|
+
|
|
86
|
+
offset += ret.written;
|
|
87
|
+
ptr = realloc(ptr, len, offset, 1) >>> 0;
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
WASM_VECTOR_LEN = offset;
|
|
91
|
+
return ptr;
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
function takeFromExternrefTable0(idx) {
|
|
95
|
+
const value = wasm.__wbindgen_externrefs.get(idx);
|
|
96
|
+
wasm.__externref_table_dealloc(idx);
|
|
97
|
+
return value;
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
let cachedTextDecoder = new TextDecoder('utf-8', { ignoreBOM: true, fatal: true });
|
|
101
|
+
cachedTextDecoder.decode();
|
|
102
|
+
const MAX_SAFARI_DECODE_BYTES = 2146435072;
|
|
103
|
+
let numBytesDecoded = 0;
|
|
104
|
+
function decodeText(ptr, len) {
|
|
105
|
+
numBytesDecoded += len;
|
|
106
|
+
if (numBytesDecoded >= MAX_SAFARI_DECODE_BYTES) {
|
|
107
|
+
cachedTextDecoder = new TextDecoder('utf-8', { ignoreBOM: true, fatal: true });
|
|
108
|
+
cachedTextDecoder.decode();
|
|
109
|
+
numBytesDecoded = len;
|
|
110
|
+
}
|
|
111
|
+
return cachedTextDecoder.decode(getUint8ArrayMemory0().subarray(ptr, ptr + len));
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
const cachedTextEncoder = new TextEncoder();
|
|
115
|
+
|
|
116
|
+
if (!('encodeInto' in cachedTextEncoder)) {
|
|
117
|
+
cachedTextEncoder.encodeInto = function (arg, view) {
|
|
118
|
+
const buf = cachedTextEncoder.encode(arg);
|
|
119
|
+
view.set(buf);
|
|
120
|
+
return {
|
|
121
|
+
read: arg.length,
|
|
122
|
+
written: buf.length
|
|
123
|
+
};
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
let WASM_VECTOR_LEN = 0;
|
|
128
|
+
|
|
129
|
+
const ADIDAForecasterFinalization = (typeof FinalizationRegistry === 'undefined')
|
|
130
|
+
? { register: () => {}, unregister: () => {} }
|
|
131
|
+
: new FinalizationRegistry(ptr => wasm.__wbg_adidaforecaster_free(ptr >>> 0, 1));
|
|
132
|
+
|
|
133
|
+
const ARIMAForecasterFinalization = (typeof FinalizationRegistry === 'undefined')
|
|
134
|
+
? { register: () => {}, unregister: () => {} }
|
|
135
|
+
: new FinalizationRegistry(ptr => wasm.__wbg_arimaforecaster_free(ptr >>> 0, 1));
|
|
136
|
+
|
|
137
|
+
const AutoARIMAForecasterFinalization = (typeof FinalizationRegistry === 'undefined')
|
|
138
|
+
? { register: () => {}, unregister: () => {} }
|
|
139
|
+
: new FinalizationRegistry(ptr => wasm.__wbg_autoarimaforecaster_free(ptr >>> 0, 1));
|
|
140
|
+
|
|
141
|
+
const AutoETSForecasterFinalization = (typeof FinalizationRegistry === 'undefined')
|
|
142
|
+
? { register: () => {}, unregister: () => {} }
|
|
143
|
+
: new FinalizationRegistry(ptr => wasm.__wbg_autoetsforecaster_free(ptr >>> 0, 1));
|
|
144
|
+
|
|
145
|
+
const AutoTBATSForecasterFinalization = (typeof FinalizationRegistry === 'undefined')
|
|
146
|
+
? { register: () => {}, unregister: () => {} }
|
|
147
|
+
: new FinalizationRegistry(ptr => wasm.__wbg_autotbatsforecaster_free(ptr >>> 0, 1));
|
|
148
|
+
|
|
149
|
+
const AutoThetaForecasterFinalization = (typeof FinalizationRegistry === 'undefined')
|
|
150
|
+
? { register: () => {}, unregister: () => {} }
|
|
151
|
+
: new FinalizationRegistry(ptr => wasm.__wbg_autothetaforecaster_free(ptr >>> 0, 1));
|
|
152
|
+
|
|
153
|
+
const CrostonForecasterFinalization = (typeof FinalizationRegistry === 'undefined')
|
|
154
|
+
? { register: () => {}, unregister: () => {} }
|
|
155
|
+
: new FinalizationRegistry(ptr => wasm.__wbg_crostonforecaster_free(ptr >>> 0, 1));
|
|
156
|
+
|
|
157
|
+
const DynamicThetaForecasterFinalization = (typeof FinalizationRegistry === 'undefined')
|
|
158
|
+
? { register: () => {}, unregister: () => {} }
|
|
159
|
+
: new FinalizationRegistry(ptr => wasm.__wbg_dynamicthetaforecaster_free(ptr >>> 0, 1));
|
|
160
|
+
|
|
161
|
+
const ETSForecasterFinalization = (typeof FinalizationRegistry === 'undefined')
|
|
162
|
+
? { register: () => {}, unregister: () => {} }
|
|
163
|
+
: new FinalizationRegistry(ptr => wasm.__wbg_etsforecaster_free(ptr >>> 0, 1));
|
|
164
|
+
|
|
165
|
+
const ForecastFinalization = (typeof FinalizationRegistry === 'undefined')
|
|
166
|
+
? { register: () => {}, unregister: () => {} }
|
|
167
|
+
: new FinalizationRegistry(ptr => wasm.__wbg_forecast_free(ptr >>> 0, 1));
|
|
168
|
+
|
|
169
|
+
const GARCHForecasterFinalization = (typeof FinalizationRegistry === 'undefined')
|
|
170
|
+
? { register: () => {}, unregister: () => {} }
|
|
171
|
+
: new FinalizationRegistry(ptr => wasm.__wbg_garchforecaster_free(ptr >>> 0, 1));
|
|
172
|
+
|
|
173
|
+
const HoltForecasterFinalization = (typeof FinalizationRegistry === 'undefined')
|
|
174
|
+
? { register: () => {}, unregister: () => {} }
|
|
175
|
+
: new FinalizationRegistry(ptr => wasm.__wbg_holtforecaster_free(ptr >>> 0, 1));
|
|
176
|
+
|
|
177
|
+
const HoltWintersForecasterFinalization = (typeof FinalizationRegistry === 'undefined')
|
|
178
|
+
? { register: () => {}, unregister: () => {} }
|
|
179
|
+
: new FinalizationRegistry(ptr => wasm.__wbg_holtwintersforecaster_free(ptr >>> 0, 1));
|
|
180
|
+
|
|
181
|
+
const IMAPAForecasterFinalization = (typeof FinalizationRegistry === 'undefined')
|
|
182
|
+
? { register: () => {}, unregister: () => {} }
|
|
183
|
+
: new FinalizationRegistry(ptr => wasm.__wbg_imapaforecaster_free(ptr >>> 0, 1));
|
|
184
|
+
|
|
185
|
+
const MFLESForecasterFinalization = (typeof FinalizationRegistry === 'undefined')
|
|
186
|
+
? { register: () => {}, unregister: () => {} }
|
|
187
|
+
: new FinalizationRegistry(ptr => wasm.__wbg_mflesforecaster_free(ptr >>> 0, 1));
|
|
188
|
+
|
|
189
|
+
const MSTLForecasterWrapperFinalization = (typeof FinalizationRegistry === 'undefined')
|
|
190
|
+
? { register: () => {}, unregister: () => {} }
|
|
191
|
+
: new FinalizationRegistry(ptr => wasm.__wbg_mstlforecasterwrapper_free(ptr >>> 0, 1));
|
|
192
|
+
|
|
193
|
+
const MeanForecasterFinalization = (typeof FinalizationRegistry === 'undefined')
|
|
194
|
+
? { register: () => {}, unregister: () => {} }
|
|
195
|
+
: new FinalizationRegistry(ptr => wasm.__wbg_meanforecaster_free(ptr >>> 0, 1));
|
|
196
|
+
|
|
197
|
+
const NaiveForecasterFinalization = (typeof FinalizationRegistry === 'undefined')
|
|
198
|
+
? { register: () => {}, unregister: () => {} }
|
|
199
|
+
: new FinalizationRegistry(ptr => wasm.__wbg_naiveforecaster_free(ptr >>> 0, 1));
|
|
200
|
+
|
|
201
|
+
const OptimizedThetaForecasterFinalization = (typeof FinalizationRegistry === 'undefined')
|
|
202
|
+
? { register: () => {}, unregister: () => {} }
|
|
203
|
+
: new FinalizationRegistry(ptr => wasm.__wbg_optimizedthetaforecaster_free(ptr >>> 0, 1));
|
|
204
|
+
|
|
205
|
+
const RandomWalkDriftForecasterFinalization = (typeof FinalizationRegistry === 'undefined')
|
|
206
|
+
? { register: () => {}, unregister: () => {} }
|
|
207
|
+
: new FinalizationRegistry(ptr => wasm.__wbg_randomwalkdriftforecaster_free(ptr >>> 0, 1));
|
|
208
|
+
|
|
209
|
+
const SARIMAForecasterFinalization = (typeof FinalizationRegistry === 'undefined')
|
|
210
|
+
? { register: () => {}, unregister: () => {} }
|
|
211
|
+
: new FinalizationRegistry(ptr => wasm.__wbg_sarimaforecaster_free(ptr >>> 0, 1));
|
|
212
|
+
|
|
213
|
+
const SESForecasterFinalization = (typeof FinalizationRegistry === 'undefined')
|
|
214
|
+
? { register: () => {}, unregister: () => {} }
|
|
215
|
+
: new FinalizationRegistry(ptr => wasm.__wbg_sesforecaster_free(ptr >>> 0, 1));
|
|
216
|
+
|
|
217
|
+
const SMAForecasterFinalization = (typeof FinalizationRegistry === 'undefined')
|
|
218
|
+
? { register: () => {}, unregister: () => {} }
|
|
219
|
+
: new FinalizationRegistry(ptr => wasm.__wbg_smaforecaster_free(ptr >>> 0, 1));
|
|
220
|
+
|
|
221
|
+
const SeasonalESForecasterFinalization = (typeof FinalizationRegistry === 'undefined')
|
|
222
|
+
? { register: () => {}, unregister: () => {} }
|
|
223
|
+
: new FinalizationRegistry(ptr => wasm.__wbg_seasonalesforecaster_free(ptr >>> 0, 1));
|
|
224
|
+
|
|
225
|
+
const SeasonalNaiveForecasterFinalization = (typeof FinalizationRegistry === 'undefined')
|
|
226
|
+
? { register: () => {}, unregister: () => {} }
|
|
227
|
+
: new FinalizationRegistry(ptr => wasm.__wbg_seasonalnaiveforecaster_free(ptr >>> 0, 1));
|
|
228
|
+
|
|
229
|
+
const SeasonalWindowAverageForecasterFinalization = (typeof FinalizationRegistry === 'undefined')
|
|
230
|
+
? { register: () => {}, unregister: () => {} }
|
|
231
|
+
: new FinalizationRegistry(ptr => wasm.__wbg_seasonalwindowaverageforecaster_free(ptr >>> 0, 1));
|
|
232
|
+
|
|
233
|
+
const TBATSForecasterFinalization = (typeof FinalizationRegistry === 'undefined')
|
|
234
|
+
? { register: () => {}, unregister: () => {} }
|
|
235
|
+
: new FinalizationRegistry(ptr => wasm.__wbg_tbatsforecaster_free(ptr >>> 0, 1));
|
|
236
|
+
|
|
237
|
+
const TSBForecasterFinalization = (typeof FinalizationRegistry === 'undefined')
|
|
238
|
+
? { register: () => {}, unregister: () => {} }
|
|
239
|
+
: new FinalizationRegistry(ptr => wasm.__wbg_tsbforecaster_free(ptr >>> 0, 1));
|
|
240
|
+
|
|
241
|
+
const ThetaForecasterFinalization = (typeof FinalizationRegistry === 'undefined')
|
|
242
|
+
? { register: () => {}, unregister: () => {} }
|
|
243
|
+
: new FinalizationRegistry(ptr => wasm.__wbg_thetaforecaster_free(ptr >>> 0, 1));
|
|
244
|
+
|
|
245
|
+
const TimeSeriesFinalization = (typeof FinalizationRegistry === 'undefined')
|
|
246
|
+
? { register: () => {}, unregister: () => {} }
|
|
247
|
+
: new FinalizationRegistry(ptr => wasm.__wbg_timeseries_free(ptr >>> 0, 1));
|
|
248
|
+
|
|
249
|
+
const WindowAverageForecasterFinalization = (typeof FinalizationRegistry === 'undefined')
|
|
250
|
+
? { register: () => {}, unregister: () => {} }
|
|
251
|
+
: new FinalizationRegistry(ptr => wasm.__wbg_windowaverageforecaster_free(ptr >>> 0, 1));
|
|
252
|
+
|
|
253
|
+
/**
|
|
254
|
+
* ADIDA (Aggregate-Disaggregate Intermittent Demand Approach).
|
|
255
|
+
*/
|
|
256
|
+
export class ADIDAForecaster {
|
|
257
|
+
__destroy_into_raw() {
|
|
258
|
+
const ptr = this.__wbg_ptr;
|
|
259
|
+
this.__wbg_ptr = 0;
|
|
260
|
+
ADIDAForecasterFinalization.unregister(this);
|
|
261
|
+
return ptr;
|
|
262
|
+
}
|
|
263
|
+
free() {
|
|
264
|
+
const ptr = this.__destroy_into_raw();
|
|
265
|
+
wasm.__wbg_adidaforecaster_free(ptr, 0);
|
|
266
|
+
}
|
|
267
|
+
/**
|
|
268
|
+
* @param {TimeSeries} series
|
|
269
|
+
*/
|
|
270
|
+
fit(series) {
|
|
271
|
+
_assertClass(series, TimeSeries);
|
|
272
|
+
const ret = wasm.adidaforecaster_fit(this.__wbg_ptr, series.__wbg_ptr);
|
|
273
|
+
if (ret[1]) {
|
|
274
|
+
throw takeFromExternrefTable0(ret[0]);
|
|
275
|
+
}
|
|
276
|
+
}
|
|
277
|
+
constructor() {
|
|
278
|
+
const ret = wasm.adidaforecaster_new();
|
|
279
|
+
this.__wbg_ptr = ret >>> 0;
|
|
280
|
+
ADIDAForecasterFinalization.register(this, this.__wbg_ptr, this);
|
|
281
|
+
return this;
|
|
282
|
+
}
|
|
283
|
+
/**
|
|
284
|
+
* @returns {string}
|
|
285
|
+
*/
|
|
286
|
+
get name() {
|
|
287
|
+
let deferred1_0;
|
|
288
|
+
let deferred1_1;
|
|
289
|
+
try {
|
|
290
|
+
const ret = wasm.adidaforecaster_name(this.__wbg_ptr);
|
|
291
|
+
deferred1_0 = ret[0];
|
|
292
|
+
deferred1_1 = ret[1];
|
|
293
|
+
return getStringFromWasm0(ret[0], ret[1]);
|
|
294
|
+
} finally {
|
|
295
|
+
wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
|
|
296
|
+
}
|
|
297
|
+
}
|
|
298
|
+
/**
|
|
299
|
+
* @param {number} horizon
|
|
300
|
+
* @returns {Forecast}
|
|
301
|
+
*/
|
|
302
|
+
predict(horizon) {
|
|
303
|
+
const ret = wasm.adidaforecaster_predict(this.__wbg_ptr, horizon);
|
|
304
|
+
if (ret[2]) {
|
|
305
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
306
|
+
}
|
|
307
|
+
return Forecast.__wrap(ret[0]);
|
|
308
|
+
}
|
|
309
|
+
}
|
|
310
|
+
if (Symbol.dispose) ADIDAForecaster.prototype[Symbol.dispose] = ADIDAForecaster.prototype.free;
|
|
311
|
+
|
|
312
|
+
/**
|
|
313
|
+
* ARIMA forecaster - Autoregressive Integrated Moving Average.
|
|
314
|
+
*/
|
|
315
|
+
export class ARIMAForecaster {
|
|
316
|
+
__destroy_into_raw() {
|
|
317
|
+
const ptr = this.__wbg_ptr;
|
|
318
|
+
this.__wbg_ptr = 0;
|
|
319
|
+
ARIMAForecasterFinalization.unregister(this);
|
|
320
|
+
return ptr;
|
|
321
|
+
}
|
|
322
|
+
free() {
|
|
323
|
+
const ptr = this.__destroy_into_raw();
|
|
324
|
+
wasm.__wbg_arimaforecaster_free(ptr, 0);
|
|
325
|
+
}
|
|
326
|
+
/**
|
|
327
|
+
* @param {number} horizon
|
|
328
|
+
* @param {number} level
|
|
329
|
+
* @returns {Forecast}
|
|
330
|
+
*/
|
|
331
|
+
predictWithIntervals(horizon, level) {
|
|
332
|
+
const ret = wasm.arimaforecaster_predictWithIntervals(this.__wbg_ptr, horizon, level);
|
|
333
|
+
if (ret[2]) {
|
|
334
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
335
|
+
}
|
|
336
|
+
return Forecast.__wrap(ret[0]);
|
|
337
|
+
}
|
|
338
|
+
/**
|
|
339
|
+
* @param {TimeSeries} series
|
|
340
|
+
*/
|
|
341
|
+
fit(series) {
|
|
342
|
+
_assertClass(series, TimeSeries);
|
|
343
|
+
const ret = wasm.arimaforecaster_fit(this.__wbg_ptr, series.__wbg_ptr);
|
|
344
|
+
if (ret[1]) {
|
|
345
|
+
throw takeFromExternrefTable0(ret[0]);
|
|
346
|
+
}
|
|
347
|
+
}
|
|
348
|
+
/**
|
|
349
|
+
* @param p - AR order (autoregressive)
|
|
350
|
+
* @param d - Differencing order
|
|
351
|
+
* @param q - MA order (moving average)
|
|
352
|
+
* @param {number} p
|
|
353
|
+
* @param {number} d
|
|
354
|
+
* @param {number} q
|
|
355
|
+
*/
|
|
356
|
+
constructor(p, d, q) {
|
|
357
|
+
const ret = wasm.arimaforecaster_new(p, d, q);
|
|
358
|
+
this.__wbg_ptr = ret >>> 0;
|
|
359
|
+
ARIMAForecasterFinalization.register(this, this.__wbg_ptr, this);
|
|
360
|
+
return this;
|
|
361
|
+
}
|
|
362
|
+
/**
|
|
363
|
+
* @returns {string}
|
|
364
|
+
*/
|
|
365
|
+
get name() {
|
|
366
|
+
let deferred1_0;
|
|
367
|
+
let deferred1_1;
|
|
368
|
+
try {
|
|
369
|
+
const ret = wasm.arimaforecaster_name(this.__wbg_ptr);
|
|
370
|
+
deferred1_0 = ret[0];
|
|
371
|
+
deferred1_1 = ret[1];
|
|
372
|
+
return getStringFromWasm0(ret[0], ret[1]);
|
|
373
|
+
} finally {
|
|
374
|
+
wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
|
|
375
|
+
}
|
|
376
|
+
}
|
|
377
|
+
/**
|
|
378
|
+
* @param {number} horizon
|
|
379
|
+
* @returns {Forecast}
|
|
380
|
+
*/
|
|
381
|
+
predict(horizon) {
|
|
382
|
+
const ret = wasm.arimaforecaster_predict(this.__wbg_ptr, horizon);
|
|
383
|
+
if (ret[2]) {
|
|
384
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
385
|
+
}
|
|
386
|
+
return Forecast.__wrap(ret[0]);
|
|
387
|
+
}
|
|
388
|
+
}
|
|
389
|
+
if (Symbol.dispose) ARIMAForecaster.prototype[Symbol.dispose] = ARIMAForecaster.prototype.free;
|
|
390
|
+
|
|
391
|
+
/**
|
|
392
|
+
* AutoARIMA - Automatic ARIMA order selection.
|
|
393
|
+
*/
|
|
394
|
+
export class AutoARIMAForecaster {
|
|
395
|
+
__destroy_into_raw() {
|
|
396
|
+
const ptr = this.__wbg_ptr;
|
|
397
|
+
this.__wbg_ptr = 0;
|
|
398
|
+
AutoARIMAForecasterFinalization.unregister(this);
|
|
399
|
+
return ptr;
|
|
400
|
+
}
|
|
401
|
+
free() {
|
|
402
|
+
const ptr = this.__destroy_into_raw();
|
|
403
|
+
wasm.__wbg_autoarimaforecaster_free(ptr, 0);
|
|
404
|
+
}
|
|
405
|
+
/**
|
|
406
|
+
* @param {number} horizon
|
|
407
|
+
* @param {number} level
|
|
408
|
+
* @returns {Forecast}
|
|
409
|
+
*/
|
|
410
|
+
predictWithIntervals(horizon, level) {
|
|
411
|
+
const ret = wasm.autoarimaforecaster_predictWithIntervals(this.__wbg_ptr, horizon, level);
|
|
412
|
+
if (ret[2]) {
|
|
413
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
414
|
+
}
|
|
415
|
+
return Forecast.__wrap(ret[0]);
|
|
416
|
+
}
|
|
417
|
+
/**
|
|
418
|
+
* @param {TimeSeries} series
|
|
419
|
+
*/
|
|
420
|
+
fit(series) {
|
|
421
|
+
_assertClass(series, TimeSeries);
|
|
422
|
+
const ret = wasm.autoarimaforecaster_fit(this.__wbg_ptr, series.__wbg_ptr);
|
|
423
|
+
if (ret[1]) {
|
|
424
|
+
throw takeFromExternrefTable0(ret[0]);
|
|
425
|
+
}
|
|
426
|
+
}
|
|
427
|
+
constructor() {
|
|
428
|
+
const ret = wasm.autoarimaforecaster_new();
|
|
429
|
+
this.__wbg_ptr = ret >>> 0;
|
|
430
|
+
AutoARIMAForecasterFinalization.register(this, this.__wbg_ptr, this);
|
|
431
|
+
return this;
|
|
432
|
+
}
|
|
433
|
+
/**
|
|
434
|
+
* @returns {string}
|
|
435
|
+
*/
|
|
436
|
+
get name() {
|
|
437
|
+
let deferred1_0;
|
|
438
|
+
let deferred1_1;
|
|
439
|
+
try {
|
|
440
|
+
const ret = wasm.autoarimaforecaster_name(this.__wbg_ptr);
|
|
441
|
+
deferred1_0 = ret[0];
|
|
442
|
+
deferred1_1 = ret[1];
|
|
443
|
+
return getStringFromWasm0(ret[0], ret[1]);
|
|
444
|
+
} finally {
|
|
445
|
+
wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
|
|
446
|
+
}
|
|
447
|
+
}
|
|
448
|
+
/**
|
|
449
|
+
* @param {number} horizon
|
|
450
|
+
* @returns {Forecast}
|
|
451
|
+
*/
|
|
452
|
+
predict(horizon) {
|
|
453
|
+
const ret = wasm.autoarimaforecaster_predict(this.__wbg_ptr, horizon);
|
|
454
|
+
if (ret[2]) {
|
|
455
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
456
|
+
}
|
|
457
|
+
return Forecast.__wrap(ret[0]);
|
|
458
|
+
}
|
|
459
|
+
}
|
|
460
|
+
if (Symbol.dispose) AutoARIMAForecaster.prototype[Symbol.dispose] = AutoARIMAForecaster.prototype.free;
|
|
461
|
+
|
|
462
|
+
/**
|
|
463
|
+
* AutoETS - Automatic ETS model selection.
|
|
464
|
+
*/
|
|
465
|
+
export class AutoETSForecaster {
|
|
466
|
+
__destroy_into_raw() {
|
|
467
|
+
const ptr = this.__wbg_ptr;
|
|
468
|
+
this.__wbg_ptr = 0;
|
|
469
|
+
AutoETSForecasterFinalization.unregister(this);
|
|
470
|
+
return ptr;
|
|
471
|
+
}
|
|
472
|
+
free() {
|
|
473
|
+
const ptr = this.__destroy_into_raw();
|
|
474
|
+
wasm.__wbg_autoetsforecaster_free(ptr, 0);
|
|
475
|
+
}
|
|
476
|
+
/**
|
|
477
|
+
* @param {TimeSeries} series
|
|
478
|
+
*/
|
|
479
|
+
fit(series) {
|
|
480
|
+
_assertClass(series, TimeSeries);
|
|
481
|
+
const ret = wasm.autoetsforecaster_fit(this.__wbg_ptr, series.__wbg_ptr);
|
|
482
|
+
if (ret[1]) {
|
|
483
|
+
throw takeFromExternrefTable0(ret[0]);
|
|
484
|
+
}
|
|
485
|
+
}
|
|
486
|
+
constructor() {
|
|
487
|
+
const ret = wasm.autoetsforecaster_new();
|
|
488
|
+
this.__wbg_ptr = ret >>> 0;
|
|
489
|
+
AutoETSForecasterFinalization.register(this, this.__wbg_ptr, this);
|
|
490
|
+
return this;
|
|
491
|
+
}
|
|
492
|
+
/**
|
|
493
|
+
* @returns {string}
|
|
494
|
+
*/
|
|
495
|
+
get name() {
|
|
496
|
+
let deferred1_0;
|
|
497
|
+
let deferred1_1;
|
|
498
|
+
try {
|
|
499
|
+
const ret = wasm.autoetsforecaster_name(this.__wbg_ptr);
|
|
500
|
+
deferred1_0 = ret[0];
|
|
501
|
+
deferred1_1 = ret[1];
|
|
502
|
+
return getStringFromWasm0(ret[0], ret[1]);
|
|
503
|
+
} finally {
|
|
504
|
+
wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
|
|
505
|
+
}
|
|
506
|
+
}
|
|
507
|
+
/**
|
|
508
|
+
* @param {number} horizon
|
|
509
|
+
* @returns {Forecast}
|
|
510
|
+
*/
|
|
511
|
+
predict(horizon) {
|
|
512
|
+
const ret = wasm.autoetsforecaster_predict(this.__wbg_ptr, horizon);
|
|
513
|
+
if (ret[2]) {
|
|
514
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
515
|
+
}
|
|
516
|
+
return Forecast.__wrap(ret[0]);
|
|
517
|
+
}
|
|
518
|
+
}
|
|
519
|
+
if (Symbol.dispose) AutoETSForecaster.prototype[Symbol.dispose] = AutoETSForecaster.prototype.free;
|
|
520
|
+
|
|
521
|
+
/**
|
|
522
|
+
* AutoTBATS - Automatic TBATS model selection.
|
|
523
|
+
*/
|
|
524
|
+
export class AutoTBATSForecaster {
|
|
525
|
+
__destroy_into_raw() {
|
|
526
|
+
const ptr = this.__wbg_ptr;
|
|
527
|
+
this.__wbg_ptr = 0;
|
|
528
|
+
AutoTBATSForecasterFinalization.unregister(this);
|
|
529
|
+
return ptr;
|
|
530
|
+
}
|
|
531
|
+
free() {
|
|
532
|
+
const ptr = this.__destroy_into_raw();
|
|
533
|
+
wasm.__wbg_autotbatsforecaster_free(ptr, 0);
|
|
534
|
+
}
|
|
535
|
+
/**
|
|
536
|
+
* @param {TimeSeries} series
|
|
537
|
+
*/
|
|
538
|
+
fit(series) {
|
|
539
|
+
_assertClass(series, TimeSeries);
|
|
540
|
+
const ret = wasm.autotbatsforecaster_fit(this.__wbg_ptr, series.__wbg_ptr);
|
|
541
|
+
if (ret[1]) {
|
|
542
|
+
throw takeFromExternrefTable0(ret[0]);
|
|
543
|
+
}
|
|
544
|
+
}
|
|
545
|
+
/**
|
|
546
|
+
* @param seasonal_periods - Array of seasonal periods
|
|
547
|
+
* @param {Uint32Array} seasonal_periods
|
|
548
|
+
*/
|
|
549
|
+
constructor(seasonal_periods) {
|
|
550
|
+
const ptr0 = passArray32ToWasm0(seasonal_periods, wasm.__wbindgen_malloc);
|
|
551
|
+
const len0 = WASM_VECTOR_LEN;
|
|
552
|
+
const ret = wasm.autotbatsforecaster_new(ptr0, len0);
|
|
553
|
+
this.__wbg_ptr = ret >>> 0;
|
|
554
|
+
AutoTBATSForecasterFinalization.register(this, this.__wbg_ptr, this);
|
|
555
|
+
return this;
|
|
556
|
+
}
|
|
557
|
+
/**
|
|
558
|
+
* @returns {string}
|
|
559
|
+
*/
|
|
560
|
+
get name() {
|
|
561
|
+
let deferred1_0;
|
|
562
|
+
let deferred1_1;
|
|
563
|
+
try {
|
|
564
|
+
const ret = wasm.autotbatsforecaster_name(this.__wbg_ptr);
|
|
565
|
+
deferred1_0 = ret[0];
|
|
566
|
+
deferred1_1 = ret[1];
|
|
567
|
+
return getStringFromWasm0(ret[0], ret[1]);
|
|
568
|
+
} finally {
|
|
569
|
+
wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
|
|
570
|
+
}
|
|
571
|
+
}
|
|
572
|
+
/**
|
|
573
|
+
* @param {number} horizon
|
|
574
|
+
* @returns {Forecast}
|
|
575
|
+
*/
|
|
576
|
+
predict(horizon) {
|
|
577
|
+
const ret = wasm.autotbatsforecaster_predict(this.__wbg_ptr, horizon);
|
|
578
|
+
if (ret[2]) {
|
|
579
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
580
|
+
}
|
|
581
|
+
return Forecast.__wrap(ret[0]);
|
|
582
|
+
}
|
|
583
|
+
}
|
|
584
|
+
if (Symbol.dispose) AutoTBATSForecaster.prototype[Symbol.dispose] = AutoTBATSForecaster.prototype.free;
|
|
585
|
+
|
|
586
|
+
/**
|
|
587
|
+
* AutoTheta - Automatic Theta model selection.
|
|
588
|
+
*/
|
|
589
|
+
export class AutoThetaForecaster {
|
|
590
|
+
__destroy_into_raw() {
|
|
591
|
+
const ptr = this.__wbg_ptr;
|
|
592
|
+
this.__wbg_ptr = 0;
|
|
593
|
+
AutoThetaForecasterFinalization.unregister(this);
|
|
594
|
+
return ptr;
|
|
595
|
+
}
|
|
596
|
+
free() {
|
|
597
|
+
const ptr = this.__destroy_into_raw();
|
|
598
|
+
wasm.__wbg_autothetaforecaster_free(ptr, 0);
|
|
599
|
+
}
|
|
600
|
+
/**
|
|
601
|
+
* @param {number} horizon
|
|
602
|
+
* @param {number} level
|
|
603
|
+
* @returns {Forecast}
|
|
604
|
+
*/
|
|
605
|
+
predictWithIntervals(horizon, level) {
|
|
606
|
+
const ret = wasm.autothetaforecaster_predictWithIntervals(this.__wbg_ptr, horizon, level);
|
|
607
|
+
if (ret[2]) {
|
|
608
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
609
|
+
}
|
|
610
|
+
return Forecast.__wrap(ret[0]);
|
|
611
|
+
}
|
|
612
|
+
/**
|
|
613
|
+
* @param {TimeSeries} series
|
|
614
|
+
*/
|
|
615
|
+
fit(series) {
|
|
616
|
+
_assertClass(series, TimeSeries);
|
|
617
|
+
const ret = wasm.autothetaforecaster_fit(this.__wbg_ptr, series.__wbg_ptr);
|
|
618
|
+
if (ret[1]) {
|
|
619
|
+
throw takeFromExternrefTable0(ret[0]);
|
|
620
|
+
}
|
|
621
|
+
}
|
|
622
|
+
constructor() {
|
|
623
|
+
const ret = wasm.autothetaforecaster_new();
|
|
624
|
+
this.__wbg_ptr = ret >>> 0;
|
|
625
|
+
AutoThetaForecasterFinalization.register(this, this.__wbg_ptr, this);
|
|
626
|
+
return this;
|
|
627
|
+
}
|
|
628
|
+
/**
|
|
629
|
+
* @returns {string}
|
|
630
|
+
*/
|
|
631
|
+
get name() {
|
|
632
|
+
let deferred1_0;
|
|
633
|
+
let deferred1_1;
|
|
634
|
+
try {
|
|
635
|
+
const ret = wasm.autothetaforecaster_name(this.__wbg_ptr);
|
|
636
|
+
deferred1_0 = ret[0];
|
|
637
|
+
deferred1_1 = ret[1];
|
|
638
|
+
return getStringFromWasm0(ret[0], ret[1]);
|
|
639
|
+
} finally {
|
|
640
|
+
wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
|
|
641
|
+
}
|
|
642
|
+
}
|
|
643
|
+
/**
|
|
644
|
+
* @param {number} horizon
|
|
645
|
+
* @returns {Forecast}
|
|
646
|
+
*/
|
|
647
|
+
predict(horizon) {
|
|
648
|
+
const ret = wasm.autothetaforecaster_predict(this.__wbg_ptr, horizon);
|
|
649
|
+
if (ret[2]) {
|
|
650
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
651
|
+
}
|
|
652
|
+
return Forecast.__wrap(ret[0]);
|
|
653
|
+
}
|
|
654
|
+
}
|
|
655
|
+
if (Symbol.dispose) AutoThetaForecaster.prototype[Symbol.dispose] = AutoThetaForecaster.prototype.free;
|
|
656
|
+
|
|
657
|
+
/**
|
|
658
|
+
* Croston's method for intermittent demand forecasting.
|
|
659
|
+
*/
|
|
660
|
+
export class CrostonForecaster {
|
|
661
|
+
__destroy_into_raw() {
|
|
662
|
+
const ptr = this.__wbg_ptr;
|
|
663
|
+
this.__wbg_ptr = 0;
|
|
664
|
+
CrostonForecasterFinalization.unregister(this);
|
|
665
|
+
return ptr;
|
|
666
|
+
}
|
|
667
|
+
free() {
|
|
668
|
+
const ptr = this.__destroy_into_raw();
|
|
669
|
+
wasm.__wbg_crostonforecaster_free(ptr, 0);
|
|
670
|
+
}
|
|
671
|
+
/**
|
|
672
|
+
* @param {TimeSeries} series
|
|
673
|
+
*/
|
|
674
|
+
fit(series) {
|
|
675
|
+
_assertClass(series, TimeSeries);
|
|
676
|
+
const ret = wasm.crostonforecaster_fit(this.__wbg_ptr, series.__wbg_ptr);
|
|
677
|
+
if (ret[1]) {
|
|
678
|
+
throw takeFromExternrefTable0(ret[0]);
|
|
679
|
+
}
|
|
680
|
+
}
|
|
681
|
+
constructor() {
|
|
682
|
+
const ret = wasm.crostonforecaster_new();
|
|
683
|
+
this.__wbg_ptr = ret >>> 0;
|
|
684
|
+
CrostonForecasterFinalization.register(this, this.__wbg_ptr, this);
|
|
685
|
+
return this;
|
|
686
|
+
}
|
|
687
|
+
/**
|
|
688
|
+
* @returns {string}
|
|
689
|
+
*/
|
|
690
|
+
get name() {
|
|
691
|
+
let deferred1_0;
|
|
692
|
+
let deferred1_1;
|
|
693
|
+
try {
|
|
694
|
+
const ret = wasm.crostonforecaster_name(this.__wbg_ptr);
|
|
695
|
+
deferred1_0 = ret[0];
|
|
696
|
+
deferred1_1 = ret[1];
|
|
697
|
+
return getStringFromWasm0(ret[0], ret[1]);
|
|
698
|
+
} finally {
|
|
699
|
+
wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
|
|
700
|
+
}
|
|
701
|
+
}
|
|
702
|
+
/**
|
|
703
|
+
* @param {number} horizon
|
|
704
|
+
* @returns {Forecast}
|
|
705
|
+
*/
|
|
706
|
+
predict(horizon) {
|
|
707
|
+
const ret = wasm.crostonforecaster_predict(this.__wbg_ptr, horizon);
|
|
708
|
+
if (ret[2]) {
|
|
709
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
710
|
+
}
|
|
711
|
+
return Forecast.__wrap(ret[0]);
|
|
712
|
+
}
|
|
713
|
+
}
|
|
714
|
+
if (Symbol.dispose) CrostonForecaster.prototype[Symbol.dispose] = CrostonForecaster.prototype.free;
|
|
715
|
+
|
|
716
|
+
/**
|
|
717
|
+
* Dynamic Theta forecaster - updates coefficients dynamically.
|
|
718
|
+
*/
|
|
719
|
+
export class DynamicThetaForecaster {
|
|
720
|
+
static __wrap(ptr) {
|
|
721
|
+
ptr = ptr >>> 0;
|
|
722
|
+
const obj = Object.create(DynamicThetaForecaster.prototype);
|
|
723
|
+
obj.__wbg_ptr = ptr;
|
|
724
|
+
DynamicThetaForecasterFinalization.register(obj, obj.__wbg_ptr, obj);
|
|
725
|
+
return obj;
|
|
726
|
+
}
|
|
727
|
+
__destroy_into_raw() {
|
|
728
|
+
const ptr = this.__wbg_ptr;
|
|
729
|
+
this.__wbg_ptr = 0;
|
|
730
|
+
DynamicThetaForecasterFinalization.unregister(this);
|
|
731
|
+
return ptr;
|
|
732
|
+
}
|
|
733
|
+
free() {
|
|
734
|
+
const ptr = this.__destroy_into_raw();
|
|
735
|
+
wasm.__wbg_dynamicthetaforecaster_free(ptr, 0);
|
|
736
|
+
}
|
|
737
|
+
/**
|
|
738
|
+
* @param {number} horizon
|
|
739
|
+
* @param {number} level
|
|
740
|
+
* @returns {Forecast}
|
|
741
|
+
*/
|
|
742
|
+
predictWithIntervals(horizon, level) {
|
|
743
|
+
const ret = wasm.dynamicthetaforecaster_predictWithIntervals(this.__wbg_ptr, horizon, level);
|
|
744
|
+
if (ret[2]) {
|
|
745
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
746
|
+
}
|
|
747
|
+
return Forecast.__wrap(ret[0]);
|
|
748
|
+
}
|
|
749
|
+
/**
|
|
750
|
+
* @param {TimeSeries} series
|
|
751
|
+
*/
|
|
752
|
+
fit(series) {
|
|
753
|
+
_assertClass(series, TimeSeries);
|
|
754
|
+
const ret = wasm.dynamicthetaforecaster_fit(this.__wbg_ptr, series.__wbg_ptr);
|
|
755
|
+
if (ret[1]) {
|
|
756
|
+
throw takeFromExternrefTable0(ret[0]);
|
|
757
|
+
}
|
|
758
|
+
}
|
|
759
|
+
/**
|
|
760
|
+
* @param alpha - Smoothing parameter for the forecast
|
|
761
|
+
* @param {number} alpha
|
|
762
|
+
*/
|
|
763
|
+
constructor(alpha) {
|
|
764
|
+
const ret = wasm.dynamicthetaforecaster_new(alpha);
|
|
765
|
+
this.__wbg_ptr = ret >>> 0;
|
|
766
|
+
DynamicThetaForecasterFinalization.register(this, this.__wbg_ptr, this);
|
|
767
|
+
return this;
|
|
768
|
+
}
|
|
769
|
+
/**
|
|
770
|
+
* @returns {string}
|
|
771
|
+
*/
|
|
772
|
+
get name() {
|
|
773
|
+
let deferred1_0;
|
|
774
|
+
let deferred1_1;
|
|
775
|
+
try {
|
|
776
|
+
const ret = wasm.dynamicthetaforecaster_name(this.__wbg_ptr);
|
|
777
|
+
deferred1_0 = ret[0];
|
|
778
|
+
deferred1_1 = ret[1];
|
|
779
|
+
return getStringFromWasm0(ret[0], ret[1]);
|
|
780
|
+
} finally {
|
|
781
|
+
wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
|
|
782
|
+
}
|
|
783
|
+
}
|
|
784
|
+
/**
|
|
785
|
+
* @param {number} horizon
|
|
786
|
+
* @returns {Forecast}
|
|
787
|
+
*/
|
|
788
|
+
predict(horizon) {
|
|
789
|
+
const ret = wasm.dynamicthetaforecaster_predict(this.__wbg_ptr, horizon);
|
|
790
|
+
if (ret[2]) {
|
|
791
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
792
|
+
}
|
|
793
|
+
return Forecast.__wrap(ret[0]);
|
|
794
|
+
}
|
|
795
|
+
/**
|
|
796
|
+
* Create a seasonal Dynamic Theta model.
|
|
797
|
+
* @param period - Seasonal period
|
|
798
|
+
* @param {number} period
|
|
799
|
+
* @returns {DynamicThetaForecaster}
|
|
800
|
+
*/
|
|
801
|
+
static seasonal(period) {
|
|
802
|
+
const ret = wasm.dynamicthetaforecaster_seasonal(period);
|
|
803
|
+
return DynamicThetaForecaster.__wrap(ret);
|
|
804
|
+
}
|
|
805
|
+
/**
|
|
806
|
+
* Create an optimized Dynamic Theta model.
|
|
807
|
+
* @returns {DynamicThetaForecaster}
|
|
808
|
+
*/
|
|
809
|
+
static optimized() {
|
|
810
|
+
const ret = wasm.dynamicthetaforecaster_optimized();
|
|
811
|
+
return DynamicThetaForecaster.__wrap(ret);
|
|
812
|
+
}
|
|
813
|
+
}
|
|
814
|
+
if (Symbol.dispose) DynamicThetaForecaster.prototype[Symbol.dispose] = DynamicThetaForecaster.prototype.free;
|
|
815
|
+
|
|
816
|
+
/**
|
|
817
|
+
* ETS (Error-Trend-Seasonal) state-space model.
|
|
818
|
+
* Use string codes: "A" = Additive, "M" = Multiplicative, "N" = None
|
|
819
|
+
*/
|
|
820
|
+
export class ETSForecaster {
|
|
821
|
+
__destroy_into_raw() {
|
|
822
|
+
const ptr = this.__wbg_ptr;
|
|
823
|
+
this.__wbg_ptr = 0;
|
|
824
|
+
ETSForecasterFinalization.unregister(this);
|
|
825
|
+
return ptr;
|
|
826
|
+
}
|
|
827
|
+
free() {
|
|
828
|
+
const ptr = this.__destroy_into_raw();
|
|
829
|
+
wasm.__wbg_etsforecaster_free(ptr, 0);
|
|
830
|
+
}
|
|
831
|
+
/**
|
|
832
|
+
* @param {TimeSeries} series
|
|
833
|
+
*/
|
|
834
|
+
fit(series) {
|
|
835
|
+
_assertClass(series, TimeSeries);
|
|
836
|
+
const ret = wasm.etsforecaster_fit(this.__wbg_ptr, series.__wbg_ptr);
|
|
837
|
+
if (ret[1]) {
|
|
838
|
+
throw takeFromExternrefTable0(ret[0]);
|
|
839
|
+
}
|
|
840
|
+
}
|
|
841
|
+
/**
|
|
842
|
+
* Create an ETS model with specified components.
|
|
843
|
+
* @param error - Error type: "A" (additive) or "M" (multiplicative)
|
|
844
|
+
* @param trend - Trend type: "N" (none), "A" (additive), or "Ad" (additive damped)
|
|
845
|
+
* @param seasonal - Seasonal type: "N" (none), "A" (additive), or "M" (multiplicative)
|
|
846
|
+
* @param period - Seasonal period (ignored if seasonal is "N")
|
|
847
|
+
* @param {string} error
|
|
848
|
+
* @param {string} trend
|
|
849
|
+
* @param {string} seasonal
|
|
850
|
+
* @param {number} period
|
|
851
|
+
*/
|
|
852
|
+
constructor(error, trend, seasonal, period) {
|
|
853
|
+
const ptr0 = passStringToWasm0(error, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
|
|
854
|
+
const len0 = WASM_VECTOR_LEN;
|
|
855
|
+
const ptr1 = passStringToWasm0(trend, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
|
|
856
|
+
const len1 = WASM_VECTOR_LEN;
|
|
857
|
+
const ptr2 = passStringToWasm0(seasonal, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
|
|
858
|
+
const len2 = WASM_VECTOR_LEN;
|
|
859
|
+
const ret = wasm.etsforecaster_new(ptr0, len0, ptr1, len1, ptr2, len2, period);
|
|
860
|
+
if (ret[2]) {
|
|
861
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
862
|
+
}
|
|
863
|
+
this.__wbg_ptr = ret[0] >>> 0;
|
|
864
|
+
ETSForecasterFinalization.register(this, this.__wbg_ptr, this);
|
|
865
|
+
return this;
|
|
866
|
+
}
|
|
867
|
+
/**
|
|
868
|
+
* @returns {string}
|
|
869
|
+
*/
|
|
870
|
+
get name() {
|
|
871
|
+
let deferred1_0;
|
|
872
|
+
let deferred1_1;
|
|
873
|
+
try {
|
|
874
|
+
const ret = wasm.etsforecaster_name(this.__wbg_ptr);
|
|
875
|
+
deferred1_0 = ret[0];
|
|
876
|
+
deferred1_1 = ret[1];
|
|
877
|
+
return getStringFromWasm0(ret[0], ret[1]);
|
|
878
|
+
} finally {
|
|
879
|
+
wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
|
|
880
|
+
}
|
|
881
|
+
}
|
|
882
|
+
/**
|
|
883
|
+
* @param {number} horizon
|
|
884
|
+
* @returns {Forecast}
|
|
885
|
+
*/
|
|
886
|
+
predict(horizon) {
|
|
887
|
+
const ret = wasm.etsforecaster_predict(this.__wbg_ptr, horizon);
|
|
888
|
+
if (ret[2]) {
|
|
889
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
890
|
+
}
|
|
891
|
+
return Forecast.__wrap(ret[0]);
|
|
892
|
+
}
|
|
893
|
+
}
|
|
894
|
+
if (Symbol.dispose) ETSForecaster.prototype[Symbol.dispose] = ETSForecaster.prototype.free;
|
|
895
|
+
|
|
896
|
+
/**
|
|
897
|
+
* Forecast result wrapper for JavaScript.
|
|
898
|
+
*
|
|
899
|
+
* Contains point predictions and optional prediction intervals.
|
|
900
|
+
*/
|
|
901
|
+
export class Forecast {
|
|
902
|
+
static __wrap(ptr) {
|
|
903
|
+
ptr = ptr >>> 0;
|
|
904
|
+
const obj = Object.create(Forecast.prototype);
|
|
905
|
+
obj.__wbg_ptr = ptr;
|
|
906
|
+
ForecastFinalization.register(obj, obj.__wbg_ptr, obj);
|
|
907
|
+
return obj;
|
|
908
|
+
}
|
|
909
|
+
__destroy_into_raw() {
|
|
910
|
+
const ptr = this.__wbg_ptr;
|
|
911
|
+
this.__wbg_ptr = 0;
|
|
912
|
+
ForecastFinalization.unregister(this);
|
|
913
|
+
return ptr;
|
|
914
|
+
}
|
|
915
|
+
free() {
|
|
916
|
+
const ptr = this.__destroy_into_raw();
|
|
917
|
+
wasm.__wbg_forecast_free(ptr, 0);
|
|
918
|
+
}
|
|
919
|
+
/**
|
|
920
|
+
* Get lower prediction interval bounds.
|
|
921
|
+
*
|
|
922
|
+
* @returns Array of lower bounds, or undefined if not available
|
|
923
|
+
* @returns {Float64Array | undefined}
|
|
924
|
+
*/
|
|
925
|
+
get lower() {
|
|
926
|
+
const ret = wasm.forecast_lower(this.__wbg_ptr);
|
|
927
|
+
let v1;
|
|
928
|
+
if (ret[0] !== 0) {
|
|
929
|
+
v1 = getArrayF64FromWasm0(ret[0], ret[1]).slice();
|
|
930
|
+
wasm.__wbindgen_free(ret[0], ret[1] * 8, 8);
|
|
931
|
+
}
|
|
932
|
+
return v1;
|
|
933
|
+
}
|
|
934
|
+
/**
|
|
935
|
+
* Get upper prediction interval bounds.
|
|
936
|
+
*
|
|
937
|
+
* @returns Array of upper bounds, or undefined if not available
|
|
938
|
+
* @returns {Float64Array | undefined}
|
|
939
|
+
*/
|
|
940
|
+
get upper() {
|
|
941
|
+
const ret = wasm.forecast_upper(this.__wbg_ptr);
|
|
942
|
+
let v1;
|
|
943
|
+
if (ret[0] !== 0) {
|
|
944
|
+
v1 = getArrayF64FromWasm0(ret[0], ret[1]).slice();
|
|
945
|
+
wasm.__wbindgen_free(ret[0], ret[1] * 8, 8);
|
|
946
|
+
}
|
|
947
|
+
return v1;
|
|
948
|
+
}
|
|
949
|
+
/**
|
|
950
|
+
* Get point predictions.
|
|
951
|
+
* @returns {Float64Array}
|
|
952
|
+
*/
|
|
953
|
+
get values() {
|
|
954
|
+
const ret = wasm.forecast_values(this.__wbg_ptr);
|
|
955
|
+
var v1 = getArrayF64FromWasm0(ret[0], ret[1]).slice();
|
|
956
|
+
wasm.__wbindgen_free(ret[0], ret[1] * 8, 8);
|
|
957
|
+
return v1;
|
|
958
|
+
}
|
|
959
|
+
/**
|
|
960
|
+
* Get the forecast horizon (number of predictions).
|
|
961
|
+
* @returns {number}
|
|
962
|
+
*/
|
|
963
|
+
get horizon() {
|
|
964
|
+
const ret = wasm.forecast_horizon(this.__wbg_ptr);
|
|
965
|
+
return ret >>> 0;
|
|
966
|
+
}
|
|
967
|
+
/**
|
|
968
|
+
* Check if lower prediction interval is available.
|
|
969
|
+
* @returns {boolean}
|
|
970
|
+
*/
|
|
971
|
+
hasLower() {
|
|
972
|
+
const ret = wasm.forecast_hasLower(this.__wbg_ptr);
|
|
973
|
+
return ret !== 0;
|
|
974
|
+
}
|
|
975
|
+
/**
|
|
976
|
+
* Check if upper prediction interval is available.
|
|
977
|
+
* @returns {boolean}
|
|
978
|
+
*/
|
|
979
|
+
hasUpper() {
|
|
980
|
+
const ret = wasm.forecast_hasUpper(this.__wbg_ptr);
|
|
981
|
+
return ret !== 0;
|
|
982
|
+
}
|
|
983
|
+
}
|
|
984
|
+
if (Symbol.dispose) Forecast.prototype[Symbol.dispose] = Forecast.prototype.free;
|
|
985
|
+
|
|
986
|
+
/**
|
|
987
|
+
* GARCH - Generalized Autoregressive Conditional Heteroskedasticity.
|
|
988
|
+
*/
|
|
989
|
+
export class GARCHForecaster {
|
|
990
|
+
__destroy_into_raw() {
|
|
991
|
+
const ptr = this.__wbg_ptr;
|
|
992
|
+
this.__wbg_ptr = 0;
|
|
993
|
+
GARCHForecasterFinalization.unregister(this);
|
|
994
|
+
return ptr;
|
|
995
|
+
}
|
|
996
|
+
free() {
|
|
997
|
+
const ptr = this.__destroy_into_raw();
|
|
998
|
+
wasm.__wbg_garchforecaster_free(ptr, 0);
|
|
999
|
+
}
|
|
1000
|
+
/**
|
|
1001
|
+
* @param {TimeSeries} series
|
|
1002
|
+
*/
|
|
1003
|
+
fit(series) {
|
|
1004
|
+
_assertClass(series, TimeSeries);
|
|
1005
|
+
const ret = wasm.garchforecaster_fit(this.__wbg_ptr, series.__wbg_ptr);
|
|
1006
|
+
if (ret[1]) {
|
|
1007
|
+
throw takeFromExternrefTable0(ret[0]);
|
|
1008
|
+
}
|
|
1009
|
+
}
|
|
1010
|
+
/**
|
|
1011
|
+
* @param p - GARCH order (lagged variance terms)
|
|
1012
|
+
* @param q - ARCH order (lagged squared residuals)
|
|
1013
|
+
* @param {number} p
|
|
1014
|
+
* @param {number} q
|
|
1015
|
+
*/
|
|
1016
|
+
constructor(p, q) {
|
|
1017
|
+
const ret = wasm.garchforecaster_new(p, q);
|
|
1018
|
+
this.__wbg_ptr = ret >>> 0;
|
|
1019
|
+
GARCHForecasterFinalization.register(this, this.__wbg_ptr, this);
|
|
1020
|
+
return this;
|
|
1021
|
+
}
|
|
1022
|
+
/**
|
|
1023
|
+
* @returns {string}
|
|
1024
|
+
*/
|
|
1025
|
+
get name() {
|
|
1026
|
+
let deferred1_0;
|
|
1027
|
+
let deferred1_1;
|
|
1028
|
+
try {
|
|
1029
|
+
const ret = wasm.garchforecaster_name(this.__wbg_ptr);
|
|
1030
|
+
deferred1_0 = ret[0];
|
|
1031
|
+
deferred1_1 = ret[1];
|
|
1032
|
+
return getStringFromWasm0(ret[0], ret[1]);
|
|
1033
|
+
} finally {
|
|
1034
|
+
wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
|
|
1035
|
+
}
|
|
1036
|
+
}
|
|
1037
|
+
/**
|
|
1038
|
+
* @param {number} horizon
|
|
1039
|
+
* @returns {Forecast}
|
|
1040
|
+
*/
|
|
1041
|
+
predict(horizon) {
|
|
1042
|
+
const ret = wasm.garchforecaster_predict(this.__wbg_ptr, horizon);
|
|
1043
|
+
if (ret[2]) {
|
|
1044
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
1045
|
+
}
|
|
1046
|
+
return Forecast.__wrap(ret[0]);
|
|
1047
|
+
}
|
|
1048
|
+
}
|
|
1049
|
+
if (Symbol.dispose) GARCHForecaster.prototype[Symbol.dispose] = GARCHForecaster.prototype.free;
|
|
1050
|
+
|
|
1051
|
+
/**
|
|
1052
|
+
* Holt Linear Trend (Double Exponential Smoothing) forecaster.
|
|
1053
|
+
*/
|
|
1054
|
+
export class HoltForecaster {
|
|
1055
|
+
__destroy_into_raw() {
|
|
1056
|
+
const ptr = this.__wbg_ptr;
|
|
1057
|
+
this.__wbg_ptr = 0;
|
|
1058
|
+
HoltForecasterFinalization.unregister(this);
|
|
1059
|
+
return ptr;
|
|
1060
|
+
}
|
|
1061
|
+
free() {
|
|
1062
|
+
const ptr = this.__destroy_into_raw();
|
|
1063
|
+
wasm.__wbg_holtforecaster_free(ptr, 0);
|
|
1064
|
+
}
|
|
1065
|
+
/**
|
|
1066
|
+
* @param {TimeSeries} series
|
|
1067
|
+
*/
|
|
1068
|
+
fit(series) {
|
|
1069
|
+
_assertClass(series, TimeSeries);
|
|
1070
|
+
const ret = wasm.holtforecaster_fit(this.__wbg_ptr, series.__wbg_ptr);
|
|
1071
|
+
if (ret[1]) {
|
|
1072
|
+
throw takeFromExternrefTable0(ret[0]);
|
|
1073
|
+
}
|
|
1074
|
+
}
|
|
1075
|
+
/**
|
|
1076
|
+
* @param alpha - Level smoothing parameter (0 < alpha <= 1)
|
|
1077
|
+
* @param beta - Trend smoothing parameter (0 < beta <= 1)
|
|
1078
|
+
* @param {number} alpha
|
|
1079
|
+
* @param {number} beta
|
|
1080
|
+
*/
|
|
1081
|
+
constructor(alpha, beta) {
|
|
1082
|
+
const ret = wasm.holtforecaster_new(alpha, beta);
|
|
1083
|
+
this.__wbg_ptr = ret >>> 0;
|
|
1084
|
+
HoltForecasterFinalization.register(this, this.__wbg_ptr, this);
|
|
1085
|
+
return this;
|
|
1086
|
+
}
|
|
1087
|
+
/**
|
|
1088
|
+
* @returns {string}
|
|
1089
|
+
*/
|
|
1090
|
+
get name() {
|
|
1091
|
+
let deferred1_0;
|
|
1092
|
+
let deferred1_1;
|
|
1093
|
+
try {
|
|
1094
|
+
const ret = wasm.holtforecaster_name(this.__wbg_ptr);
|
|
1095
|
+
deferred1_0 = ret[0];
|
|
1096
|
+
deferred1_1 = ret[1];
|
|
1097
|
+
return getStringFromWasm0(ret[0], ret[1]);
|
|
1098
|
+
} finally {
|
|
1099
|
+
wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
|
|
1100
|
+
}
|
|
1101
|
+
}
|
|
1102
|
+
/**
|
|
1103
|
+
* @param {number} horizon
|
|
1104
|
+
* @returns {Forecast}
|
|
1105
|
+
*/
|
|
1106
|
+
predict(horizon) {
|
|
1107
|
+
const ret = wasm.holtforecaster_predict(this.__wbg_ptr, horizon);
|
|
1108
|
+
if (ret[2]) {
|
|
1109
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
1110
|
+
}
|
|
1111
|
+
return Forecast.__wrap(ret[0]);
|
|
1112
|
+
}
|
|
1113
|
+
}
|
|
1114
|
+
if (Symbol.dispose) HoltForecaster.prototype[Symbol.dispose] = HoltForecaster.prototype.free;
|
|
1115
|
+
|
|
1116
|
+
/**
|
|
1117
|
+
* Holt-Winters (Triple Exponential Smoothing) forecaster.
|
|
1118
|
+
*/
|
|
1119
|
+
export class HoltWintersForecaster {
|
|
1120
|
+
static __wrap(ptr) {
|
|
1121
|
+
ptr = ptr >>> 0;
|
|
1122
|
+
const obj = Object.create(HoltWintersForecaster.prototype);
|
|
1123
|
+
obj.__wbg_ptr = ptr;
|
|
1124
|
+
HoltWintersForecasterFinalization.register(obj, obj.__wbg_ptr, obj);
|
|
1125
|
+
return obj;
|
|
1126
|
+
}
|
|
1127
|
+
__destroy_into_raw() {
|
|
1128
|
+
const ptr = this.__wbg_ptr;
|
|
1129
|
+
this.__wbg_ptr = 0;
|
|
1130
|
+
HoltWintersForecasterFinalization.unregister(this);
|
|
1131
|
+
return ptr;
|
|
1132
|
+
}
|
|
1133
|
+
free() {
|
|
1134
|
+
const ptr = this.__destroy_into_raw();
|
|
1135
|
+
wasm.__wbg_holtwintersforecaster_free(ptr, 0);
|
|
1136
|
+
}
|
|
1137
|
+
/**
|
|
1138
|
+
* Create with multiplicative seasonality.
|
|
1139
|
+
* @param {number} alpha
|
|
1140
|
+
* @param {number} beta
|
|
1141
|
+
* @param {number} gamma
|
|
1142
|
+
* @param {number} period
|
|
1143
|
+
* @returns {HoltWintersForecaster}
|
|
1144
|
+
*/
|
|
1145
|
+
static multiplicative(alpha, beta, gamma, period) {
|
|
1146
|
+
const ret = wasm.holtwintersforecaster_multiplicative(alpha, beta, gamma, period);
|
|
1147
|
+
return HoltWintersForecaster.__wrap(ret);
|
|
1148
|
+
}
|
|
1149
|
+
/**
|
|
1150
|
+
* @param {TimeSeries} series
|
|
1151
|
+
*/
|
|
1152
|
+
fit(series) {
|
|
1153
|
+
_assertClass(series, TimeSeries);
|
|
1154
|
+
const ret = wasm.holtwintersforecaster_fit(this.__wbg_ptr, series.__wbg_ptr);
|
|
1155
|
+
if (ret[1]) {
|
|
1156
|
+
throw takeFromExternrefTable0(ret[0]);
|
|
1157
|
+
}
|
|
1158
|
+
}
|
|
1159
|
+
/**
|
|
1160
|
+
* Create with additive seasonality.
|
|
1161
|
+
* @param alpha - Level smoothing parameter
|
|
1162
|
+
* @param beta - Trend smoothing parameter
|
|
1163
|
+
* @param gamma - Seasonal smoothing parameter
|
|
1164
|
+
* @param period - Seasonal period
|
|
1165
|
+
* @param {number} alpha
|
|
1166
|
+
* @param {number} beta
|
|
1167
|
+
* @param {number} gamma
|
|
1168
|
+
* @param {number} period
|
|
1169
|
+
*/
|
|
1170
|
+
constructor(alpha, beta, gamma, period) {
|
|
1171
|
+
const ret = wasm.holtwintersforecaster_new(alpha, beta, gamma, period);
|
|
1172
|
+
this.__wbg_ptr = ret >>> 0;
|
|
1173
|
+
HoltWintersForecasterFinalization.register(this, this.__wbg_ptr, this);
|
|
1174
|
+
return this;
|
|
1175
|
+
}
|
|
1176
|
+
/**
|
|
1177
|
+
* @returns {string}
|
|
1178
|
+
*/
|
|
1179
|
+
get name() {
|
|
1180
|
+
let deferred1_0;
|
|
1181
|
+
let deferred1_1;
|
|
1182
|
+
try {
|
|
1183
|
+
const ret = wasm.holtwintersforecaster_name(this.__wbg_ptr);
|
|
1184
|
+
deferred1_0 = ret[0];
|
|
1185
|
+
deferred1_1 = ret[1];
|
|
1186
|
+
return getStringFromWasm0(ret[0], ret[1]);
|
|
1187
|
+
} finally {
|
|
1188
|
+
wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
|
|
1189
|
+
}
|
|
1190
|
+
}
|
|
1191
|
+
/**
|
|
1192
|
+
* @param {number} horizon
|
|
1193
|
+
* @returns {Forecast}
|
|
1194
|
+
*/
|
|
1195
|
+
predict(horizon) {
|
|
1196
|
+
const ret = wasm.holtwintersforecaster_predict(this.__wbg_ptr, horizon);
|
|
1197
|
+
if (ret[2]) {
|
|
1198
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
1199
|
+
}
|
|
1200
|
+
return Forecast.__wrap(ret[0]);
|
|
1201
|
+
}
|
|
1202
|
+
}
|
|
1203
|
+
if (Symbol.dispose) HoltWintersForecaster.prototype[Symbol.dispose] = HoltWintersForecaster.prototype.free;
|
|
1204
|
+
|
|
1205
|
+
/**
|
|
1206
|
+
* IMAPA (Intermittent Multiple Aggregation Prediction Algorithm).
|
|
1207
|
+
*/
|
|
1208
|
+
export class IMAPAForecaster {
|
|
1209
|
+
__destroy_into_raw() {
|
|
1210
|
+
const ptr = this.__wbg_ptr;
|
|
1211
|
+
this.__wbg_ptr = 0;
|
|
1212
|
+
IMAPAForecasterFinalization.unregister(this);
|
|
1213
|
+
return ptr;
|
|
1214
|
+
}
|
|
1215
|
+
free() {
|
|
1216
|
+
const ptr = this.__destroy_into_raw();
|
|
1217
|
+
wasm.__wbg_imapaforecaster_free(ptr, 0);
|
|
1218
|
+
}
|
|
1219
|
+
/**
|
|
1220
|
+
* @param {TimeSeries} series
|
|
1221
|
+
*/
|
|
1222
|
+
fit(series) {
|
|
1223
|
+
_assertClass(series, TimeSeries);
|
|
1224
|
+
const ret = wasm.imapaforecaster_fit(this.__wbg_ptr, series.__wbg_ptr);
|
|
1225
|
+
if (ret[1]) {
|
|
1226
|
+
throw takeFromExternrefTable0(ret[0]);
|
|
1227
|
+
}
|
|
1228
|
+
}
|
|
1229
|
+
constructor() {
|
|
1230
|
+
const ret = wasm.imapaforecaster_new();
|
|
1231
|
+
this.__wbg_ptr = ret >>> 0;
|
|
1232
|
+
IMAPAForecasterFinalization.register(this, this.__wbg_ptr, this);
|
|
1233
|
+
return this;
|
|
1234
|
+
}
|
|
1235
|
+
/**
|
|
1236
|
+
* @returns {string}
|
|
1237
|
+
*/
|
|
1238
|
+
get name() {
|
|
1239
|
+
let deferred1_0;
|
|
1240
|
+
let deferred1_1;
|
|
1241
|
+
try {
|
|
1242
|
+
const ret = wasm.imapaforecaster_name(this.__wbg_ptr);
|
|
1243
|
+
deferred1_0 = ret[0];
|
|
1244
|
+
deferred1_1 = ret[1];
|
|
1245
|
+
return getStringFromWasm0(ret[0], ret[1]);
|
|
1246
|
+
} finally {
|
|
1247
|
+
wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
|
|
1248
|
+
}
|
|
1249
|
+
}
|
|
1250
|
+
/**
|
|
1251
|
+
* @param {number} horizon
|
|
1252
|
+
* @returns {Forecast}
|
|
1253
|
+
*/
|
|
1254
|
+
predict(horizon) {
|
|
1255
|
+
const ret = wasm.imapaforecaster_predict(this.__wbg_ptr, horizon);
|
|
1256
|
+
if (ret[2]) {
|
|
1257
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
1258
|
+
}
|
|
1259
|
+
return Forecast.__wrap(ret[0]);
|
|
1260
|
+
}
|
|
1261
|
+
}
|
|
1262
|
+
if (Symbol.dispose) IMAPAForecaster.prototype[Symbol.dispose] = IMAPAForecaster.prototype.free;
|
|
1263
|
+
|
|
1264
|
+
/**
|
|
1265
|
+
* MFLES - Multiple Frequency Locally Estimated Scatterplot Smoothing.
|
|
1266
|
+
*/
|
|
1267
|
+
export class MFLESForecaster {
|
|
1268
|
+
__destroy_into_raw() {
|
|
1269
|
+
const ptr = this.__wbg_ptr;
|
|
1270
|
+
this.__wbg_ptr = 0;
|
|
1271
|
+
MFLESForecasterFinalization.unregister(this);
|
|
1272
|
+
return ptr;
|
|
1273
|
+
}
|
|
1274
|
+
free() {
|
|
1275
|
+
const ptr = this.__destroy_into_raw();
|
|
1276
|
+
wasm.__wbg_mflesforecaster_free(ptr, 0);
|
|
1277
|
+
}
|
|
1278
|
+
/**
|
|
1279
|
+
* @param {TimeSeries} series
|
|
1280
|
+
*/
|
|
1281
|
+
fit(series) {
|
|
1282
|
+
_assertClass(series, TimeSeries);
|
|
1283
|
+
const ret = wasm.mflesforecaster_fit(this.__wbg_ptr, series.__wbg_ptr);
|
|
1284
|
+
if (ret[1]) {
|
|
1285
|
+
throw takeFromExternrefTable0(ret[0]);
|
|
1286
|
+
}
|
|
1287
|
+
}
|
|
1288
|
+
/**
|
|
1289
|
+
* @param seasonal_periods - Array of seasonal periods
|
|
1290
|
+
* @param {Uint32Array} seasonal_periods
|
|
1291
|
+
*/
|
|
1292
|
+
constructor(seasonal_periods) {
|
|
1293
|
+
const ptr0 = passArray32ToWasm0(seasonal_periods, wasm.__wbindgen_malloc);
|
|
1294
|
+
const len0 = WASM_VECTOR_LEN;
|
|
1295
|
+
const ret = wasm.mflesforecaster_new(ptr0, len0);
|
|
1296
|
+
this.__wbg_ptr = ret >>> 0;
|
|
1297
|
+
MFLESForecasterFinalization.register(this, this.__wbg_ptr, this);
|
|
1298
|
+
return this;
|
|
1299
|
+
}
|
|
1300
|
+
/**
|
|
1301
|
+
* @returns {string}
|
|
1302
|
+
*/
|
|
1303
|
+
get name() {
|
|
1304
|
+
let deferred1_0;
|
|
1305
|
+
let deferred1_1;
|
|
1306
|
+
try {
|
|
1307
|
+
const ret = wasm.mflesforecaster_name(this.__wbg_ptr);
|
|
1308
|
+
deferred1_0 = ret[0];
|
|
1309
|
+
deferred1_1 = ret[1];
|
|
1310
|
+
return getStringFromWasm0(ret[0], ret[1]);
|
|
1311
|
+
} finally {
|
|
1312
|
+
wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
|
|
1313
|
+
}
|
|
1314
|
+
}
|
|
1315
|
+
/**
|
|
1316
|
+
* @param {number} horizon
|
|
1317
|
+
* @returns {Forecast}
|
|
1318
|
+
*/
|
|
1319
|
+
predict(horizon) {
|
|
1320
|
+
const ret = wasm.mflesforecaster_predict(this.__wbg_ptr, horizon);
|
|
1321
|
+
if (ret[2]) {
|
|
1322
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
1323
|
+
}
|
|
1324
|
+
return Forecast.__wrap(ret[0]);
|
|
1325
|
+
}
|
|
1326
|
+
}
|
|
1327
|
+
if (Symbol.dispose) MFLESForecaster.prototype[Symbol.dispose] = MFLESForecaster.prototype.free;
|
|
1328
|
+
|
|
1329
|
+
/**
|
|
1330
|
+
* MSTL Forecaster - Multiple Seasonal-Trend decomposition using LOESS.
|
|
1331
|
+
*/
|
|
1332
|
+
export class MSTLForecasterWrapper {
|
|
1333
|
+
__destroy_into_raw() {
|
|
1334
|
+
const ptr = this.__wbg_ptr;
|
|
1335
|
+
this.__wbg_ptr = 0;
|
|
1336
|
+
MSTLForecasterWrapperFinalization.unregister(this);
|
|
1337
|
+
return ptr;
|
|
1338
|
+
}
|
|
1339
|
+
free() {
|
|
1340
|
+
const ptr = this.__destroy_into_raw();
|
|
1341
|
+
wasm.__wbg_mstlforecasterwrapper_free(ptr, 0);
|
|
1342
|
+
}
|
|
1343
|
+
/**
|
|
1344
|
+
* @param {TimeSeries} series
|
|
1345
|
+
*/
|
|
1346
|
+
fit(series) {
|
|
1347
|
+
_assertClass(series, TimeSeries);
|
|
1348
|
+
const ret = wasm.mstlforecasterwrapper_fit(this.__wbg_ptr, series.__wbg_ptr);
|
|
1349
|
+
if (ret[1]) {
|
|
1350
|
+
throw takeFromExternrefTable0(ret[0]);
|
|
1351
|
+
}
|
|
1352
|
+
}
|
|
1353
|
+
/**
|
|
1354
|
+
* @param seasonal_periods - Array of seasonal periods
|
|
1355
|
+
* @param {Uint32Array} seasonal_periods
|
|
1356
|
+
*/
|
|
1357
|
+
constructor(seasonal_periods) {
|
|
1358
|
+
const ptr0 = passArray32ToWasm0(seasonal_periods, wasm.__wbindgen_malloc);
|
|
1359
|
+
const len0 = WASM_VECTOR_LEN;
|
|
1360
|
+
const ret = wasm.mstlforecasterwrapper_new(ptr0, len0);
|
|
1361
|
+
this.__wbg_ptr = ret >>> 0;
|
|
1362
|
+
MSTLForecasterWrapperFinalization.register(this, this.__wbg_ptr, this);
|
|
1363
|
+
return this;
|
|
1364
|
+
}
|
|
1365
|
+
/**
|
|
1366
|
+
* @returns {string}
|
|
1367
|
+
*/
|
|
1368
|
+
get name() {
|
|
1369
|
+
let deferred1_0;
|
|
1370
|
+
let deferred1_1;
|
|
1371
|
+
try {
|
|
1372
|
+
const ret = wasm.mstlforecasterwrapper_name(this.__wbg_ptr);
|
|
1373
|
+
deferred1_0 = ret[0];
|
|
1374
|
+
deferred1_1 = ret[1];
|
|
1375
|
+
return getStringFromWasm0(ret[0], ret[1]);
|
|
1376
|
+
} finally {
|
|
1377
|
+
wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
|
|
1378
|
+
}
|
|
1379
|
+
}
|
|
1380
|
+
/**
|
|
1381
|
+
* @param {number} horizon
|
|
1382
|
+
* @returns {Forecast}
|
|
1383
|
+
*/
|
|
1384
|
+
predict(horizon) {
|
|
1385
|
+
const ret = wasm.mstlforecasterwrapper_predict(this.__wbg_ptr, horizon);
|
|
1386
|
+
if (ret[2]) {
|
|
1387
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
1388
|
+
}
|
|
1389
|
+
return Forecast.__wrap(ret[0]);
|
|
1390
|
+
}
|
|
1391
|
+
}
|
|
1392
|
+
if (Symbol.dispose) MSTLForecasterWrapper.prototype[Symbol.dispose] = MSTLForecasterWrapper.prototype.free;
|
|
1393
|
+
|
|
1394
|
+
/**
|
|
1395
|
+
* Mean (Historic Average) forecaster - uses the historical mean as forecast.
|
|
1396
|
+
*/
|
|
1397
|
+
export class MeanForecaster {
|
|
1398
|
+
__destroy_into_raw() {
|
|
1399
|
+
const ptr = this.__wbg_ptr;
|
|
1400
|
+
this.__wbg_ptr = 0;
|
|
1401
|
+
MeanForecasterFinalization.unregister(this);
|
|
1402
|
+
return ptr;
|
|
1403
|
+
}
|
|
1404
|
+
free() {
|
|
1405
|
+
const ptr = this.__destroy_into_raw();
|
|
1406
|
+
wasm.__wbg_meanforecaster_free(ptr, 0);
|
|
1407
|
+
}
|
|
1408
|
+
/**
|
|
1409
|
+
* @param {number} horizon
|
|
1410
|
+
* @param {number} level
|
|
1411
|
+
* @returns {Forecast}
|
|
1412
|
+
*/
|
|
1413
|
+
predictWithIntervals(horizon, level) {
|
|
1414
|
+
const ret = wasm.meanforecaster_predictWithIntervals(this.__wbg_ptr, horizon, level);
|
|
1415
|
+
if (ret[2]) {
|
|
1416
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
1417
|
+
}
|
|
1418
|
+
return Forecast.__wrap(ret[0]);
|
|
1419
|
+
}
|
|
1420
|
+
/**
|
|
1421
|
+
* @param {TimeSeries} series
|
|
1422
|
+
*/
|
|
1423
|
+
fit(series) {
|
|
1424
|
+
_assertClass(series, TimeSeries);
|
|
1425
|
+
const ret = wasm.meanforecaster_fit(this.__wbg_ptr, series.__wbg_ptr);
|
|
1426
|
+
if (ret[1]) {
|
|
1427
|
+
throw takeFromExternrefTable0(ret[0]);
|
|
1428
|
+
}
|
|
1429
|
+
}
|
|
1430
|
+
constructor() {
|
|
1431
|
+
const ret = wasm.meanforecaster_new();
|
|
1432
|
+
this.__wbg_ptr = ret >>> 0;
|
|
1433
|
+
MeanForecasterFinalization.register(this, this.__wbg_ptr, this);
|
|
1434
|
+
return this;
|
|
1435
|
+
}
|
|
1436
|
+
/**
|
|
1437
|
+
* @returns {string}
|
|
1438
|
+
*/
|
|
1439
|
+
get name() {
|
|
1440
|
+
let deferred1_0;
|
|
1441
|
+
let deferred1_1;
|
|
1442
|
+
try {
|
|
1443
|
+
const ret = wasm.meanforecaster_name(this.__wbg_ptr);
|
|
1444
|
+
deferred1_0 = ret[0];
|
|
1445
|
+
deferred1_1 = ret[1];
|
|
1446
|
+
return getStringFromWasm0(ret[0], ret[1]);
|
|
1447
|
+
} finally {
|
|
1448
|
+
wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
|
|
1449
|
+
}
|
|
1450
|
+
}
|
|
1451
|
+
/**
|
|
1452
|
+
* @param {number} horizon
|
|
1453
|
+
* @returns {Forecast}
|
|
1454
|
+
*/
|
|
1455
|
+
predict(horizon) {
|
|
1456
|
+
const ret = wasm.meanforecaster_predict(this.__wbg_ptr, horizon);
|
|
1457
|
+
if (ret[2]) {
|
|
1458
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
1459
|
+
}
|
|
1460
|
+
return Forecast.__wrap(ret[0]);
|
|
1461
|
+
}
|
|
1462
|
+
}
|
|
1463
|
+
if (Symbol.dispose) MeanForecaster.prototype[Symbol.dispose] = MeanForecaster.prototype.free;
|
|
1464
|
+
|
|
1465
|
+
/**
|
|
1466
|
+
* Naive forecaster - uses the last observation as forecast.
|
|
1467
|
+
*/
|
|
1468
|
+
export class NaiveForecaster {
|
|
1469
|
+
__destroy_into_raw() {
|
|
1470
|
+
const ptr = this.__wbg_ptr;
|
|
1471
|
+
this.__wbg_ptr = 0;
|
|
1472
|
+
NaiveForecasterFinalization.unregister(this);
|
|
1473
|
+
return ptr;
|
|
1474
|
+
}
|
|
1475
|
+
free() {
|
|
1476
|
+
const ptr = this.__destroy_into_raw();
|
|
1477
|
+
wasm.__wbg_naiveforecaster_free(ptr, 0);
|
|
1478
|
+
}
|
|
1479
|
+
/**
|
|
1480
|
+
* @param {number} horizon
|
|
1481
|
+
* @param {number} level
|
|
1482
|
+
* @returns {Forecast}
|
|
1483
|
+
*/
|
|
1484
|
+
predictWithIntervals(horizon, level) {
|
|
1485
|
+
const ret = wasm.naiveforecaster_predictWithIntervals(this.__wbg_ptr, horizon, level);
|
|
1486
|
+
if (ret[2]) {
|
|
1487
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
1488
|
+
}
|
|
1489
|
+
return Forecast.__wrap(ret[0]);
|
|
1490
|
+
}
|
|
1491
|
+
/**
|
|
1492
|
+
* @param {TimeSeries} series
|
|
1493
|
+
*/
|
|
1494
|
+
fit(series) {
|
|
1495
|
+
_assertClass(series, TimeSeries);
|
|
1496
|
+
const ret = wasm.naiveforecaster_fit(this.__wbg_ptr, series.__wbg_ptr);
|
|
1497
|
+
if (ret[1]) {
|
|
1498
|
+
throw takeFromExternrefTable0(ret[0]);
|
|
1499
|
+
}
|
|
1500
|
+
}
|
|
1501
|
+
constructor() {
|
|
1502
|
+
const ret = wasm.naiveforecaster_new();
|
|
1503
|
+
this.__wbg_ptr = ret >>> 0;
|
|
1504
|
+
NaiveForecasterFinalization.register(this, this.__wbg_ptr, this);
|
|
1505
|
+
return this;
|
|
1506
|
+
}
|
|
1507
|
+
/**
|
|
1508
|
+
* @returns {string}
|
|
1509
|
+
*/
|
|
1510
|
+
get name() {
|
|
1511
|
+
let deferred1_0;
|
|
1512
|
+
let deferred1_1;
|
|
1513
|
+
try {
|
|
1514
|
+
const ret = wasm.naiveforecaster_name(this.__wbg_ptr);
|
|
1515
|
+
deferred1_0 = ret[0];
|
|
1516
|
+
deferred1_1 = ret[1];
|
|
1517
|
+
return getStringFromWasm0(ret[0], ret[1]);
|
|
1518
|
+
} finally {
|
|
1519
|
+
wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
|
|
1520
|
+
}
|
|
1521
|
+
}
|
|
1522
|
+
/**
|
|
1523
|
+
* @param {number} horizon
|
|
1524
|
+
* @returns {Forecast}
|
|
1525
|
+
*/
|
|
1526
|
+
predict(horizon) {
|
|
1527
|
+
const ret = wasm.naiveforecaster_predict(this.__wbg_ptr, horizon);
|
|
1528
|
+
if (ret[2]) {
|
|
1529
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
1530
|
+
}
|
|
1531
|
+
return Forecast.__wrap(ret[0]);
|
|
1532
|
+
}
|
|
1533
|
+
}
|
|
1534
|
+
if (Symbol.dispose) NaiveForecaster.prototype[Symbol.dispose] = NaiveForecaster.prototype.free;
|
|
1535
|
+
|
|
1536
|
+
/**
|
|
1537
|
+
* Optimized Theta forecaster - automatically optimizes parameters.
|
|
1538
|
+
*/
|
|
1539
|
+
export class OptimizedThetaForecaster {
|
|
1540
|
+
__destroy_into_raw() {
|
|
1541
|
+
const ptr = this.__wbg_ptr;
|
|
1542
|
+
this.__wbg_ptr = 0;
|
|
1543
|
+
OptimizedThetaForecasterFinalization.unregister(this);
|
|
1544
|
+
return ptr;
|
|
1545
|
+
}
|
|
1546
|
+
free() {
|
|
1547
|
+
const ptr = this.__destroy_into_raw();
|
|
1548
|
+
wasm.__wbg_optimizedthetaforecaster_free(ptr, 0);
|
|
1549
|
+
}
|
|
1550
|
+
/**
|
|
1551
|
+
* @param {number} horizon
|
|
1552
|
+
* @param {number} level
|
|
1553
|
+
* @returns {Forecast}
|
|
1554
|
+
*/
|
|
1555
|
+
predictWithIntervals(horizon, level) {
|
|
1556
|
+
const ret = wasm.optimizedthetaforecaster_predictWithIntervals(this.__wbg_ptr, horizon, level);
|
|
1557
|
+
if (ret[2]) {
|
|
1558
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
1559
|
+
}
|
|
1560
|
+
return Forecast.__wrap(ret[0]);
|
|
1561
|
+
}
|
|
1562
|
+
/**
|
|
1563
|
+
* @param {TimeSeries} series
|
|
1564
|
+
*/
|
|
1565
|
+
fit(series) {
|
|
1566
|
+
_assertClass(series, TimeSeries);
|
|
1567
|
+
const ret = wasm.optimizedthetaforecaster_fit(this.__wbg_ptr, series.__wbg_ptr);
|
|
1568
|
+
if (ret[1]) {
|
|
1569
|
+
throw takeFromExternrefTable0(ret[0]);
|
|
1570
|
+
}
|
|
1571
|
+
}
|
|
1572
|
+
constructor() {
|
|
1573
|
+
const ret = wasm.optimizedthetaforecaster_new();
|
|
1574
|
+
this.__wbg_ptr = ret >>> 0;
|
|
1575
|
+
OptimizedThetaForecasterFinalization.register(this, this.__wbg_ptr, this);
|
|
1576
|
+
return this;
|
|
1577
|
+
}
|
|
1578
|
+
/**
|
|
1579
|
+
* @returns {string}
|
|
1580
|
+
*/
|
|
1581
|
+
get name() {
|
|
1582
|
+
let deferred1_0;
|
|
1583
|
+
let deferred1_1;
|
|
1584
|
+
try {
|
|
1585
|
+
const ret = wasm.optimizedthetaforecaster_name(this.__wbg_ptr);
|
|
1586
|
+
deferred1_0 = ret[0];
|
|
1587
|
+
deferred1_1 = ret[1];
|
|
1588
|
+
return getStringFromWasm0(ret[0], ret[1]);
|
|
1589
|
+
} finally {
|
|
1590
|
+
wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
|
|
1591
|
+
}
|
|
1592
|
+
}
|
|
1593
|
+
/**
|
|
1594
|
+
* @param {number} horizon
|
|
1595
|
+
* @returns {Forecast}
|
|
1596
|
+
*/
|
|
1597
|
+
predict(horizon) {
|
|
1598
|
+
const ret = wasm.optimizedthetaforecaster_predict(this.__wbg_ptr, horizon);
|
|
1599
|
+
if (ret[2]) {
|
|
1600
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
1601
|
+
}
|
|
1602
|
+
return Forecast.__wrap(ret[0]);
|
|
1603
|
+
}
|
|
1604
|
+
}
|
|
1605
|
+
if (Symbol.dispose) OptimizedThetaForecaster.prototype[Symbol.dispose] = OptimizedThetaForecaster.prototype.free;
|
|
1606
|
+
|
|
1607
|
+
/**
|
|
1608
|
+
* Random Walk with Drift forecaster.
|
|
1609
|
+
*/
|
|
1610
|
+
export class RandomWalkDriftForecaster {
|
|
1611
|
+
__destroy_into_raw() {
|
|
1612
|
+
const ptr = this.__wbg_ptr;
|
|
1613
|
+
this.__wbg_ptr = 0;
|
|
1614
|
+
RandomWalkDriftForecasterFinalization.unregister(this);
|
|
1615
|
+
return ptr;
|
|
1616
|
+
}
|
|
1617
|
+
free() {
|
|
1618
|
+
const ptr = this.__destroy_into_raw();
|
|
1619
|
+
wasm.__wbg_randomwalkdriftforecaster_free(ptr, 0);
|
|
1620
|
+
}
|
|
1621
|
+
/**
|
|
1622
|
+
* @param {number} horizon
|
|
1623
|
+
* @param {number} level
|
|
1624
|
+
* @returns {Forecast}
|
|
1625
|
+
*/
|
|
1626
|
+
predictWithIntervals(horizon, level) {
|
|
1627
|
+
const ret = wasm.randomwalkdriftforecaster_predictWithIntervals(this.__wbg_ptr, horizon, level);
|
|
1628
|
+
if (ret[2]) {
|
|
1629
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
1630
|
+
}
|
|
1631
|
+
return Forecast.__wrap(ret[0]);
|
|
1632
|
+
}
|
|
1633
|
+
/**
|
|
1634
|
+
* @param {TimeSeries} series
|
|
1635
|
+
*/
|
|
1636
|
+
fit(series) {
|
|
1637
|
+
_assertClass(series, TimeSeries);
|
|
1638
|
+
const ret = wasm.randomwalkdriftforecaster_fit(this.__wbg_ptr, series.__wbg_ptr);
|
|
1639
|
+
if (ret[1]) {
|
|
1640
|
+
throw takeFromExternrefTable0(ret[0]);
|
|
1641
|
+
}
|
|
1642
|
+
}
|
|
1643
|
+
constructor() {
|
|
1644
|
+
const ret = wasm.randomwalkdriftforecaster_new();
|
|
1645
|
+
this.__wbg_ptr = ret >>> 0;
|
|
1646
|
+
RandomWalkDriftForecasterFinalization.register(this, this.__wbg_ptr, this);
|
|
1647
|
+
return this;
|
|
1648
|
+
}
|
|
1649
|
+
/**
|
|
1650
|
+
* @returns {string}
|
|
1651
|
+
*/
|
|
1652
|
+
get name() {
|
|
1653
|
+
let deferred1_0;
|
|
1654
|
+
let deferred1_1;
|
|
1655
|
+
try {
|
|
1656
|
+
const ret = wasm.randomwalkdriftforecaster_name(this.__wbg_ptr);
|
|
1657
|
+
deferred1_0 = ret[0];
|
|
1658
|
+
deferred1_1 = ret[1];
|
|
1659
|
+
return getStringFromWasm0(ret[0], ret[1]);
|
|
1660
|
+
} finally {
|
|
1661
|
+
wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
|
|
1662
|
+
}
|
|
1663
|
+
}
|
|
1664
|
+
/**
|
|
1665
|
+
* @param {number} horizon
|
|
1666
|
+
* @returns {Forecast}
|
|
1667
|
+
*/
|
|
1668
|
+
predict(horizon) {
|
|
1669
|
+
const ret = wasm.randomwalkdriftforecaster_predict(this.__wbg_ptr, horizon);
|
|
1670
|
+
if (ret[2]) {
|
|
1671
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
1672
|
+
}
|
|
1673
|
+
return Forecast.__wrap(ret[0]);
|
|
1674
|
+
}
|
|
1675
|
+
}
|
|
1676
|
+
if (Symbol.dispose) RandomWalkDriftForecaster.prototype[Symbol.dispose] = RandomWalkDriftForecaster.prototype.free;
|
|
1677
|
+
|
|
1678
|
+
/**
|
|
1679
|
+
* SARIMA forecaster - Seasonal ARIMA.
|
|
1680
|
+
*/
|
|
1681
|
+
export class SARIMAForecaster {
|
|
1682
|
+
__destroy_into_raw() {
|
|
1683
|
+
const ptr = this.__wbg_ptr;
|
|
1684
|
+
this.__wbg_ptr = 0;
|
|
1685
|
+
SARIMAForecasterFinalization.unregister(this);
|
|
1686
|
+
return ptr;
|
|
1687
|
+
}
|
|
1688
|
+
free() {
|
|
1689
|
+
const ptr = this.__destroy_into_raw();
|
|
1690
|
+
wasm.__wbg_sarimaforecaster_free(ptr, 0);
|
|
1691
|
+
}
|
|
1692
|
+
/**
|
|
1693
|
+
* @param {number} horizon
|
|
1694
|
+
* @param {number} level
|
|
1695
|
+
* @returns {Forecast}
|
|
1696
|
+
*/
|
|
1697
|
+
predictWithIntervals(horizon, level) {
|
|
1698
|
+
const ret = wasm.sarimaforecaster_predictWithIntervals(this.__wbg_ptr, horizon, level);
|
|
1699
|
+
if (ret[2]) {
|
|
1700
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
1701
|
+
}
|
|
1702
|
+
return Forecast.__wrap(ret[0]);
|
|
1703
|
+
}
|
|
1704
|
+
/**
|
|
1705
|
+
* @param {TimeSeries} series
|
|
1706
|
+
*/
|
|
1707
|
+
fit(series) {
|
|
1708
|
+
_assertClass(series, TimeSeries);
|
|
1709
|
+
const ret = wasm.sarimaforecaster_fit(this.__wbg_ptr, series.__wbg_ptr);
|
|
1710
|
+
if (ret[1]) {
|
|
1711
|
+
throw takeFromExternrefTable0(ret[0]);
|
|
1712
|
+
}
|
|
1713
|
+
}
|
|
1714
|
+
/**
|
|
1715
|
+
* @param p - AR order
|
|
1716
|
+
* @param d - Differencing order
|
|
1717
|
+
* @param q - MA order
|
|
1718
|
+
* @param seasonal_p - Seasonal AR order
|
|
1719
|
+
* @param seasonal_d - Seasonal differencing order
|
|
1720
|
+
* @param seasonal_q - Seasonal MA order
|
|
1721
|
+
* @param period - Seasonal period
|
|
1722
|
+
* @param {number} p
|
|
1723
|
+
* @param {number} d
|
|
1724
|
+
* @param {number} q
|
|
1725
|
+
* @param {number} seasonal_p
|
|
1726
|
+
* @param {number} seasonal_d
|
|
1727
|
+
* @param {number} seasonal_q
|
|
1728
|
+
* @param {number} period
|
|
1729
|
+
*/
|
|
1730
|
+
constructor(p, d, q, seasonal_p, seasonal_d, seasonal_q, period) {
|
|
1731
|
+
const ret = wasm.sarimaforecaster_new(p, d, q, seasonal_p, seasonal_d, seasonal_q, period);
|
|
1732
|
+
this.__wbg_ptr = ret >>> 0;
|
|
1733
|
+
SARIMAForecasterFinalization.register(this, this.__wbg_ptr, this);
|
|
1734
|
+
return this;
|
|
1735
|
+
}
|
|
1736
|
+
/**
|
|
1737
|
+
* @returns {string}
|
|
1738
|
+
*/
|
|
1739
|
+
get name() {
|
|
1740
|
+
let deferred1_0;
|
|
1741
|
+
let deferred1_1;
|
|
1742
|
+
try {
|
|
1743
|
+
const ret = wasm.sarimaforecaster_name(this.__wbg_ptr);
|
|
1744
|
+
deferred1_0 = ret[0];
|
|
1745
|
+
deferred1_1 = ret[1];
|
|
1746
|
+
return getStringFromWasm0(ret[0], ret[1]);
|
|
1747
|
+
} finally {
|
|
1748
|
+
wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
|
|
1749
|
+
}
|
|
1750
|
+
}
|
|
1751
|
+
/**
|
|
1752
|
+
* @param {number} horizon
|
|
1753
|
+
* @returns {Forecast}
|
|
1754
|
+
*/
|
|
1755
|
+
predict(horizon) {
|
|
1756
|
+
const ret = wasm.sarimaforecaster_predict(this.__wbg_ptr, horizon);
|
|
1757
|
+
if (ret[2]) {
|
|
1758
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
1759
|
+
}
|
|
1760
|
+
return Forecast.__wrap(ret[0]);
|
|
1761
|
+
}
|
|
1762
|
+
}
|
|
1763
|
+
if (Symbol.dispose) SARIMAForecaster.prototype[Symbol.dispose] = SARIMAForecaster.prototype.free;
|
|
1764
|
+
|
|
1765
|
+
/**
|
|
1766
|
+
* Simple Exponential Smoothing forecaster.
|
|
1767
|
+
*/
|
|
1768
|
+
export class SESForecaster {
|
|
1769
|
+
__destroy_into_raw() {
|
|
1770
|
+
const ptr = this.__wbg_ptr;
|
|
1771
|
+
this.__wbg_ptr = 0;
|
|
1772
|
+
SESForecasterFinalization.unregister(this);
|
|
1773
|
+
return ptr;
|
|
1774
|
+
}
|
|
1775
|
+
free() {
|
|
1776
|
+
const ptr = this.__destroy_into_raw();
|
|
1777
|
+
wasm.__wbg_sesforecaster_free(ptr, 0);
|
|
1778
|
+
}
|
|
1779
|
+
/**
|
|
1780
|
+
* @param {TimeSeries} series
|
|
1781
|
+
*/
|
|
1782
|
+
fit(series) {
|
|
1783
|
+
_assertClass(series, TimeSeries);
|
|
1784
|
+
const ret = wasm.sesforecaster_fit(this.__wbg_ptr, series.__wbg_ptr);
|
|
1785
|
+
if (ret[1]) {
|
|
1786
|
+
throw takeFromExternrefTable0(ret[0]);
|
|
1787
|
+
}
|
|
1788
|
+
}
|
|
1789
|
+
/**
|
|
1790
|
+
* @param alpha - Smoothing parameter (0 < alpha <= 1)
|
|
1791
|
+
* @param {number} alpha
|
|
1792
|
+
*/
|
|
1793
|
+
constructor(alpha) {
|
|
1794
|
+
const ret = wasm.sesforecaster_new(alpha);
|
|
1795
|
+
this.__wbg_ptr = ret >>> 0;
|
|
1796
|
+
SESForecasterFinalization.register(this, this.__wbg_ptr, this);
|
|
1797
|
+
return this;
|
|
1798
|
+
}
|
|
1799
|
+
/**
|
|
1800
|
+
* @returns {string}
|
|
1801
|
+
*/
|
|
1802
|
+
get name() {
|
|
1803
|
+
let deferred1_0;
|
|
1804
|
+
let deferred1_1;
|
|
1805
|
+
try {
|
|
1806
|
+
const ret = wasm.sesforecaster_name(this.__wbg_ptr);
|
|
1807
|
+
deferred1_0 = ret[0];
|
|
1808
|
+
deferred1_1 = ret[1];
|
|
1809
|
+
return getStringFromWasm0(ret[0], ret[1]);
|
|
1810
|
+
} finally {
|
|
1811
|
+
wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
|
|
1812
|
+
}
|
|
1813
|
+
}
|
|
1814
|
+
/**
|
|
1815
|
+
* @param {number} horizon
|
|
1816
|
+
* @returns {Forecast}
|
|
1817
|
+
*/
|
|
1818
|
+
predict(horizon) {
|
|
1819
|
+
const ret = wasm.sesforecaster_predict(this.__wbg_ptr, horizon);
|
|
1820
|
+
if (ret[2]) {
|
|
1821
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
1822
|
+
}
|
|
1823
|
+
return Forecast.__wrap(ret[0]);
|
|
1824
|
+
}
|
|
1825
|
+
}
|
|
1826
|
+
if (Symbol.dispose) SESForecaster.prototype[Symbol.dispose] = SESForecaster.prototype.free;
|
|
1827
|
+
|
|
1828
|
+
/**
|
|
1829
|
+
* Simple Moving Average forecaster.
|
|
1830
|
+
*/
|
|
1831
|
+
export class SMAForecaster {
|
|
1832
|
+
__destroy_into_raw() {
|
|
1833
|
+
const ptr = this.__wbg_ptr;
|
|
1834
|
+
this.__wbg_ptr = 0;
|
|
1835
|
+
SMAForecasterFinalization.unregister(this);
|
|
1836
|
+
return ptr;
|
|
1837
|
+
}
|
|
1838
|
+
free() {
|
|
1839
|
+
const ptr = this.__destroy_into_raw();
|
|
1840
|
+
wasm.__wbg_smaforecaster_free(ptr, 0);
|
|
1841
|
+
}
|
|
1842
|
+
/**
|
|
1843
|
+
* @param {TimeSeries} series
|
|
1844
|
+
*/
|
|
1845
|
+
fit(series) {
|
|
1846
|
+
_assertClass(series, TimeSeries);
|
|
1847
|
+
const ret = wasm.smaforecaster_fit(this.__wbg_ptr, series.__wbg_ptr);
|
|
1848
|
+
if (ret[1]) {
|
|
1849
|
+
throw takeFromExternrefTable0(ret[0]);
|
|
1850
|
+
}
|
|
1851
|
+
}
|
|
1852
|
+
/**
|
|
1853
|
+
* @param window - Window size for the moving average
|
|
1854
|
+
* @param {number} window
|
|
1855
|
+
*/
|
|
1856
|
+
constructor(window) {
|
|
1857
|
+
const ret = wasm.smaforecaster_new(window);
|
|
1858
|
+
this.__wbg_ptr = ret >>> 0;
|
|
1859
|
+
SMAForecasterFinalization.register(this, this.__wbg_ptr, this);
|
|
1860
|
+
return this;
|
|
1861
|
+
}
|
|
1862
|
+
/**
|
|
1863
|
+
* @returns {string}
|
|
1864
|
+
*/
|
|
1865
|
+
get name() {
|
|
1866
|
+
let deferred1_0;
|
|
1867
|
+
let deferred1_1;
|
|
1868
|
+
try {
|
|
1869
|
+
const ret = wasm.smaforecaster_name(this.__wbg_ptr);
|
|
1870
|
+
deferred1_0 = ret[0];
|
|
1871
|
+
deferred1_1 = ret[1];
|
|
1872
|
+
return getStringFromWasm0(ret[0], ret[1]);
|
|
1873
|
+
} finally {
|
|
1874
|
+
wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
|
|
1875
|
+
}
|
|
1876
|
+
}
|
|
1877
|
+
/**
|
|
1878
|
+
* @param {number} horizon
|
|
1879
|
+
* @returns {Forecast}
|
|
1880
|
+
*/
|
|
1881
|
+
predict(horizon) {
|
|
1882
|
+
const ret = wasm.smaforecaster_predict(this.__wbg_ptr, horizon);
|
|
1883
|
+
if (ret[2]) {
|
|
1884
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
1885
|
+
}
|
|
1886
|
+
return Forecast.__wrap(ret[0]);
|
|
1887
|
+
}
|
|
1888
|
+
}
|
|
1889
|
+
if (Symbol.dispose) SMAForecaster.prototype[Symbol.dispose] = SMAForecaster.prototype.free;
|
|
1890
|
+
|
|
1891
|
+
/**
|
|
1892
|
+
* Seasonal Exponential Smoothing forecaster.
|
|
1893
|
+
*/
|
|
1894
|
+
export class SeasonalESForecaster {
|
|
1895
|
+
__destroy_into_raw() {
|
|
1896
|
+
const ptr = this.__wbg_ptr;
|
|
1897
|
+
this.__wbg_ptr = 0;
|
|
1898
|
+
SeasonalESForecasterFinalization.unregister(this);
|
|
1899
|
+
return ptr;
|
|
1900
|
+
}
|
|
1901
|
+
free() {
|
|
1902
|
+
const ptr = this.__destroy_into_raw();
|
|
1903
|
+
wasm.__wbg_seasonalesforecaster_free(ptr, 0);
|
|
1904
|
+
}
|
|
1905
|
+
/**
|
|
1906
|
+
* @param {TimeSeries} series
|
|
1907
|
+
*/
|
|
1908
|
+
fit(series) {
|
|
1909
|
+
_assertClass(series, TimeSeries);
|
|
1910
|
+
const ret = wasm.seasonalesforecaster_fit(this.__wbg_ptr, series.__wbg_ptr);
|
|
1911
|
+
if (ret[1]) {
|
|
1912
|
+
throw takeFromExternrefTable0(ret[0]);
|
|
1913
|
+
}
|
|
1914
|
+
}
|
|
1915
|
+
/**
|
|
1916
|
+
* @param period - Seasonal period
|
|
1917
|
+
* @param {number} period
|
|
1918
|
+
*/
|
|
1919
|
+
constructor(period) {
|
|
1920
|
+
const ret = wasm.seasonalesforecaster_new(period);
|
|
1921
|
+
this.__wbg_ptr = ret >>> 0;
|
|
1922
|
+
SeasonalESForecasterFinalization.register(this, this.__wbg_ptr, this);
|
|
1923
|
+
return this;
|
|
1924
|
+
}
|
|
1925
|
+
/**
|
|
1926
|
+
* @returns {string}
|
|
1927
|
+
*/
|
|
1928
|
+
get name() {
|
|
1929
|
+
let deferred1_0;
|
|
1930
|
+
let deferred1_1;
|
|
1931
|
+
try {
|
|
1932
|
+
const ret = wasm.seasonalesforecaster_name(this.__wbg_ptr);
|
|
1933
|
+
deferred1_0 = ret[0];
|
|
1934
|
+
deferred1_1 = ret[1];
|
|
1935
|
+
return getStringFromWasm0(ret[0], ret[1]);
|
|
1936
|
+
} finally {
|
|
1937
|
+
wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
|
|
1938
|
+
}
|
|
1939
|
+
}
|
|
1940
|
+
/**
|
|
1941
|
+
* @param {number} horizon
|
|
1942
|
+
* @returns {Forecast}
|
|
1943
|
+
*/
|
|
1944
|
+
predict(horizon) {
|
|
1945
|
+
const ret = wasm.seasonalesforecaster_predict(this.__wbg_ptr, horizon);
|
|
1946
|
+
if (ret[2]) {
|
|
1947
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
1948
|
+
}
|
|
1949
|
+
return Forecast.__wrap(ret[0]);
|
|
1950
|
+
}
|
|
1951
|
+
}
|
|
1952
|
+
if (Symbol.dispose) SeasonalESForecaster.prototype[Symbol.dispose] = SeasonalESForecaster.prototype.free;
|
|
1953
|
+
|
|
1954
|
+
/**
|
|
1955
|
+
* Seasonal Naive forecaster - uses observations from the same season.
|
|
1956
|
+
*/
|
|
1957
|
+
export class SeasonalNaiveForecaster {
|
|
1958
|
+
__destroy_into_raw() {
|
|
1959
|
+
const ptr = this.__wbg_ptr;
|
|
1960
|
+
this.__wbg_ptr = 0;
|
|
1961
|
+
SeasonalNaiveForecasterFinalization.unregister(this);
|
|
1962
|
+
return ptr;
|
|
1963
|
+
}
|
|
1964
|
+
free() {
|
|
1965
|
+
const ptr = this.__destroy_into_raw();
|
|
1966
|
+
wasm.__wbg_seasonalnaiveforecaster_free(ptr, 0);
|
|
1967
|
+
}
|
|
1968
|
+
/**
|
|
1969
|
+
* @param {number} horizon
|
|
1970
|
+
* @param {number} level
|
|
1971
|
+
* @returns {Forecast}
|
|
1972
|
+
*/
|
|
1973
|
+
predictWithIntervals(horizon, level) {
|
|
1974
|
+
const ret = wasm.seasonalnaiveforecaster_predictWithIntervals(this.__wbg_ptr, horizon, level);
|
|
1975
|
+
if (ret[2]) {
|
|
1976
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
1977
|
+
}
|
|
1978
|
+
return Forecast.__wrap(ret[0]);
|
|
1979
|
+
}
|
|
1980
|
+
/**
|
|
1981
|
+
* @param {TimeSeries} series
|
|
1982
|
+
*/
|
|
1983
|
+
fit(series) {
|
|
1984
|
+
_assertClass(series, TimeSeries);
|
|
1985
|
+
const ret = wasm.seasonalnaiveforecaster_fit(this.__wbg_ptr, series.__wbg_ptr);
|
|
1986
|
+
if (ret[1]) {
|
|
1987
|
+
throw takeFromExternrefTable0(ret[0]);
|
|
1988
|
+
}
|
|
1989
|
+
}
|
|
1990
|
+
/**
|
|
1991
|
+
* @param period - Seasonal period (e.g., 12 for monthly data with yearly seasonality)
|
|
1992
|
+
* @param {number} period
|
|
1993
|
+
*/
|
|
1994
|
+
constructor(period) {
|
|
1995
|
+
const ret = wasm.seasonalnaiveforecaster_new(period);
|
|
1996
|
+
this.__wbg_ptr = ret >>> 0;
|
|
1997
|
+
SeasonalNaiveForecasterFinalization.register(this, this.__wbg_ptr, this);
|
|
1998
|
+
return this;
|
|
1999
|
+
}
|
|
2000
|
+
/**
|
|
2001
|
+
* @returns {string}
|
|
2002
|
+
*/
|
|
2003
|
+
get name() {
|
|
2004
|
+
let deferred1_0;
|
|
2005
|
+
let deferred1_1;
|
|
2006
|
+
try {
|
|
2007
|
+
const ret = wasm.seasonalnaiveforecaster_name(this.__wbg_ptr);
|
|
2008
|
+
deferred1_0 = ret[0];
|
|
2009
|
+
deferred1_1 = ret[1];
|
|
2010
|
+
return getStringFromWasm0(ret[0], ret[1]);
|
|
2011
|
+
} finally {
|
|
2012
|
+
wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
|
|
2013
|
+
}
|
|
2014
|
+
}
|
|
2015
|
+
/**
|
|
2016
|
+
* @param {number} horizon
|
|
2017
|
+
* @returns {Forecast}
|
|
2018
|
+
*/
|
|
2019
|
+
predict(horizon) {
|
|
2020
|
+
const ret = wasm.seasonalnaiveforecaster_predict(this.__wbg_ptr, horizon);
|
|
2021
|
+
if (ret[2]) {
|
|
2022
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
2023
|
+
}
|
|
2024
|
+
return Forecast.__wrap(ret[0]);
|
|
2025
|
+
}
|
|
2026
|
+
}
|
|
2027
|
+
if (Symbol.dispose) SeasonalNaiveForecaster.prototype[Symbol.dispose] = SeasonalNaiveForecaster.prototype.free;
|
|
2028
|
+
|
|
2029
|
+
/**
|
|
2030
|
+
* Seasonal Window Average forecaster.
|
|
2031
|
+
*/
|
|
2032
|
+
export class SeasonalWindowAverageForecaster {
|
|
2033
|
+
__destroy_into_raw() {
|
|
2034
|
+
const ptr = this.__wbg_ptr;
|
|
2035
|
+
this.__wbg_ptr = 0;
|
|
2036
|
+
SeasonalWindowAverageForecasterFinalization.unregister(this);
|
|
2037
|
+
return ptr;
|
|
2038
|
+
}
|
|
2039
|
+
free() {
|
|
2040
|
+
const ptr = this.__destroy_into_raw();
|
|
2041
|
+
wasm.__wbg_seasonalwindowaverageforecaster_free(ptr, 0);
|
|
2042
|
+
}
|
|
2043
|
+
/**
|
|
2044
|
+
* @param {TimeSeries} series
|
|
2045
|
+
*/
|
|
2046
|
+
fit(series) {
|
|
2047
|
+
_assertClass(series, TimeSeries);
|
|
2048
|
+
const ret = wasm.seasonalwindowaverageforecaster_fit(this.__wbg_ptr, series.__wbg_ptr);
|
|
2049
|
+
if (ret[1]) {
|
|
2050
|
+
throw takeFromExternrefTable0(ret[0]);
|
|
2051
|
+
}
|
|
2052
|
+
}
|
|
2053
|
+
/**
|
|
2054
|
+
* @param period - Seasonal period
|
|
2055
|
+
* @param window - Number of seasonal cycles to average
|
|
2056
|
+
* @param {number} period
|
|
2057
|
+
* @param {number} window
|
|
2058
|
+
*/
|
|
2059
|
+
constructor(period, window) {
|
|
2060
|
+
const ret = wasm.seasonalwindowaverageforecaster_new(period, window);
|
|
2061
|
+
this.__wbg_ptr = ret >>> 0;
|
|
2062
|
+
SeasonalWindowAverageForecasterFinalization.register(this, this.__wbg_ptr, this);
|
|
2063
|
+
return this;
|
|
2064
|
+
}
|
|
2065
|
+
/**
|
|
2066
|
+
* @returns {string}
|
|
2067
|
+
*/
|
|
2068
|
+
get name() {
|
|
2069
|
+
let deferred1_0;
|
|
2070
|
+
let deferred1_1;
|
|
2071
|
+
try {
|
|
2072
|
+
const ret = wasm.seasonalwindowaverageforecaster_name(this.__wbg_ptr);
|
|
2073
|
+
deferred1_0 = ret[0];
|
|
2074
|
+
deferred1_1 = ret[1];
|
|
2075
|
+
return getStringFromWasm0(ret[0], ret[1]);
|
|
2076
|
+
} finally {
|
|
2077
|
+
wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
|
|
2078
|
+
}
|
|
2079
|
+
}
|
|
2080
|
+
/**
|
|
2081
|
+
* @param {number} horizon
|
|
2082
|
+
* @returns {Forecast}
|
|
2083
|
+
*/
|
|
2084
|
+
predict(horizon) {
|
|
2085
|
+
const ret = wasm.seasonalwindowaverageforecaster_predict(this.__wbg_ptr, horizon);
|
|
2086
|
+
if (ret[2]) {
|
|
2087
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
2088
|
+
}
|
|
2089
|
+
return Forecast.__wrap(ret[0]);
|
|
2090
|
+
}
|
|
2091
|
+
}
|
|
2092
|
+
if (Symbol.dispose) SeasonalWindowAverageForecaster.prototype[Symbol.dispose] = SeasonalWindowAverageForecaster.prototype.free;
|
|
2093
|
+
|
|
2094
|
+
/**
|
|
2095
|
+
* TBATS - Trigonometric seasonality, Box-Cox, ARMA errors, Trend, Seasonal.
|
|
2096
|
+
*/
|
|
2097
|
+
export class TBATSForecaster {
|
|
2098
|
+
__destroy_into_raw() {
|
|
2099
|
+
const ptr = this.__wbg_ptr;
|
|
2100
|
+
this.__wbg_ptr = 0;
|
|
2101
|
+
TBATSForecasterFinalization.unregister(this);
|
|
2102
|
+
return ptr;
|
|
2103
|
+
}
|
|
2104
|
+
free() {
|
|
2105
|
+
const ptr = this.__destroy_into_raw();
|
|
2106
|
+
wasm.__wbg_tbatsforecaster_free(ptr, 0);
|
|
2107
|
+
}
|
|
2108
|
+
/**
|
|
2109
|
+
* @param {TimeSeries} series
|
|
2110
|
+
*/
|
|
2111
|
+
fit(series) {
|
|
2112
|
+
_assertClass(series, TimeSeries);
|
|
2113
|
+
const ret = wasm.tbatsforecaster_fit(this.__wbg_ptr, series.__wbg_ptr);
|
|
2114
|
+
if (ret[1]) {
|
|
2115
|
+
throw takeFromExternrefTable0(ret[0]);
|
|
2116
|
+
}
|
|
2117
|
+
}
|
|
2118
|
+
/**
|
|
2119
|
+
* @param seasonal_periods - Array of seasonal periods (e.g., [7, 365] for daily data)
|
|
2120
|
+
* @param {Uint32Array} seasonal_periods
|
|
2121
|
+
*/
|
|
2122
|
+
constructor(seasonal_periods) {
|
|
2123
|
+
const ptr0 = passArray32ToWasm0(seasonal_periods, wasm.__wbindgen_malloc);
|
|
2124
|
+
const len0 = WASM_VECTOR_LEN;
|
|
2125
|
+
const ret = wasm.tbatsforecaster_new(ptr0, len0);
|
|
2126
|
+
this.__wbg_ptr = ret >>> 0;
|
|
2127
|
+
TBATSForecasterFinalization.register(this, this.__wbg_ptr, this);
|
|
2128
|
+
return this;
|
|
2129
|
+
}
|
|
2130
|
+
/**
|
|
2131
|
+
* @returns {string}
|
|
2132
|
+
*/
|
|
2133
|
+
get name() {
|
|
2134
|
+
let deferred1_0;
|
|
2135
|
+
let deferred1_1;
|
|
2136
|
+
try {
|
|
2137
|
+
const ret = wasm.tbatsforecaster_name(this.__wbg_ptr);
|
|
2138
|
+
deferred1_0 = ret[0];
|
|
2139
|
+
deferred1_1 = ret[1];
|
|
2140
|
+
return getStringFromWasm0(ret[0], ret[1]);
|
|
2141
|
+
} finally {
|
|
2142
|
+
wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
|
|
2143
|
+
}
|
|
2144
|
+
}
|
|
2145
|
+
/**
|
|
2146
|
+
* @param {number} horizon
|
|
2147
|
+
* @returns {Forecast}
|
|
2148
|
+
*/
|
|
2149
|
+
predict(horizon) {
|
|
2150
|
+
const ret = wasm.tbatsforecaster_predict(this.__wbg_ptr, horizon);
|
|
2151
|
+
if (ret[2]) {
|
|
2152
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
2153
|
+
}
|
|
2154
|
+
return Forecast.__wrap(ret[0]);
|
|
2155
|
+
}
|
|
2156
|
+
}
|
|
2157
|
+
if (Symbol.dispose) TBATSForecaster.prototype[Symbol.dispose] = TBATSForecaster.prototype.free;
|
|
2158
|
+
|
|
2159
|
+
/**
|
|
2160
|
+
* TSB (Teunter-Syntetos-Babai) method for intermittent demand.
|
|
2161
|
+
*/
|
|
2162
|
+
export class TSBForecaster {
|
|
2163
|
+
__destroy_into_raw() {
|
|
2164
|
+
const ptr = this.__wbg_ptr;
|
|
2165
|
+
this.__wbg_ptr = 0;
|
|
2166
|
+
TSBForecasterFinalization.unregister(this);
|
|
2167
|
+
return ptr;
|
|
2168
|
+
}
|
|
2169
|
+
free() {
|
|
2170
|
+
const ptr = this.__destroy_into_raw();
|
|
2171
|
+
wasm.__wbg_tsbforecaster_free(ptr, 0);
|
|
2172
|
+
}
|
|
2173
|
+
/**
|
|
2174
|
+
* @param {TimeSeries} series
|
|
2175
|
+
*/
|
|
2176
|
+
fit(series) {
|
|
2177
|
+
_assertClass(series, TimeSeries);
|
|
2178
|
+
const ret = wasm.tsbforecaster_fit(this.__wbg_ptr, series.__wbg_ptr);
|
|
2179
|
+
if (ret[1]) {
|
|
2180
|
+
throw takeFromExternrefTable0(ret[0]);
|
|
2181
|
+
}
|
|
2182
|
+
}
|
|
2183
|
+
constructor() {
|
|
2184
|
+
const ret = wasm.tsbforecaster_new();
|
|
2185
|
+
this.__wbg_ptr = ret >>> 0;
|
|
2186
|
+
TSBForecasterFinalization.register(this, this.__wbg_ptr, this);
|
|
2187
|
+
return this;
|
|
2188
|
+
}
|
|
2189
|
+
/**
|
|
2190
|
+
* @returns {string}
|
|
2191
|
+
*/
|
|
2192
|
+
get name() {
|
|
2193
|
+
let deferred1_0;
|
|
2194
|
+
let deferred1_1;
|
|
2195
|
+
try {
|
|
2196
|
+
const ret = wasm.tsbforecaster_name(this.__wbg_ptr);
|
|
2197
|
+
deferred1_0 = ret[0];
|
|
2198
|
+
deferred1_1 = ret[1];
|
|
2199
|
+
return getStringFromWasm0(ret[0], ret[1]);
|
|
2200
|
+
} finally {
|
|
2201
|
+
wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
|
|
2202
|
+
}
|
|
2203
|
+
}
|
|
2204
|
+
/**
|
|
2205
|
+
* @param {number} horizon
|
|
2206
|
+
* @returns {Forecast}
|
|
2207
|
+
*/
|
|
2208
|
+
predict(horizon) {
|
|
2209
|
+
const ret = wasm.tsbforecaster_predict(this.__wbg_ptr, horizon);
|
|
2210
|
+
if (ret[2]) {
|
|
2211
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
2212
|
+
}
|
|
2213
|
+
return Forecast.__wrap(ret[0]);
|
|
2214
|
+
}
|
|
2215
|
+
}
|
|
2216
|
+
if (Symbol.dispose) TSBForecaster.prototype[Symbol.dispose] = TSBForecaster.prototype.free;
|
|
2217
|
+
|
|
2218
|
+
/**
|
|
2219
|
+
* Theta forecaster - the standard Theta method.
|
|
2220
|
+
*/
|
|
2221
|
+
export class ThetaForecaster {
|
|
2222
|
+
__destroy_into_raw() {
|
|
2223
|
+
const ptr = this.__wbg_ptr;
|
|
2224
|
+
this.__wbg_ptr = 0;
|
|
2225
|
+
ThetaForecasterFinalization.unregister(this);
|
|
2226
|
+
return ptr;
|
|
2227
|
+
}
|
|
2228
|
+
free() {
|
|
2229
|
+
const ptr = this.__destroy_into_raw();
|
|
2230
|
+
wasm.__wbg_thetaforecaster_free(ptr, 0);
|
|
2231
|
+
}
|
|
2232
|
+
/**
|
|
2233
|
+
* @param {number} horizon
|
|
2234
|
+
* @param {number} level
|
|
2235
|
+
* @returns {Forecast}
|
|
2236
|
+
*/
|
|
2237
|
+
predictWithIntervals(horizon, level) {
|
|
2238
|
+
const ret = wasm.thetaforecaster_predictWithIntervals(this.__wbg_ptr, horizon, level);
|
|
2239
|
+
if (ret[2]) {
|
|
2240
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
2241
|
+
}
|
|
2242
|
+
return Forecast.__wrap(ret[0]);
|
|
2243
|
+
}
|
|
2244
|
+
/**
|
|
2245
|
+
* @param {TimeSeries} series
|
|
2246
|
+
*/
|
|
2247
|
+
fit(series) {
|
|
2248
|
+
_assertClass(series, TimeSeries);
|
|
2249
|
+
const ret = wasm.thetaforecaster_fit(this.__wbg_ptr, series.__wbg_ptr);
|
|
2250
|
+
if (ret[1]) {
|
|
2251
|
+
throw takeFromExternrefTable0(ret[0]);
|
|
2252
|
+
}
|
|
2253
|
+
}
|
|
2254
|
+
constructor() {
|
|
2255
|
+
const ret = wasm.thetaforecaster_new();
|
|
2256
|
+
this.__wbg_ptr = ret >>> 0;
|
|
2257
|
+
ThetaForecasterFinalization.register(this, this.__wbg_ptr, this);
|
|
2258
|
+
return this;
|
|
2259
|
+
}
|
|
2260
|
+
/**
|
|
2261
|
+
* @returns {string}
|
|
2262
|
+
*/
|
|
2263
|
+
get name() {
|
|
2264
|
+
let deferred1_0;
|
|
2265
|
+
let deferred1_1;
|
|
2266
|
+
try {
|
|
2267
|
+
const ret = wasm.thetaforecaster_name(this.__wbg_ptr);
|
|
2268
|
+
deferred1_0 = ret[0];
|
|
2269
|
+
deferred1_1 = ret[1];
|
|
2270
|
+
return getStringFromWasm0(ret[0], ret[1]);
|
|
2271
|
+
} finally {
|
|
2272
|
+
wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
|
|
2273
|
+
}
|
|
2274
|
+
}
|
|
2275
|
+
/**
|
|
2276
|
+
* @param {number} horizon
|
|
2277
|
+
* @returns {Forecast}
|
|
2278
|
+
*/
|
|
2279
|
+
predict(horizon) {
|
|
2280
|
+
const ret = wasm.thetaforecaster_predict(this.__wbg_ptr, horizon);
|
|
2281
|
+
if (ret[2]) {
|
|
2282
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
2283
|
+
}
|
|
2284
|
+
return Forecast.__wrap(ret[0]);
|
|
2285
|
+
}
|
|
2286
|
+
}
|
|
2287
|
+
if (Symbol.dispose) ThetaForecaster.prototype[Symbol.dispose] = ThetaForecaster.prototype.free;
|
|
2288
|
+
|
|
2289
|
+
/**
|
|
2290
|
+
* A time series wrapper for JavaScript.
|
|
2291
|
+
*
|
|
2292
|
+
* Represents a univariate time series with values indexed by position.
|
|
2293
|
+
* Timestamps are optional and can be provided as milliseconds since Unix epoch.
|
|
2294
|
+
*/
|
|
2295
|
+
export class TimeSeries {
|
|
2296
|
+
static __wrap(ptr) {
|
|
2297
|
+
ptr = ptr >>> 0;
|
|
2298
|
+
const obj = Object.create(TimeSeries.prototype);
|
|
2299
|
+
obj.__wbg_ptr = ptr;
|
|
2300
|
+
TimeSeriesFinalization.register(obj, obj.__wbg_ptr, obj);
|
|
2301
|
+
return obj;
|
|
2302
|
+
}
|
|
2303
|
+
__destroy_into_raw() {
|
|
2304
|
+
const ptr = this.__wbg_ptr;
|
|
2305
|
+
this.__wbg_ptr = 0;
|
|
2306
|
+
TimeSeriesFinalization.unregister(this);
|
|
2307
|
+
return ptr;
|
|
2308
|
+
}
|
|
2309
|
+
free() {
|
|
2310
|
+
const ptr = this.__destroy_into_raw();
|
|
2311
|
+
wasm.__wbg_timeseries_free(ptr, 0);
|
|
2312
|
+
}
|
|
2313
|
+
/**
|
|
2314
|
+
* Create a time series with timestamps.
|
|
2315
|
+
*
|
|
2316
|
+
* @param values - Array of numeric values
|
|
2317
|
+
* @param timestamps - Array of timestamps as milliseconds since Unix epoch
|
|
2318
|
+
* @returns A new TimeSeries instance
|
|
2319
|
+
* @param {Float64Array} values
|
|
2320
|
+
* @param {Float64Array} timestamps_ms
|
|
2321
|
+
* @returns {TimeSeries}
|
|
2322
|
+
*/
|
|
2323
|
+
static withTimestamps(values, timestamps_ms) {
|
|
2324
|
+
const ptr0 = passArrayF64ToWasm0(values, wasm.__wbindgen_malloc);
|
|
2325
|
+
const len0 = WASM_VECTOR_LEN;
|
|
2326
|
+
const ptr1 = passArrayF64ToWasm0(timestamps_ms, wasm.__wbindgen_malloc);
|
|
2327
|
+
const len1 = WASM_VECTOR_LEN;
|
|
2328
|
+
const ret = wasm.timeseries_withTimestamps(ptr0, len0, ptr1, len1);
|
|
2329
|
+
if (ret[2]) {
|
|
2330
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
2331
|
+
}
|
|
2332
|
+
return TimeSeries.__wrap(ret[0]);
|
|
2333
|
+
}
|
|
2334
|
+
/**
|
|
2335
|
+
* Check if the series has missing values (NaN).
|
|
2336
|
+
* @returns {boolean}
|
|
2337
|
+
*/
|
|
2338
|
+
hasMissingValues() {
|
|
2339
|
+
const ret = wasm.timeseries_hasMissingValues(this.__wbg_ptr);
|
|
2340
|
+
return ret !== 0;
|
|
2341
|
+
}
|
|
2342
|
+
/**
|
|
2343
|
+
* Create a new time series from an array of values.
|
|
2344
|
+
*
|
|
2345
|
+
* @param values - Array of numeric values
|
|
2346
|
+
* @returns A new TimeSeries instance
|
|
2347
|
+
* @param {Float64Array} values
|
|
2348
|
+
*/
|
|
2349
|
+
constructor(values) {
|
|
2350
|
+
const ptr0 = passArrayF64ToWasm0(values, wasm.__wbindgen_malloc);
|
|
2351
|
+
const len0 = WASM_VECTOR_LEN;
|
|
2352
|
+
const ret = wasm.timeseries_new(ptr0, len0);
|
|
2353
|
+
if (ret[2]) {
|
|
2354
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
2355
|
+
}
|
|
2356
|
+
this.__wbg_ptr = ret[0] >>> 0;
|
|
2357
|
+
TimeSeriesFinalization.register(this, this.__wbg_ptr, this);
|
|
2358
|
+
return this;
|
|
2359
|
+
}
|
|
2360
|
+
/**
|
|
2361
|
+
* Get a slice of values.
|
|
2362
|
+
*
|
|
2363
|
+
* @param start - Start index (inclusive)
|
|
2364
|
+
* @param end - End index (exclusive)
|
|
2365
|
+
* @returns Array of values in the specified range
|
|
2366
|
+
* @param {number} start
|
|
2367
|
+
* @param {number} end
|
|
2368
|
+
* @returns {TimeSeries}
|
|
2369
|
+
*/
|
|
2370
|
+
slice(start, end) {
|
|
2371
|
+
const ret = wasm.timeseries_slice(this.__wbg_ptr, start, end);
|
|
2372
|
+
if (ret[2]) {
|
|
2373
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
2374
|
+
}
|
|
2375
|
+
return TimeSeries.__wrap(ret[0]);
|
|
2376
|
+
}
|
|
2377
|
+
/**
|
|
2378
|
+
* Get the number of observations.
|
|
2379
|
+
* @returns {number}
|
|
2380
|
+
*/
|
|
2381
|
+
get length() {
|
|
2382
|
+
const ret = wasm.timeseries_length(this.__wbg_ptr);
|
|
2383
|
+
return ret >>> 0;
|
|
2384
|
+
}
|
|
2385
|
+
/**
|
|
2386
|
+
* Get all values as an array.
|
|
2387
|
+
* @returns {Float64Array}
|
|
2388
|
+
*/
|
|
2389
|
+
get values() {
|
|
2390
|
+
const ret = wasm.timeseries_values(this.__wbg_ptr);
|
|
2391
|
+
var v1 = getArrayF64FromWasm0(ret[0], ret[1]).slice();
|
|
2392
|
+
wasm.__wbindgen_free(ret[0], ret[1] * 8, 8);
|
|
2393
|
+
return v1;
|
|
2394
|
+
}
|
|
2395
|
+
/**
|
|
2396
|
+
* Check if the series is empty.
|
|
2397
|
+
* @returns {boolean}
|
|
2398
|
+
*/
|
|
2399
|
+
isEmpty() {
|
|
2400
|
+
const ret = wasm.timeseries_isEmpty(this.__wbg_ptr);
|
|
2401
|
+
return ret !== 0;
|
|
2402
|
+
}
|
|
2403
|
+
}
|
|
2404
|
+
if (Symbol.dispose) TimeSeries.prototype[Symbol.dispose] = TimeSeries.prototype.free;
|
|
2405
|
+
|
|
2406
|
+
/**
|
|
2407
|
+
* Window Average forecaster - uses the last N observations.
|
|
2408
|
+
*/
|
|
2409
|
+
export class WindowAverageForecaster {
|
|
2410
|
+
__destroy_into_raw() {
|
|
2411
|
+
const ptr = this.__wbg_ptr;
|
|
2412
|
+
this.__wbg_ptr = 0;
|
|
2413
|
+
WindowAverageForecasterFinalization.unregister(this);
|
|
2414
|
+
return ptr;
|
|
2415
|
+
}
|
|
2416
|
+
free() {
|
|
2417
|
+
const ptr = this.__destroy_into_raw();
|
|
2418
|
+
wasm.__wbg_windowaverageforecaster_free(ptr, 0);
|
|
2419
|
+
}
|
|
2420
|
+
/**
|
|
2421
|
+
* @param {TimeSeries} series
|
|
2422
|
+
*/
|
|
2423
|
+
fit(series) {
|
|
2424
|
+
_assertClass(series, TimeSeries);
|
|
2425
|
+
const ret = wasm.windowaverageforecaster_fit(this.__wbg_ptr, series.__wbg_ptr);
|
|
2426
|
+
if (ret[1]) {
|
|
2427
|
+
throw takeFromExternrefTable0(ret[0]);
|
|
2428
|
+
}
|
|
2429
|
+
}
|
|
2430
|
+
/**
|
|
2431
|
+
* @param window_size - Size of the rolling window
|
|
2432
|
+
* @param {number} window_size
|
|
2433
|
+
*/
|
|
2434
|
+
constructor(window_size) {
|
|
2435
|
+
const ret = wasm.windowaverageforecaster_new(window_size);
|
|
2436
|
+
this.__wbg_ptr = ret >>> 0;
|
|
2437
|
+
WindowAverageForecasterFinalization.register(this, this.__wbg_ptr, this);
|
|
2438
|
+
return this;
|
|
2439
|
+
}
|
|
2440
|
+
/**
|
|
2441
|
+
* @returns {string}
|
|
2442
|
+
*/
|
|
2443
|
+
get name() {
|
|
2444
|
+
let deferred1_0;
|
|
2445
|
+
let deferred1_1;
|
|
2446
|
+
try {
|
|
2447
|
+
const ret = wasm.windowaverageforecaster_name(this.__wbg_ptr);
|
|
2448
|
+
deferred1_0 = ret[0];
|
|
2449
|
+
deferred1_1 = ret[1];
|
|
2450
|
+
return getStringFromWasm0(ret[0], ret[1]);
|
|
2451
|
+
} finally {
|
|
2452
|
+
wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
|
|
2453
|
+
}
|
|
2454
|
+
}
|
|
2455
|
+
/**
|
|
2456
|
+
* @param {number} horizon
|
|
2457
|
+
* @returns {Forecast}
|
|
2458
|
+
*/
|
|
2459
|
+
predict(horizon) {
|
|
2460
|
+
const ret = wasm.windowaverageforecaster_predict(this.__wbg_ptr, horizon);
|
|
2461
|
+
if (ret[2]) {
|
|
2462
|
+
throw takeFromExternrefTable0(ret[1]);
|
|
2463
|
+
}
|
|
2464
|
+
return Forecast.__wrap(ret[0]);
|
|
2465
|
+
}
|
|
2466
|
+
}
|
|
2467
|
+
if (Symbol.dispose) WindowAverageForecaster.prototype[Symbol.dispose] = WindowAverageForecaster.prototype.free;
|
|
2468
|
+
|
|
2469
|
+
/**
|
|
2470
|
+
* Initialize the WASM module.
|
|
2471
|
+
*
|
|
2472
|
+
* This function is called automatically when the module is loaded.
|
|
2473
|
+
*/
|
|
2474
|
+
export function init() {
|
|
2475
|
+
wasm.init();
|
|
2476
|
+
}
|
|
2477
|
+
|
|
2478
|
+
/**
|
|
2479
|
+
* Get the library version.
|
|
2480
|
+
* @returns {string}
|
|
2481
|
+
*/
|
|
2482
|
+
export function version() {
|
|
2483
|
+
let deferred1_0;
|
|
2484
|
+
let deferred1_1;
|
|
2485
|
+
try {
|
|
2486
|
+
const ret = wasm.version();
|
|
2487
|
+
deferred1_0 = ret[0];
|
|
2488
|
+
deferred1_1 = ret[1];
|
|
2489
|
+
return getStringFromWasm0(ret[0], ret[1]);
|
|
2490
|
+
} finally {
|
|
2491
|
+
wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
|
|
2492
|
+
}
|
|
2493
|
+
}
|
|
2494
|
+
|
|
2495
|
+
const EXPECTED_RESPONSE_TYPES = new Set(['basic', 'cors', 'default']);
|
|
2496
|
+
|
|
2497
|
+
async function __wbg_load(module, imports) {
|
|
2498
|
+
if (typeof Response === 'function' && module instanceof Response) {
|
|
2499
|
+
if (typeof WebAssembly.instantiateStreaming === 'function') {
|
|
2500
|
+
try {
|
|
2501
|
+
return await WebAssembly.instantiateStreaming(module, imports);
|
|
2502
|
+
} catch (e) {
|
|
2503
|
+
const validResponse = module.ok && EXPECTED_RESPONSE_TYPES.has(module.type);
|
|
2504
|
+
|
|
2505
|
+
if (validResponse && module.headers.get('Content-Type') !== 'application/wasm') {
|
|
2506
|
+
console.warn("`WebAssembly.instantiateStreaming` failed because your server does not serve Wasm with `application/wasm` MIME type. Falling back to `WebAssembly.instantiate` which is slower. Original error:\n", e);
|
|
2507
|
+
|
|
2508
|
+
} else {
|
|
2509
|
+
throw e;
|
|
2510
|
+
}
|
|
2511
|
+
}
|
|
2512
|
+
}
|
|
2513
|
+
|
|
2514
|
+
const bytes = await module.arrayBuffer();
|
|
2515
|
+
return await WebAssembly.instantiate(bytes, imports);
|
|
2516
|
+
} else {
|
|
2517
|
+
const instance = await WebAssembly.instantiate(module, imports);
|
|
2518
|
+
|
|
2519
|
+
if (instance instanceof WebAssembly.Instance) {
|
|
2520
|
+
return { instance, module };
|
|
2521
|
+
} else {
|
|
2522
|
+
return instance;
|
|
2523
|
+
}
|
|
2524
|
+
}
|
|
2525
|
+
}
|
|
2526
|
+
|
|
2527
|
+
function __wbg_get_imports() {
|
|
2528
|
+
const imports = {};
|
|
2529
|
+
imports.wbg = {};
|
|
2530
|
+
imports.wbg.__wbg_Error_52673b7de5a0ca89 = function(arg0, arg1) {
|
|
2531
|
+
const ret = Error(getStringFromWasm0(arg0, arg1));
|
|
2532
|
+
return ret;
|
|
2533
|
+
};
|
|
2534
|
+
imports.wbg.__wbg___wbindgen_throw_dd24417ed36fc46e = function(arg0, arg1) {
|
|
2535
|
+
throw new Error(getStringFromWasm0(arg0, arg1));
|
|
2536
|
+
};
|
|
2537
|
+
imports.wbg.__wbg_getTime_ad1e9878a735af08 = function(arg0) {
|
|
2538
|
+
const ret = arg0.getTime();
|
|
2539
|
+
return ret;
|
|
2540
|
+
};
|
|
2541
|
+
imports.wbg.__wbg_new_0_23cedd11d9b40c9d = function() {
|
|
2542
|
+
const ret = new Date();
|
|
2543
|
+
return ret;
|
|
2544
|
+
};
|
|
2545
|
+
imports.wbg.__wbindgen_init_externref_table = function() {
|
|
2546
|
+
const table = wasm.__wbindgen_externrefs;
|
|
2547
|
+
const offset = table.grow(4);
|
|
2548
|
+
table.set(0, undefined);
|
|
2549
|
+
table.set(offset + 0, undefined);
|
|
2550
|
+
table.set(offset + 1, null);
|
|
2551
|
+
table.set(offset + 2, true);
|
|
2552
|
+
table.set(offset + 3, false);
|
|
2553
|
+
};
|
|
2554
|
+
|
|
2555
|
+
return imports;
|
|
2556
|
+
}
|
|
2557
|
+
|
|
2558
|
+
function __wbg_finalize_init(instance, module) {
|
|
2559
|
+
wasm = instance.exports;
|
|
2560
|
+
__wbg_init.__wbindgen_wasm_module = module;
|
|
2561
|
+
cachedFloat64ArrayMemory0 = null;
|
|
2562
|
+
cachedUint32ArrayMemory0 = null;
|
|
2563
|
+
cachedUint8ArrayMemory0 = null;
|
|
2564
|
+
|
|
2565
|
+
|
|
2566
|
+
wasm.__wbindgen_start();
|
|
2567
|
+
return wasm;
|
|
2568
|
+
}
|
|
2569
|
+
|
|
2570
|
+
function initSync(module) {
|
|
2571
|
+
if (wasm !== undefined) return wasm;
|
|
2572
|
+
|
|
2573
|
+
|
|
2574
|
+
if (typeof module !== 'undefined') {
|
|
2575
|
+
if (Object.getPrototypeOf(module) === Object.prototype) {
|
|
2576
|
+
({module} = module)
|
|
2577
|
+
} else {
|
|
2578
|
+
console.warn('using deprecated parameters for `initSync()`; pass a single object instead')
|
|
2579
|
+
}
|
|
2580
|
+
}
|
|
2581
|
+
|
|
2582
|
+
const imports = __wbg_get_imports();
|
|
2583
|
+
if (!(module instanceof WebAssembly.Module)) {
|
|
2584
|
+
module = new WebAssembly.Module(module);
|
|
2585
|
+
}
|
|
2586
|
+
const instance = new WebAssembly.Instance(module, imports);
|
|
2587
|
+
return __wbg_finalize_init(instance, module);
|
|
2588
|
+
}
|
|
2589
|
+
|
|
2590
|
+
async function __wbg_init(module_or_path) {
|
|
2591
|
+
if (wasm !== undefined) return wasm;
|
|
2592
|
+
|
|
2593
|
+
|
|
2594
|
+
if (typeof module_or_path !== 'undefined') {
|
|
2595
|
+
if (Object.getPrototypeOf(module_or_path) === Object.prototype) {
|
|
2596
|
+
({module_or_path} = module_or_path)
|
|
2597
|
+
} else {
|
|
2598
|
+
console.warn('using deprecated parameters for the initialization function; pass a single object instead')
|
|
2599
|
+
}
|
|
2600
|
+
}
|
|
2601
|
+
|
|
2602
|
+
if (typeof module_or_path === 'undefined') {
|
|
2603
|
+
module_or_path = new URL('anofox_forecast_js_bg.wasm', import.meta.url);
|
|
2604
|
+
}
|
|
2605
|
+
const imports = __wbg_get_imports();
|
|
2606
|
+
|
|
2607
|
+
if (typeof module_or_path === 'string' || (typeof Request === 'function' && module_or_path instanceof Request) || (typeof URL === 'function' && module_or_path instanceof URL)) {
|
|
2608
|
+
module_or_path = fetch(module_or_path);
|
|
2609
|
+
}
|
|
2610
|
+
|
|
2611
|
+
const { instance, module } = await __wbg_load(await module_or_path, imports);
|
|
2612
|
+
|
|
2613
|
+
return __wbg_finalize_init(instance, module);
|
|
2614
|
+
}
|
|
2615
|
+
|
|
2616
|
+
export { initSync };
|
|
2617
|
+
export default __wbg_init;
|