@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.
@@ -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;