(function () { const e = document.createElement('link').relList; if (e && e.supports && e.supports('modulepreload')) return; for (const u of document.querySelectorAll('link[rel="modulepreload"]')) i(u); new MutationObserver((u) => { for (const n of u) if (n.type === 'childList') for (const s of n.addedNodes) s.tagName === 'LINK' && s.rel === 'modulepreload' && i(s); }).observe(document, { childList: !0, subtree: !0 }); function o(u) { const n = {}; return ( u.integrity && (n.integrity = u.integrity), u.referrerPolicy && (n.referrerPolicy = u.referrerPolicy), u.crossOrigin === 'use-credentials' ? (n.credentials = 'include') : u.crossOrigin === 'anonymous' ? (n.credentials = 'omit') : (n.credentials = 'same-origin'), n ); } function i(u) { if (u.ep) return; u.ep = !0; const n = o(u); fetch(u.href, n); } })(); function dispatchCallback(t, e) { t && t(e); } function reverseDictionary(t) { return Object.fromEntries(Object.entries(t).map(([e, o]) => [o, e])); } const Callable = class { constructor() { let t = function (...e) { return t._call(...e); }; return Object.setPrototypeOf(t, new.target.prototype); } _call(...t) { throw Error('Must implement _call method in subclass'); } }; function isTypedArray(t) { return t?.prototype?.__proto__?.constructor?.name === 'TypedArray'; } function isIntegralNumber(t) { return Number.isInteger(t) || typeof t == 'bigint'; } function exists(t) { return t != null; } function calculateDimensions(t) { const e = []; let o = t; for (; Array.isArray(o); ) e.push(o.length), (o = o[0]); return e; } function mergeArrays(...t) { return Array.prototype.concat.apply([], t); } function calculateReflectOffset(t, e) { return Math.abs(((t + e) % (2 * e)) - e); } const sharp = {}, ONNX_NODE = Object.freeze( Object.defineProperty({ __proto__: null, default: sharp }, Symbol.toStringTag, { value: 'Module' }) ), VERSION = '3.0.0-alpha.0', BROWSER_ENV$1 = typeof self < 'u', WEB_CACHE_AVAILABLE = BROWSER_ENV$1 && 'caches' in self, FS_AVAILABLE = !isEmpty(sharp), PATH_AVAILABLE = !isEmpty(sharp), RUNNING_LOCALLY = FS_AVAILABLE && PATH_AVAILABLE, __dirname$1 = RUNNING_LOCALLY ? sharp.dirname(sharp.dirname(sharp.fileURLToPath(import.meta.url))) : './', DEFAULT_CACHE_DIR = RUNNING_LOCALLY ? sharp.join(__dirname$1, '/.cache/') : null, DEFAULT_LOCAL_MODEL_PATH = '/models/', localModelPath = RUNNING_LOCALLY ? sharp.join(__dirname$1, DEFAULT_LOCAL_MODEL_PATH) : DEFAULT_LOCAL_MODEL_PATH, env = { backends: { onnx: {}, tfjs: {} }, experimental: { useWebGPU: !1 }, __dirname: __dirname$1, version: VERSION, allowRemoteModels: !0, remoteHost: 'https://huggingface.co/', remotePathTemplate: '{model}/resolve/{revision}/', allowLocalModels: !BROWSER_ENV$1, localModelPath, useFS: FS_AVAILABLE, useBrowserCache: WEB_CACHE_AVAILABLE, useFSCache: FS_AVAILABLE, cacheDir: DEFAULT_CACHE_DIR, useCustomCache: !1, customCache: null, }; function isEmpty(t) { return Object.keys(t).length === 0; } var define_process_env_default = {}; class FileResponse { _CONTENT_TYPE_MAP = { txt: 'text/plain', html: 'text/html', css: 'text/css', js: 'text/javascript', json: 'application/json', png: 'image/png', jpg: 'image/jpeg', jpeg: 'image/jpeg', gif: 'image/gif', }; constructor(e) { if (((this.filePath = e), (this.headers = new Headers()), (this.exists = sharp.existsSync(e)), this.exists)) { (this.status = 200), (this.statusText = 'OK'); let o = sharp.statSync(e); this.headers.set('content-length', o.size.toString()), this.updateContentType(); let i = this; this.body = new ReadableStream({ start(u) { i.arrayBuffer().then((n) => { u.enqueue(new Uint8Array(n)), u.close(); }); }, }); } else (this.status = 404), (this.statusText = 'Not Found'), (this.body = null); } updateContentType() { const e = this.filePath.toString().split('.').pop().toLowerCase(); this.headers.set('content-type', this._CONTENT_TYPE_MAP[e] ?? 'application/octet-stream'); } clone() { let e = new FileResponse(this.filePath); return ( (e.exists = this.exists), (e.status = this.status), (e.statusText = this.statusText), (e.headers = new Headers(this.headers)), e ); } async arrayBuffer() { return (await sharp.promises.readFile(this.filePath)).buffer; } async blob() { const e = await sharp.promises.readFile(this.filePath); return new Blob([e], { type: this.headers.get('content-type') }); } async text() { return await sharp.promises.readFile(this.filePath, 'utf8'); } async json() { return JSON.parse(await this.text()); } } function isValidHttpUrl(t, e = null) { let o; try { o = new URL(t); } catch { return !1; } return e && !e.includes(o.hostname) ? !1 : o.protocol === 'http:' || o.protocol === 'https:'; } async function getFile(t) { if (env.useFS && !isValidHttpUrl(t)) return new FileResponse(t); if (typeof process < 'u' && process?.release?.name === 'node') { const e = !!define_process_env_default?.TESTING_REMOTELY, o = env.version, i = new Headers(); if ( (i.set('User-Agent', `transformers.js/${o}; is_ci/${e};`), isValidHttpUrl(t, ['huggingface.co', 'hf.co'])) ) { const n = define_process_env_default?.HF_TOKEN ?? define_process_env_default?.HF_ACCESS_TOKEN; n && i.set('Authorization', `Bearer ${n}`); } return fetch(t, { headers: i }); } else return fetch(t); } const ERROR_MAPPING = { 400: 'Bad request error occurred while trying to load file', 401: 'Unauthorized access to file', 403: 'Forbidden access to file', 404: 'Could not locate file', 408: 'Request timeout error occurred while trying to load file', 500: 'Internal server error error occurred while trying to load file', 502: 'Bad gateway error occurred while trying to load file', 503: 'Service unavailable error occurred while trying to load file', 504: 'Gateway timeout error occurred while trying to load file', }; function handleError(t, e, o) { if (!o) return null; const i = ERROR_MAPPING[t] ?? `Error (${t}) occurred while trying to load file`; throw Error(`${i}: "${e}".`); } class FileCache { constructor(e) { this.path = e; } async match(e) { let o = sharp.join(this.path, e), i = new FileResponse(o); if (i.exists) return i; } async put(e, o) { const i = Buffer.from(await o.arrayBuffer()); let u = sharp.join(this.path, e); try { await sharp.promises.mkdir(sharp.dirname(u), { recursive: !0 }), await sharp.promises.writeFile(u, i); } catch (n) { console.warn('An error occurred while writing the file to cache:', n); } } } async function tryCache(t, ...e) { for (let o of e) try { let i = await t.match(o); if (i) return i; } catch { continue; } } async function getModelFile(t, e, o = !0, i = {}) { if (!env.allowLocalModels && i.local_files_only) throw Error( 'Invalid configuration detected: local models are disabled (`env.allowLocalModels=false`) but you have requested to only use local models (`local_files_only=true`).' ); dispatchCallback(i.progress_callback, { status: 'initiate', name: t, file: e }); let u; if (!u && env.useBrowserCache) { if (typeof caches > 'u') throw Error('Browser cache is not available in this environment.'); try { u = await caches.open('transformers-cache'); } catch (S) { console.warn('An error occurred while opening the browser cache:', S); } } if ((!u && env.useFSCache && (u = new FileCache(i.cache_dir ?? env.cacheDir)), !u && env.useCustomCache)) throw Error('`env.useCustomCache=true`, but `env.customCache` is not defined.'); const n = i.revision ?? 'main'; let s = pathJoin(t, e), d = pathJoin(env.localModelPath, s), f = pathJoin( env.remoteHost, env.remotePathTemplate.replaceAll('{model}', t).replaceAll('{revision}', encodeURIComponent(n)), e ), r = n === 'main' ? s : pathJoin(t, n, e), a, l = u instanceof FileCache ? r : f, p = !1, m; u && (m = await tryCache(u, d, l)); const y = m !== void 0; if (m === void 0) { if (env.allowLocalModels) if (isValidHttpUrl(s)) { if (i.local_files_only) throw new Error(`\`local_files_only=true\`, but attempted to load a remote file from: ${s}.`); } else try { (m = await getFile(d)), (a = d); } catch (E) { console.warn(`Unable to load from local path "${d}": "${E}"`); } if (m === void 0 || m.status === 404) { if (i.local_files_only || !env.allowRemoteModels) { if (o) throw Error( `\`local_files_only=true\` or \`env.allowRemoteModels=false\` and file was not found locally at "${d}".` ); return null; } if (((m = await getFile(f)), m.status !== 200)) return handleError(m.status, f, o); a = l; } p = u && typeof Response < 'u' && m instanceof Response && m.status === 200; } dispatchCallback(i.progress_callback, { status: 'download', name: t, file: e }); const T = { status: 'progress', name: t, file: e }; let v; return ( i.progress_callback ? y && typeof navigator < 'u' && /firefox/i.test(navigator.userAgent) ? ((v = new Uint8Array(await m.arrayBuffer())), dispatchCallback(i.progress_callback, { ...T, progress: 100, loaded: v.length, total: v.length })) : (v = await readResponse(m, (S) => { dispatchCallback(i.progress_callback, { ...T, ...S }); })) : (v = new Uint8Array(await m.arrayBuffer())), p && a && (await u.match(a)) === void 0 && (await u.put(a, new Response(v, { headers: m.headers })).catch((S) => { console.warn(`Unable to add response to browser cache: ${S}.`); })), dispatchCallback(i.progress_callback, { status: 'done', name: t, file: e }), v ); } async function getModelJSON(t, e, o = !0, i = {}) { let u = await getModelFile(t, e, o, i); if (u === null) return {}; let s = new TextDecoder('utf-8').decode(u); return JSON.parse(s); } async function readResponse(t, e) { const o = t.headers.get('Content-Length'); o === null && console.warn('Unable to determine content-length from response headers. Will expand buffer when needed.'); let i = parseInt(o ?? '0'), u = new Uint8Array(i), n = 0; const s = t.body.getReader(); async function d() { const { done: f, value: r } = await s.read(); if (f) return; let a = n + r.length; if (a > i) { i = a; let p = new Uint8Array(i); p.set(u), (u = p); } u.set(r, n), (n = a); const l = (n / i) * 100; return e({ progress: l, loaded: n, total: i }), d(); } return await d(), u; } function pathJoin(...t) { return ( (t = t.map( (e, o) => ( o && (e = e.replace(new RegExp('^/'), '')), o !== t.length - 1 && (e = e.replace(new RegExp('/$'), '')), e ) )), t.join('/') ); } function interpolate_data(t, [e, o, i], [u, n], s = 'bilinear', d = !1) { const f = n / i, r = u / o, a = new t.constructor(u * n * e), l = o * i, p = u * n; for (let m = 0; m < u; ++m) for (let y = 0; y < n; ++y) { const T = m * n + y, v = (y + 0.5) / f - 0.5, S = (m + 0.5) / r - 0.5; let E = Math.floor(v), A = Math.floor(S); const F = Math.min(E + 1, i - 1), B = Math.min(A + 1, o - 1); (E = Math.max(E, 0)), (A = Math.max(A, 0)); const J = v - E, Q = S - A, re = (1 - J) * (1 - Q), V = J * (1 - Q), de = (1 - J) * Q, ke = J * Q, Ne = A * i, Me = B * i, Y = Ne + E, _e = Ne + F, he = Me + E, ue = Me + F; for (let pe = 0; pe < e; ++pe) { const X = pe * l; a[pe * p + T] = re * t[X + Y] + V * t[X + _e] + de * t[X + he] + ke * t[X + ue]; } } return a; } function transpose_data(t, e, o) { const i = new Array(o.length), u = new Array(o.length); for (let d = o.length - 1, f = 1; d >= 0; --d) (u[d] = f), (i[d] = e[o[d]]), (f *= i[d]); const n = o.map((d, f) => u[o.indexOf(f)]), s = new t.constructor(t.length); for (let d = 0; d < t.length; ++d) { let f = 0; for (let r = e.length - 1, a = d; r >= 0; --r) (f += (a % e[r]) * n[r]), (a = Math.floor(a / e[r])); s[f] = t[d]; } return [s, i]; } function softmax(t) { const e = max(t)[0], o = t.map((n) => Math.exp(n - e)), i = o.reduce((n, s) => n + s, 0); return o.map((n) => n / i); } function log_softmax(t) { return softmax(t).map((i) => Math.log(i)); } function getTopItems(t, e = 0) { return ( (t = Array.from(t) .map((o, i) => [i, o]) .sort((o, i) => i[1] - o[1])), e !== null && e > 0 && (t = t.slice(0, e)), t ); } function min(t) { if (t.length === 0) throw Error('Array must not be empty'); let e = t[0], o = 0; for (let i = 1; i < t.length; ++i) t[i] < e && ((e = t[i]), (o = i)); return [e, o]; } function max(t) { if (t.length === 0) throw Error('Array must not be empty'); let e = t[0], o = 0; for (let i = 1; i < t.length; ++i) t[i] > e && ((e = t[i]), (o = i)); return [Number(e), o]; } function isPowerOfTwo(t) { return t > 0 && (t & (t - 1)) === 0; } class P2FFT { constructor(e) { if (((this.size = e | 0), this.size <= 1 || !isPowerOfTwo(this.size))) throw new Error('FFT size must be a power of two larger than 1'); (this._csize = e << 1), (this.table = new Float64Array(this.size * 2)); for (let i = 0; i < this.table.length; i += 2) { const u = (Math.PI * i) / this.size; (this.table[i] = Math.cos(u)), (this.table[i + 1] = -Math.sin(u)); } let o = 0; for (let i = 1; this.size > i; i <<= 1) ++o; (this._width = o % 2 === 0 ? o - 1 : o), (this._bitrev = new Int32Array(1 << this._width)); for (let i = 0; i < this._bitrev.length; ++i) { this._bitrev[i] = 0; for (let u = 0; u < this._width; u += 2) { const n = this._width - u - 2; this._bitrev[i] |= ((i >>> u) & 3) << n; } } } createComplexArray() { return new Float64Array(this._csize); } fromComplexArray(e, o) { const i = o || new Array(e.length >>> 1); for (let u = 0; u < e.length; u += 2) i[u >>> 1] = e[u]; return i; } toComplexArray(e, o) { const i = o || this.createComplexArray(); for (let u = 0; u < i.length; u += 2) (i[u] = e[u >>> 1]), (i[u + 1] = 0); return i; } completeSpectrum(e) { const o = this._csize, i = o >>> 1; for (let u = 2; u < i; u += 2) (e[o - u] = e[u]), (e[o - u + 1] = -e[u + 1]); } transform(e, o) { if (e === o) throw new Error('Input and output buffers must be different'); this._transform4(e, o, 1); } realTransform(e, o) { if (e === o) throw new Error('Input and output buffers must be different'); this._realTransform4(e, o, 1); } inverseTransform(e, o) { if (e === o) throw new Error('Input and output buffers must be different'); this._transform4(e, o, -1); for (let i = 0; i < e.length; ++i) e[i] /= this.size; } _transform4(e, o, i) { const u = this._csize; let s = 1 << this._width, d = (u / s) << 1, f, r; const a = this._bitrev; if (d === 4) for (f = 0, r = 0; f < u; f += d, ++r) { const l = a[r]; this._singleTransform2(o, e, f, l, s); } else for (f = 0, r = 0; f < u; f += d, ++r) { const l = a[r]; this._singleTransform4(o, e, f, l, s, i); } for (s >>= 2; s >= 2; s >>= 2) { d = (u / s) << 1; const l = d >>> 2; for (f = 0; f < u; f += d) { const p = f + l - 1; for (let m = f, y = 0; m < p; m += 2, y += s) { const T = m, v = T + l, S = v + l, E = S + l, A = e[T], F = e[T + 1], B = e[v], J = e[v + 1], Q = e[S], re = e[S + 1], V = e[E], de = e[E + 1], ke = this.table[y], Ne = i * this.table[y + 1], Me = B * ke - J * Ne, Y = B * Ne + J * ke, _e = this.table[2 * y], he = i * this.table[2 * y + 1], ue = Q * _e - re * he, pe = Q * he + re * _e, X = this.table[3 * y], ve = i * this.table[3 * y + 1], we = V * X - de * ve, rt = V * ve + de * X, ot = A + ue, qe = F + pe, He = A - ue, Qe = F - pe, Be = Me + we, Ce = Y + rt, Se = i * (Me - we), je = i * (Y - rt); (e[T] = ot + Be), (e[T + 1] = qe + Ce), (e[v] = He + je), (e[v + 1] = Qe - Se), (e[S] = ot - Be), (e[S + 1] = qe - Ce), (e[E] = He - je), (e[E + 1] = Qe + Se); } } } } _singleTransform2(e, o, i, u, n) { const s = e[u], d = e[u + 1], f = e[u + n], r = e[u + n + 1]; (o[i] = s + f), (o[i + 1] = d + r), (o[i + 2] = s - f), (o[i + 3] = d - r); } _singleTransform4(e, o, i, u, n, s) { const d = n * 2, f = n * 3, r = e[u], a = e[u + 1], l = e[u + n], p = e[u + n + 1], m = e[u + d], y = e[u + d + 1], T = e[u + f], v = e[u + f + 1], S = r + m, E = a + y, A = r - m, F = a - y, B = l + T, J = p + v, Q = s * (l - T), re = s * (p - v); (o[i] = S + B), (o[i + 1] = E + J), (o[i + 2] = A + re), (o[i + 3] = F - Q), (o[i + 4] = S - B), (o[i + 5] = E - J), (o[i + 6] = A - re), (o[i + 7] = F + Q); } _realTransform4(e, o, i) { const u = this._csize; let s = 1 << this._width, d = (u / s) << 1, f, r; const a = this._bitrev; if (d === 4) for (f = 0, r = 0; f < u; f += d, ++r) { const l = a[r]; this._singleRealTransform2(o, e, f, l >>> 1, s >>> 1); } else for (f = 0, r = 0; f < u; f += d, ++r) { const l = a[r]; this._singleRealTransform4(o, e, f, l >>> 1, s >>> 1, i); } for (s >>= 2; s >= 2; s >>= 2) { d = (u / s) << 1; const l = d >>> 2; for (f = 0; f < u; f += d) { const p = f + l - 1; for (let m = f, y = 0; m < p; m += 2, y += s) { const T = m, v = T + l, S = v + l, E = S + l, A = e[T], F = e[T + 1], B = e[v], J = e[v + 1], Q = e[S], re = e[S + 1], V = e[E], de = e[E + 1], ke = this.table[y], Ne = i * this.table[y + 1], Me = B * ke - J * Ne, Y = B * Ne + J * ke, _e = this.table[2 * y], he = i * this.table[2 * y + 1], ue = Q * _e - re * he, pe = Q * he + re * _e, X = this.table[3 * y], ve = i * this.table[3 * y + 1], we = V * X - de * ve, rt = V * ve + de * X, ot = A + ue, qe = F + pe, He = A - ue, Qe = F - pe, Be = Me + we, Ce = Y + rt, Se = i * (Me - we), je = i * (Y - rt); (e[T] = ot + Be), (e[T + 1] = qe + Ce), (e[v] = He + je), (e[v + 1] = Qe - Se), (e[S] = ot - Be), (e[S + 1] = qe - Ce), (e[E] = He - je), (e[E + 1] = Qe + Se); } } } } _singleRealTransform2(e, o, i, u, n) { const s = e[u], d = e[u + n]; (o[i] = s + d), (o[i + 1] = 0), (o[i + 2] = s - d), (o[i + 3] = 0); } _singleRealTransform4(e, o, i, u, n, s) { const d = n * 2, f = n * 3, r = e[u], a = e[u + n], l = e[u + d], p = e[u + f], m = r + l, y = r - l, T = a + p, v = s * (a - p); (o[i] = m + T), (o[i + 1] = 0), (o[i + 2] = y), (o[i + 3] = -v), (o[i + 4] = m - T), (o[i + 5] = 0), (o[i + 6] = y), (o[i + 7] = v); } } class NP2FFT { constructor(e) { const o = 2 * (e - 1), i = 2 * (2 * e - 1), u = 2 ** Math.ceil(Math.log2(i)); (this.bufferSize = u), (this._a = o); const n = new Float64Array(i), s = new Float64Array(u); (this._chirpBuffer = new Float64Array(u)), (this._buffer1 = new Float64Array(u)), (this._buffer2 = new Float64Array(u)), (this._outBuffer1 = new Float64Array(u)), (this._outBuffer2 = new Float64Array(u)); const d = (-2 * Math.PI) / e, f = Math.cos(d), r = Math.sin(d); for (let a = 0; a < i >> 1; ++a) { const l = (a + 1 - e) ** 2 / 2, p = Math.sqrt(f ** 2 + r ** 2) ** l, m = l * Math.atan2(r, f), y = 2 * a; (n[y] = p * Math.cos(m)), (n[y + 1] = p * Math.sin(m)), (s[y] = n[y]), (s[y + 1] = -n[y + 1]); } (this._slicedChirpBuffer = n.subarray(o, i)), (this._f = new P2FFT(u >> 1)), this._f.transform(this._chirpBuffer, s); } _transform(e, o, i) { const u = this._buffer1, n = this._buffer2, s = this._outBuffer1, d = this._outBuffer2, f = this._chirpBuffer, r = this._slicedChirpBuffer, a = this._a; if (i) for (let l = 0; l < r.length; l += 2) { const p = l + 1, m = l >> 1, y = o[m]; (u[l] = y * r[l]), (u[p] = y * r[p]); } else for (let l = 0; l < r.length; l += 2) { const p = l + 1; (u[l] = o[l] * r[l] - o[p] * r[p]), (u[p] = o[l] * r[p] + o[p] * r[l]); } this._f.transform(s, u); for (let l = 0; l < f.length; l += 2) { const p = l + 1; (n[l] = s[l] * f[l] - s[p] * f[p]), (n[p] = s[l] * f[p] + s[p] * f[l]); } this._f.inverseTransform(d, n); for (let l = 0; l < d.length; l += 2) { const p = d[l + a], m = d[l + a + 1], y = r[l], T = r[l + 1]; (e[l] = p * y - m * T), (e[l + 1] = p * T + m * y); } } transform(e, o) { this._transform(e, o, !1); } realTransform(e, o) { this._transform(e, o, !0); } } class FFT { constructor(e) { (this.fft_length = e), (this.isPowerOfTwo = isPowerOfTwo(e)), this.isPowerOfTwo ? ((this.fft = new P2FFT(e)), (this.outputBufferSize = 2 * e)) : ((this.fft = new NP2FFT(e)), (this.outputBufferSize = this.fft.bufferSize)); } realTransform(e, o) { this.fft.realTransform(e, o); } transform(e, o) { this.fft.transform(e, o); } } function medianFilter(t, e) { if (e % 2 === 0 || e <= 0) throw new Error('Window size must be a positive odd number'); const o = new t.constructor(t.length), i = new t.constructor(e), u = Math.floor(e / 2); for (let n = 0; n < t.length; ++n) { let s = 0; for (let d = -u; d <= u; ++d) { let f = n + d; f < 0 ? (f = Math.abs(f)) : f >= t.length && (f = 2 * (t.length - 1) - f), (i[s++] = t[f]); } i.sort(), (o[n] = i[u]); } return o; } const scriptRel = 'modulepreload', assetsURL = function (t) { return '/' + t; }, seen = {}, __vitePreload = function (e, o, i) { let u = Promise.resolve(); if (o && o.length > 0) { const n = document.getElementsByTagName('link'); u = Promise.all( o.map((s) => { if (((s = assetsURL(s)), s in seen)) return; seen[s] = !0; const d = s.endsWith('.css'), f = d ? '[rel="stylesheet"]' : ''; if (!!i) for (let l = n.length - 1; l >= 0; l--) { const p = n[l]; if (p.href === s && (!d || p.rel === 'stylesheet')) return; } else if (document.querySelector(`link[href="${s}"]${f}`)) return; const a = document.createElement('link'); if ( ((a.rel = d ? 'stylesheet' : scriptRel), d || ((a.as = 'script'), (a.crossOrigin = '')), (a.href = s), document.head.appendChild(a), d) ) return new Promise((l, p) => { a.addEventListener('load', l), a.addEventListener('error', () => p(new Error(`Unable to preload CSS for ${s}`))); }); }) ); } return u .then(() => e()) .catch((n) => { const s = new Event('vite:preloadError', { cancelable: !0 }); if (((s.payload = n), window.dispatchEvent(s), !s.defaultPrevented)) throw n; }); }; /*! * ONNX Runtime Web v1.17.1 * Copyright (c) Microsoft Corporation. All rights reserved. * Licensed under the MIT License. */ var vd = Object.create, En = Object.defineProperty, wd = Object.getOwnPropertyDescriptor, _d = Object.getOwnPropertyNames, Od = Object.getPrototypeOf, Id = Object.prototype.hasOwnProperty, L = (t, e) => () => (t && (e = t((t = 0))), e), me = (t, e) => () => (e || t((e = { exports: {} }).exports, e), e.exports), Pr = (t, e) => { for (var o in e) En(t, o, { get: e[o], enumerable: !0 }); }, Ha = (t, e, o, i) => { if ((e && typeof e == 'object') || typeof e == 'function') for (let u of _d(e)) !Id.call(t, u) && u !== o && En(t, u, { get: () => e[u], enumerable: !(i = wd(e, u)) || i.enumerable }); return t; }, Er = (t, e, o) => ( (o = t != null ? vd(Od(t)) : {}), Ha(e || !t || !t.__esModule ? En(o, 'default', { value: t, enumerable: !0 }) : o, t) ), rr = (t) => Ha(En({}, '__esModule', { value: !0 }), t), Dn, nr, or, Ln, Fn = L(() => { (Dn = new Map()), (nr = []), (or = (t, e, o) => { if (e && typeof e.init == 'function' && typeof e.createInferenceSessionHandler == 'function') { let i = Dn.get(t); if (i === void 0) Dn.set(t, { backend: e, priority: o }); else { if (i.priority > o) return; if (i.priority === o && i.backend !== e) throw new Error(`cannot register backend "${t}" using priority ${o}`); } if (o >= 0) { let u = nr.indexOf(t); u !== -1 && nr.splice(u, 1); for (let n = 0; n < nr.length; n++) if (Dn.get(nr[n]).priority <= o) { nr.splice(n, 0, t); return; } nr.push(t); } return; } throw new TypeError('not a valid backend'); }), (Ln = async (t) => { let e = t.length === 0 ? nr : t, o = []; for (let i of e) { let u = Dn.get(i); if (u) { if (u.initialized) return u.backend; if (u.aborted) continue; let n = !!u.initPromise; try { return ( n || (u.initPromise = u.backend.init(i)), await u.initPromise, (u.initialized = !0), u.backend ); } catch (s) { n || o.push({ name: i, err: s }), (u.aborted = !0); } finally { delete u.initPromise; } } } throw new Error(`no available backend found. ERR: ${o.map((i) => `[${i.name}] ${i.err}`).join(', ')}`); }); }), qa = L(() => { Fn(); }), ja, Ya = L(() => { ja = '1.17.1'; }), Xa, ir, Ho = L(() => { Ya(), (Xa = 'warning'), (ir = { wasm: {}, webgl: {}, webgpu: {}, versions: { common: ja }, set logLevel(t) { if (t !== void 0) { if (typeof t != 'string' || ['verbose', 'info', 'warning', 'error', 'fatal'].indexOf(t) === -1) throw new Error(`Unsupported logging level: ${t}`); Xa = t; } }, get logLevel() { return Xa; }, }), Object.defineProperty(ir, 'logLevel', { enumerable: !0 }); }), Z, Ka = L(() => { Ho(), (Z = ir); }), Ja, Za, Qa = L(() => { (Ja = (t, e) => { let o = typeof document < 'u' ? document.createElement('canvas') : new OffscreenCanvas(1, 1); (o.width = t.dims[3]), (o.height = t.dims[2]); let i = o.getContext('2d'); if (i != null) { let u, n; e?.tensorLayout !== void 0 && e.tensorLayout === 'NHWC' ? ((u = t.dims[2]), (n = t.dims[3])) : ((u = t.dims[3]), (n = t.dims[2])); let s = e?.format !== void 0 ? e.format : 'RGB', d = e?.norm, f, r; d === void 0 || d.mean === void 0 ? (f = [255, 255, 255, 255]) : typeof d.mean == 'number' ? (f = [d.mean, d.mean, d.mean, d.mean]) : ((f = [d.mean[0], d.mean[1], d.mean[2], 0]), d.mean[3] !== void 0 && (f[3] = d.mean[3])), d === void 0 || d.bias === void 0 ? (r = [0, 0, 0, 0]) : typeof d.bias == 'number' ? (r = [d.bias, d.bias, d.bias, d.bias]) : ((r = [d.bias[0], d.bias[1], d.bias[2], 0]), d.bias[3] !== void 0 && (r[3] = d.bias[3])); let a = n * u, l = 0, p = a, m = a * 2, y = -1; s === 'RGBA' ? ((l = 0), (p = a), (m = a * 2), (y = a * 3)) : s === 'RGB' ? ((l = 0), (p = a), (m = a * 2)) : s === 'RBG' && ((l = 0), (m = a), (p = a * 2)); for (let T = 0; T < n; T++) for (let v = 0; v < u; v++) { let S = (t.data[l++] - r[0]) * f[0], E = (t.data[p++] - r[1]) * f[1], A = (t.data[m++] - r[2]) * f[2], F = y === -1 ? 255 : (t.data[y++] - r[3]) * f[3]; (i.fillStyle = 'rgba(' + S + ',' + E + ',' + A + ',' + F + ')'), i.fillRect(v, T, 1, 1); } if ('toDataURL' in o) return o.toDataURL(); throw new Error('toDataURL is not supported'); } else throw new Error('Can not access image data'); }), (Za = (t, e) => { let o = typeof document < 'u' ? document.createElement('canvas').getContext('2d') : new OffscreenCanvas(1, 1).getContext('2d'), i; if (o != null) { let u, n, s; e?.tensorLayout !== void 0 && e.tensorLayout === 'NHWC' ? ((u = t.dims[2]), (n = t.dims[1]), (s = t.dims[3])) : ((u = t.dims[3]), (n = t.dims[2]), (s = t.dims[1])); let d = e !== void 0 && e.format !== void 0 ? e.format : 'RGB', f = e?.norm, r, a; f === void 0 || f.mean === void 0 ? (r = [255, 255, 255, 255]) : typeof f.mean == 'number' ? (r = [f.mean, f.mean, f.mean, f.mean]) : ((r = [f.mean[0], f.mean[1], f.mean[2], 255]), f.mean[3] !== void 0 && (r[3] = f.mean[3])), f === void 0 || f.bias === void 0 ? (a = [0, 0, 0, 0]) : typeof f.bias == 'number' ? (a = [f.bias, f.bias, f.bias, f.bias]) : ((a = [f.bias[0], f.bias[1], f.bias[2], 0]), f.bias[3] !== void 0 && (a[3] = f.bias[3])); let l = n * u; if ( e !== void 0 && ((e.format !== void 0 && s === 4 && e.format !== 'RGBA') || (s === 3 && e.format !== 'RGB' && e.format !== 'BGR')) ) throw new Error("Tensor format doesn't match input tensor dims"); let p = 4, m = 0, y = 1, T = 2, v = 3, S = 0, E = l, A = l * 2, F = -1; d === 'RGBA' ? ((S = 0), (E = l), (A = l * 2), (F = l * 3)) : d === 'RGB' ? ((S = 0), (E = l), (A = l * 2)) : d === 'RBG' && ((S = 0), (A = l), (E = l * 2)), (i = o.createImageData(u, n)); for (let B = 0; B < n * u; m += p, y += p, T += p, v += p, B++) (i.data[m] = (t.data[S++] - a[0]) * r[0]), (i.data[y] = (t.data[E++] - a[1]) * r[1]), (i.data[T] = (t.data[A++] - a[2]) * r[2]), (i.data[v] = F === -1 ? 255 : (t.data[F++] - a[3]) * r[3]); } else throw new Error('Can not access image data'); return i; }); }), qo, es, ts, rs, ns, os = L(() => { $n(), (qo = (t, e) => { if (t === void 0) throw new Error('Image buffer must be defined'); if (e.height === void 0 || e.width === void 0) throw new Error('Image height and width must be defined'); if (e.tensorLayout === 'NHWC') throw new Error('NHWC Tensor layout is not supported yet'); let { height: o, width: i } = e, u = e.norm ?? { mean: 255, bias: 0 }, n, s; typeof u.mean == 'number' ? (n = [u.mean, u.mean, u.mean, u.mean]) : (n = [u.mean[0], u.mean[1], u.mean[2], u.mean[3] ?? 255]), typeof u.bias == 'number' ? (s = [u.bias, u.bias, u.bias, u.bias]) : (s = [u.bias[0], u.bias[1], u.bias[2], u.bias[3] ?? 0]); let d = e.format !== void 0 ? e.format : 'RGBA', f = e.tensorFormat !== void 0 && e.tensorFormat !== void 0 ? e.tensorFormat : 'RGB', r = o * i, a = f === 'RGBA' ? new Float32Array(r * 4) : new Float32Array(r * 3), l = 4, p = 0, m = 1, y = 2, T = 3, v = 0, S = r, E = r * 2, A = -1; d === 'RGB' && ((l = 3), (p = 0), (m = 1), (y = 2), (T = -1)), f === 'RGBA' ? (A = r * 3) : f === 'RBG' ? ((v = 0), (E = r), (S = r * 2)) : f === 'BGR' && ((E = 0), (S = r), (v = r * 2)); for (let F = 0; F < r; F++, p += l, y += l, m += l, T += l) (a[v++] = (t[p] + s[0]) / n[0]), (a[S++] = (t[m] + s[1]) / n[1]), (a[E++] = (t[y] + s[2]) / n[2]), A !== -1 && T !== -1 && (a[A++] = (t[T] + s[3]) / n[3]); return f === 'RGBA' ? new Ye('float32', a, [1, 4, o, i]) : new Ye('float32', a, [1, 3, o, i]); }), (es = async (t, e) => { let o = typeof HTMLImageElement < 'u' && t instanceof HTMLImageElement, i = typeof ImageData < 'u' && t instanceof ImageData, u = typeof ImageBitmap < 'u' && t instanceof ImageBitmap, n = typeof t == 'string', s, d = e ?? {}, f = () => { if (typeof document < 'u') return document.createElement('canvas'); if (typeof OffscreenCanvas < 'u') return new OffscreenCanvas(1, 1); throw new Error('Canvas is not supported'); }, r = (a) => a instanceof HTMLCanvasElement || a instanceof OffscreenCanvas ? a.getContext('2d') : null; if (o) { let a = f(); (a.width = t.width), (a.height = t.height); let l = r(a); if (l != null) { let p = t.height, m = t.width; if ( (e !== void 0 && e.resizedHeight !== void 0 && e.resizedWidth !== void 0 && ((p = e.resizedHeight), (m = e.resizedWidth)), e !== void 0) ) { if (((d = e), e.tensorFormat !== void 0)) throw new Error('Image input config format must be RGBA for HTMLImageElement'); (d.tensorFormat = 'RGBA'), (d.height = p), (d.width = m); } else (d.tensorFormat = 'RGBA'), (d.height = p), (d.width = m); l.drawImage(t, 0, 0), (s = l.getImageData(0, 0, m, p).data); } else throw new Error('Can not access image data'); } else if (i) { let a, l; if ( (e !== void 0 && e.resizedWidth !== void 0 && e.resizedHeight !== void 0 ? ((a = e.resizedHeight), (l = e.resizedWidth)) : ((a = t.height), (l = t.width)), e !== void 0 && (d = e), (d.format = 'RGBA'), (d.height = a), (d.width = l), e !== void 0) ) { let p = f(); (p.width = l), (p.height = a); let m = r(p); if (m != null) m.putImageData(t, 0, 0), (s = m.getImageData(0, 0, l, a).data); else throw new Error('Can not access image data'); } else s = t.data; } else if (u) { if (e === void 0) throw new Error('Please provide image config with format for Imagebitmap'); let a = f(); (a.width = t.width), (a.height = t.height); let l = r(a); if (l != null) { let p = t.height, m = t.width; return ( l.drawImage(t, 0, 0, m, p), (s = l.getImageData(0, 0, m, p).data), (d.height = p), (d.width = m), qo(s, d) ); } else throw new Error('Can not access image data'); } else { if (n) return new Promise((a, l) => { let p = f(), m = r(p); if (!t || !m) return l(); let y = new Image(); (y.crossOrigin = 'Anonymous'), (y.src = t), (y.onload = () => { (p.width = y.width), (p.height = y.height), m.drawImage(y, 0, 0, p.width, p.height); let T = m.getImageData(0, 0, p.width, p.height); (d.height = p.height), (d.width = p.width), a(qo(T.data, d)); }); }); throw new Error('Input data provided is not supported - aborted tensor creation'); } if (s !== void 0) return qo(s, d); throw new Error('Input data provided is not supported - aborted tensor creation'); }), (ts = (t, e) => { let { width: o, height: i, download: u, dispose: n } = e, s = [1, i, o, 4]; return new Ye({ location: 'texture', type: 'float32', texture: t, dims: s, download: u, dispose: n }); }), (rs = (t, e) => { let { dataType: o, dims: i, download: u, dispose: n } = e; return new Ye({ location: 'gpu-buffer', type: o ?? 'float32', gpuBuffer: t, dims: i, download: u, dispose: n, }); }), (ns = (t, e, o) => new Ye({ location: 'cpu-pinned', type: t, data: e, dims: o ?? [e.length] })); }), Qr, Cn, is, as, ss = L(() => { (Qr = new Map([ ['float32', Float32Array], ['uint8', Uint8Array], ['int8', Int8Array], ['uint16', Uint16Array], ['float16', Uint16Array], ['int16', Int16Array], ['int32', Int32Array], ['bool', Uint8Array], ['float64', Float64Array], ['uint32', Uint32Array], ])), (Cn = new Map([ [Float32Array, 'float32'], [Uint8Array, 'uint8'], [Int8Array, 'int8'], [Uint16Array, 'uint16'], [Int16Array, 'int16'], [Int32Array, 'int32'], [Float64Array, 'float64'], [Uint32Array, 'uint32'], ])), (is = !1), (as = () => { if (!is) { is = !0; let t = typeof BigInt64Array < 'u' && typeof BigInt64Array.from == 'function', e = typeof BigUint64Array < 'u' && typeof BigUint64Array.from == 'function'; t && (Qr.set('int64', BigInt64Array), Cn.set(BigInt64Array, 'int64')), e && (Qr.set('uint64', BigUint64Array), Cn.set(BigUint64Array, 'uint64')); } }); }), us, ls, fs = L(() => { $n(), (us = (t) => { let e = 1; for (let o = 0; o < t.length; o++) { let i = t[o]; if (typeof i != 'number' || !Number.isSafeInteger(i)) throw new TypeError(`dims[${o}] must be an integer, got: ${i}`); if (i < 0) throw new RangeError(`dims[${o}] must be a non-negative integer, got: ${i}`); e *= i; } return e; }), (ls = (t, e) => { switch (t.location) { case 'cpu': return new Ye(t.type, t.data, e); case 'cpu-pinned': return new Ye({ location: 'cpu-pinned', data: t.data, type: t.type, dims: e }); case 'texture': return new Ye({ location: 'texture', texture: t.texture, type: t.type, dims: e }); case 'gpu-buffer': return new Ye({ location: 'gpu-buffer', gpuBuffer: t.gpuBuffer, type: t.type, dims: e }); default: throw new Error(`tensorReshape: tensor location ${t.location} is not supported`); } }); }), Ye, $n = L(() => { Qa(), os(), ss(), fs(), (Ye = class { constructor(t, e, o) { as(); let i, u; if (typeof t == 'object' && 'location' in t) switch (((this.dataLocation = t.location), (i = t.type), (u = t.dims), t.location)) { case 'cpu-pinned': { let s = Qr.get(i); if (!s) throw new TypeError(`unsupported type "${i}" to create tensor from pinned buffer`); if (!(t.data instanceof s)) throw new TypeError(`buffer should be of type ${s.name}`); this.cpuData = t.data; break; } case 'texture': { if (i !== 'float32') throw new TypeError(`unsupported type "${i}" to create tensor from texture`); (this.gpuTextureData = t.texture), (this.downloader = t.download), (this.disposer = t.dispose); break; } case 'gpu-buffer': { if ( i !== 'float32' && i !== 'float16' && i !== 'int32' && i !== 'int64' && i !== 'uint32' && i !== 'bool' ) throw new TypeError(`unsupported type "${i}" to create tensor from gpu buffer`); (this.gpuBufferData = t.gpuBuffer), (this.downloader = t.download), (this.disposer = t.dispose); break; } default: throw new Error(`Tensor constructor: unsupported location '${this.dataLocation}'`); } else { let s, d; if (typeof t == 'string') if (((i = t), (d = o), t === 'string')) { if (!Array.isArray(e)) throw new TypeError("A string tensor's data must be a string array."); s = e; } else { let f = Qr.get(t); if (f === void 0) throw new TypeError(`Unsupported tensor type: ${t}.`); if (Array.isArray(e)) { if (t === 'float16') throw new TypeError( 'Creating a float16 tensor from number array is not supported. Please use Uint16Array as data.' ); t === 'uint64' || t === 'int64' ? (s = f.from(e, BigInt)) : (s = f.from(e)); } else if (e instanceof f) s = e; else throw new TypeError(`A ${i} tensor's data must be type of ${f}`); } else if (((d = e), Array.isArray(t))) { if (t.length === 0) throw new TypeError('Tensor type cannot be inferred from an empty array.'); let f = typeof t[0]; if (f === 'string') (i = 'string'), (s = t); else if (f === 'boolean') (i = 'bool'), (s = Uint8Array.from(t)); else throw new TypeError(`Invalid element type of data array: ${f}.`); } else { let f = Cn.get(t.constructor); if (f === void 0) throw new TypeError(`Unsupported type for tensor data: ${t.constructor}.`); (i = f), (s = t); } if (d === void 0) d = [s.length]; else if (!Array.isArray(d)) throw new TypeError("A tensor's dims must be a number array"); (u = d), (this.cpuData = s), (this.dataLocation = 'cpu'); } let n = us(u); if (this.cpuData && n !== this.cpuData.length) throw new Error(`Tensor's size(${n}) does not match data length(${this.cpuData.length}).`); (this.type = i), (this.dims = u), (this.size = n); } static async fromImage(t, e) { return es(t, e); } static fromTexture(t, e) { return ts(t, e); } static fromGpuBuffer(t, e) { return rs(t, e); } static fromPinnedBuffer(t, e, o) { return ns(t, e, o); } toDataURL(t) { return Ja(this, t); } toImageData(t) { return Za(this, t); } get data() { if ((this.ensureValid(), !this.cpuData)) throw new Error( 'The data is not on CPU. Use `getData()` to download GPU data to CPU, or use `texture` or `gpuBuffer` property to access the GPU data directly.' ); return this.cpuData; } get location() { return this.dataLocation; } get texture() { if ((this.ensureValid(), !this.gpuTextureData)) throw new Error('The data is not stored as a WebGL texture.'); return this.gpuTextureData; } get gpuBuffer() { if ((this.ensureValid(), !this.gpuBufferData)) throw new Error('The data is not stored as a WebGPU buffer.'); return this.gpuBufferData; } async getData(t) { switch ((this.ensureValid(), this.dataLocation)) { case 'cpu': case 'cpu-pinned': return this.data; case 'texture': case 'gpu-buffer': { if (!this.downloader) throw new Error('The current tensor is not created with a specified data downloader.'); if (this.isDownloading) throw new Error('The current tensor is being downloaded.'); try { this.isDownloading = !0; let e = await this.downloader(); return ( (this.downloader = void 0), (this.dataLocation = 'cpu'), (this.cpuData = e), t && this.disposer && (this.disposer(), (this.disposer = void 0)), e ); } finally { this.isDownloading = !1; } } default: throw new Error(`cannot get data from location: ${this.dataLocation}`); } } dispose() { if (this.isDownloading) throw new Error('The current tensor is being downloaded.'); this.disposer && (this.disposer(), (this.disposer = void 0)), (this.cpuData = void 0), (this.gpuTextureData = void 0), (this.gpuBufferData = void 0), (this.downloader = void 0), (this.isDownloading = void 0), (this.dataLocation = 'none'); } ensureValid() { if (this.dataLocation === 'none') throw new Error('The tensor is disposed.'); } reshape(t) { if ((this.ensureValid(), this.downloader || this.disposer)) throw new Error('Cannot reshape a tensor that owns GPU resource.'); return ls(this, t); } }); }), Re, kn = L(() => { $n(), (Re = Ye); }), cs, ps, ar, sr, jo = L(() => { Ho(), (cs = (t, e) => { ir.wasm.trace && console.timeStamp(`${t}::ORT::${e}`); }), (ps = (t, e) => { let o = new Error().stack?.split(/\r\n|\r|\n/g) || [], i = !1; for (let u = 0; u < o.length; u++) { if (i && !o[u].includes('TRACE_FUNC')) { let n = `FUNC_${t}::${o[u].trim().split(' ')[1]}`; e && (n += `::${e}`), cs('CPU', n); return; } o[u].includes('TRACE_FUNC') && (i = !0); } }), (ar = (t) => { ir.wasm.trace && ps('BEGIN', t); }), (sr = (t) => { ir.wasm.trace && ps('END', t); }); }), Bn, ds = L(() => { Fn(), kn(), jo(), (Bn = class Rs { constructor(e) { this.handler = e; } async run(e, o, i) { ar(); let u = {}, n = {}; if (typeof e != 'object' || e === null || e instanceof Re || Array.isArray(e)) throw new TypeError( "'feeds' must be an object that use input names as keys and OnnxValue as corresponding values." ); let s = !0; if (typeof o == 'object') { if (o === null) throw new TypeError('Unexpected argument[1]: cannot be null.'); if (o instanceof Re) throw new TypeError("'fetches' cannot be a Tensor"); if (Array.isArray(o)) { if (o.length === 0) throw new TypeError("'fetches' cannot be an empty array."); s = !1; for (let r of o) { if (typeof r != 'string') throw new TypeError("'fetches' must be a string array or an object."); if (this.outputNames.indexOf(r) === -1) throw new RangeError(`'fetches' contains invalid output name: ${r}.`); u[r] = null; } if (typeof i == 'object' && i !== null) n = i; else if (typeof i < 'u') throw new TypeError("'options' must be an object."); } else { let r = !1, a = Object.getOwnPropertyNames(o); for (let l of this.outputNames) if (a.indexOf(l) !== -1) { let p = o[l]; (p === null || p instanceof Re) && ((r = !0), (s = !1), (u[l] = p)); } if (r) { if (typeof i == 'object' && i !== null) n = i; else if (typeof i < 'u') throw new TypeError("'options' must be an object."); } else n = o; } } else if (typeof o < 'u') throw new TypeError("Unexpected argument[1]: must be 'fetches' or 'options'."); for (let r of this.inputNames) if (typeof e[r] > 'u') throw new Error(`input '${r}' is missing in 'feeds'.`); if (s) for (let r of this.outputNames) u[r] = null; let d = await this.handler.run(e, u, n), f = {}; for (let r in d) if (Object.hasOwnProperty.call(d, r)) { let a = d[r]; a instanceof Re ? (f[r] = a) : (f[r] = new Re(a.type, a.data, a.dims)); } return sr(), f; } async release() { return this.handler.dispose(); } static async create(e, o, i, u) { ar(); let n, s = {}; if (typeof e == 'string') { if (((n = e), typeof o == 'object' && o !== null)) s = o; else if (typeof o < 'u') throw new TypeError("'options' must be an object."); } else if (e instanceof Uint8Array) { if (((n = e), typeof o == 'object' && o !== null)) s = o; else if (typeof o < 'u') throw new TypeError("'options' must be an object."); } else if ( e instanceof ArrayBuffer || (typeof SharedArrayBuffer < 'u' && e instanceof SharedArrayBuffer) ) { let r = e, a = 0, l = e.byteLength; if (typeof o == 'object' && o !== null) s = o; else if (typeof o == 'number') { if (((a = o), !Number.isSafeInteger(a))) throw new RangeError("'byteOffset' must be an integer."); if (a < 0 || a >= r.byteLength) throw new RangeError(`'byteOffset' is out of range [0, ${r.byteLength}).`); if (((l = e.byteLength - a), typeof i == 'number')) { if (((l = i), !Number.isSafeInteger(l))) throw new RangeError("'byteLength' must be an integer."); if (l <= 0 || a + l > r.byteLength) throw new RangeError(`'byteLength' is out of range (0, ${r.byteLength - a}].`); if (typeof u == 'object' && u !== null) s = u; else if (typeof u < 'u') throw new TypeError("'options' must be an object."); } else if (typeof i < 'u') throw new TypeError("'byteLength' must be a number."); } else if (typeof o < 'u') throw new TypeError("'options' must be an object."); n = new Uint8Array(r, a, l); } else throw new TypeError("Unexpected argument[0]: must be 'path' or 'buffer'."); let d = (s.executionProviders || []).map((r) => (typeof r == 'string' ? r : r.name)), f = await (await Ln(d)).createInferenceSessionHandler(n, s); return sr(), new Rs(f); } startProfiling() { this.handler.startProfiling(); } endProfiling() { this.handler.endProfiling(); } get inputNames() { return this.handler.inputNames; } get outputNames() { return this.handler.outputNames; } }); }), Sd, hs = L(() => { ds(), (Sd = Bn); }), ms = L(() => {}), Ad, Nn, bs = L(() => { Fn(), kn(), (Ad = "Training backend could not be resolved. Make sure you're using the correct configuration & WebAssembly files."), (Nn = class Bs { constructor(e, o, i) { (this.handler = e), (this.hasOptimizerModel = o), (this.hasEvalModel = i); } get trainingInputNames() { return this.handler.inputNames; } get trainingOutputNames() { return this.handler.outputNames; } get evalInputNames() { if (this.hasEvalModel) return this.handler.evalInputNames; throw new Error('This training session has no evalModel loaded.'); } get evalOutputNames() { if (this.hasEvalModel) return this.handler.evalOutputNames; throw new Error('This training session has no evalModel loaded.'); } static async create(e, o) { let i = e.evalModel || '', u = e.optimizerModel || '', n = o || {}, s = (n.executionProviders || []).map((f) => (typeof f == 'string' ? f : f.name)), d = await Ln(s); if (d.createTrainingSessionHandler) { let f = await d.createTrainingSessionHandler(e.checkpointState, e.trainModel, i, u, n); return new Bs(f, !!e.optimizerModel, !!e.evalModel); } else throw new Error(Ad); } typeNarrowingForRunStep(e, o, i, u, n) { let s = {}, d = {}; if (typeof i != 'object' || i === null || i instanceof Re || Array.isArray(i)) throw new TypeError( "'feeds' must be an object that use input names as keys and OnnxValue as corresponding values." ); let f = !0; if (typeof u == 'object') { if (u === null) throw new TypeError('Unexpected argument[1]: cannot be null.'); if (u instanceof Re) throw new TypeError("'fetches' cannot be a Tensor"); if (Array.isArray(u)) { if (u.length === 0) throw new TypeError("'fetches' cannot be an empty array."); f = !1; for (let r of u) { if (typeof r != 'string') throw new TypeError("'fetches' must be a string array or an object."); if (o.indexOf(r) === -1) throw new RangeError(`'fetches' contains invalid output name: ${r}.`); s[r] = null; } if (typeof n == 'object' && n !== null) d = n; else if (typeof n < 'u') throw new TypeError("'options' must be an object."); } else { let r = !1, a = Object.getOwnPropertyNames(u); for (let l of o) if (a.indexOf(l) !== -1) { let p = u[l]; (p === null || p instanceof Re) && ((r = !0), (f = !1), (s[l] = p)); } if (r) { if (typeof n == 'object' && n !== null) d = n; else if (typeof n < 'u') throw new TypeError("'options' must be an object."); } else d = u; } } else if (typeof u < 'u') throw new TypeError("Unexpected argument[1]: must be 'fetches' or 'options'."); for (let r of e) if (typeof i[r] > 'u') throw new Error(`input '${r}' is missing in 'feeds'.`); if (f) for (let r of o) s[r] = null; return [s, d]; } convertHandlerReturnTypeToMapOfTensors(e) { let o = {}; for (let i in e) if (Object.hasOwnProperty.call(e, i)) { let u = e[i]; u instanceof Re ? (o[i] = u) : (o[i] = new Re(u.type, u.data, u.dims)); } return o; } async lazyResetGrad() { await this.handler.lazyResetGrad(); } async runTrainStep(e, o, i) { let [u, n] = this.typeNarrowingForRunStep( this.trainingInputNames, this.trainingOutputNames, e, o, i ), s = await this.handler.runTrainStep(e, u, n); return this.convertHandlerReturnTypeToMapOfTensors(s); } async runOptimizerStep(e) { if (this.hasOptimizerModel) await this.handler.runOptimizerStep(e || {}); else throw new Error('This TrainingSession has no OptimizerModel loaded.'); } async runEvalStep(e, o, i) { if (this.hasEvalModel) { let [u, n] = this.typeNarrowingForRunStep(this.evalInputNames, this.evalOutputNames, e, o, i), s = await this.handler.runEvalStep(e, u, n); return this.convertHandlerReturnTypeToMapOfTensors(s); } else throw new Error('This TrainingSession has no EvalModel loaded.'); } async getParametersSize(e = !0) { return this.handler.getParametersSize(e); } async loadParametersBuffer(e, o = !0) { let i = await this.getParametersSize(o); if (e.length !== 4 * i) throw new Error( 'Size of the buffer passed into loadParametersBuffer must match the number of parameters in the model. Please use getParametersSize method to check.' ); return this.handler.loadParametersBuffer(e, o); } async getContiguousParameters(e = !0) { return this.handler.getContiguousParameters(e); } async release() { return this.handler.dispose(); } }); }), Pd, gs = L(() => { bs(), (Pd = Nn); }), Yo = {}; Pr(Yo, { InferenceSession: () => Sd, TRACE: () => cs, TRACE_FUNC_BEGIN: () => ar, TRACE_FUNC_END: () => sr, Tensor: () => Re, TrainingSession: () => Pd, env: () => Z, registerBackend: () => or, }); var vt = L(() => { qa(), Ka(), hs(), kn(), jo(), ms(), gs(); }); function jt(t, e, o, i) { if (e === void 0) return Dd(t); if (o === void 0) Rn(t, e); else if (typeof o == 'number' && i === void 0) Rn(t, e); else if (typeof o == 'string' && i === void 0) Rn(t, o, 1, e); else if (typeof o == 'string' && typeof i == 'number') Rn(t, o, i, e); else throw new TypeError('input is valid'); } function Dd(t) { return { verbose: jt.verbose.bind(null, t), info: jt.info.bind(null, t), warning: jt.warning.bind(null, t), error: jt.error.bind(null, t), fatal: jt.fatal.bind(null, t), }; } function Rn(t, e, o, i) { let u = en[i || ''] || en['']; Ts[t] < Ts[u.minimalSeverity] || (u.logDateTime && (e = `${new Date().toISOString()}|${e}`), u.logSourceLocation, Ed[u.provider].log(t, e, i)); } var Xo, Ko, Ts, Ed, xs, en, ce, Gn, Un, zn, Mn, ut = L(() => { (Xo = class { log(t, e, o) {} }), (Ko = class { log(t, e, o) { console.log(`${this.color(t)} ${o ? '\x1B[35m' + o + '\x1B[0m ' : ''}${e}`); } color(t) { switch (t) { case 'verbose': return '\x1B[34;40mv\x1B[0m'; case 'info': return '\x1B[32mi\x1B[0m'; case 'warning': return '\x1B[30;43mw\x1B[0m'; case 'error': return '\x1B[31;40me\x1B[0m'; case 'fatal': return '\x1B[101mf\x1B[0m'; default: throw new Error(`unsupported severity: ${t}`); } } }), (Ts = { verbose: 1e3, info: 2e3, warning: 4e3, error: 5e3, fatal: 6e3 }), (Ed = { none: new Xo(), console: new Ko() }), (xs = { provider: 'console', minimalSeverity: 'warning', logDateTime: !0, logSourceLocation: !1 }), (en = { '': xs }), ((t) => { function e(r, a) { t('verbose', r, a); } t.verbose = e; function o(r, a) { t('info', r, a); } t.info = o; function i(r, a) { t('warning', r, a); } t.warning = i; function u(r, a) { t('error', r, a); } t.error = u; function n(r, a) { t('fatal', r, a); } t.fatal = n; function s(r) { (en = {}), d('', r || {}); } t.reset = s; function d(r, a) { if (r === '*') s(a); else { let l = en[r] || xs; en[r] = { provider: a.provider || l.provider, minimalSeverity: a.minimalSeverity || l.minimalSeverity, logDateTime: a.logDateTime === void 0 ? l.logDateTime : a.logDateTime, logSourceLocation: a.logSourceLocation === void 0 ? l.logSourceLocation : a.logSourceLocation, }; } } t.set = d; function f(r) { let a = {}; r.logLevel && (a.minimalSeverity = r.logLevel), d('', a); } t.setWithEnv = f; })((jt ||= {})), (ce = jt), (Gn = class { constructor(t, e, o, i, u, n) { (this.category = t), (this.name = e), (this.startTime = o), (this.endCallback = i), (this.timer = u), (this.ctx = n); } async end() { return this.endCallback(this); } async checkTimer() { if (this.ctx === void 0 || this.timer === void 0) throw new Error('No webgl timer found'); return this.ctx.endTimer(), this.ctx.waitForQueryAndGetTime(this.timer); } }), (Un = class { constructor(t, e, o, i) { (this.category = t), (this.name = e), (this.startTime = o), (this.endTime = i); } }), (zn = class { constructor(t, e, o) { (this._started = !1), (this._flushPointer = 0), (this._started = !1), (this._maxNumberEvents = t === void 0 ? 1e4 : t), (this._flushBatchSize = e === void 0 ? 10 : e), (this._flushIntervalInMilliseconds = o === void 0 ? 5e3 : o); } static create(t) { return t === void 0 ? new this() : new this(t.maxNumberEvents, t.flushBatchSize, t.flushIntervalInMilliseconds); } start() { (this._started = !0), (this._timingEvents = []), (this._flushTime = Mn()), (this._flushPointer = 0); } stop() { for (this._started = !1; this._flushPointer < this._timingEvents.length; this._flushPointer++) this.logOneEvent(this._timingEvents[this._flushPointer]); } event(t, e, o, i) { let u = this._started ? this.begin(t, e, i) : void 0, n = !1, s = o(); if (s && typeof s.then == 'function') return ( (n = !0), new Promise((d, f) => { s.then( async (r) => { u && (await u.end()), d(r); }, async (r) => { u && (await u.end()), f(r); } ); }) ); if (!n && u) { let d = u.end(); if (d && typeof d.then == 'function') return new Promise((f, r) => { d.then( () => { f(s); }, (a) => { r(a); } ); }); } return s; } begin(t, e, o) { if (!this._started) throw new Error('profiler is not started yet'); if (o === void 0) { let i = Mn(); return this.flush(i), new Gn(t, e, i, (u) => this.endSync(u)); } else { let i = o.beginTimer(); return new Gn(t, e, 0, async (u) => this.end(u), i, o); } } async end(t) { let e = await t.checkTimer(); this._timingEvents.length < this._maxNumberEvents && (this._timingEvents.push(new Un(t.category, t.name, t.startTime, e)), this.flush(e)); } endSync(t) { let e = Mn(); this._timingEvents.length < this._maxNumberEvents && (this._timingEvents.push(new Un(t.category, t.name, t.startTime, e)), this.flush(e)); } logOneEvent(t) { ce.verbose( `Profiler.${t.category}`, `${(t.endTime - t.startTime).toFixed(2)}ms on event '${t.name}' at ${t.endTime.toFixed(2)}` ); } flush(t) { if ( this._timingEvents.length - this._flushPointer >= this._flushBatchSize || t - this._flushTime >= this._flushIntervalInMilliseconds ) { for ( let e = this._flushPointer; this._flushPointer < e + this._flushBatchSize && this._flushPointer < this._timingEvents.length; this._flushPointer++ ) this.logOneEvent(this._timingEvents[this._flushPointer]); this._flushTime = Mn(); } } get started() { return this._started; } }), (Mn = typeof performance < 'u' && performance.now ? () => performance.now() : Date.now); }); function vs(t, e, o) { for (let i of o) { let u = i[0], n = i[1], s = i[2], d = i[3], f = i[4]; if (t.opType === u) { for (let r of e) if ((r.domain === n || (r.domain === 'ai.onnx' && n === '')) && Ld(r.version, s)) return { opImpl: d, opInit: f }; } } throw new TypeError( `cannot resolve operator '${t.opType}' with opsets: ${e .map((i) => `${i.domain || 'ai.onnx'} v${i.version}`) .join(', ')}` ); } function Ld(t, e) { if (e.endsWith('+')) { let o = Number.parseInt(e.substring(0, e.length - 1), 10); return !isNaN(o) && o <= t; } else if (e.split('-').length === 2) { let o = e.split('-'), i = Number.parseInt(o[0], 10), u = Number.parseInt(o[1], 10); return !isNaN(i) && !isNaN(u) && i <= t && t <= u; } else return Number.parseInt(e, 10) === t; } var ws = L(() => {}), _s = me((t) => { t.__esModule = !0; var e = (function () { function o(i) { if (!i) throw new TypeError('Invalid argument; `value` has no value.'); (this.value = o.EMPTY), i && o.isGuid(i) && (this.value = i); } return ( (o.isGuid = function (i) { var u = i.toString(); return i && (i instanceof o || o.validator.test(u)); }), (o.create = function () { return new o([o.gen(2), o.gen(1), o.gen(1), o.gen(1), o.gen(3)].join('-')); }), (o.createEmpty = function () { return new o('emptyguid'); }), (o.parse = function (i) { return new o(i); }), (o.raw = function () { return [o.gen(2), o.gen(1), o.gen(1), o.gen(1), o.gen(3)].join('-'); }), (o.gen = function (i) { for (var u = '', n = 0; n < i; n++) u += (((1 + Math.random()) * 65536) | 0).toString(16).substring(1); return u; }), (o.prototype.equals = function (i) { return o.isGuid(i) && this.value === i.toString(); }), (o.prototype.isEmpty = function () { return this.value === o.EMPTY; }), (o.prototype.toString = function () { return this.value; }), (o.prototype.toJSON = function () { return { value: this.value }; }), (o.validator = new RegExp('^[a-z0-9]{8}-[a-z0-9]{4}-[a-z0-9]{4}-[a-z0-9]{4}-[a-z0-9]{12}$', 'i')), (o.EMPTY = '00000000-0000-0000-0000-000000000000'), o ); })(); t.Guid = e; }); function be(t, e, o) { (this.low = t | 0), (this.high = e | 0), (this.unsigned = !!o); } function We(t) { return (t && t.__isLong__) === !0; } function Os(t) { var e = Math.clz32(t & -t); return t ? 31 - e : e; } function ur(t, e) { var o, i, u; return e ? ((t >>>= 0), (u = 0 <= t && t < 256) && ((i = Ss[t]), i) ? i : ((o = le(t, 0, !0)), u && (Ss[t] = o), o)) : ((t |= 0), (u = -128 <= t && t < 128) && ((i = Is[t]), i) ? i : ((o = le(t, t < 0 ? -1 : 0, !1)), u && (Is[t] = o), o)); } function ft(t, e) { if (isNaN(t)) return e ? Ut : wt; if (e) { if (t < 0) return Ut; if (t >= Ds) return $s; } else { if (t <= -Ps) return tt; if (t + 1 >= Ps) return Fs; } return t < 0 ? ft(-t, e).neg() : le(t % Lr | 0, (t / Lr) | 0, e); } function le(t, e, o) { return new be(t, e, o); } function Qo(t, e, o) { if (t.length === 0) throw Error('empty string'); if ( (typeof e == 'number' ? ((o = e), (e = !1)) : (e = !!e), t === 'NaN' || t === 'Infinity' || t === '+Infinity' || t === '-Infinity') ) return e ? Ut : wt; if (((o = o || 10), o < 2 || 36 < o)) throw RangeError('radix'); var i; if ((i = t.indexOf('-')) > 0) throw Error('interior hyphen'); if (i === 0) return Qo(t.substring(1), e, o).neg(); for (var u = ft(Vn(o, 8)), n = wt, s = 0; s < t.length; s += 8) { var d = Math.min(8, t.length - s), f = parseInt(t.substring(s, s + d), o); if (d < 8) { var r = ft(Vn(o, d)); n = n.mul(r).add(ft(f)); } else (n = n.mul(u)), (n = n.add(ft(f))); } return (n.unsigned = e), n; } function _t(t, e) { return typeof t == 'number' ? ft(t, e) : typeof t == 'string' ? Qo(t, e) : le(t.low, t.high, typeof e == 'boolean' ? e : t.unsigned); } var lt, Is, Ss, Vn, As, $d, Lr, Ds, Ps, Es, wt, Ut, Dr, Ls, Zo, Fs, $s, tt, $, zt, ei = L(() => { lt = null; try { lt = new WebAssembly.Instance( new WebAssembly.Module( new Uint8Array([ 0, 97, 115, 109, 1, 0, 0, 0, 1, 13, 2, 96, 0, 1, 127, 96, 4, 127, 127, 127, 127, 1, 127, 3, 7, 6, 0, 1, 1, 1, 1, 1, 6, 6, 1, 127, 1, 65, 0, 11, 7, 50, 6, 3, 109, 117, 108, 0, 1, 5, 100, 105, 118, 95, 115, 0, 2, 5, 100, 105, 118, 95, 117, 0, 3, 5, 114, 101, 109, 95, 115, 0, 4, 5, 114, 101, 109, 95, 117, 0, 5, 8, 103, 101, 116, 95, 104, 105, 103, 104, 0, 0, 10, 191, 1, 6, 4, 0, 35, 0, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 126, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 127, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 128, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 129, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 130, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11, ]) ), {} ).exports; } catch {} be.prototype.__isLong__, Object.defineProperty(be.prototype, '__isLong__', { value: !0 }), (be.isLong = We), (Is = {}), (Ss = {}), (be.fromInt = ur), (be.fromNumber = ft), (be.fromBits = le), (Vn = Math.pow), (be.fromString = Qo), (be.fromValue = _t), (As = 65536), ($d = 1 << 24), (Lr = As * As), (Ds = Lr * Lr), (Ps = Ds / 2), (Es = ur($d)), (wt = ur(0)), (be.ZERO = wt), (Ut = ur(0, !0)), (be.UZERO = Ut), (Dr = ur(1)), (be.ONE = Dr), (Ls = ur(1, !0)), (be.UONE = Ls), (Zo = ur(-1)), (be.NEG_ONE = Zo), (Fs = le(-1, 2147483647, !1)), (be.MAX_VALUE = Fs), ($s = le(-1, -1, !0)), (be.MAX_UNSIGNED_VALUE = $s), (tt = le(0, -2147483648, !1)), (be.MIN_VALUE = tt), ($ = be.prototype), ($.toInt = function () { return this.unsigned ? this.low >>> 0 : this.low; }), ($.toNumber = function () { return this.unsigned ? (this.high >>> 0) * Lr + (this.low >>> 0) : this.high * Lr + (this.low >>> 0); }), ($.toString = function (t) { if (((t = t || 10), t < 2 || 36 < t)) throw RangeError('radix'); if (this.isZero()) return '0'; if (this.isNegative()) if (this.eq(tt)) { var e = ft(t), o = this.div(e), i = o.mul(e).sub(this); return o.toString(t) + i.toInt().toString(t); } else return '-' + this.neg().toString(t); for (var u = ft(Vn(t, 6), this.unsigned), n = this, s = ''; ; ) { var d = n.div(u), f = n.sub(d.mul(u)).toInt() >>> 0, r = f.toString(t); if (((n = d), n.isZero())) return r + s; for (; r.length < 6; ) r = '0' + r; s = '' + r + s; } }), ($.getHighBits = function () { return this.high; }), ($.getHighBitsUnsigned = function () { return this.high >>> 0; }), ($.getLowBits = function () { return this.low; }), ($.getLowBitsUnsigned = function () { return this.low >>> 0; }), ($.getNumBitsAbs = function () { if (this.isNegative()) return this.eq(tt) ? 64 : this.neg().getNumBitsAbs(); for (var t = this.high != 0 ? this.high : this.low, e = 31; e > 0 && !(t & (1 << e)); e--); return this.high != 0 ? e + 33 : e + 1; }), ($.isZero = function () { return this.high === 0 && this.low === 0; }), ($.eqz = $.isZero), ($.isNegative = function () { return !this.unsigned && this.high < 0; }), ($.isPositive = function () { return this.unsigned || this.high >= 0; }), ($.isOdd = function () { return (this.low & 1) === 1; }), ($.isEven = function () { return (this.low & 1) === 0; }), ($.equals = function (t) { return ( We(t) || (t = _t(t)), this.unsigned !== t.unsigned && this.high >>> 31 === 1 && t.high >>> 31 === 1 ? !1 : this.high === t.high && this.low === t.low ); }), ($.eq = $.equals), ($.notEquals = function (t) { return !this.eq(t); }), ($.neq = $.notEquals), ($.ne = $.notEquals), ($.lessThan = function (t) { return this.comp(t) < 0; }), ($.lt = $.lessThan), ($.lessThanOrEqual = function (t) { return this.comp(t) <= 0; }), ($.lte = $.lessThanOrEqual), ($.le = $.lessThanOrEqual), ($.greaterThan = function (t) { return this.comp(t) > 0; }), ($.gt = $.greaterThan), ($.greaterThanOrEqual = function (t) { return this.comp(t) >= 0; }), ($.gte = $.greaterThanOrEqual), ($.ge = $.greaterThanOrEqual), ($.compare = function (t) { if ((We(t) || (t = _t(t)), this.eq(t))) return 0; var e = this.isNegative(), o = t.isNegative(); return e && !o ? -1 : !e && o ? 1 : this.unsigned ? t.high >>> 0 > this.high >>> 0 || (t.high === this.high && t.low >>> 0 > this.low >>> 0) ? -1 : 1 : this.sub(t).isNegative() ? -1 : 1; }), ($.comp = $.compare), ($.negate = function () { return !this.unsigned && this.eq(tt) ? tt : this.not().add(Dr); }), ($.neg = $.negate), ($.add = function (t) { We(t) || (t = _t(t)); var e = this.high >>> 16, o = this.high & 65535, i = this.low >>> 16, u = this.low & 65535, n = t.high >>> 16, s = t.high & 65535, d = t.low >>> 16, f = t.low & 65535, r = 0, a = 0, l = 0, p = 0; return ( (p += u + f), (l += p >>> 16), (p &= 65535), (l += i + d), (a += l >>> 16), (l &= 65535), (a += o + s), (r += a >>> 16), (a &= 65535), (r += e + n), (r &= 65535), le((l << 16) | p, (r << 16) | a, this.unsigned) ); }), ($.subtract = function (t) { return We(t) || (t = _t(t)), this.add(t.neg()); }), ($.sub = $.subtract), ($.multiply = function (t) { if (this.isZero()) return this; if ((We(t) || (t = _t(t)), lt)) { var e = lt.mul(this.low, this.high, t.low, t.high); return le(e, lt.get_high(), this.unsigned); } if (t.isZero()) return this.unsigned ? Ut : wt; if (this.eq(tt)) return t.isOdd() ? tt : wt; if (t.eq(tt)) return this.isOdd() ? tt : wt; if (this.isNegative()) return t.isNegative() ? this.neg().mul(t.neg()) : this.neg().mul(t).neg(); if (t.isNegative()) return this.mul(t.neg()).neg(); if (this.lt(Es) && t.lt(Es)) return ft(this.toNumber() * t.toNumber(), this.unsigned); var o = this.high >>> 16, i = this.high & 65535, u = this.low >>> 16, n = this.low & 65535, s = t.high >>> 16, d = t.high & 65535, f = t.low >>> 16, r = t.low & 65535, a = 0, l = 0, p = 0, m = 0; return ( (m += n * r), (p += m >>> 16), (m &= 65535), (p += u * r), (l += p >>> 16), (p &= 65535), (p += n * f), (l += p >>> 16), (p &= 65535), (l += i * r), (a += l >>> 16), (l &= 65535), (l += u * f), (a += l >>> 16), (l &= 65535), (l += n * d), (a += l >>> 16), (l &= 65535), (a += o * r + i * f + u * d + n * s), (a &= 65535), le((p << 16) | m, (a << 16) | l, this.unsigned) ); }), ($.mul = $.multiply), ($.divide = function (t) { if ((We(t) || (t = _t(t)), t.isZero())) throw Error('division by zero'); if (lt) { if (!this.unsigned && this.high === -2147483648 && t.low === -1 && t.high === -1) return this; var e = (this.unsigned ? lt.div_u : lt.div_s)(this.low, this.high, t.low, t.high); return le(e, lt.get_high(), this.unsigned); } if (this.isZero()) return this.unsigned ? Ut : wt; var o, i, u; if (this.unsigned) { if ((t.unsigned || (t = t.toUnsigned()), t.gt(this))) return Ut; if (t.gt(this.shru(1))) return Ls; u = Ut; } else { if (this.eq(tt)) { if (t.eq(Dr) || t.eq(Zo)) return tt; if (t.eq(tt)) return Dr; var n = this.shr(1); return ( (o = n.div(t).shl(1)), o.eq(wt) ? (t.isNegative() ? Dr : Zo) : ((i = this.sub(t.mul(o))), (u = o.add(i.div(t))), u) ); } else if (t.eq(tt)) return this.unsigned ? Ut : wt; if (this.isNegative()) return t.isNegative() ? this.neg().div(t.neg()) : this.neg().div(t).neg(); if (t.isNegative()) return this.div(t.neg()).neg(); u = wt; } for (i = this; i.gte(t); ) { o = Math.max(1, Math.floor(i.toNumber() / t.toNumber())); for ( var s = Math.ceil(Math.log(o) / Math.LN2), d = s <= 48 ? 1 : Vn(2, s - 48), f = ft(o), r = f.mul(t); r.isNegative() || r.gt(i); ) (o -= d), (f = ft(o, this.unsigned)), (r = f.mul(t)); f.isZero() && (f = Dr), (u = u.add(f)), (i = i.sub(r)); } return u; }), ($.div = $.divide), ($.modulo = function (t) { if ((We(t) || (t = _t(t)), lt)) { var e = (this.unsigned ? lt.rem_u : lt.rem_s)(this.low, this.high, t.low, t.high); return le(e, lt.get_high(), this.unsigned); } return this.sub(this.div(t).mul(t)); }), ($.mod = $.modulo), ($.rem = $.modulo), ($.not = function () { return le(~this.low, ~this.high, this.unsigned); }), ($.countLeadingZeros = function () { return this.high ? Math.clz32(this.high) : Math.clz32(this.low) + 32; }), ($.clz = $.countLeadingZeros), ($.countTrailingZeros = function () { return this.low ? Os(this.low) : Os(this.high) + 32; }), ($.ctz = $.countTrailingZeros), ($.and = function (t) { return We(t) || (t = _t(t)), le(this.low & t.low, this.high & t.high, this.unsigned); }), ($.or = function (t) { return We(t) || (t = _t(t)), le(this.low | t.low, this.high | t.high, this.unsigned); }), ($.xor = function (t) { return We(t) || (t = _t(t)), le(this.low ^ t.low, this.high ^ t.high, this.unsigned); }), ($.shiftLeft = function (t) { return ( We(t) && (t = t.toInt()), (t &= 63) === 0 ? this : t < 32 ? le(this.low << t, (this.high << t) | (this.low >>> (32 - t)), this.unsigned) : le(0, this.low << (t - 32), this.unsigned) ); }), ($.shl = $.shiftLeft), ($.shiftRight = function (t) { return ( We(t) && (t = t.toInt()), (t &= 63) === 0 ? this : t < 32 ? le((this.low >>> t) | (this.high << (32 - t)), this.high >> t, this.unsigned) : le(this.high >> (t - 32), this.high >= 0 ? 0 : -1, this.unsigned) ); }), ($.shr = $.shiftRight), ($.shiftRightUnsigned = function (t) { return ( We(t) && (t = t.toInt()), (t &= 63) === 0 ? this : t < 32 ? le((this.low >>> t) | (this.high << (32 - t)), this.high >>> t, this.unsigned) : t === 32 ? le(this.high, 0, this.unsigned) : le(this.high >>> (t - 32), 0, this.unsigned) ); }), ($.shru = $.shiftRightUnsigned), ($.shr_u = $.shiftRightUnsigned), ($.rotateLeft = function (t) { var e; return ( We(t) && (t = t.toInt()), (t &= 63) === 0 ? this : t === 32 ? le(this.high, this.low, this.unsigned) : t < 32 ? ((e = 32 - t), le((this.low << t) | (this.high >>> e), (this.high << t) | (this.low >>> e), this.unsigned)) : ((t -= 32), (e = 32 - t), le((this.high << t) | (this.low >>> e), (this.low << t) | (this.high >>> e), this.unsigned)) ); }), ($.rotl = $.rotateLeft), ($.rotateRight = function (t) { var e; return ( We(t) && (t = t.toInt()), (t &= 63) === 0 ? this : t === 32 ? le(this.high, this.low, this.unsigned) : t < 32 ? ((e = 32 - t), le((this.high << e) | (this.low >>> t), (this.low << e) | (this.high >>> t), this.unsigned)) : ((t -= 32), (e = 32 - t), le((this.low << e) | (this.high >>> t), (this.high << e) | (this.low >>> t), this.unsigned)) ); }), ($.rotr = $.rotateRight), ($.toSigned = function () { return this.unsigned ? le(this.low, this.high, !1) : this; }), ($.toUnsigned = function () { return this.unsigned ? this : le(this.low, this.high, !0); }), ($.toBytes = function (t) { return t ? this.toBytesLE() : this.toBytesBE(); }), ($.toBytesLE = function () { var t = this.high, e = this.low; return [ e & 255, (e >>> 8) & 255, (e >>> 16) & 255, e >>> 24, t & 255, (t >>> 8) & 255, (t >>> 16) & 255, t >>> 24, ]; }), ($.toBytesBE = function () { var t = this.high, e = this.low; return [ t >>> 24, (t >>> 16) & 255, (t >>> 8) & 255, t & 255, e >>> 24, (e >>> 16) & 255, (e >>> 8) & 255, e & 255, ]; }), (be.fromBytes = function (t, e, o) { return o ? be.fromBytesLE(t, e) : be.fromBytesBE(t, e); }), (be.fromBytesLE = function (t, e) { return new be( t[0] | (t[1] << 8) | (t[2] << 16) | (t[3] << 24), t[4] | (t[5] << 8) | (t[6] << 16) | (t[7] << 24), e ); }), (be.fromBytesBE = function (t, e) { return new be( (t[4] << 24) | (t[5] << 16) | (t[6] << 8) | t[7], (t[0] << 24) | (t[1] << 16) | (t[2] << 8) | t[3], e ); }), (zt = be); }), _, Wn = L(() => { (_ = {}), _.Offset, _.Table, (_.SIZEOF_SHORT = 2), (_.SIZEOF_INT = 4), (_.FILE_IDENTIFIER_LENGTH = 4), (_.SIZE_PREFIX_LENGTH = 4), (_.Encoding = { UTF8_BYTES: 1, UTF16_STRING: 2 }), (_.int32 = new Int32Array(2)), (_.float32 = new Float32Array(_.int32.buffer)), (_.float64 = new Float64Array(_.int32.buffer)), (_.isLittleEndian = new Uint16Array(new Uint8Array([1, 0]).buffer)[0] === 1), (_.Long = function (t, e) { (this.low = t | 0), (this.high = e | 0); }), (_.Long.create = function (t, e) { return t == 0 && e == 0 ? _.Long.ZERO : new _.Long(t, e); }), (_.Long.prototype.toFloat64 = function () { return (this.low >>> 0) + this.high * 4294967296; }), (_.Long.prototype.equals = function (t) { return this.low == t.low && this.high == t.high; }), (_.Long.ZERO = new _.Long(0, 0)), (_.Builder = function (t) { if (t) var e = t; else var e = 1024; (this.bb = _.ByteBuffer.allocate(e)), (this.space = e), (this.minalign = 1), (this.vtable = null), (this.vtable_in_use = 0), (this.isNested = !1), (this.object_start = 0), (this.vtables = []), (this.vector_num_elems = 0), (this.force_defaults = !1); }), (_.Builder.prototype.clear = function () { this.bb.clear(), (this.space = this.bb.capacity()), (this.minalign = 1), (this.vtable = null), (this.vtable_in_use = 0), (this.isNested = !1), (this.object_start = 0), (this.vtables = []), (this.vector_num_elems = 0), (this.force_defaults = !1); }), (_.Builder.prototype.forceDefaults = function (t) { this.force_defaults = t; }), (_.Builder.prototype.dataBuffer = function () { return this.bb; }), (_.Builder.prototype.asUint8Array = function () { return this.bb.bytes().subarray(this.bb.position(), this.bb.position() + this.offset()); }), (_.Builder.prototype.prep = function (t, e) { t > this.minalign && (this.minalign = t); for (var o = (~(this.bb.capacity() - this.space + e) + 1) & (t - 1); this.space < o + t + e; ) { var i = this.bb.capacity(); (this.bb = _.Builder.growByteBuffer(this.bb)), (this.space += this.bb.capacity() - i); } this.pad(o); }), (_.Builder.prototype.pad = function (t) { for (var e = 0; e < t; e++) this.bb.writeInt8(--this.space, 0); }), (_.Builder.prototype.writeInt8 = function (t) { this.bb.writeInt8((this.space -= 1), t); }), (_.Builder.prototype.writeInt16 = function (t) { this.bb.writeInt16((this.space -= 2), t); }), (_.Builder.prototype.writeInt32 = function (t) { this.bb.writeInt32((this.space -= 4), t); }), (_.Builder.prototype.writeInt64 = function (t) { this.bb.writeInt64((this.space -= 8), t); }), (_.Builder.prototype.writeFloat32 = function (t) { this.bb.writeFloat32((this.space -= 4), t); }), (_.Builder.prototype.writeFloat64 = function (t) { this.bb.writeFloat64((this.space -= 8), t); }), (_.Builder.prototype.addInt8 = function (t) { this.prep(1, 0), this.writeInt8(t); }), (_.Builder.prototype.addInt16 = function (t) { this.prep(2, 0), this.writeInt16(t); }), (_.Builder.prototype.addInt32 = function (t) { this.prep(4, 0), this.writeInt32(t); }), (_.Builder.prototype.addInt64 = function (t) { this.prep(8, 0), this.writeInt64(t); }), (_.Builder.prototype.addFloat32 = function (t) { this.prep(4, 0), this.writeFloat32(t); }), (_.Builder.prototype.addFloat64 = function (t) { this.prep(8, 0), this.writeFloat64(t); }), (_.Builder.prototype.addFieldInt8 = function (t, e, o) { (this.force_defaults || e != o) && (this.addInt8(e), this.slot(t)); }), (_.Builder.prototype.addFieldInt16 = function (t, e, o) { (this.force_defaults || e != o) && (this.addInt16(e), this.slot(t)); }), (_.Builder.prototype.addFieldInt32 = function (t, e, o) { (this.force_defaults || e != o) && (this.addInt32(e), this.slot(t)); }), (_.Builder.prototype.addFieldInt64 = function (t, e, o) { (this.force_defaults || !e.equals(o)) && (this.addInt64(e), this.slot(t)); }), (_.Builder.prototype.addFieldFloat32 = function (t, e, o) { (this.force_defaults || e != o) && (this.addFloat32(e), this.slot(t)); }), (_.Builder.prototype.addFieldFloat64 = function (t, e, o) { (this.force_defaults || e != o) && (this.addFloat64(e), this.slot(t)); }), (_.Builder.prototype.addFieldOffset = function (t, e, o) { (this.force_defaults || e != o) && (this.addOffset(e), this.slot(t)); }), (_.Builder.prototype.addFieldStruct = function (t, e, o) { e != o && (this.nested(e), this.slot(t)); }), (_.Builder.prototype.nested = function (t) { if (t != this.offset()) throw new Error('FlatBuffers: struct must be serialized inline.'); }), (_.Builder.prototype.notNested = function () { if (this.isNested) throw new Error('FlatBuffers: object serialization must not be nested.'); }), (_.Builder.prototype.slot = function (t) { this.vtable[t] = this.offset(); }), (_.Builder.prototype.offset = function () { return this.bb.capacity() - this.space; }), (_.Builder.growByteBuffer = function (t) { var e = t.capacity(); if (e & 3221225472) throw new Error('FlatBuffers: cannot grow buffer beyond 2 gigabytes.'); var o = e << 1, i = _.ByteBuffer.allocate(o); return i.setPosition(o - e), i.bytes().set(t.bytes(), o - e), i; }), (_.Builder.prototype.addOffset = function (t) { this.prep(_.SIZEOF_INT, 0), this.writeInt32(this.offset() - t + _.SIZEOF_INT); }), (_.Builder.prototype.startObject = function (t) { this.notNested(), this.vtable == null && (this.vtable = []), (this.vtable_in_use = t); for (var e = 0; e < t; e++) this.vtable[e] = 0; (this.isNested = !0), (this.object_start = this.offset()); }), (_.Builder.prototype.endObject = function () { if (this.vtable == null || !this.isNested) throw new Error('FlatBuffers: endObject called without startObject'); this.addInt32(0); for (var t = this.offset(), e = this.vtable_in_use - 1; e >= 0 && this.vtable[e] == 0; e--); for (var o = e + 1; e >= 0; e--) this.addInt16(this.vtable[e] != 0 ? t - this.vtable[e] : 0); var i = 2; this.addInt16(t - this.object_start); var u = (o + i) * _.SIZEOF_SHORT; this.addInt16(u); var n = 0, s = this.space; e: for (e = 0; e < this.vtables.length; e++) { var d = this.bb.capacity() - this.vtables[e]; if (u == this.bb.readInt16(d)) { for (var f = _.SIZEOF_SHORT; f < u; f += _.SIZEOF_SHORT) if (this.bb.readInt16(s + f) != this.bb.readInt16(d + f)) continue e; n = this.vtables[e]; break; } } return ( n ? ((this.space = this.bb.capacity() - t), this.bb.writeInt32(this.space, n - t)) : (this.vtables.push(this.offset()), this.bb.writeInt32(this.bb.capacity() - t, this.offset() - t)), (this.isNested = !1), t ); }), (_.Builder.prototype.finish = function (t, e, o) { var i = o ? _.SIZE_PREFIX_LENGTH : 0; if (e) { var u = e; if ( (this.prep(this.minalign, _.SIZEOF_INT + _.FILE_IDENTIFIER_LENGTH + i), u.length != _.FILE_IDENTIFIER_LENGTH) ) throw new Error('FlatBuffers: file identifier must be length ' + _.FILE_IDENTIFIER_LENGTH); for (var n = _.FILE_IDENTIFIER_LENGTH - 1; n >= 0; n--) this.writeInt8(u.charCodeAt(n)); } this.prep(this.minalign, _.SIZEOF_INT + i), this.addOffset(t), i && this.addInt32(this.bb.capacity() - this.space), this.bb.setPosition(this.space); }), (_.Builder.prototype.finishSizePrefixed = function (t, e) { this.finish(t, e, !0); }), (_.Builder.prototype.requiredField = function (t, e) { var o = this.bb.capacity() - t, i = o - this.bb.readInt32(o), u = this.bb.readInt16(i + e) != 0; if (!u) throw new Error('FlatBuffers: field ' + e + ' must be set'); }), (_.Builder.prototype.startVector = function (t, e, o) { this.notNested(), (this.vector_num_elems = e), this.prep(_.SIZEOF_INT, t * e), this.prep(o, t * e); }), (_.Builder.prototype.endVector = function () { return this.writeInt32(this.vector_num_elems), this.offset(); }), (_.Builder.prototype.createString = function (t) { if (t instanceof Uint8Array) var e = t; else for (var e = [], o = 0; o < t.length; ) { var i, u = t.charCodeAt(o++); if (u < 55296 || u >= 56320) i = u; else { var n = t.charCodeAt(o++); i = (u << 10) + n + -56613888; } i < 128 ? e.push(i) : (i < 2048 ? e.push(((i >> 6) & 31) | 192) : (i < 65536 ? e.push(((i >> 12) & 15) | 224) : e.push(((i >> 18) & 7) | 240, ((i >> 12) & 63) | 128), e.push(((i >> 6) & 63) | 128)), e.push((i & 63) | 128)); } this.addInt8(0), this.startVector(1, e.length, 1), this.bb.setPosition((this.space -= e.length)); for (var o = 0, s = this.space, d = this.bb.bytes(); o < e.length; o++) d[s++] = e[o]; return this.endVector(); }), (_.Builder.prototype.createLong = function (t, e) { return _.Long.create(t, e); }), (_.ByteBuffer = function (t) { (this.bytes_ = t), (this.position_ = 0); }), (_.ByteBuffer.allocate = function (t) { return new _.ByteBuffer(new Uint8Array(t)); }), (_.ByteBuffer.prototype.clear = function () { this.position_ = 0; }), (_.ByteBuffer.prototype.bytes = function () { return this.bytes_; }), (_.ByteBuffer.prototype.position = function () { return this.position_; }), (_.ByteBuffer.prototype.setPosition = function (t) { this.position_ = t; }), (_.ByteBuffer.prototype.capacity = function () { return this.bytes_.length; }), (_.ByteBuffer.prototype.readInt8 = function (t) { return (this.readUint8(t) << 24) >> 24; }), (_.ByteBuffer.prototype.readUint8 = function (t) { return this.bytes_[t]; }), (_.ByteBuffer.prototype.readInt16 = function (t) { return (this.readUint16(t) << 16) >> 16; }), (_.ByteBuffer.prototype.readUint16 = function (t) { return this.bytes_[t] | (this.bytes_[t + 1] << 8); }), (_.ByteBuffer.prototype.readInt32 = function (t) { return ( this.bytes_[t] | (this.bytes_[t + 1] << 8) | (this.bytes_[t + 2] << 16) | (this.bytes_[t + 3] << 24) ); }), (_.ByteBuffer.prototype.readUint32 = function (t) { return this.readInt32(t) >>> 0; }), (_.ByteBuffer.prototype.readInt64 = function (t) { return new _.Long(this.readInt32(t), this.readInt32(t + 4)); }), (_.ByteBuffer.prototype.readUint64 = function (t) { return new _.Long(this.readUint32(t), this.readUint32(t + 4)); }), (_.ByteBuffer.prototype.readFloat32 = function (t) { return (_.int32[0] = this.readInt32(t)), _.float32[0]; }), (_.ByteBuffer.prototype.readFloat64 = function (t) { return ( (_.int32[_.isLittleEndian ? 0 : 1] = this.readInt32(t)), (_.int32[_.isLittleEndian ? 1 : 0] = this.readInt32(t + 4)), _.float64[0] ); }), (_.ByteBuffer.prototype.writeInt8 = function (t, e) { this.bytes_[t] = e; }), (_.ByteBuffer.prototype.writeUint8 = function (t, e) { this.bytes_[t] = e; }), (_.ByteBuffer.prototype.writeInt16 = function (t, e) { (this.bytes_[t] = e), (this.bytes_[t + 1] = e >> 8); }), (_.ByteBuffer.prototype.writeUint16 = function (t, e) { (this.bytes_[t] = e), (this.bytes_[t + 1] = e >> 8); }), (_.ByteBuffer.prototype.writeInt32 = function (t, e) { (this.bytes_[t] = e), (this.bytes_[t + 1] = e >> 8), (this.bytes_[t + 2] = e >> 16), (this.bytes_[t + 3] = e >> 24); }), (_.ByteBuffer.prototype.writeUint32 = function (t, e) { (this.bytes_[t] = e), (this.bytes_[t + 1] = e >> 8), (this.bytes_[t + 2] = e >> 16), (this.bytes_[t + 3] = e >> 24); }), (_.ByteBuffer.prototype.writeInt64 = function (t, e) { this.writeInt32(t, e.low), this.writeInt32(t + 4, e.high); }), (_.ByteBuffer.prototype.writeUint64 = function (t, e) { this.writeUint32(t, e.low), this.writeUint32(t + 4, e.high); }), (_.ByteBuffer.prototype.writeFloat32 = function (t, e) { (_.float32[0] = e), this.writeInt32(t, _.int32[0]); }), (_.ByteBuffer.prototype.writeFloat64 = function (t, e) { (_.float64[0] = e), this.writeInt32(t, _.int32[_.isLittleEndian ? 0 : 1]), this.writeInt32(t + 4, _.int32[_.isLittleEndian ? 1 : 0]); }), (_.ByteBuffer.prototype.getBufferIdentifier = function () { if (this.bytes_.length < this.position_ + _.SIZEOF_INT + _.FILE_IDENTIFIER_LENGTH) throw new Error('FlatBuffers: ByteBuffer is too short to contain an identifier.'); for (var t = '', e = 0; e < _.FILE_IDENTIFIER_LENGTH; e++) t += String.fromCharCode(this.readInt8(this.position_ + _.SIZEOF_INT + e)); return t; }), (_.ByteBuffer.prototype.__offset = function (t, e) { var o = t - this.readInt32(t); return e < this.readInt16(o) ? this.readInt16(o + e) : 0; }), (_.ByteBuffer.prototype.__union = function (t, e) { return (t.bb_pos = e + this.readInt32(e)), (t.bb = this), t; }), (_.ByteBuffer.prototype.__string = function (t, e) { t += this.readInt32(t); var o = this.readInt32(t), i = '', u = 0; if (((t += _.SIZEOF_INT), e === _.Encoding.UTF8_BYTES)) return this.bytes_.subarray(t, t + o); for (; u < o; ) { var n, s = this.readUint8(t + u++); if (s < 192) n = s; else { var d = this.readUint8(t + u++); if (s < 224) n = ((s & 31) << 6) | (d & 63); else { var f = this.readUint8(t + u++); if (s < 240) n = ((s & 15) << 12) | ((d & 63) << 6) | (f & 63); else { var r = this.readUint8(t + u++); n = ((s & 7) << 18) | ((d & 63) << 12) | ((f & 63) << 6) | (r & 63); } } } n < 65536 ? (i += String.fromCharCode(n)) : ((n -= 65536), (i += String.fromCharCode((n >> 10) + 55296, (n & 1023) + 56320))); } return i; }), (_.ByteBuffer.prototype.__indirect = function (t) { return t + this.readInt32(t); }), (_.ByteBuffer.prototype.__vector = function (t) { return t + this.readInt32(t) + _.SIZEOF_INT; }), (_.ByteBuffer.prototype.__vector_len = function (t) { return this.readInt32(t + this.readInt32(t)); }), (_.ByteBuffer.prototype.__has_identifier = function (t) { if (t.length != _.FILE_IDENTIFIER_LENGTH) throw new Error('FlatBuffers: file identifier must be length ' + _.FILE_IDENTIFIER_LENGTH); for (var e = 0; e < _.FILE_IDENTIFIER_LENGTH; e++) if (t.charCodeAt(e) != this.readInt8(this.position_ + _.SIZEOF_INT + e)) return !1; return !0; }), (_.ByteBuffer.prototype.createLong = function (t, e) { return _.Long.create(t, e); }); }), W, tn = L(() => { Wn(), ((t) => { ((e) => { ((o) => { ((i) => ( (i[(i.UNDEFINED = 0)] = 'UNDEFINED'), (i[(i.FLOAT = 1)] = 'FLOAT'), (i[(i.INT = 2)] = 'INT'), (i[(i.STRING = 3)] = 'STRING'), (i[(i.TENSOR = 4)] = 'TENSOR'), (i[(i.GRAPH = 5)] = 'GRAPH'), (i[(i.FLOATS = 6)] = 'FLOATS'), (i[(i.INTS = 7)] = 'INTS'), (i[(i.STRINGS = 8)] = 'STRINGS'), (i[(i.TENSORS = 9)] = 'TENSORS'), (i[(i.GRAPHS = 10)] = 'GRAPHS'), (i[(i.SPARSE_TENSOR = 11)] = 'SPARSE_TENSOR'), (i[(i.SPARSE_TENSORS = 12)] = 'SPARSE_TENSORS') ))((o.AttributeType ||= {})); })((e.fbs ||= {})); })((t.experimental ||= {})); })((W ||= {})), ((t) => { ((e) => { ((o) => { ((i) => ( (i[(i.UNKNOWN = 0)] = 'UNKNOWN'), (i[(i.VALUE = 1)] = 'VALUE'), (i[(i.PARAM = 2)] = 'PARAM') ))((o.DimensionValueType ||= {})); })((e.fbs ||= {})); })((t.experimental ||= {})); })((W ||= {})), ((t) => { ((e) => { ((o) => { ((i) => ( (i[(i.UNDEFINED = 0)] = 'UNDEFINED'), (i[(i.FLOAT = 1)] = 'FLOAT'), (i[(i.UINT8 = 2)] = 'UINT8'), (i[(i.INT8 = 3)] = 'INT8'), (i[(i.UINT16 = 4)] = 'UINT16'), (i[(i.INT16 = 5)] = 'INT16'), (i[(i.INT32 = 6)] = 'INT32'), (i[(i.INT64 = 7)] = 'INT64'), (i[(i.STRING = 8)] = 'STRING'), (i[(i.BOOL = 9)] = 'BOOL'), (i[(i.FLOAT16 = 10)] = 'FLOAT16'), (i[(i.DOUBLE = 11)] = 'DOUBLE'), (i[(i.UINT32 = 12)] = 'UINT32'), (i[(i.UINT64 = 13)] = 'UINT64'), (i[(i.COMPLEX64 = 14)] = 'COMPLEX64'), (i[(i.COMPLEX128 = 15)] = 'COMPLEX128'), (i[(i.BFLOAT16 = 16)] = 'BFLOAT16'), (i[(i.FLOAT8E4M3FN = 17)] = 'FLOAT8E4M3FN'), (i[(i.FLOAT8E4M3FNUZ = 18)] = 'FLOAT8E4M3FNUZ'), (i[(i.FLOAT8E5M2 = 19)] = 'FLOAT8E5M2'), (i[(i.FLOAT8E5M2FNUZ = 20)] = 'FLOAT8E5M2FNUZ') ))((o.TensorDataType ||= {})); })((e.fbs ||= {})); })((t.experimental ||= {})); })((W ||= {})), ((t) => { ((e) => { ((o) => { ((i) => ((i[(i.Primitive = 0)] = 'Primitive'), (i[(i.Fused = 1)] = 'Fused')))( (o.NodeType ||= {}) ); })((e.fbs ||= {})); })((t.experimental ||= {})); })((W ||= {})), ((t) => { ((e) => { ((o) => { ((i) => ( (i[(i.NONE = 0)] = 'NONE'), (i[(i.tensor_type = 1)] = 'tensor_type'), (i[(i.sequence_type = 2)] = 'sequence_type'), (i[(i.map_type = 3)] = 'map_type') ))((o.TypeInfoValue ||= {})); })((e.fbs ||= {})); })((t.experimental ||= {})); })((W ||= {})), ((t) => { ((e) => { ((o) => { class i { constructor() { (this.bb = null), (this.bb_pos = 0); } __init(n, s) { return (this.bb_pos = n), (this.bb = s), this; } static getRootAsShape(n, s) { return (s || new i()).__init(n.readInt32(n.position()) + n.position(), n); } static getSizePrefixedRootAsShape(n, s) { return ( n.setPosition(n.position() + _.SIZE_PREFIX_LENGTH), (s || new i()).__init(n.readInt32(n.position()) + n.position(), n) ); } dim(n, s) { let d = this.bb.__offset(this.bb_pos, 4); return d ? (s || new t.experimental.fbs.Dimension()).__init( this.bb.__indirect(this.bb.__vector(this.bb_pos + d) + n * 4), this.bb ) : null; } dimLength() { let n = this.bb.__offset(this.bb_pos, 4); return n ? this.bb.__vector_len(this.bb_pos + n) : 0; } static startShape(n) { n.startObject(1); } static addDim(n, s) { n.addFieldOffset(0, s, 0); } static createDimVector(n, s) { n.startVector(4, s.length, 4); for (let d = s.length - 1; d >= 0; d--) n.addOffset(s[d]); return n.endVector(); } static startDimVector(n, s) { n.startVector(4, s, 4); } static endShape(n) { return n.endObject(); } static createShape(n, s) { return i.startShape(n), i.addDim(n, s), i.endShape(n); } } o.Shape = i; })((e.fbs ||= {})); })((t.experimental ||= {})); })((W ||= {})), ((t) => { ((e) => { ((o) => { class i { constructor() { (this.bb = null), (this.bb_pos = 0); } __init(n, s) { return (this.bb_pos = n), (this.bb = s), this; } static getRootAsDimension(n, s) { return (s || new i()).__init(n.readInt32(n.position()) + n.position(), n); } static getSizePrefixedRootAsDimension(n, s) { return ( n.setPosition(n.position() + _.SIZE_PREFIX_LENGTH), (s || new i()).__init(n.readInt32(n.position()) + n.position(), n) ); } value(n) { let s = this.bb.__offset(this.bb_pos, 4); return s ? (n || new t.experimental.fbs.DimensionValue()).__init( this.bb.__indirect(this.bb_pos + s), this.bb ) : null; } denotation(n) { let s = this.bb.__offset(this.bb_pos, 6); return s ? this.bb.__string(this.bb_pos + s, n) : null; } static startDimension(n) { n.startObject(2); } static addValue(n, s) { n.addFieldOffset(0, s, 0); } static addDenotation(n, s) { n.addFieldOffset(1, s, 0); } static endDimension(n) { return n.endObject(); } static createDimension(n, s, d) { return i.startDimension(n), i.addValue(n, s), i.addDenotation(n, d), i.endDimension(n); } } o.Dimension = i; })((e.fbs ||= {})); })((t.experimental ||= {})); })((W ||= {})), ((t) => { ((e) => { ((o) => { class i { constructor() { (this.bb = null), (this.bb_pos = 0); } __init(n, s) { return (this.bb_pos = n), (this.bb = s), this; } static getRootAsDimensionValue(n, s) { return (s || new i()).__init(n.readInt32(n.position()) + n.position(), n); } static getSizePrefixedRootAsDimensionValue(n, s) { return ( n.setPosition(n.position() + _.SIZE_PREFIX_LENGTH), (s || new i()).__init(n.readInt32(n.position()) + n.position(), n) ); } dimType() { let n = this.bb.__offset(this.bb_pos, 4); return n ? this.bb.readInt8(this.bb_pos + n) : 0; } dimValue() { let n = this.bb.__offset(this.bb_pos, 6); return n ? this.bb.readInt64(this.bb_pos + n) : this.bb.createLong(0, 0); } dimParam(n) { let s = this.bb.__offset(this.bb_pos, 8); return s ? this.bb.__string(this.bb_pos + s, n) : null; } static startDimensionValue(n) { n.startObject(3); } static addDimType(n, s) { n.addFieldInt8(0, s, 0); } static addDimValue(n, s) { n.addFieldInt64(1, s, n.createLong(0, 0)); } static addDimParam(n, s) { n.addFieldOffset(2, s, 0); } static endDimensionValue(n) { return n.endObject(); } static createDimensionValue(n, s, d, f) { return ( i.startDimensionValue(n), i.addDimType(n, s), i.addDimValue(n, d), i.addDimParam(n, f), i.endDimensionValue(n) ); } } o.DimensionValue = i; })((e.fbs ||= {})); })((t.experimental ||= {})); })((W ||= {})), ((t) => { ((e) => { ((o) => { class i { constructor() { (this.bb = null), (this.bb_pos = 0); } __init(n, s) { return (this.bb_pos = n), (this.bb = s), this; } static getRootAsTensorTypeAndShape(n, s) { return (s || new i()).__init(n.readInt32(n.position()) + n.position(), n); } static getSizePrefixedRootAsTensorTypeAndShape(n, s) { return ( n.setPosition(n.position() + _.SIZE_PREFIX_LENGTH), (s || new i()).__init(n.readInt32(n.position()) + n.position(), n) ); } elemType() { let n = this.bb.__offset(this.bb_pos, 4); return n ? this.bb.readInt32(this.bb_pos + n) : 0; } shape(n) { let s = this.bb.__offset(this.bb_pos, 6); return s ? (n || new t.experimental.fbs.Shape()).__init( this.bb.__indirect(this.bb_pos + s), this.bb ) : null; } static startTensorTypeAndShape(n) { n.startObject(2); } static addElemType(n, s) { n.addFieldInt32(0, s, 0); } static addShape(n, s) { n.addFieldOffset(1, s, 0); } static endTensorTypeAndShape(n) { return n.endObject(); } static createTensorTypeAndShape(n, s, d) { return ( i.startTensorTypeAndShape(n), i.addElemType(n, s), i.addShape(n, d), i.endTensorTypeAndShape(n) ); } } o.TensorTypeAndShape = i; })((e.fbs ||= {})); })((t.experimental ||= {})); })((W ||= {})), ((t) => { ((e) => { ((o) => { class i { constructor() { (this.bb = null), (this.bb_pos = 0); } __init(n, s) { return (this.bb_pos = n), (this.bb = s), this; } static getRootAsMapType(n, s) { return (s || new i()).__init(n.readInt32(n.position()) + n.position(), n); } static getSizePrefixedRootAsMapType(n, s) { return ( n.setPosition(n.position() + _.SIZE_PREFIX_LENGTH), (s || new i()).__init(n.readInt32(n.position()) + n.position(), n) ); } keyType() { let n = this.bb.__offset(this.bb_pos, 4); return n ? this.bb.readInt32(this.bb_pos + n) : 0; } valueType(n) { let s = this.bb.__offset(this.bb_pos, 6); return s ? (n || new t.experimental.fbs.TypeInfo()).__init( this.bb.__indirect(this.bb_pos + s), this.bb ) : null; } static startMapType(n) { n.startObject(2); } static addKeyType(n, s) { n.addFieldInt32(0, s, 0); } static addValueType(n, s) { n.addFieldOffset(1, s, 0); } static endMapType(n) { return n.endObject(); } static createMapType(n, s, d) { return i.startMapType(n), i.addKeyType(n, s), i.addValueType(n, d), i.endMapType(n); } } o.MapType = i; })((e.fbs ||= {})); })((t.experimental ||= {})); })((W ||= {})), ((t) => { ((e) => { ((o) => { class i { constructor() { (this.bb = null), (this.bb_pos = 0); } __init(n, s) { return (this.bb_pos = n), (this.bb = s), this; } static getRootAsSequenceType(n, s) { return (s || new i()).__init(n.readInt32(n.position()) + n.position(), n); } static getSizePrefixedRootAsSequenceType(n, s) { return ( n.setPosition(n.position() + _.SIZE_PREFIX_LENGTH), (s || new i()).__init(n.readInt32(n.position()) + n.position(), n) ); } elemType(n) { let s = this.bb.__offset(this.bb_pos, 4); return s ? (n || new t.experimental.fbs.TypeInfo()).__init( this.bb.__indirect(this.bb_pos + s), this.bb ) : null; } static startSequenceType(n) { n.startObject(1); } static addElemType(n, s) { n.addFieldOffset(0, s, 0); } static endSequenceType(n) { return n.endObject(); } static createSequenceType(n, s) { return i.startSequenceType(n), i.addElemType(n, s), i.endSequenceType(n); } } o.SequenceType = i; })((e.fbs ||= {})); })((t.experimental ||= {})); })((W ||= {})), ((t) => { ((e) => { ((o) => { class i { constructor() { (this.bb = null), (this.bb_pos = 0); } __init(n, s) { return (this.bb_pos = n), (this.bb = s), this; } nodeIndex() { return this.bb.readUint32(this.bb_pos); } srcArgIndex() { return this.bb.readInt32(this.bb_pos + 4); } dstArgIndex() { return this.bb.readInt32(this.bb_pos + 8); } static createEdgeEnd(n, s, d, f) { return n.prep(4, 12), n.writeInt32(f), n.writeInt32(d), n.writeInt32(s), n.offset(); } } o.EdgeEnd = i; })((e.fbs ||= {})); })((t.experimental ||= {})); })((W ||= {})), ((t) => { ((e) => { ((o) => { class i { constructor() { (this.bb = null), (this.bb_pos = 0); } __init(n, s) { return (this.bb_pos = n), (this.bb = s), this; } static getRootAsNodeEdge(n, s) { return (s || new i()).__init(n.readInt32(n.position()) + n.position(), n); } static getSizePrefixedRootAsNodeEdge(n, s) { return ( n.setPosition(n.position() + _.SIZE_PREFIX_LENGTH), (s || new i()).__init(n.readInt32(n.position()) + n.position(), n) ); } nodeIndex() { let n = this.bb.__offset(this.bb_pos, 4); return n ? this.bb.readUint32(this.bb_pos + n) : 0; } inputEdges(n, s) { let d = this.bb.__offset(this.bb_pos, 6); return d ? (s || new t.experimental.fbs.EdgeEnd()).__init( this.bb.__vector(this.bb_pos + d) + n * 12, this.bb ) : null; } inputEdgesLength() { let n = this.bb.__offset(this.bb_pos, 6); return n ? this.bb.__vector_len(this.bb_pos + n) : 0; } outputEdges(n, s) { let d = this.bb.__offset(this.bb_pos, 8); return d ? (s || new t.experimental.fbs.EdgeEnd()).__init( this.bb.__vector(this.bb_pos + d) + n * 12, this.bb ) : null; } outputEdgesLength() { let n = this.bb.__offset(this.bb_pos, 8); return n ? this.bb.__vector_len(this.bb_pos + n) : 0; } static startNodeEdge(n) { n.startObject(3); } static addNodeIndex(n, s) { n.addFieldInt32(0, s, 0); } static addInputEdges(n, s) { n.addFieldOffset(1, s, 0); } static startInputEdgesVector(n, s) { n.startVector(12, s, 4); } static addOutputEdges(n, s) { n.addFieldOffset(2, s, 0); } static startOutputEdgesVector(n, s) { n.startVector(12, s, 4); } static endNodeEdge(n) { return n.endObject(); } static createNodeEdge(n, s, d, f) { return ( i.startNodeEdge(n), i.addNodeIndex(n, s), i.addInputEdges(n, d), i.addOutputEdges(n, f), i.endNodeEdge(n) ); } } o.NodeEdge = i; })((e.fbs ||= {})); })((t.experimental ||= {})); })((W ||= {})), ((t) => { ((e) => { ((o) => { class i { constructor() { (this.bb = null), (this.bb_pos = 0); } __init(n, s) { return (this.bb_pos = n), (this.bb = s), this; } static getRootAsNode(n, s) { return (s || new i()).__init(n.readInt32(n.position()) + n.position(), n); } static getSizePrefixedRootAsNode(n, s) { return ( n.setPosition(n.position() + _.SIZE_PREFIX_LENGTH), (s || new i()).__init(n.readInt32(n.position()) + n.position(), n) ); } name(n) { let s = this.bb.__offset(this.bb_pos, 4); return s ? this.bb.__string(this.bb_pos + s, n) : null; } docString(n) { let s = this.bb.__offset(this.bb_pos, 6); return s ? this.bb.__string(this.bb_pos + s, n) : null; } domain(n) { let s = this.bb.__offset(this.bb_pos, 8); return s ? this.bb.__string(this.bb_pos + s, n) : null; } sinceVersion() { let n = this.bb.__offset(this.bb_pos, 10); return n ? this.bb.readInt32(this.bb_pos + n) : 0; } index() { let n = this.bb.__offset(this.bb_pos, 12); return n ? this.bb.readUint32(this.bb_pos + n) : 0; } opType(n) { let s = this.bb.__offset(this.bb_pos, 14); return s ? this.bb.__string(this.bb_pos + s, n) : null; } type() { let n = this.bb.__offset(this.bb_pos, 16); return n ? this.bb.readInt32(this.bb_pos + n) : 0; } executionProviderType(n) { let s = this.bb.__offset(this.bb_pos, 18); return s ? this.bb.__string(this.bb_pos + s, n) : null; } inputs(n, s) { let d = this.bb.__offset(this.bb_pos, 20); return d ? this.bb.__string(this.bb.__vector(this.bb_pos + d) + n * 4, s) : null; } inputsLength() { let n = this.bb.__offset(this.bb_pos, 20); return n ? this.bb.__vector_len(this.bb_pos + n) : 0; } outputs(n, s) { let d = this.bb.__offset(this.bb_pos, 22); return d ? this.bb.__string(this.bb.__vector(this.bb_pos + d) + n * 4, s) : null; } outputsLength() { let n = this.bb.__offset(this.bb_pos, 22); return n ? this.bb.__vector_len(this.bb_pos + n) : 0; } attributes(n, s) { let d = this.bb.__offset(this.bb_pos, 24); return d ? (s || new t.experimental.fbs.Attribute()).__init( this.bb.__indirect(this.bb.__vector(this.bb_pos + d) + n * 4), this.bb ) : null; } attributesLength() { let n = this.bb.__offset(this.bb_pos, 24); return n ? this.bb.__vector_len(this.bb_pos + n) : 0; } inputArgCounts(n) { let s = this.bb.__offset(this.bb_pos, 26); return s ? this.bb.readInt32(this.bb.__vector(this.bb_pos + s) + n * 4) : 0; } inputArgCountsLength() { let n = this.bb.__offset(this.bb_pos, 26); return n ? this.bb.__vector_len(this.bb_pos + n) : 0; } inputArgCountsArray() { let n = this.bb.__offset(this.bb_pos, 26); return n ? new Int32Array( this.bb.bytes().buffer, this.bb.bytes().byteOffset + this.bb.__vector(this.bb_pos + n), this.bb.__vector_len(this.bb_pos + n) ) : null; } implicitInputs(n, s) { let d = this.bb.__offset(this.bb_pos, 28); return d ? this.bb.__string(this.bb.__vector(this.bb_pos + d) + n * 4, s) : null; } implicitInputsLength() { let n = this.bb.__offset(this.bb_pos, 28); return n ? this.bb.__vector_len(this.bb_pos + n) : 0; } static startNode(n) { n.startObject(13); } static addName(n, s) { n.addFieldOffset(0, s, 0); } static addDocString(n, s) { n.addFieldOffset(1, s, 0); } static addDomain(n, s) { n.addFieldOffset(2, s, 0); } static addSinceVersion(n, s) { n.addFieldInt32(3, s, 0); } static addIndex(n, s) { n.addFieldInt32(4, s, 0); } static addOpType(n, s) { n.addFieldOffset(5, s, 0); } static addType(n, s) { n.addFieldInt32(6, s, 0); } static addExecutionProviderType(n, s) { n.addFieldOffset(7, s, 0); } static addInputs(n, s) { n.addFieldOffset(8, s, 0); } static createInputsVector(n, s) { n.startVector(4, s.length, 4); for (let d = s.length - 1; d >= 0; d--) n.addOffset(s[d]); return n.endVector(); } static startInputsVector(n, s) { n.startVector(4, s, 4); } static addOutputs(n, s) { n.addFieldOffset(9, s, 0); } static createOutputsVector(n, s) { n.startVector(4, s.length, 4); for (let d = s.length - 1; d >= 0; d--) n.addOffset(s[d]); return n.endVector(); } static startOutputsVector(n, s) { n.startVector(4, s, 4); } static addAttributes(n, s) { n.addFieldOffset(10, s, 0); } static createAttributesVector(n, s) { n.startVector(4, s.length, 4); for (let d = s.length - 1; d >= 0; d--) n.addOffset(s[d]); return n.endVector(); } static startAttributesVector(n, s) { n.startVector(4, s, 4); } static addInputArgCounts(n, s) { n.addFieldOffset(11, s, 0); } static createInputArgCountsVector(n, s) { n.startVector(4, s.length, 4); for (let d = s.length - 1; d >= 0; d--) n.addInt32(s[d]); return n.endVector(); } static startInputArgCountsVector(n, s) { n.startVector(4, s, 4); } static addImplicitInputs(n, s) { n.addFieldOffset(12, s, 0); } static createImplicitInputsVector(n, s) { n.startVector(4, s.length, 4); for (let d = s.length - 1; d >= 0; d--) n.addOffset(s[d]); return n.endVector(); } static startImplicitInputsVector(n, s) { n.startVector(4, s, 4); } static endNode(n) { return n.endObject(); } static createNode(n, s, d, f, r, a, l, p, m, y, T, v, S, E) { return ( i.startNode(n), i.addName(n, s), i.addDocString(n, d), i.addDomain(n, f), i.addSinceVersion(n, r), i.addIndex(n, a), i.addOpType(n, l), i.addType(n, p), i.addExecutionProviderType(n, m), i.addInputs(n, y), i.addOutputs(n, T), i.addAttributes(n, v), i.addInputArgCounts(n, S), i.addImplicitInputs(n, E), i.endNode(n) ); } } o.Node = i; })((e.fbs ||= {})); })((t.experimental ||= {})); })((W ||= {})), ((t) => { ((e) => { ((o) => { class i { constructor() { (this.bb = null), (this.bb_pos = 0); } __init(n, s) { return (this.bb_pos = n), (this.bb = s), this; } static getRootAsValueInfo(n, s) { return (s || new i()).__init(n.readInt32(n.position()) + n.position(), n); } static getSizePrefixedRootAsValueInfo(n, s) { return ( n.setPosition(n.position() + _.SIZE_PREFIX_LENGTH), (s || new i()).__init(n.readInt32(n.position()) + n.position(), n) ); } name(n) { let s = this.bb.__offset(this.bb_pos, 4); return s ? this.bb.__string(this.bb_pos + s, n) : null; } docString(n) { let s = this.bb.__offset(this.bb_pos, 6); return s ? this.bb.__string(this.bb_pos + s, n) : null; } type(n) { let s = this.bb.__offset(this.bb_pos, 8); return s ? (n || new t.experimental.fbs.TypeInfo()).__init( this.bb.__indirect(this.bb_pos + s), this.bb ) : null; } static startValueInfo(n) { n.startObject(3); } static addName(n, s) { n.addFieldOffset(0, s, 0); } static addDocString(n, s) { n.addFieldOffset(1, s, 0); } static addType(n, s) { n.addFieldOffset(2, s, 0); } static endValueInfo(n) { return n.endObject(); } static createValueInfo(n, s, d, f) { return ( i.startValueInfo(n), i.addName(n, s), i.addDocString(n, d), i.addType(n, f), i.endValueInfo(n) ); } } o.ValueInfo = i; })((e.fbs ||= {})); })((t.experimental ||= {})); })((W ||= {})), ((t) => { ((e) => { ((o) => { class i { constructor() { (this.bb = null), (this.bb_pos = 0); } __init(n, s) { return (this.bb_pos = n), (this.bb = s), this; } static getRootAsTypeInfo(n, s) { return (s || new i()).__init(n.readInt32(n.position()) + n.position(), n); } static getSizePrefixedRootAsTypeInfo(n, s) { return ( n.setPosition(n.position() + _.SIZE_PREFIX_LENGTH), (s || new i()).__init(n.readInt32(n.position()) + n.position(), n) ); } denotation(n) { let s = this.bb.__offset(this.bb_pos, 4); return s ? this.bb.__string(this.bb_pos + s, n) : null; } valueType() { let n = this.bb.__offset(this.bb_pos, 6); return n ? this.bb.readUint8(this.bb_pos + n) : 0; } value(n) { let s = this.bb.__offset(this.bb_pos, 8); return s ? this.bb.__union(n, this.bb_pos + s) : null; } static startTypeInfo(n) { n.startObject(3); } static addDenotation(n, s) { n.addFieldOffset(0, s, 0); } static addValueType(n, s) { n.addFieldInt8(1, s, 0); } static addValue(n, s) { n.addFieldOffset(2, s, 0); } static endTypeInfo(n) { return n.endObject(); } static createTypeInfo(n, s, d, f) { return ( i.startTypeInfo(n), i.addDenotation(n, s), i.addValueType(n, d), i.addValue(n, f), i.endTypeInfo(n) ); } } o.TypeInfo = i; })((e.fbs ||= {})); })((t.experimental ||= {})); })((W ||= {})), ((t) => { ((e) => { ((o) => { class i { constructor() { (this.bb = null), (this.bb_pos = 0); } __init(n, s) { return (this.bb_pos = n), (this.bb = s), this; } static getRootAsOperatorSetId(n, s) { return (s || new i()).__init(n.readInt32(n.position()) + n.position(), n); } static getSizePrefixedRootAsOperatorSetId(n, s) { return ( n.setPosition(n.position() + _.SIZE_PREFIX_LENGTH), (s || new i()).__init(n.readInt32(n.position()) + n.position(), n) ); } domain(n) { let s = this.bb.__offset(this.bb_pos, 4); return s ? this.bb.__string(this.bb_pos + s, n) : null; } version() { let n = this.bb.__offset(this.bb_pos, 6); return n ? this.bb.readInt64(this.bb_pos + n) : this.bb.createLong(0, 0); } static startOperatorSetId(n) { n.startObject(2); } static addDomain(n, s) { n.addFieldOffset(0, s, 0); } static addVersion(n, s) { n.addFieldInt64(1, s, n.createLong(0, 0)); } static endOperatorSetId(n) { return n.endObject(); } static createOperatorSetId(n, s, d) { return ( i.startOperatorSetId(n), i.addDomain(n, s), i.addVersion(n, d), i.endOperatorSetId(n) ); } } o.OperatorSetId = i; })((e.fbs ||= {})); })((t.experimental ||= {})); })((W ||= {})), ((t) => { ((e) => { ((o) => { class i { constructor() { (this.bb = null), (this.bb_pos = 0); } __init(n, s) { return (this.bb_pos = n), (this.bb = s), this; } static getRootAsTensor(n, s) { return (s || new i()).__init(n.readInt32(n.position()) + n.position(), n); } static getSizePrefixedRootAsTensor(n, s) { return ( n.setPosition(n.position() + _.SIZE_PREFIX_LENGTH), (s || new i()).__init(n.readInt32(n.position()) + n.position(), n) ); } name(n) { let s = this.bb.__offset(this.bb_pos, 4); return s ? this.bb.__string(this.bb_pos + s, n) : null; } docString(n) { let s = this.bb.__offset(this.bb_pos, 6); return s ? this.bb.__string(this.bb_pos + s, n) : null; } dims(n) { let s = this.bb.__offset(this.bb_pos, 8); return s ? this.bb.readInt64(this.bb.__vector(this.bb_pos + s) + n * 8) : this.bb.createLong(0, 0); } dimsLength() { let n = this.bb.__offset(this.bb_pos, 8); return n ? this.bb.__vector_len(this.bb_pos + n) : 0; } dataType() { let n = this.bb.__offset(this.bb_pos, 10); return n ? this.bb.readInt32(this.bb_pos + n) : 0; } rawData(n) { let s = this.bb.__offset(this.bb_pos, 12); return s ? this.bb.readUint8(this.bb.__vector(this.bb_pos + s) + n) : 0; } rawDataLength() { let n = this.bb.__offset(this.bb_pos, 12); return n ? this.bb.__vector_len(this.bb_pos + n) : 0; } rawDataArray() { let n = this.bb.__offset(this.bb_pos, 12); return n ? new Uint8Array( this.bb.bytes().buffer, this.bb.bytes().byteOffset + this.bb.__vector(this.bb_pos + n), this.bb.__vector_len(this.bb_pos + n) ) : null; } stringData(n, s) { let d = this.bb.__offset(this.bb_pos, 14); return d ? this.bb.__string(this.bb.__vector(this.bb_pos + d) + n * 4, s) : null; } stringDataLength() { let n = this.bb.__offset(this.bb_pos, 14); return n ? this.bb.__vector_len(this.bb_pos + n) : 0; } static startTensor(n) { n.startObject(6); } static addName(n, s) { n.addFieldOffset(0, s, 0); } static addDocString(n, s) { n.addFieldOffset(1, s, 0); } static addDims(n, s) { n.addFieldOffset(2, s, 0); } static createDimsVector(n, s) { n.startVector(8, s.length, 8); for (let d = s.length - 1; d >= 0; d--) n.addInt64(s[d]); return n.endVector(); } static startDimsVector(n, s) { n.startVector(8, s, 8); } static addDataType(n, s) { n.addFieldInt32(3, s, 0); } static addRawData(n, s) { n.addFieldOffset(4, s, 0); } static createRawDataVector(n, s) { n.startVector(1, s.length, 1); for (let d = s.length - 1; d >= 0; d--) n.addInt8(s[d]); return n.endVector(); } static startRawDataVector(n, s) { n.startVector(1, s, 1); } static addStringData(n, s) { n.addFieldOffset(5, s, 0); } static createStringDataVector(n, s) { n.startVector(4, s.length, 4); for (let d = s.length - 1; d >= 0; d--) n.addOffset(s[d]); return n.endVector(); } static startStringDataVector(n, s) { n.startVector(4, s, 4); } static endTensor(n) { return n.endObject(); } static createTensor(n, s, d, f, r, a, l) { return ( i.startTensor(n), i.addName(n, s), i.addDocString(n, d), i.addDims(n, f), i.addDataType(n, r), i.addRawData(n, a), i.addStringData(n, l), i.endTensor(n) ); } } o.Tensor = i; })((e.fbs ||= {})); })((t.experimental ||= {})); })((W ||= {})), ((t) => { ((e) => { ((o) => { class i { constructor() { (this.bb = null), (this.bb_pos = 0); } __init(n, s) { return (this.bb_pos = n), (this.bb = s), this; } static getRootAsSparseTensor(n, s) { return (s || new i()).__init(n.readInt32(n.position()) + n.position(), n); } static getSizePrefixedRootAsSparseTensor(n, s) { return ( n.setPosition(n.position() + _.SIZE_PREFIX_LENGTH), (s || new i()).__init(n.readInt32(n.position()) + n.position(), n) ); } values(n) { let s = this.bb.__offset(this.bb_pos, 4); return s ? (n || new t.experimental.fbs.Tensor()).__init( this.bb.__indirect(this.bb_pos + s), this.bb ) : null; } indices(n) { let s = this.bb.__offset(this.bb_pos, 6); return s ? (n || new t.experimental.fbs.Tensor()).__init( this.bb.__indirect(this.bb_pos + s), this.bb ) : null; } dims(n) { let s = this.bb.__offset(this.bb_pos, 8); return s ? this.bb.readInt64(this.bb.__vector(this.bb_pos + s) + n * 8) : this.bb.createLong(0, 0); } dimsLength() { let n = this.bb.__offset(this.bb_pos, 8); return n ? this.bb.__vector_len(this.bb_pos + n) : 0; } static startSparseTensor(n) { n.startObject(3); } static addValues(n, s) { n.addFieldOffset(0, s, 0); } static addIndices(n, s) { n.addFieldOffset(1, s, 0); } static addDims(n, s) { n.addFieldOffset(2, s, 0); } static createDimsVector(n, s) { n.startVector(8, s.length, 8); for (let d = s.length - 1; d >= 0; d--) n.addInt64(s[d]); return n.endVector(); } static startDimsVector(n, s) { n.startVector(8, s, 8); } static endSparseTensor(n) { return n.endObject(); } static createSparseTensor(n, s, d, f) { return ( i.startSparseTensor(n), i.addValues(n, s), i.addIndices(n, d), i.addDims(n, f), i.endSparseTensor(n) ); } } o.SparseTensor = i; })((e.fbs ||= {})); })((t.experimental ||= {})); })((W ||= {})), ((t) => { ((e) => { ((o) => { class i { constructor() { (this.bb = null), (this.bb_pos = 0); } __init(n, s) { return (this.bb_pos = n), (this.bb = s), this; } static getRootAsAttribute(n, s) { return (s || new i()).__init(n.readInt32(n.position()) + n.position(), n); } static getSizePrefixedRootAsAttribute(n, s) { return ( n.setPosition(n.position() + _.SIZE_PREFIX_LENGTH), (s || new i()).__init(n.readInt32(n.position()) + n.position(), n) ); } name(n) { let s = this.bb.__offset(this.bb_pos, 4); return s ? this.bb.__string(this.bb_pos + s, n) : null; } docString(n) { let s = this.bb.__offset(this.bb_pos, 6); return s ? this.bb.__string(this.bb_pos + s, n) : null; } type() { let n = this.bb.__offset(this.bb_pos, 8); return n ? this.bb.readInt32(this.bb_pos + n) : 0; } f() { let n = this.bb.__offset(this.bb_pos, 10); return n ? this.bb.readFloat32(this.bb_pos + n) : 0; } i() { let n = this.bb.__offset(this.bb_pos, 12); return n ? this.bb.readInt64(this.bb_pos + n) : this.bb.createLong(0, 0); } s(n) { let s = this.bb.__offset(this.bb_pos, 14); return s ? this.bb.__string(this.bb_pos + s, n) : null; } t(n) { let s = this.bb.__offset(this.bb_pos, 16); return s ? (n || new t.experimental.fbs.Tensor()).__init( this.bb.__indirect(this.bb_pos + s), this.bb ) : null; } g(n) { let s = this.bb.__offset(this.bb_pos, 18); return s ? (n || new t.experimental.fbs.Graph()).__init( this.bb.__indirect(this.bb_pos + s), this.bb ) : null; } floats(n) { let s = this.bb.__offset(this.bb_pos, 20); return s ? this.bb.readFloat32(this.bb.__vector(this.bb_pos + s) + n * 4) : 0; } floatsLength() { let n = this.bb.__offset(this.bb_pos, 20); return n ? this.bb.__vector_len(this.bb_pos + n) : 0; } floatsArray() { let n = this.bb.__offset(this.bb_pos, 20); return n ? new Float32Array( this.bb.bytes().buffer, this.bb.bytes().byteOffset + this.bb.__vector(this.bb_pos + n), this.bb.__vector_len(this.bb_pos + n) ) : null; } ints(n) { let s = this.bb.__offset(this.bb_pos, 22); return s ? this.bb.readInt64(this.bb.__vector(this.bb_pos + s) + n * 8) : this.bb.createLong(0, 0); } intsLength() { let n = this.bb.__offset(this.bb_pos, 22); return n ? this.bb.__vector_len(this.bb_pos + n) : 0; } strings(n, s) { let d = this.bb.__offset(this.bb_pos, 24); return d ? this.bb.__string(this.bb.__vector(this.bb_pos + d) + n * 4, s) : null; } stringsLength() { let n = this.bb.__offset(this.bb_pos, 24); return n ? this.bb.__vector_len(this.bb_pos + n) : 0; } tensors(n, s) { let d = this.bb.__offset(this.bb_pos, 26); return d ? (s || new t.experimental.fbs.Tensor()).__init( this.bb.__indirect(this.bb.__vector(this.bb_pos + d) + n * 4), this.bb ) : null; } tensorsLength() { let n = this.bb.__offset(this.bb_pos, 26); return n ? this.bb.__vector_len(this.bb_pos + n) : 0; } graphs(n, s) { let d = this.bb.__offset(this.bb_pos, 28); return d ? (s || new t.experimental.fbs.Graph()).__init( this.bb.__indirect(this.bb.__vector(this.bb_pos + d) + n * 4), this.bb ) : null; } graphsLength() { let n = this.bb.__offset(this.bb_pos, 28); return n ? this.bb.__vector_len(this.bb_pos + n) : 0; } static startAttribute(n) { n.startObject(13); } static addName(n, s) { n.addFieldOffset(0, s, 0); } static addDocString(n, s) { n.addFieldOffset(1, s, 0); } static addType(n, s) { n.addFieldInt32(2, s, 0); } static addF(n, s) { n.addFieldFloat32(3, s, 0); } static addI(n, s) { n.addFieldInt64(4, s, n.createLong(0, 0)); } static addS(n, s) { n.addFieldOffset(5, s, 0); } static addT(n, s) { n.addFieldOffset(6, s, 0); } static addG(n, s) { n.addFieldOffset(7, s, 0); } static addFloats(n, s) { n.addFieldOffset(8, s, 0); } static createFloatsVector(n, s) { n.startVector(4, s.length, 4); for (let d = s.length - 1; d >= 0; d--) n.addFloat32(s[d]); return n.endVector(); } static startFloatsVector(n, s) { n.startVector(4, s, 4); } static addInts(n, s) { n.addFieldOffset(9, s, 0); } static createIntsVector(n, s) { n.startVector(8, s.length, 8); for (let d = s.length - 1; d >= 0; d--) n.addInt64(s[d]); return n.endVector(); } static startIntsVector(n, s) { n.startVector(8, s, 8); } static addStrings(n, s) { n.addFieldOffset(10, s, 0); } static createStringsVector(n, s) { n.startVector(4, s.length, 4); for (let d = s.length - 1; d >= 0; d--) n.addOffset(s[d]); return n.endVector(); } static startStringsVector(n, s) { n.startVector(4, s, 4); } static addTensors(n, s) { n.addFieldOffset(11, s, 0); } static createTensorsVector(n, s) { n.startVector(4, s.length, 4); for (let d = s.length - 1; d >= 0; d--) n.addOffset(s[d]); return n.endVector(); } static startTensorsVector(n, s) { n.startVector(4, s, 4); } static addGraphs(n, s) { n.addFieldOffset(12, s, 0); } static createGraphsVector(n, s) { n.startVector(4, s.length, 4); for (let d = s.length - 1; d >= 0; d--) n.addOffset(s[d]); return n.endVector(); } static startGraphsVector(n, s) { n.startVector(4, s, 4); } static endAttribute(n) { return n.endObject(); } static createAttribute(n, s, d, f, r, a, l, p, m, y, T, v, S, E) { return ( i.startAttribute(n), i.addName(n, s), i.addDocString(n, d), i.addType(n, f), i.addF(n, r), i.addI(n, a), i.addS(n, l), i.addT(n, p), i.addG(n, m), i.addFloats(n, y), i.addInts(n, T), i.addStrings(n, v), i.addTensors(n, S), i.addGraphs(n, E), i.endAttribute(n) ); } } o.Attribute = i; })((e.fbs ||= {})); })((t.experimental ||= {})); })((W ||= {})), ((t) => { ((e) => { ((o) => { class i { constructor() { (this.bb = null), (this.bb_pos = 0); } __init(n, s) { return (this.bb_pos = n), (this.bb = s), this; } static getRootAsGraph(n, s) { return (s || new i()).__init(n.readInt32(n.position()) + n.position(), n); } static getSizePrefixedRootAsGraph(n, s) { return ( n.setPosition(n.position() + _.SIZE_PREFIX_LENGTH), (s || new i()).__init(n.readInt32(n.position()) + n.position(), n) ); } initializers(n, s) { let d = this.bb.__offset(this.bb_pos, 4); return d ? (s || new t.experimental.fbs.Tensor()).__init( this.bb.__indirect(this.bb.__vector(this.bb_pos + d) + n * 4), this.bb ) : null; } initializersLength() { let n = this.bb.__offset(this.bb_pos, 4); return n ? this.bb.__vector_len(this.bb_pos + n) : 0; } nodeArgs(n, s) { let d = this.bb.__offset(this.bb_pos, 6); return d ? (s || new t.experimental.fbs.ValueInfo()).__init( this.bb.__indirect(this.bb.__vector(this.bb_pos + d) + n * 4), this.bb ) : null; } nodeArgsLength() { let n = this.bb.__offset(this.bb_pos, 6); return n ? this.bb.__vector_len(this.bb_pos + n) : 0; } nodes(n, s) { let d = this.bb.__offset(this.bb_pos, 8); return d ? (s || new t.experimental.fbs.Node()).__init( this.bb.__indirect(this.bb.__vector(this.bb_pos + d) + n * 4), this.bb ) : null; } nodesLength() { let n = this.bb.__offset(this.bb_pos, 8); return n ? this.bb.__vector_len(this.bb_pos + n) : 0; } maxNodeIndex() { let n = this.bb.__offset(this.bb_pos, 10); return n ? this.bb.readUint32(this.bb_pos + n) : 0; } nodeEdges(n, s) { let d = this.bb.__offset(this.bb_pos, 12); return d ? (s || new t.experimental.fbs.NodeEdge()).__init( this.bb.__indirect(this.bb.__vector(this.bb_pos + d) + n * 4), this.bb ) : null; } nodeEdgesLength() { let n = this.bb.__offset(this.bb_pos, 12); return n ? this.bb.__vector_len(this.bb_pos + n) : 0; } inputs(n, s) { let d = this.bb.__offset(this.bb_pos, 14); return d ? this.bb.__string(this.bb.__vector(this.bb_pos + d) + n * 4, s) : null; } inputsLength() { let n = this.bb.__offset(this.bb_pos, 14); return n ? this.bb.__vector_len(this.bb_pos + n) : 0; } outputs(n, s) { let d = this.bb.__offset(this.bb_pos, 16); return d ? this.bb.__string(this.bb.__vector(this.bb_pos + d) + n * 4, s) : null; } outputsLength() { let n = this.bb.__offset(this.bb_pos, 16); return n ? this.bb.__vector_len(this.bb_pos + n) : 0; } sparseInitializers(n, s) { let d = this.bb.__offset(this.bb_pos, 18); return d ? (s || new t.experimental.fbs.SparseTensor()).__init( this.bb.__indirect(this.bb.__vector(this.bb_pos + d) + n * 4), this.bb ) : null; } sparseInitializersLength() { let n = this.bb.__offset(this.bb_pos, 18); return n ? this.bb.__vector_len(this.bb_pos + n) : 0; } static startGraph(n) { n.startObject(8); } static addInitializers(n, s) { n.addFieldOffset(0, s, 0); } static createInitializersVector(n, s) { n.startVector(4, s.length, 4); for (let d = s.length - 1; d >= 0; d--) n.addOffset(s[d]); return n.endVector(); } static startInitializersVector(n, s) { n.startVector(4, s, 4); } static addNodeArgs(n, s) { n.addFieldOffset(1, s, 0); } static createNodeArgsVector(n, s) { n.startVector(4, s.length, 4); for (let d = s.length - 1; d >= 0; d--) n.addOffset(s[d]); return n.endVector(); } static startNodeArgsVector(n, s) { n.startVector(4, s, 4); } static addNodes(n, s) { n.addFieldOffset(2, s, 0); } static createNodesVector(n, s) { n.startVector(4, s.length, 4); for (let d = s.length - 1; d >= 0; d--) n.addOffset(s[d]); return n.endVector(); } static startNodesVector(n, s) { n.startVector(4, s, 4); } static addMaxNodeIndex(n, s) { n.addFieldInt32(3, s, 0); } static addNodeEdges(n, s) { n.addFieldOffset(4, s, 0); } static createNodeEdgesVector(n, s) { n.startVector(4, s.length, 4); for (let d = s.length - 1; d >= 0; d--) n.addOffset(s[d]); return n.endVector(); } static startNodeEdgesVector(n, s) { n.startVector(4, s, 4); } static addInputs(n, s) { n.addFieldOffset(5, s, 0); } static createInputsVector(n, s) { n.startVector(4, s.length, 4); for (let d = s.length - 1; d >= 0; d--) n.addOffset(s[d]); return n.endVector(); } static startInputsVector(n, s) { n.startVector(4, s, 4); } static addOutputs(n, s) { n.addFieldOffset(6, s, 0); } static createOutputsVector(n, s) { n.startVector(4, s.length, 4); for (let d = s.length - 1; d >= 0; d--) n.addOffset(s[d]); return n.endVector(); } static startOutputsVector(n, s) { n.startVector(4, s, 4); } static addSparseInitializers(n, s) { n.addFieldOffset(7, s, 0); } static createSparseInitializersVector(n, s) { n.startVector(4, s.length, 4); for (let d = s.length - 1; d >= 0; d--) n.addOffset(s[d]); return n.endVector(); } static startSparseInitializersVector(n, s) { n.startVector(4, s, 4); } static endGraph(n) { return n.endObject(); } static createGraph(n, s, d, f, r, a, l, p, m) { return ( i.startGraph(n), i.addInitializers(n, s), i.addNodeArgs(n, d), i.addNodes(n, f), i.addMaxNodeIndex(n, r), i.addNodeEdges(n, a), i.addInputs(n, l), i.addOutputs(n, p), i.addSparseInitializers(n, m), i.endGraph(n) ); } } o.Graph = i; })((e.fbs ||= {})); })((t.experimental ||= {})); })((W ||= {})), ((t) => { ((e) => { ((o) => { class i { constructor() { (this.bb = null), (this.bb_pos = 0); } __init(n, s) { return (this.bb_pos = n), (this.bb = s), this; } static getRootAsModel(n, s) { return (s || new i()).__init(n.readInt32(n.position()) + n.position(), n); } static getSizePrefixedRootAsModel(n, s) { return ( n.setPosition(n.position() + _.SIZE_PREFIX_LENGTH), (s || new i()).__init(n.readInt32(n.position()) + n.position(), n) ); } irVersion() { let n = this.bb.__offset(this.bb_pos, 4); return n ? this.bb.readInt64(this.bb_pos + n) : this.bb.createLong(0, 0); } opsetImport(n, s) { let d = this.bb.__offset(this.bb_pos, 6); return d ? (s || new t.experimental.fbs.OperatorSetId()).__init( this.bb.__indirect(this.bb.__vector(this.bb_pos + d) + n * 4), this.bb ) : null; } opsetImportLength() { let n = this.bb.__offset(this.bb_pos, 6); return n ? this.bb.__vector_len(this.bb_pos + n) : 0; } producerName(n) { let s = this.bb.__offset(this.bb_pos, 8); return s ? this.bb.__string(this.bb_pos + s, n) : null; } producerVersion(n) { let s = this.bb.__offset(this.bb_pos, 10); return s ? this.bb.__string(this.bb_pos + s, n) : null; } domain(n) { let s = this.bb.__offset(this.bb_pos, 12); return s ? this.bb.__string(this.bb_pos + s, n) : null; } modelVersion() { let n = this.bb.__offset(this.bb_pos, 14); return n ? this.bb.readInt64(this.bb_pos + n) : this.bb.createLong(0, 0); } docString(n) { let s = this.bb.__offset(this.bb_pos, 16); return s ? this.bb.__string(this.bb_pos + s, n) : null; } graph(n) { let s = this.bb.__offset(this.bb_pos, 18); return s ? (n || new t.experimental.fbs.Graph()).__init( this.bb.__indirect(this.bb_pos + s), this.bb ) : null; } graphDocString(n) { let s = this.bb.__offset(this.bb_pos, 20); return s ? this.bb.__string(this.bb_pos + s, n) : null; } static startModel(n) { n.startObject(9); } static addIrVersion(n, s) { n.addFieldInt64(0, s, n.createLong(0, 0)); } static addOpsetImport(n, s) { n.addFieldOffset(1, s, 0); } static createOpsetImportVector(n, s) { n.startVector(4, s.length, 4); for (let d = s.length - 1; d >= 0; d--) n.addOffset(s[d]); return n.endVector(); } static startOpsetImportVector(n, s) { n.startVector(4, s, 4); } static addProducerName(n, s) { n.addFieldOffset(2, s, 0); } static addProducerVersion(n, s) { n.addFieldOffset(3, s, 0); } static addDomain(n, s) { n.addFieldOffset(4, s, 0); } static addModelVersion(n, s) { n.addFieldInt64(5, s, n.createLong(0, 0)); } static addDocString(n, s) { n.addFieldOffset(6, s, 0); } static addGraph(n, s) { n.addFieldOffset(7, s, 0); } static addGraphDocString(n, s) { n.addFieldOffset(8, s, 0); } static endModel(n) { return n.endObject(); } static createModel(n, s, d, f, r, a, l, p, m, y) { return ( i.startModel(n), i.addIrVersion(n, s), i.addOpsetImport(n, d), i.addProducerName(n, f), i.addProducerVersion(n, r), i.addDomain(n, a), i.addModelVersion(n, l), i.addDocString(n, p), i.addGraph(n, m), i.addGraphDocString(n, y), i.endModel(n) ); } } o.Model = i; })((e.fbs ||= {})); })((t.experimental ||= {})); })((W ||= {})), ((t) => { ((e) => { ((o) => { class i { constructor() { (this.bb = null), (this.bb_pos = 0); } __init(n, s) { return (this.bb_pos = n), (this.bb = s), this; } static getRootAsKernelCreateInfos(n, s) { return (s || new i()).__init(n.readInt32(n.position()) + n.position(), n); } static getSizePrefixedRootAsKernelCreateInfos(n, s) { return ( n.setPosition(n.position() + _.SIZE_PREFIX_LENGTH), (s || new i()).__init(n.readInt32(n.position()) + n.position(), n) ); } nodeIndices(n) { let s = this.bb.__offset(this.bb_pos, 4); return s ? this.bb.readUint32(this.bb.__vector(this.bb_pos + s) + n * 4) : 0; } nodeIndicesLength() { let n = this.bb.__offset(this.bb_pos, 4); return n ? this.bb.__vector_len(this.bb_pos + n) : 0; } nodeIndicesArray() { let n = this.bb.__offset(this.bb_pos, 4); return n ? new Uint32Array( this.bb.bytes().buffer, this.bb.bytes().byteOffset + this.bb.__vector(this.bb_pos + n), this.bb.__vector_len(this.bb_pos + n) ) : null; } kernelDefHashes(n) { let s = this.bb.__offset(this.bb_pos, 6); return s ? this.bb.readUint64(this.bb.__vector(this.bb_pos + s) + n * 8) : this.bb.createLong(0, 0); } kernelDefHashesLength() { let n = this.bb.__offset(this.bb_pos, 6); return n ? this.bb.__vector_len(this.bb_pos + n) : 0; } static startKernelCreateInfos(n) { n.startObject(2); } static addNodeIndices(n, s) { n.addFieldOffset(0, s, 0); } static createNodeIndicesVector(n, s) { n.startVector(4, s.length, 4); for (let d = s.length - 1; d >= 0; d--) n.addInt32(s[d]); return n.endVector(); } static startNodeIndicesVector(n, s) { n.startVector(4, s, 4); } static addKernelDefHashes(n, s) { n.addFieldOffset(1, s, 0); } static createKernelDefHashesVector(n, s) { n.startVector(8, s.length, 8); for (let d = s.length - 1; d >= 0; d--) n.addInt64(s[d]); return n.endVector(); } static startKernelDefHashesVector(n, s) { n.startVector(8, s, 8); } static endKernelCreateInfos(n) { return n.endObject(); } static createKernelCreateInfos(n, s, d) { return ( i.startKernelCreateInfos(n), i.addNodeIndices(n, s), i.addKernelDefHashes(n, d), i.endKernelCreateInfos(n) ); } } o.KernelCreateInfos = i; })((e.fbs ||= {})); })((t.experimental ||= {})); })((W ||= {})), ((t) => { ((e) => { ((o) => { class i { constructor() { (this.bb = null), (this.bb_pos = 0); } __init(n, s) { return (this.bb_pos = n), (this.bb = s), this; } static getRootAsSubGraphSessionState(n, s) { return (s || new i()).__init(n.readInt32(n.position()) + n.position(), n); } static getSizePrefixedRootAsSubGraphSessionState(n, s) { return ( n.setPosition(n.position() + _.SIZE_PREFIX_LENGTH), (s || new i()).__init(n.readInt32(n.position()) + n.position(), n) ); } graphId(n) { let s = this.bb.__offset(this.bb_pos, 4); return s ? this.bb.__string(this.bb_pos + s, n) : null; } sessionState(n) { let s = this.bb.__offset(this.bb_pos, 6); return s ? (n || new t.experimental.fbs.SessionState()).__init( this.bb.__indirect(this.bb_pos + s), this.bb ) : null; } static startSubGraphSessionState(n) { n.startObject(2); } static addGraphId(n, s) { n.addFieldOffset(0, s, 0); } static addSessionState(n, s) { n.addFieldOffset(1, s, 0); } static endSubGraphSessionState(n) { let s = n.endObject(); return n.requiredField(s, 4), s; } static createSubGraphSessionState(n, s, d) { return ( i.startSubGraphSessionState(n), i.addGraphId(n, s), i.addSessionState(n, d), i.endSubGraphSessionState(n) ); } } o.SubGraphSessionState = i; })((e.fbs ||= {})); })((t.experimental ||= {})); })((W ||= {})), ((t) => { ((e) => { ((o) => { class i { constructor() { (this.bb = null), (this.bb_pos = 0); } __init(n, s) { return (this.bb_pos = n), (this.bb = s), this; } static getRootAsSessionState(n, s) { return (s || new i()).__init(n.readInt32(n.position()) + n.position(), n); } static getSizePrefixedRootAsSessionState(n, s) { return ( n.setPosition(n.position() + _.SIZE_PREFIX_LENGTH), (s || new i()).__init(n.readInt32(n.position()) + n.position(), n) ); } kernels(n) { let s = this.bb.__offset(this.bb_pos, 4); return s ? (n || new t.experimental.fbs.KernelCreateInfos()).__init( this.bb.__indirect(this.bb_pos + s), this.bb ) : null; } subGraphSessionStates(n, s) { let d = this.bb.__offset(this.bb_pos, 6); return d ? (s || new t.experimental.fbs.SubGraphSessionState()).__init( this.bb.__indirect(this.bb.__vector(this.bb_pos + d) + n * 4), this.bb ) : null; } subGraphSessionStatesLength() { let n = this.bb.__offset(this.bb_pos, 6); return n ? this.bb.__vector_len(this.bb_pos + n) : 0; } static startSessionState(n) { n.startObject(2); } static addKernels(n, s) { n.addFieldOffset(0, s, 0); } static addSubGraphSessionStates(n, s) { n.addFieldOffset(1, s, 0); } static createSubGraphSessionStatesVector(n, s) { n.startVector(4, s.length, 4); for (let d = s.length - 1; d >= 0; d--) n.addOffset(s[d]); return n.endVector(); } static startSubGraphSessionStatesVector(n, s) { n.startVector(4, s, 4); } static endSessionState(n) { return n.endObject(); } static createSessionState(n, s, d) { return ( i.startSessionState(n), i.addKernels(n, s), i.addSubGraphSessionStates(n, d), i.endSessionState(n) ); } } o.SessionState = i; })((e.fbs ||= {})); })((t.experimental ||= {})); })((W ||= {})), ((t) => { ((e) => { ((o) => { class i { constructor() { (this.bb = null), (this.bb_pos = 0); } __init(n, s) { return (this.bb_pos = n), (this.bb = s), this; } static getRootAsInferenceSession(n, s) { return (s || new i()).__init(n.readInt32(n.position()) + n.position(), n); } static getSizePrefixedRootAsInferenceSession(n, s) { return ( n.setPosition(n.position() + _.SIZE_PREFIX_LENGTH), (s || new i()).__init(n.readInt32(n.position()) + n.position(), n) ); } static bufferHasIdentifier(n) { return n.__has_identifier('ORTM'); } ortVersion(n) { let s = this.bb.__offset(this.bb_pos, 4); return s ? this.bb.__string(this.bb_pos + s, n) : null; } model(n) { let s = this.bb.__offset(this.bb_pos, 6); return s ? (n || new t.experimental.fbs.Model()).__init( this.bb.__indirect(this.bb_pos + s), this.bb ) : null; } sessionState(n) { let s = this.bb.__offset(this.bb_pos, 8); return s ? (n || new t.experimental.fbs.SessionState()).__init( this.bb.__indirect(this.bb_pos + s), this.bb ) : null; } static startInferenceSession(n) { n.startObject(3); } static addOrtVersion(n, s) { n.addFieldOffset(0, s, 0); } static addModel(n, s) { n.addFieldOffset(1, s, 0); } static addSessionState(n, s) { n.addFieldOffset(2, s, 0); } static endInferenceSession(n) { return n.endObject(); } static finishInferenceSessionBuffer(n, s) { n.finish(s, 'ORTM'); } static finishSizePrefixedInferenceSessionBuffer(n, s) { n.finish(s, 'ORTM', !0); } static createInferenceSession(n, s, d, f) { return ( i.startInferenceSession(n), i.addOrtVersion(n, s), i.addModel(n, d), i.addSessionState(n, f), i.endInferenceSession(n) ); } } o.InferenceSession = i; })((e.fbs ||= {})); })((t.experimental ||= {})); })((W ||= {})); }), ks = me((t, e) => { e.exports = o; function o(i, u) { for (var n = new Array(arguments.length - 1), s = 0, d = 2, f = !0; d < arguments.length; ) n[s++] = arguments[d++]; return new Promise(function (r, a) { n[s] = function (l) { if (f) if (((f = !1), l)) a(l); else { for (var p = new Array(arguments.length - 1), m = 0; m < p.length; ) p[m++] = arguments[m]; r.apply(null, p); } }; try { i.apply(u || null, n); } catch (l) { f && ((f = !1), a(l)); } }); } }), Ms = me((t) => { var e = t; e.length = function (s) { var d = s.length; if (!d) return 0; for (var f = 0; --d % 4 > 1 && s.charAt(d) === '='; ) ++f; return Math.ceil(s.length * 3) / 4 - f; }; var o = new Array(64), i = new Array(123); for (u = 0; u < 64; ) i[(o[u] = u < 26 ? u + 65 : u < 52 ? u + 71 : u < 62 ? u - 4 : (u - 59) | 43)] = u++; var u; e.encode = function (s, d, f) { for (var r = null, a = [], l = 0, p = 0, m; d < f; ) { var y = s[d++]; switch (p) { case 0: (a[l++] = o[y >> 2]), (m = (y & 3) << 4), (p = 1); break; case 1: (a[l++] = o[m | (y >> 4)]), (m = (y & 15) << 2), (p = 2); break; case 2: (a[l++] = o[m | (y >> 6)]), (a[l++] = o[y & 63]), (p = 0); break; } l > 8191 && ((r || (r = [])).push(String.fromCharCode.apply(String, a)), (l = 0)); } return ( p && ((a[l++] = o[m]), (a[l++] = 61), p === 1 && (a[l++] = 61)), r ? (l && r.push(String.fromCharCode.apply(String, a.slice(0, l))), r.join('')) : String.fromCharCode.apply(String, a.slice(0, l)) ); }; var n = 'invalid encoding'; (e.decode = function (s, d, f) { for (var r = f, a = 0, l, p = 0; p < s.length; ) { var m = s.charCodeAt(p++); if (m === 61 && a > 1) break; if ((m = i[m]) === void 0) throw Error(n); switch (a) { case 0: (l = m), (a = 1); break; case 1: (d[f++] = (l << 2) | ((m & 48) >> 4)), (l = m), (a = 2); break; case 2: (d[f++] = ((l & 15) << 4) | ((m & 60) >> 2)), (l = m), (a = 3); break; case 3: (d[f++] = ((l & 3) << 6) | m), (a = 0); break; } } if (a === 1) throw Error(n); return f - r; }), (e.test = function (s) { return /^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/.test(s); }); }), Us = me((t, e) => { e.exports = o; function o() { this._listeners = {}; } (o.prototype.on = function (i, u, n) { return (this._listeners[i] || (this._listeners[i] = [])).push({ fn: u, ctx: n || this }), this; }), (o.prototype.off = function (i, u) { if (i === void 0) this._listeners = {}; else if (u === void 0) this._listeners[i] = []; else for (var n = this._listeners[i], s = 0; s < n.length; ) n[s].fn === u ? n.splice(s, 1) : ++s; return this; }), (o.prototype.emit = function (i) { var u = this._listeners[i]; if (u) { for (var n = [], s = 1; s < arguments.length; ) n.push(arguments[s++]); for (s = 0; s < u.length; ) u[s].fn.apply(u[s++].ctx, n); } return this; }); }), Ys = me((t, e) => { e.exports = o(o); function o(d) { return ( typeof Float32Array < 'u' ? (function () { var f = new Float32Array([-0]), r = new Uint8Array(f.buffer), a = r[3] === 128; function l(T, v, S) { (f[0] = T), (v[S] = r[0]), (v[S + 1] = r[1]), (v[S + 2] = r[2]), (v[S + 3] = r[3]); } function p(T, v, S) { (f[0] = T), (v[S] = r[3]), (v[S + 1] = r[2]), (v[S + 2] = r[1]), (v[S + 3] = r[0]); } (d.writeFloatLE = a ? l : p), (d.writeFloatBE = a ? p : l); function m(T, v) { return (r[0] = T[v]), (r[1] = T[v + 1]), (r[2] = T[v + 2]), (r[3] = T[v + 3]), f[0]; } function y(T, v) { return (r[3] = T[v]), (r[2] = T[v + 1]), (r[1] = T[v + 2]), (r[0] = T[v + 3]), f[0]; } (d.readFloatLE = a ? m : y), (d.readFloatBE = a ? y : m); })() : (function () { function f(a, l, p, m) { var y = l < 0 ? 1 : 0; if ((y && (l = -l), l === 0)) a(1 / l > 0 ? 0 : 2147483648, p, m); else if (isNaN(l)) a(2143289344, p, m); else if (l > 34028234663852886e22) a(((y << 31) | 2139095040) >>> 0, p, m); else if (l < 11754943508222875e-54) a(((y << 31) | Math.round(l / 1401298464324817e-60)) >>> 0, p, m); else { var T = Math.floor(Math.log(l) / Math.LN2), v = Math.round(l * Math.pow(2, -T) * 8388608) & 8388607; a(((y << 31) | ((T + 127) << 23) | v) >>> 0, p, m); } } (d.writeFloatLE = f.bind(null, i)), (d.writeFloatBE = f.bind(null, u)); function r(a, l, p) { var m = a(l, p), y = (m >> 31) * 2 + 1, T = (m >>> 23) & 255, v = m & 8388607; return T === 255 ? v ? NaN : y * (1 / 0) : T === 0 ? y * 1401298464324817e-60 * v : y * Math.pow(2, T - 150) * (v + 8388608); } (d.readFloatLE = r.bind(null, n)), (d.readFloatBE = r.bind(null, s)); })(), typeof Float64Array < 'u' ? (function () { var f = new Float64Array([-0]), r = new Uint8Array(f.buffer), a = r[7] === 128; function l(T, v, S) { (f[0] = T), (v[S] = r[0]), (v[S + 1] = r[1]), (v[S + 2] = r[2]), (v[S + 3] = r[3]), (v[S + 4] = r[4]), (v[S + 5] = r[5]), (v[S + 6] = r[6]), (v[S + 7] = r[7]); } function p(T, v, S) { (f[0] = T), (v[S] = r[7]), (v[S + 1] = r[6]), (v[S + 2] = r[5]), (v[S + 3] = r[4]), (v[S + 4] = r[3]), (v[S + 5] = r[2]), (v[S + 6] = r[1]), (v[S + 7] = r[0]); } (d.writeDoubleLE = a ? l : p), (d.writeDoubleBE = a ? p : l); function m(T, v) { return ( (r[0] = T[v]), (r[1] = T[v + 1]), (r[2] = T[v + 2]), (r[3] = T[v + 3]), (r[4] = T[v + 4]), (r[5] = T[v + 5]), (r[6] = T[v + 6]), (r[7] = T[v + 7]), f[0] ); } function y(T, v) { return ( (r[7] = T[v]), (r[6] = T[v + 1]), (r[5] = T[v + 2]), (r[4] = T[v + 3]), (r[3] = T[v + 4]), (r[2] = T[v + 5]), (r[1] = T[v + 6]), (r[0] = T[v + 7]), f[0] ); } (d.readDoubleLE = a ? m : y), (d.readDoubleBE = a ? y : m); })() : (function () { function f(a, l, p, m, y, T) { var v = m < 0 ? 1 : 0; if ((v && (m = -m), m === 0)) a(0, y, T + l), a(1 / m > 0 ? 0 : 2147483648, y, T + p); else if (isNaN(m)) a(0, y, T + l), a(2146959360, y, T + p); else if (m > 17976931348623157e292) a(0, y, T + l), a(((v << 31) | 2146435072) >>> 0, y, T + p); else { var S; if (m < 22250738585072014e-324) (S = m / 5e-324), a(S >>> 0, y, T + l), a(((v << 31) | (S / 4294967296)) >>> 0, y, T + p); else { var E = Math.floor(Math.log(m) / Math.LN2); E === 1024 && (E = 1023), (S = m * Math.pow(2, -E)), a((S * 4503599627370496) >>> 0, y, T + l), a( ((v << 31) | ((E + 1023) << 20) | ((S * 1048576) & 1048575)) >>> 0, y, T + p ); } } } (d.writeDoubleLE = f.bind(null, i, 0, 4)), (d.writeDoubleBE = f.bind(null, u, 4, 0)); function r(a, l, p, m, y) { var T = a(m, y + l), v = a(m, y + p), S = (v >> 31) * 2 + 1, E = (v >>> 20) & 2047, A = 4294967296 * (v & 1048575) + T; return E === 2047 ? A ? NaN : S * (1 / 0) : E === 0 ? S * 5e-324 * A : S * Math.pow(2, E - 1075) * (A + 4503599627370496); } (d.readDoubleLE = r.bind(null, n, 0, 4)), (d.readDoubleBE = r.bind(null, s, 4, 0)); })(), d ); } function i(d, f, r) { (f[r] = d & 255), (f[r + 1] = (d >>> 8) & 255), (f[r + 2] = (d >>> 16) & 255), (f[r + 3] = d >>> 24); } function u(d, f, r) { (f[r] = d >>> 24), (f[r + 1] = (d >>> 16) & 255), (f[r + 2] = (d >>> 8) & 255), (f[r + 3] = d & 255); } function n(d, f) { return (d[f] | (d[f + 1] << 8) | (d[f + 2] << 16) | (d[f + 3] << 24)) >>> 0; } function s(d, f) { return ((d[f] << 24) | (d[f + 1] << 16) | (d[f + 2] << 8) | d[f + 3]) >>> 0; } }), Xs = me((exports, module) => { module.exports = inquire; function inquire(moduleName) { try { var mod = eval('quire'.replace(/^/, 're'))(moduleName); if (mod && (mod.length || Object.keys(mod).length)) return mod; } catch (t) {} return null; } }), Js = me((t) => { var e = t; (e.length = function (o) { for (var i = 0, u = 0, n = 0; n < o.length; ++n) (u = o.charCodeAt(n)), u < 128 ? (i += 1) : u < 2048 ? (i += 2) : (u & 64512) === 55296 && (o.charCodeAt(n + 1) & 64512) === 56320 ? (++n, (i += 4)) : (i += 3); return i; }), (e.read = function (o, i, u) { var n = u - i; if (n < 1) return ''; for (var s = null, d = [], f = 0, r; i < u; ) (r = o[i++]), r < 128 ? (d[f++] = r) : r > 191 && r < 224 ? (d[f++] = ((r & 31) << 6) | (o[i++] & 63)) : r > 239 && r < 365 ? ((r = (((r & 7) << 18) | ((o[i++] & 63) << 12) | ((o[i++] & 63) << 6) | (o[i++] & 63)) - 65536), (d[f++] = 55296 + (r >> 10)), (d[f++] = 56320 + (r & 1023))) : (d[f++] = ((r & 15) << 12) | ((o[i++] & 63) << 6) | (o[i++] & 63)), f > 8191 && ((s || (s = [])).push(String.fromCharCode.apply(String, d)), (f = 0)); return s ? (f && s.push(String.fromCharCode.apply(String, d.slice(0, f))), s.join('')) : String.fromCharCode.apply(String, d.slice(0, f)); }), (e.write = function (o, i, u) { for (var n = u, s, d, f = 0; f < o.length; ++f) (s = o.charCodeAt(f)), s < 128 ? (i[u++] = s) : s < 2048 ? ((i[u++] = (s >> 6) | 192), (i[u++] = (s & 63) | 128)) : (s & 64512) === 55296 && ((d = o.charCodeAt(f + 1)) & 64512) === 56320 ? ((s = 65536 + ((s & 1023) << 10) + (d & 1023)), ++f, (i[u++] = (s >> 18) | 240), (i[u++] = ((s >> 12) & 63) | 128), (i[u++] = ((s >> 6) & 63) | 128), (i[u++] = (s & 63) | 128)) : ((i[u++] = (s >> 12) | 224), (i[u++] = ((s >> 6) & 63) | 128), (i[u++] = (s & 63) | 128)); return u - n; }); }), Qs = me((t, e) => { e.exports = o; function o(i, u, n) { var s = n || 8192, d = s >>> 1, f = null, r = s; return function (a) { if (a < 1 || a > d) return i(a); r + a > s && ((f = i(s)), (r = 0)); var l = u.call(f, r, (r += a)); return r & 7 && (r = (r | 7) + 1), l; }; } }), tu = me((t, e) => { e.exports = i; var o = Xt(); function i(d, f) { (this.lo = d >>> 0), (this.hi = f >>> 0); } var u = (i.zero = new i(0, 0)); (u.toNumber = function () { return 0; }), (u.zzEncode = u.zzDecode = function () { return this; }), (u.length = function () { return 1; }); var n = (i.zeroHash = '\0\0\0\0\0\0\0\0'); (i.fromNumber = function (d) { if (d === 0) return u; var f = d < 0; f && (d = -d); var r = d >>> 0, a = ((d - r) / 4294967296) >>> 0; return ( f && ((a = ~a >>> 0), (r = ~r >>> 0), ++r > 4294967295 && ((r = 0), ++a > 4294967295 && (a = 0))), new i(r, a) ); }), (i.from = function (d) { if (typeof d == 'number') return i.fromNumber(d); if (o.isString(d)) if (o.Long) d = o.Long.fromString(d); else return i.fromNumber(parseInt(d, 10)); return d.low || d.high ? new i(d.low >>> 0, d.high >>> 0) : u; }), (i.prototype.toNumber = function (d) { if (!d && this.hi >>> 31) { var f = (~this.lo + 1) >>> 0, r = ~this.hi >>> 0; return f || (r = (r + 1) >>> 0), -(f + r * 4294967296); } return this.lo + this.hi * 4294967296; }), (i.prototype.toLong = function (d) { return o.Long ? new o.Long(this.lo | 0, this.hi | 0, !!d) : { low: this.lo | 0, high: this.hi | 0, unsigned: !!d }; }); var s = String.prototype.charCodeAt; (i.fromHash = function (d) { return d === n ? u : new i( (s.call(d, 0) | (s.call(d, 1) << 8) | (s.call(d, 2) << 16) | (s.call(d, 3) << 24)) >>> 0, (s.call(d, 4) | (s.call(d, 5) << 8) | (s.call(d, 6) << 16) | (s.call(d, 7) << 24)) >>> 0 ); }), (i.prototype.toHash = function () { return String.fromCharCode( this.lo & 255, (this.lo >>> 8) & 255, (this.lo >>> 16) & 255, this.lo >>> 24, this.hi & 255, (this.hi >>> 8) & 255, (this.hi >>> 16) & 255, this.hi >>> 24 ); }), (i.prototype.zzEncode = function () { var d = this.hi >> 31; return ( (this.hi = (((this.hi << 1) | (this.lo >>> 31)) ^ d) >>> 0), (this.lo = ((this.lo << 1) ^ d) >>> 0), this ); }), (i.prototype.zzDecode = function () { var d = -(this.lo & 1); return ( (this.lo = (((this.lo >>> 1) | (this.hi << 31)) ^ d) >>> 0), (this.hi = ((this.hi >>> 1) ^ d) >>> 0), this ); }), (i.prototype.length = function () { var d = this.lo, f = ((this.lo >>> 28) | (this.hi << 4)) >>> 0, r = this.hi >>> 24; return r === 0 ? f === 0 ? d < 16384 ? d < 128 ? 1 : 2 : d < 2097152 ? 3 : 4 : f < 16384 ? f < 128 ? 5 : 6 : f < 2097152 ? 7 : 8 : r < 128 ? 9 : 10; }); }), Xt = me((t) => { var e = t; (e.asPromise = ks()), (e.base64 = Ms()), (e.EventEmitter = Us()), (e.float = Ys()), (e.inquire = Xs()), (e.utf8 = Js()), (e.pool = Qs()), (e.LongBits = tu()), (e.isNode = !!( typeof global < 'u' && global && global.process && global.process.versions && global.process.versions.node )), (e.global = (e.isNode && global) || (typeof window < 'u' && window) || (typeof self < 'u' && self) || t), (e.emptyArray = Object.freeze ? Object.freeze([]) : []), (e.emptyObject = Object.freeze ? Object.freeze({}) : {}), (e.isInteger = Number.isInteger || function (u) { return typeof u == 'number' && isFinite(u) && Math.floor(u) === u; }), (e.isString = function (u) { return typeof u == 'string' || u instanceof String; }), (e.isObject = function (u) { return u && typeof u == 'object'; }), (e.isset = e.isSet = function (u, n) { var s = u[n]; return s != null && u.hasOwnProperty(n) ? typeof s != 'object' || (Array.isArray(s) ? s.length : Object.keys(s).length) > 0 : !1; }), (e.Buffer = (function () { try { var u = e.inquire('buffer').Buffer; return u.prototype.utf8Write ? u : null; } catch { return null; } })()), (e._Buffer_from = null), (e._Buffer_allocUnsafe = null), (e.newBuffer = function (u) { return typeof u == 'number' ? e.Buffer ? e._Buffer_allocUnsafe(u) : new e.Array(u) : e.Buffer ? e._Buffer_from(u) : typeof Uint8Array > 'u' ? u : new Uint8Array(u); }), (e.Array = typeof Uint8Array < 'u' ? Uint8Array : Array), (e.Long = (e.global.dcodeIO && e.global.dcodeIO.Long) || e.global.Long || e.inquire('long')), (e.key2Re = /^true|false|0|1$/), (e.key32Re = /^-?(?:0|[1-9][0-9]*)$/), (e.key64Re = /^(?:[\\x00-\\xff]{8}|-?(?:0|[1-9][0-9]*))$/), (e.longToHash = function (u) { return u ? e.LongBits.from(u).toHash() : e.LongBits.zeroHash; }), (e.longFromHash = function (u, n) { var s = e.LongBits.fromHash(u); return e.Long ? e.Long.fromBits(s.lo, s.hi, n) : s.toNumber(!!n); }); function o(u, n, s) { for (var d = Object.keys(n), f = 0; f < d.length; ++f) (u[d[f]] === void 0 || !s) && (u[d[f]] = n[d[f]]); return u; } (e.merge = o), (e.lcFirst = function (u) { return u.charAt(0).toLowerCase() + u.substring(1); }); function i(u) { function n(s, d) { if (!(this instanceof n)) return new n(s, d); Object.defineProperty(this, 'message', { get: function () { return s; }, }), Error.captureStackTrace ? Error.captureStackTrace(this, n) : Object.defineProperty(this, 'stack', { value: new Error().stack || '' }), d && o(this, d); } return ( (n.prototype = Object.create(Error.prototype, { constructor: { value: n, writable: !0, enumerable: !1, configurable: !0 }, name: { get: function () { return u; }, set: void 0, enumerable: !1, configurable: !0, }, toString: { value: function () { return this.name + ': ' + this.message; }, writable: !0, enumerable: !1, configurable: !0, }, })), n ); } (e.newError = i), (e.ProtocolError = i('ProtocolError')), (e.oneOfGetter = function (u) { for (var n = {}, s = 0; s < u.length; ++s) n[u[s]] = 1; return function () { for (var d = Object.keys(this), f = d.length - 1; f > -1; --f) if (n[d[f]] === 1 && this[d[f]] !== void 0 && this[d[f]] !== null) return d[f]; }; }), (e.oneOfSetter = function (u) { return function (n) { for (var s = 0; s < u.length; ++s) u[s] !== n && delete this[u[s]]; }; }), (e.toJSONOptions = { longs: String, enums: String, bytes: String, json: !0 }), (e._configure = function () { var u = e.Buffer; if (!u) { e._Buffer_from = e._Buffer_allocUnsafe = null; return; } (e._Buffer_from = (u.from !== Uint8Array.from && u.from) || function (n, s) { return new u(n, s); }), (e._Buffer_allocUnsafe = u.allocUnsafe || function (n) { return new u(n); }); }); }), li = me((t, e) => { e.exports = a; var o = Xt(), i, u = o.LongBits, n = o.base64, s = o.utf8; function d(E, A, F) { (this.fn = E), (this.len = A), (this.next = void 0), (this.val = F); } function f() {} function r(E) { (this.head = E.head), (this.tail = E.tail), (this.len = E.len), (this.next = E.states); } function a() { (this.len = 0), (this.head = new d(f, 0, 0)), (this.tail = this.head), (this.states = null); } var l = function () { return o.Buffer ? function () { return (a.create = function () { return new i(); })(); } : function () { return new a(); }; }; (a.create = l()), (a.alloc = function (E) { return new o.Array(E); }), o.Array !== Array && (a.alloc = o.pool(a.alloc, o.Array.prototype.subarray)), (a.prototype._push = function (E, A, F) { return (this.tail = this.tail.next = new d(E, A, F)), (this.len += A), this; }); function p(E, A, F) { A[F] = E & 255; } function m(E, A, F) { for (; E > 127; ) (A[F++] = (E & 127) | 128), (E >>>= 7); A[F] = E; } function y(E, A) { (this.len = E), (this.next = void 0), (this.val = A); } (y.prototype = Object.create(d.prototype)), (y.prototype.fn = m), (a.prototype.uint32 = function (E) { return ( (this.len += (this.tail = this.tail.next = new y( (E = E >>> 0) < 128 ? 1 : E < 16384 ? 2 : E < 2097152 ? 3 : E < 268435456 ? 4 : 5, E )).len), this ); }), (a.prototype.int32 = function (E) { return E < 0 ? this._push(T, 10, u.fromNumber(E)) : this.uint32(E); }), (a.prototype.sint32 = function (E) { return this.uint32(((E << 1) ^ (E >> 31)) >>> 0); }); function T(E, A, F) { for (; E.hi; ) (A[F++] = (E.lo & 127) | 128), (E.lo = ((E.lo >>> 7) | (E.hi << 25)) >>> 0), (E.hi >>>= 7); for (; E.lo > 127; ) (A[F++] = (E.lo & 127) | 128), (E.lo = E.lo >>> 7); A[F++] = E.lo; } (a.prototype.uint64 = function (E) { var A = u.from(E); return this._push(T, A.length(), A); }), (a.prototype.int64 = a.prototype.uint64), (a.prototype.sint64 = function (E) { var A = u.from(E).zzEncode(); return this._push(T, A.length(), A); }), (a.prototype.bool = function (E) { return this._push(p, 1, E ? 1 : 0); }); function v(E, A, F) { (A[F] = E & 255), (A[F + 1] = (E >>> 8) & 255), (A[F + 2] = (E >>> 16) & 255), (A[F + 3] = E >>> 24); } (a.prototype.fixed32 = function (E) { return this._push(v, 4, E >>> 0); }), (a.prototype.sfixed32 = a.prototype.fixed32), (a.prototype.fixed64 = function (E) { var A = u.from(E); return this._push(v, 4, A.lo)._push(v, 4, A.hi); }), (a.prototype.sfixed64 = a.prototype.fixed64), (a.prototype.float = function (E) { return this._push(o.float.writeFloatLE, 4, E); }), (a.prototype.double = function (E) { return this._push(o.float.writeDoubleLE, 8, E); }); var S = o.Array.prototype.set ? function (E, A, F) { A.set(E, F); } : function (E, A, F) { for (var B = 0; B < E.length; ++B) A[F + B] = E[B]; }; (a.prototype.bytes = function (E) { var A = E.length >>> 0; if (!A) return this._push(p, 1, 0); if (o.isString(E)) { var F = a.alloc((A = n.length(E))); n.decode(E, F, 0), (E = F); } return this.uint32(A)._push(S, A, E); }), (a.prototype.string = function (E) { var A = s.length(E); return A ? this.uint32(A)._push(s.write, A, E) : this._push(p, 1, 0); }), (a.prototype.fork = function () { return (this.states = new r(this)), (this.head = this.tail = new d(f, 0, 0)), (this.len = 0), this; }), (a.prototype.reset = function () { return ( this.states ? ((this.head = this.states.head), (this.tail = this.states.tail), (this.len = this.states.len), (this.states = this.states.next)) : ((this.head = this.tail = new d(f, 0, 0)), (this.len = 0)), this ); }), (a.prototype.ldelim = function () { var E = this.head, A = this.tail, F = this.len; return this.reset().uint32(F), F && ((this.tail.next = E.next), (this.tail = A), (this.len += F)), this; }), (a.prototype.finish = function () { for (var E = this.head.next, A = this.constructor.alloc(this.len), F = 0; E; ) E.fn(E.val, A, F), (F += E.len), (E = E.next); return A; }), (a._configure = function (E) { (i = E), (a.create = l()), i._configure(); }); }), fu = me((t, e) => { e.exports = u; var o = li(); (u.prototype = Object.create(o.prototype)).constructor = u; var i = Xt(); function u() { o.call(this); } (u._configure = function () { (u.alloc = i._Buffer_allocUnsafe), (u.writeBytesBuffer = i.Buffer && i.Buffer.prototype instanceof Uint8Array && i.Buffer.prototype.set.name === 'set' ? function (s, d, f) { d.set(s, f); } : function (s, d, f) { if (s.copy) s.copy(d, f, 0, s.length); else for (var r = 0; r < s.length; ) d[f++] = s[r++]; }); }), (u.prototype.bytes = function (s) { i.isString(s) && (s = i._Buffer_from(s, 'base64')); var d = s.length >>> 0; return this.uint32(d), d && this._push(u.writeBytesBuffer, d, s), this; }); function n(s, d, f) { s.length < 40 ? i.utf8.write(s, d, f) : d.utf8Write ? d.utf8Write(s, f) : d.write(s, f); } (u.prototype.string = function (s) { var d = i.Buffer.byteLength(s); return this.uint32(d), d && this._push(n, d, s), this; }), u._configure(); }), pi = me((t, e) => { e.exports = d; var o = Xt(), i, u = o.LongBits, n = o.utf8; function s(m, y) { return RangeError('index out of range: ' + m.pos + ' + ' + (y || 1) + ' > ' + m.len); } function d(m) { (this.buf = m), (this.pos = 0), (this.len = m.length); } var f = typeof Uint8Array < 'u' ? function (m) { if (m instanceof Uint8Array || Array.isArray(m)) return new d(m); throw Error('illegal buffer'); } : function (m) { if (Array.isArray(m)) return new d(m); throw Error('illegal buffer'); }, r = function () { return o.Buffer ? function (m) { return (d.create = function (y) { return o.Buffer.isBuffer(y) ? new i(y) : f(y); })(m); } : f; }; (d.create = r()), (d.prototype._slice = o.Array.prototype.subarray || o.Array.prototype.slice), (d.prototype.uint32 = (function () { var m = 4294967295; return function () { if ( ((m = (this.buf[this.pos] & 127) >>> 0), this.buf[this.pos++] < 128 || ((m = (m | ((this.buf[this.pos] & 127) << 7)) >>> 0), this.buf[this.pos++] < 128) || ((m = (m | ((this.buf[this.pos] & 127) << 14)) >>> 0), this.buf[this.pos++] < 128) || ((m = (m | ((this.buf[this.pos] & 127) << 21)) >>> 0), this.buf[this.pos++] < 128) || ((m = (m | ((this.buf[this.pos] & 15) << 28)) >>> 0), this.buf[this.pos++] < 128)) ) return m; if ((this.pos += 5) > this.len) throw ((this.pos = this.len), s(this, 10)); return m; }; })()), (d.prototype.int32 = function () { return this.uint32() | 0; }), (d.prototype.sint32 = function () { var m = this.uint32(); return ((m >>> 1) ^ -(m & 1)) | 0; }); function a() { var m = new u(0, 0), y = 0; if (this.len - this.pos > 4) { for (; y < 4; ++y) if (((m.lo = (m.lo | ((this.buf[this.pos] & 127) << (y * 7))) >>> 0), this.buf[this.pos++] < 128)) return m; if ( ((m.lo = (m.lo | ((this.buf[this.pos] & 127) << 28)) >>> 0), (m.hi = (m.hi | ((this.buf[this.pos] & 127) >> 4)) >>> 0), this.buf[this.pos++] < 128) ) return m; y = 0; } else { for (; y < 3; ++y) { if (this.pos >= this.len) throw s(this); if (((m.lo = (m.lo | ((this.buf[this.pos] & 127) << (y * 7))) >>> 0), this.buf[this.pos++] < 128)) return m; } return (m.lo = (m.lo | ((this.buf[this.pos++] & 127) << (y * 7))) >>> 0), m; } if (this.len - this.pos > 4) { for (; y < 5; ++y) if ( ((m.hi = (m.hi | ((this.buf[this.pos] & 127) << (y * 7 + 3))) >>> 0), this.buf[this.pos++] < 128) ) return m; } else for (; y < 5; ++y) { if (this.pos >= this.len) throw s(this); if ( ((m.hi = (m.hi | ((this.buf[this.pos] & 127) << (y * 7 + 3))) >>> 0), this.buf[this.pos++] < 128) ) return m; } throw Error('invalid varint encoding'); } d.prototype.bool = function () { return this.uint32() !== 0; }; function l(m, y) { return (m[y - 4] | (m[y - 3] << 8) | (m[y - 2] << 16) | (m[y - 1] << 24)) >>> 0; } (d.prototype.fixed32 = function () { if (this.pos + 4 > this.len) throw s(this, 4); return l(this.buf, (this.pos += 4)); }), (d.prototype.sfixed32 = function () { if (this.pos + 4 > this.len) throw s(this, 4); return l(this.buf, (this.pos += 4)) | 0; }); function p() { if (this.pos + 8 > this.len) throw s(this, 8); return new u(l(this.buf, (this.pos += 4)), l(this.buf, (this.pos += 4))); } (d.prototype.float = function () { if (this.pos + 4 > this.len) throw s(this, 4); var m = o.float.readFloatLE(this.buf, this.pos); return (this.pos += 4), m; }), (d.prototype.double = function () { if (this.pos + 8 > this.len) throw s(this, 4); var m = o.float.readDoubleLE(this.buf, this.pos); return (this.pos += 8), m; }), (d.prototype.bytes = function () { var m = this.uint32(), y = this.pos, T = this.pos + m; if (T > this.len) throw s(this, m); return ( (this.pos += m), Array.isArray(this.buf) ? this.buf.slice(y, T) : y === T ? new this.buf.constructor(0) : this._slice.call(this.buf, y, T) ); }), (d.prototype.string = function () { var m = this.bytes(); return n.read(m, 0, m.length); }), (d.prototype.skip = function (m) { if (typeof m == 'number') { if (this.pos + m > this.len) throw s(this, m); this.pos += m; } else do if (this.pos >= this.len) throw s(this); while (this.buf[this.pos++] & 128); return this; }), (d.prototype.skipType = function (m) { switch (m) { case 0: this.skip(); break; case 1: this.skip(8); break; case 2: this.skip(this.uint32()); break; case 3: for (; (m = this.uint32() & 7) !== 4; ) this.skipType(m); break; case 5: this.skip(4); break; default: throw Error('invalid wire type ' + m + ' at offset ' + this.pos); } return this; }), (d._configure = function (m) { (i = m), (d.create = r()), i._configure(); var y = o.Long ? 'toLong' : 'toNumber'; o.merge(d.prototype, { int64: function () { return a.call(this)[y](!1); }, uint64: function () { return a.call(this)[y](!0); }, sint64: function () { return a.call(this).zzDecode()[y](!1); }, fixed64: function () { return p.call(this)[y](!0); }, sfixed64: function () { return p.call(this)[y](!1); }, }); }); }), Tu = me((t, e) => { e.exports = u; var o = pi(); (u.prototype = Object.create(o.prototype)).constructor = u; var i = Xt(); function u(n) { o.call(this, n); } (u._configure = function () { i.Buffer && (u.prototype._slice = i.Buffer.prototype.slice); }), (u.prototype.string = function () { var n = this.uint32(); return this.buf.utf8Slice ? this.buf.utf8Slice(this.pos, (this.pos = Math.min(this.pos + n, this.len))) : this.buf.toString('utf-8', this.pos, (this.pos = Math.min(this.pos + n, this.len))); }), u._configure(); }), vu = me((t, e) => { e.exports = i; var o = Xt(); (i.prototype = Object.create(o.EventEmitter.prototype)).constructor = i; function i(u, n, s) { if (typeof u != 'function') throw TypeError('rpcImpl must be a function'); o.EventEmitter.call(this), (this.rpcImpl = u), (this.requestDelimited = !!n), (this.responseDelimited = !!s); } (i.prototype.rpcCall = function u(n, s, d, f, r) { if (!f) throw TypeError('request must be specified'); var a = this; if (!r) return o.asPromise(u, a, n, s, d, f); if (!a.rpcImpl) { setTimeout(function () { r(Error('already ended')); }, 0); return; } try { return a.rpcImpl(n, s[a.requestDelimited ? 'encodeDelimited' : 'encode'](f).finish(), function (l, p) { if (l) return a.emit('error', l, n), r(l); if (p === null) { a.end(!0); return; } if (!(p instanceof d)) try { p = d[a.responseDelimited ? 'decodeDelimited' : 'decode'](p); } catch (m) { return a.emit('error', m, n), r(m); } return a.emit('data', p, n), r(null, p); }); } catch (l) { a.emit('error', l, n), setTimeout(function () { r(l); }, 0); return; } }), (i.prototype.end = function (u) { return ( this.rpcImpl && (u || this.rpcImpl(null, null, null), (this.rpcImpl = null), this.emit('end').off()), this ); }); }), _u = me((t) => { var e = t; e.Service = vu(); }), Iu = me((t, e) => { e.exports = {}; }), Pu = me((t) => { var e = t; (e.build = 'minimal'), (e.Writer = li()), (e.BufferWriter = fu()), (e.Reader = pi()), (e.BufferReader = Tu()), (e.util = Xt()), (e.rpc = _u()), (e.roots = Iu()), (e.configure = o); function o() { e.util._configure(), e.Writer._configure(e.BufferWriter), e.Reader._configure(e.BufferReader); } o(); }), Du = me((t, e) => { e.exports = Pu(); }), $r = me((t, e) => { var o = Du(), i = o.Reader, u = o.Writer, n = o.util, s = o.roots.default || (o.roots.default = {}); (s.onnx = (function () { var d = {}; return ( (d.Version = (function () { var f = {}, r = Object.create(f); return ( (r[(f[0] = '_START_VERSION')] = 0), (r[(f[1] = 'IR_VERSION_2017_10_10')] = 1), (r[(f[2] = 'IR_VERSION_2017_10_30')] = 2), (r[(f[3] = 'IR_VERSION_2017_11_3')] = 3), (r[(f[4] = 'IR_VERSION_2019_1_22')] = 4), (r[(f[5] = 'IR_VERSION_2019_3_18')] = 5), (r[(f[6] = 'IR_VERSION_2019_9_19')] = 6), (r[(f[7] = 'IR_VERSION_2020_5_8')] = 7), (r[(f[8] = 'IR_VERSION_2021_7_30')] = 8), (r[(f[9] = 'IR_VERSION')] = 9), r ); })()), (d.AttributeProto = (function () { function f(r) { if ( ((this.floats = []), (this.ints = []), (this.strings = []), (this.tensors = []), (this.graphs = []), (this.sparseTensors = []), (this.typeProtos = []), r) ) for (var a = Object.keys(r), l = 0; l < a.length; ++l) r[a[l]] != null && (this[a[l]] = r[a[l]]); } return ( (f.prototype.name = ''), (f.prototype.refAttrName = ''), (f.prototype.docString = ''), (f.prototype.type = 0), (f.prototype.f = 0), (f.prototype.i = n.Long ? n.Long.fromBits(0, 0, !1) : 0), (f.prototype.s = n.newBuffer([])), (f.prototype.t = null), (f.prototype.g = null), (f.prototype.sparseTensor = null), (f.prototype.tp = null), (f.prototype.floats = n.emptyArray), (f.prototype.ints = n.emptyArray), (f.prototype.strings = n.emptyArray), (f.prototype.tensors = n.emptyArray), (f.prototype.graphs = n.emptyArray), (f.prototype.sparseTensors = n.emptyArray), (f.prototype.typeProtos = n.emptyArray), (f.create = function (r) { return new f(r); }), (f.encode = function (r, a) { if ( (a || (a = u.create()), r.name != null && Object.hasOwnProperty.call(r, 'name') && a.uint32(10).string(r.name), r.f != null && Object.hasOwnProperty.call(r, 'f') && a.uint32(21).float(r.f), r.i != null && Object.hasOwnProperty.call(r, 'i') && a.uint32(24).int64(r.i), r.s != null && Object.hasOwnProperty.call(r, 's') && a.uint32(34).bytes(r.s), r.t != null && Object.hasOwnProperty.call(r, 't') && s.onnx.TensorProto.encode(r.t, a.uint32(42).fork()).ldelim(), r.g != null && Object.hasOwnProperty.call(r, 'g') && s.onnx.GraphProto.encode(r.g, a.uint32(50).fork()).ldelim(), r.floats != null && r.floats.length) ) { a.uint32(58).fork(); for (var l = 0; l < r.floats.length; ++l) a.float(r.floats[l]); a.ldelim(); } if (r.ints != null && r.ints.length) { a.uint32(66).fork(); for (var l = 0; l < r.ints.length; ++l) a.int64(r.ints[l]); a.ldelim(); } if (r.strings != null && r.strings.length) for (var l = 0; l < r.strings.length; ++l) a.uint32(74).bytes(r.strings[l]); if (r.tensors != null && r.tensors.length) for (var l = 0; l < r.tensors.length; ++l) s.onnx.TensorProto.encode(r.tensors[l], a.uint32(82).fork()).ldelim(); if (r.graphs != null && r.graphs.length) for (var l = 0; l < r.graphs.length; ++l) s.onnx.GraphProto.encode(r.graphs[l], a.uint32(90).fork()).ldelim(); if ( (r.docString != null && Object.hasOwnProperty.call(r, 'docString') && a.uint32(106).string(r.docString), r.tp != null && Object.hasOwnProperty.call(r, 'tp') && s.onnx.TypeProto.encode(r.tp, a.uint32(114).fork()).ldelim(), r.typeProtos != null && r.typeProtos.length) ) for (var l = 0; l < r.typeProtos.length; ++l) s.onnx.TypeProto.encode(r.typeProtos[l], a.uint32(122).fork()).ldelim(); if ( (r.type != null && Object.hasOwnProperty.call(r, 'type') && a.uint32(160).int32(r.type), r.refAttrName != null && Object.hasOwnProperty.call(r, 'refAttrName') && a.uint32(170).string(r.refAttrName), r.sparseTensor != null && Object.hasOwnProperty.call(r, 'sparseTensor') && s.onnx.SparseTensorProto.encode(r.sparseTensor, a.uint32(178).fork()).ldelim(), r.sparseTensors != null && r.sparseTensors.length) ) for (var l = 0; l < r.sparseTensors.length; ++l) s.onnx.SparseTensorProto.encode(r.sparseTensors[l], a.uint32(186).fork()).ldelim(); return a; }), (f.encodeDelimited = function (r, a) { return this.encode(r, a).ldelim(); }), (f.decode = function (r, a) { r instanceof i || (r = i.create(r)); for ( var l = a === void 0 ? r.len : r.pos + a, p = new s.onnx.AttributeProto(); r.pos < l; ) { var m = r.uint32(); switch (m >>> 3) { case 1: { p.name = r.string(); break; } case 21: { p.refAttrName = r.string(); break; } case 13: { p.docString = r.string(); break; } case 20: { p.type = r.int32(); break; } case 2: { p.f = r.float(); break; } case 3: { p.i = r.int64(); break; } case 4: { p.s = r.bytes(); break; } case 5: { p.t = s.onnx.TensorProto.decode(r, r.uint32()); break; } case 6: { p.g = s.onnx.GraphProto.decode(r, r.uint32()); break; } case 22: { p.sparseTensor = s.onnx.SparseTensorProto.decode(r, r.uint32()); break; } case 14: { p.tp = s.onnx.TypeProto.decode(r, r.uint32()); break; } case 7: { if (((p.floats && p.floats.length) || (p.floats = []), (m & 7) === 2)) for (var y = r.uint32() + r.pos; r.pos < y; ) p.floats.push(r.float()); else p.floats.push(r.float()); break; } case 8: { if (((p.ints && p.ints.length) || (p.ints = []), (m & 7) === 2)) for (var y = r.uint32() + r.pos; r.pos < y; ) p.ints.push(r.int64()); else p.ints.push(r.int64()); break; } case 9: { (p.strings && p.strings.length) || (p.strings = []), p.strings.push(r.bytes()); break; } case 10: { (p.tensors && p.tensors.length) || (p.tensors = []), p.tensors.push(s.onnx.TensorProto.decode(r, r.uint32())); break; } case 11: { (p.graphs && p.graphs.length) || (p.graphs = []), p.graphs.push(s.onnx.GraphProto.decode(r, r.uint32())); break; } case 23: { (p.sparseTensors && p.sparseTensors.length) || (p.sparseTensors = []), p.sparseTensors.push(s.onnx.SparseTensorProto.decode(r, r.uint32())); break; } case 15: { (p.typeProtos && p.typeProtos.length) || (p.typeProtos = []), p.typeProtos.push(s.onnx.TypeProto.decode(r, r.uint32())); break; } default: r.skipType(m & 7); break; } } return p; }), (f.decodeDelimited = function (r) { return r instanceof i || (r = new i(r)), this.decode(r, r.uint32()); }), (f.verify = function (r) { if (typeof r != 'object' || r === null) return 'object expected'; if (r.name != null && r.hasOwnProperty('name') && !n.isString(r.name)) return 'name: string expected'; if (r.refAttrName != null && r.hasOwnProperty('refAttrName') && !n.isString(r.refAttrName)) return 'refAttrName: string expected'; if (r.docString != null && r.hasOwnProperty('docString') && !n.isString(r.docString)) return 'docString: string expected'; if (r.type != null && r.hasOwnProperty('type')) switch (r.type) { default: return 'type: enum value expected'; case 0: case 1: case 2: case 3: case 4: case 5: case 11: case 13: case 6: case 7: case 8: case 9: case 10: case 12: case 14: break; } if (r.f != null && r.hasOwnProperty('f') && typeof r.f != 'number') return 'f: number expected'; if ( r.i != null && r.hasOwnProperty('i') && !n.isInteger(r.i) && !(r.i && n.isInteger(r.i.low) && n.isInteger(r.i.high)) ) return 'i: integer|Long expected'; if ( r.s != null && r.hasOwnProperty('s') && !((r.s && typeof r.s.length == 'number') || n.isString(r.s)) ) return 's: buffer expected'; if (r.t != null && r.hasOwnProperty('t')) { var a = s.onnx.TensorProto.verify(r.t); if (a) return 't.' + a; } if (r.g != null && r.hasOwnProperty('g')) { var a = s.onnx.GraphProto.verify(r.g); if (a) return 'g.' + a; } if (r.sparseTensor != null && r.hasOwnProperty('sparseTensor')) { var a = s.onnx.SparseTensorProto.verify(r.sparseTensor); if (a) return 'sparseTensor.' + a; } if (r.tp != null && r.hasOwnProperty('tp')) { var a = s.onnx.TypeProto.verify(r.tp); if (a) return 'tp.' + a; } if (r.floats != null && r.hasOwnProperty('floats')) { if (!Array.isArray(r.floats)) return 'floats: array expected'; for (var l = 0; l < r.floats.length; ++l) if (typeof r.floats[l] != 'number') return 'floats: number[] expected'; } if (r.ints != null && r.hasOwnProperty('ints')) { if (!Array.isArray(r.ints)) return 'ints: array expected'; for (var l = 0; l < r.ints.length; ++l) if ( !n.isInteger(r.ints[l]) && !(r.ints[l] && n.isInteger(r.ints[l].low) && n.isInteger(r.ints[l].high)) ) return 'ints: integer|Long[] expected'; } if (r.strings != null && r.hasOwnProperty('strings')) { if (!Array.isArray(r.strings)) return 'strings: array expected'; for (var l = 0; l < r.strings.length; ++l) if ( !( (r.strings[l] && typeof r.strings[l].length == 'number') || n.isString(r.strings[l]) ) ) return 'strings: buffer[] expected'; } if (r.tensors != null && r.hasOwnProperty('tensors')) { if (!Array.isArray(r.tensors)) return 'tensors: array expected'; for (var l = 0; l < r.tensors.length; ++l) { var a = s.onnx.TensorProto.verify(r.tensors[l]); if (a) return 'tensors.' + a; } } if (r.graphs != null && r.hasOwnProperty('graphs')) { if (!Array.isArray(r.graphs)) return 'graphs: array expected'; for (var l = 0; l < r.graphs.length; ++l) { var a = s.onnx.GraphProto.verify(r.graphs[l]); if (a) return 'graphs.' + a; } } if (r.sparseTensors != null && r.hasOwnProperty('sparseTensors')) { if (!Array.isArray(r.sparseTensors)) return 'sparseTensors: array expected'; for (var l = 0; l < r.sparseTensors.length; ++l) { var a = s.onnx.SparseTensorProto.verify(r.sparseTensors[l]); if (a) return 'sparseTensors.' + a; } } if (r.typeProtos != null && r.hasOwnProperty('typeProtos')) { if (!Array.isArray(r.typeProtos)) return 'typeProtos: array expected'; for (var l = 0; l < r.typeProtos.length; ++l) { var a = s.onnx.TypeProto.verify(r.typeProtos[l]); if (a) return 'typeProtos.' + a; } } return null; }), (f.fromObject = function (r) { if (r instanceof s.onnx.AttributeProto) return r; var a = new s.onnx.AttributeProto(); switch ( (r.name != null && (a.name = String(r.name)), r.refAttrName != null && (a.refAttrName = String(r.refAttrName)), r.docString != null && (a.docString = String(r.docString)), r.type) ) { default: if (typeof r.type == 'number') { a.type = r.type; break; } break; case 'UNDEFINED': case 0: a.type = 0; break; case 'FLOAT': case 1: a.type = 1; break; case 'INT': case 2: a.type = 2; break; case 'STRING': case 3: a.type = 3; break; case 'TENSOR': case 4: a.type = 4; break; case 'GRAPH': case 5: a.type = 5; break; case 'SPARSE_TENSOR': case 11: a.type = 11; break; case 'TYPE_PROTO': case 13: a.type = 13; break; case 'FLOATS': case 6: a.type = 6; break; case 'INTS': case 7: a.type = 7; break; case 'STRINGS': case 8: a.type = 8; break; case 'TENSORS': case 9: a.type = 9; break; case 'GRAPHS': case 10: a.type = 10; break; case 'SPARSE_TENSORS': case 12: a.type = 12; break; case 'TYPE_PROTOS': case 14: a.type = 14; break; } if ( (r.f != null && (a.f = Number(r.f)), r.i != null && (n.Long ? ((a.i = n.Long.fromValue(r.i)).unsigned = !1) : typeof r.i == 'string' ? (a.i = parseInt(r.i, 10)) : typeof r.i == 'number' ? (a.i = r.i) : typeof r.i == 'object' && (a.i = new n.LongBits(r.i.low >>> 0, r.i.high >>> 0).toNumber())), r.s != null && (typeof r.s == 'string' ? n.base64.decode(r.s, (a.s = n.newBuffer(n.base64.length(r.s))), 0) : r.s.length >= 0 && (a.s = r.s)), r.t != null) ) { if (typeof r.t != 'object') throw TypeError('.onnx.AttributeProto.t: object expected'); a.t = s.onnx.TensorProto.fromObject(r.t); } if (r.g != null) { if (typeof r.g != 'object') throw TypeError('.onnx.AttributeProto.g: object expected'); a.g = s.onnx.GraphProto.fromObject(r.g); } if (r.sparseTensor != null) { if (typeof r.sparseTensor != 'object') throw TypeError('.onnx.AttributeProto.sparseTensor: object expected'); a.sparseTensor = s.onnx.SparseTensorProto.fromObject(r.sparseTensor); } if (r.tp != null) { if (typeof r.tp != 'object') throw TypeError('.onnx.AttributeProto.tp: object expected'); a.tp = s.onnx.TypeProto.fromObject(r.tp); } if (r.floats) { if (!Array.isArray(r.floats)) throw TypeError('.onnx.AttributeProto.floats: array expected'); a.floats = []; for (var l = 0; l < r.floats.length; ++l) a.floats[l] = Number(r.floats[l]); } if (r.ints) { if (!Array.isArray(r.ints)) throw TypeError('.onnx.AttributeProto.ints: array expected'); a.ints = []; for (var l = 0; l < r.ints.length; ++l) n.Long ? ((a.ints[l] = n.Long.fromValue(r.ints[l])).unsigned = !1) : typeof r.ints[l] == 'string' ? (a.ints[l] = parseInt(r.ints[l], 10)) : typeof r.ints[l] == 'number' ? (a.ints[l] = r.ints[l]) : typeof r.ints[l] == 'object' && (a.ints[l] = new n.LongBits( r.ints[l].low >>> 0, r.ints[l].high >>> 0 ).toNumber()); } if (r.strings) { if (!Array.isArray(r.strings)) throw TypeError('.onnx.AttributeProto.strings: array expected'); a.strings = []; for (var l = 0; l < r.strings.length; ++l) typeof r.strings[l] == 'string' ? n.base64.decode( r.strings[l], (a.strings[l] = n.newBuffer(n.base64.length(r.strings[l]))), 0 ) : r.strings[l].length >= 0 && (a.strings[l] = r.strings[l]); } if (r.tensors) { if (!Array.isArray(r.tensors)) throw TypeError('.onnx.AttributeProto.tensors: array expected'); a.tensors = []; for (var l = 0; l < r.tensors.length; ++l) { if (typeof r.tensors[l] != 'object') throw TypeError('.onnx.AttributeProto.tensors: object expected'); a.tensors[l] = s.onnx.TensorProto.fromObject(r.tensors[l]); } } if (r.graphs) { if (!Array.isArray(r.graphs)) throw TypeError('.onnx.AttributeProto.graphs: array expected'); a.graphs = []; for (var l = 0; l < r.graphs.length; ++l) { if (typeof r.graphs[l] != 'object') throw TypeError('.onnx.AttributeProto.graphs: object expected'); a.graphs[l] = s.onnx.GraphProto.fromObject(r.graphs[l]); } } if (r.sparseTensors) { if (!Array.isArray(r.sparseTensors)) throw TypeError('.onnx.AttributeProto.sparseTensors: array expected'); a.sparseTensors = []; for (var l = 0; l < r.sparseTensors.length; ++l) { if (typeof r.sparseTensors[l] != 'object') throw TypeError('.onnx.AttributeProto.sparseTensors: object expected'); a.sparseTensors[l] = s.onnx.SparseTensorProto.fromObject(r.sparseTensors[l]); } } if (r.typeProtos) { if (!Array.isArray(r.typeProtos)) throw TypeError('.onnx.AttributeProto.typeProtos: array expected'); a.typeProtos = []; for (var l = 0; l < r.typeProtos.length; ++l) { if (typeof r.typeProtos[l] != 'object') throw TypeError('.onnx.AttributeProto.typeProtos: object expected'); a.typeProtos[l] = s.onnx.TypeProto.fromObject(r.typeProtos[l]); } } return a; }), (f.toObject = function (r, a) { a || (a = {}); var l = {}; if ( ((a.arrays || a.defaults) && ((l.floats = []), (l.ints = []), (l.strings = []), (l.tensors = []), (l.graphs = []), (l.typeProtos = []), (l.sparseTensors = [])), a.defaults) ) { if (((l.name = ''), (l.f = 0), n.Long)) { var p = new n.Long(0, 0, !1); l.i = a.longs === String ? p.toString() : a.longs === Number ? p.toNumber() : p; } else l.i = a.longs === String ? '0' : 0; a.bytes === String ? (l.s = '') : ((l.s = []), a.bytes !== Array && (l.s = n.newBuffer(l.s))), (l.t = null), (l.g = null), (l.docString = ''), (l.tp = null), (l.type = a.enums === String ? 'UNDEFINED' : 0), (l.refAttrName = ''), (l.sparseTensor = null); } if ( (r.name != null && r.hasOwnProperty('name') && (l.name = r.name), r.f != null && r.hasOwnProperty('f') && (l.f = a.json && !isFinite(r.f) ? String(r.f) : r.f), r.i != null && r.hasOwnProperty('i') && (typeof r.i == 'number' ? (l.i = a.longs === String ? String(r.i) : r.i) : (l.i = a.longs === String ? n.Long.prototype.toString.call(r.i) : a.longs === Number ? new n.LongBits(r.i.low >>> 0, r.i.high >>> 0).toNumber() : r.i)), r.s != null && r.hasOwnProperty('s') && (l.s = a.bytes === String ? n.base64.encode(r.s, 0, r.s.length) : a.bytes === Array ? Array.prototype.slice.call(r.s) : r.s), r.t != null && r.hasOwnProperty('t') && (l.t = s.onnx.TensorProto.toObject(r.t, a)), r.g != null && r.hasOwnProperty('g') && (l.g = s.onnx.GraphProto.toObject(r.g, a)), r.floats && r.floats.length) ) { l.floats = []; for (var m = 0; m < r.floats.length; ++m) l.floats[m] = a.json && !isFinite(r.floats[m]) ? String(r.floats[m]) : r.floats[m]; } if (r.ints && r.ints.length) { l.ints = []; for (var m = 0; m < r.ints.length; ++m) typeof r.ints[m] == 'number' ? (l.ints[m] = a.longs === String ? String(r.ints[m]) : r.ints[m]) : (l.ints[m] = a.longs === String ? n.Long.prototype.toString.call(r.ints[m]) : a.longs === Number ? new n.LongBits(r.ints[m].low >>> 0, r.ints[m].high >>> 0).toNumber() : r.ints[m]); } if (r.strings && r.strings.length) { l.strings = []; for (var m = 0; m < r.strings.length; ++m) l.strings[m] = a.bytes === String ? n.base64.encode(r.strings[m], 0, r.strings[m].length) : a.bytes === Array ? Array.prototype.slice.call(r.strings[m]) : r.strings[m]; } if (r.tensors && r.tensors.length) { l.tensors = []; for (var m = 0; m < r.tensors.length; ++m) l.tensors[m] = s.onnx.TensorProto.toObject(r.tensors[m], a); } if (r.graphs && r.graphs.length) { l.graphs = []; for (var m = 0; m < r.graphs.length; ++m) l.graphs[m] = s.onnx.GraphProto.toObject(r.graphs[m], a); } if ( (r.docString != null && r.hasOwnProperty('docString') && (l.docString = r.docString), r.tp != null && r.hasOwnProperty('tp') && (l.tp = s.onnx.TypeProto.toObject(r.tp, a)), r.typeProtos && r.typeProtos.length) ) { l.typeProtos = []; for (var m = 0; m < r.typeProtos.length; ++m) l.typeProtos[m] = s.onnx.TypeProto.toObject(r.typeProtos[m], a); } if ( (r.type != null && r.hasOwnProperty('type') && (l.type = a.enums === String ? s.onnx.AttributeProto.AttributeType[r.type] === void 0 ? r.type : s.onnx.AttributeProto.AttributeType[r.type] : r.type), r.refAttrName != null && r.hasOwnProperty('refAttrName') && (l.refAttrName = r.refAttrName), r.sparseTensor != null && r.hasOwnProperty('sparseTensor') && (l.sparseTensor = s.onnx.SparseTensorProto.toObject(r.sparseTensor, a)), r.sparseTensors && r.sparseTensors.length) ) { l.sparseTensors = []; for (var m = 0; m < r.sparseTensors.length; ++m) l.sparseTensors[m] = s.onnx.SparseTensorProto.toObject(r.sparseTensors[m], a); } return l; }), (f.prototype.toJSON = function () { return this.constructor.toObject(this, o.util.toJSONOptions); }), (f.getTypeUrl = function (r) { return r === void 0 && (r = 'type.googleapis.com'), r + '/onnx.AttributeProto'; }), (f.AttributeType = (function () { var r = {}, a = Object.create(r); return ( (a[(r[0] = 'UNDEFINED')] = 0), (a[(r[1] = 'FLOAT')] = 1), (a[(r[2] = 'INT')] = 2), (a[(r[3] = 'STRING')] = 3), (a[(r[4] = 'TENSOR')] = 4), (a[(r[5] = 'GRAPH')] = 5), (a[(r[11] = 'SPARSE_TENSOR')] = 11), (a[(r[13] = 'TYPE_PROTO')] = 13), (a[(r[6] = 'FLOATS')] = 6), (a[(r[7] = 'INTS')] = 7), (a[(r[8] = 'STRINGS')] = 8), (a[(r[9] = 'TENSORS')] = 9), (a[(r[10] = 'GRAPHS')] = 10), (a[(r[12] = 'SPARSE_TENSORS')] = 12), (a[(r[14] = 'TYPE_PROTOS')] = 14), a ); })()), f ); })()), (d.ValueInfoProto = (function () { function f(r) { if (r) for (var a = Object.keys(r), l = 0; l < a.length; ++l) r[a[l]] != null && (this[a[l]] = r[a[l]]); } return ( (f.prototype.name = ''), (f.prototype.type = null), (f.prototype.docString = ''), (f.create = function (r) { return new f(r); }), (f.encode = function (r, a) { return ( a || (a = u.create()), r.name != null && Object.hasOwnProperty.call(r, 'name') && a.uint32(10).string(r.name), r.type != null && Object.hasOwnProperty.call(r, 'type') && s.onnx.TypeProto.encode(r.type, a.uint32(18).fork()).ldelim(), r.docString != null && Object.hasOwnProperty.call(r, 'docString') && a.uint32(26).string(r.docString), a ); }), (f.encodeDelimited = function (r, a) { return this.encode(r, a).ldelim(); }), (f.decode = function (r, a) { r instanceof i || (r = i.create(r)); for ( var l = a === void 0 ? r.len : r.pos + a, p = new s.onnx.ValueInfoProto(); r.pos < l; ) { var m = r.uint32(); switch (m >>> 3) { case 1: { p.name = r.string(); break; } case 2: { p.type = s.onnx.TypeProto.decode(r, r.uint32()); break; } case 3: { p.docString = r.string(); break; } default: r.skipType(m & 7); break; } } return p; }), (f.decodeDelimited = function (r) { return r instanceof i || (r = new i(r)), this.decode(r, r.uint32()); }), (f.verify = function (r) { if (typeof r != 'object' || r === null) return 'object expected'; if (r.name != null && r.hasOwnProperty('name') && !n.isString(r.name)) return 'name: string expected'; if (r.type != null && r.hasOwnProperty('type')) { var a = s.onnx.TypeProto.verify(r.type); if (a) return 'type.' + a; } return r.docString != null && r.hasOwnProperty('docString') && !n.isString(r.docString) ? 'docString: string expected' : null; }), (f.fromObject = function (r) { if (r instanceof s.onnx.ValueInfoProto) return r; var a = new s.onnx.ValueInfoProto(); if ((r.name != null && (a.name = String(r.name)), r.type != null)) { if (typeof r.type != 'object') throw TypeError('.onnx.ValueInfoProto.type: object expected'); a.type = s.onnx.TypeProto.fromObject(r.type); } return r.docString != null && (a.docString = String(r.docString)), a; }), (f.toObject = function (r, a) { a || (a = {}); var l = {}; return ( a.defaults && ((l.name = ''), (l.type = null), (l.docString = '')), r.name != null && r.hasOwnProperty('name') && (l.name = r.name), r.type != null && r.hasOwnProperty('type') && (l.type = s.onnx.TypeProto.toObject(r.type, a)), r.docString != null && r.hasOwnProperty('docString') && (l.docString = r.docString), l ); }), (f.prototype.toJSON = function () { return this.constructor.toObject(this, o.util.toJSONOptions); }), (f.getTypeUrl = function (r) { return r === void 0 && (r = 'type.googleapis.com'), r + '/onnx.ValueInfoProto'; }), f ); })()), (d.NodeProto = (function () { function f(r) { if (((this.input = []), (this.output = []), (this.attribute = []), r)) for (var a = Object.keys(r), l = 0; l < a.length; ++l) r[a[l]] != null && (this[a[l]] = r[a[l]]); } return ( (f.prototype.input = n.emptyArray), (f.prototype.output = n.emptyArray), (f.prototype.name = ''), (f.prototype.opType = ''), (f.prototype.domain = ''), (f.prototype.attribute = n.emptyArray), (f.prototype.docString = ''), (f.create = function (r) { return new f(r); }), (f.encode = function (r, a) { if ((a || (a = u.create()), r.input != null && r.input.length)) for (var l = 0; l < r.input.length; ++l) a.uint32(10).string(r.input[l]); if (r.output != null && r.output.length) for (var l = 0; l < r.output.length; ++l) a.uint32(18).string(r.output[l]); if ( (r.name != null && Object.hasOwnProperty.call(r, 'name') && a.uint32(26).string(r.name), r.opType != null && Object.hasOwnProperty.call(r, 'opType') && a.uint32(34).string(r.opType), r.attribute != null && r.attribute.length) ) for (var l = 0; l < r.attribute.length; ++l) s.onnx.AttributeProto.encode(r.attribute[l], a.uint32(42).fork()).ldelim(); return ( r.docString != null && Object.hasOwnProperty.call(r, 'docString') && a.uint32(50).string(r.docString), r.domain != null && Object.hasOwnProperty.call(r, 'domain') && a.uint32(58).string(r.domain), a ); }), (f.encodeDelimited = function (r, a) { return this.encode(r, a).ldelim(); }), (f.decode = function (r, a) { r instanceof i || (r = i.create(r)); for (var l = a === void 0 ? r.len : r.pos + a, p = new s.onnx.NodeProto(); r.pos < l; ) { var m = r.uint32(); switch (m >>> 3) { case 1: { (p.input && p.input.length) || (p.input = []), p.input.push(r.string()); break; } case 2: { (p.output && p.output.length) || (p.output = []), p.output.push(r.string()); break; } case 3: { p.name = r.string(); break; } case 4: { p.opType = r.string(); break; } case 7: { p.domain = r.string(); break; } case 5: { (p.attribute && p.attribute.length) || (p.attribute = []), p.attribute.push(s.onnx.AttributeProto.decode(r, r.uint32())); break; } case 6: { p.docString = r.string(); break; } default: r.skipType(m & 7); break; } } return p; }), (f.decodeDelimited = function (r) { return r instanceof i || (r = new i(r)), this.decode(r, r.uint32()); }), (f.verify = function (r) { if (typeof r != 'object' || r === null) return 'object expected'; if (r.input != null && r.hasOwnProperty('input')) { if (!Array.isArray(r.input)) return 'input: array expected'; for (var a = 0; a < r.input.length; ++a) if (!n.isString(r.input[a])) return 'input: string[] expected'; } if (r.output != null && r.hasOwnProperty('output')) { if (!Array.isArray(r.output)) return 'output: array expected'; for (var a = 0; a < r.output.length; ++a) if (!n.isString(r.output[a])) return 'output: string[] expected'; } if (r.name != null && r.hasOwnProperty('name') && !n.isString(r.name)) return 'name: string expected'; if (r.opType != null && r.hasOwnProperty('opType') && !n.isString(r.opType)) return 'opType: string expected'; if (r.domain != null && r.hasOwnProperty('domain') && !n.isString(r.domain)) return 'domain: string expected'; if (r.attribute != null && r.hasOwnProperty('attribute')) { if (!Array.isArray(r.attribute)) return 'attribute: array expected'; for (var a = 0; a < r.attribute.length; ++a) { var l = s.onnx.AttributeProto.verify(r.attribute[a]); if (l) return 'attribute.' + l; } } return r.docString != null && r.hasOwnProperty('docString') && !n.isString(r.docString) ? 'docString: string expected' : null; }), (f.fromObject = function (r) { if (r instanceof s.onnx.NodeProto) return r; var a = new s.onnx.NodeProto(); if (r.input) { if (!Array.isArray(r.input)) throw TypeError('.onnx.NodeProto.input: array expected'); a.input = []; for (var l = 0; l < r.input.length; ++l) a.input[l] = String(r.input[l]); } if (r.output) { if (!Array.isArray(r.output)) throw TypeError('.onnx.NodeProto.output: array expected'); a.output = []; for (var l = 0; l < r.output.length; ++l) a.output[l] = String(r.output[l]); } if ( (r.name != null && (a.name = String(r.name)), r.opType != null && (a.opType = String(r.opType)), r.domain != null && (a.domain = String(r.domain)), r.attribute) ) { if (!Array.isArray(r.attribute)) throw TypeError('.onnx.NodeProto.attribute: array expected'); a.attribute = []; for (var l = 0; l < r.attribute.length; ++l) { if (typeof r.attribute[l] != 'object') throw TypeError('.onnx.NodeProto.attribute: object expected'); a.attribute[l] = s.onnx.AttributeProto.fromObject(r.attribute[l]); } } return r.docString != null && (a.docString = String(r.docString)), a; }), (f.toObject = function (r, a) { a || (a = {}); var l = {}; if ( ((a.arrays || a.defaults) && ((l.input = []), (l.output = []), (l.attribute = [])), a.defaults && ((l.name = ''), (l.opType = ''), (l.docString = ''), (l.domain = '')), r.input && r.input.length) ) { l.input = []; for (var p = 0; p < r.input.length; ++p) l.input[p] = r.input[p]; } if (r.output && r.output.length) { l.output = []; for (var p = 0; p < r.output.length; ++p) l.output[p] = r.output[p]; } if ( (r.name != null && r.hasOwnProperty('name') && (l.name = r.name), r.opType != null && r.hasOwnProperty('opType') && (l.opType = r.opType), r.attribute && r.attribute.length) ) { l.attribute = []; for (var p = 0; p < r.attribute.length; ++p) l.attribute[p] = s.onnx.AttributeProto.toObject(r.attribute[p], a); } return ( r.docString != null && r.hasOwnProperty('docString') && (l.docString = r.docString), r.domain != null && r.hasOwnProperty('domain') && (l.domain = r.domain), l ); }), (f.prototype.toJSON = function () { return this.constructor.toObject(this, o.util.toJSONOptions); }), (f.getTypeUrl = function (r) { return r === void 0 && (r = 'type.googleapis.com'), r + '/onnx.NodeProto'; }), f ); })()), (d.TrainingInfoProto = (function () { function f(r) { if (((this.initializationBinding = []), (this.updateBinding = []), r)) for (var a = Object.keys(r), l = 0; l < a.length; ++l) r[a[l]] != null && (this[a[l]] = r[a[l]]); } return ( (f.prototype.initialization = null), (f.prototype.algorithm = null), (f.prototype.initializationBinding = n.emptyArray), (f.prototype.updateBinding = n.emptyArray), (f.create = function (r) { return new f(r); }), (f.encode = function (r, a) { if ( (a || (a = u.create()), r.initialization != null && Object.hasOwnProperty.call(r, 'initialization') && s.onnx.GraphProto.encode(r.initialization, a.uint32(10).fork()).ldelim(), r.algorithm != null && Object.hasOwnProperty.call(r, 'algorithm') && s.onnx.GraphProto.encode(r.algorithm, a.uint32(18).fork()).ldelim(), r.initializationBinding != null && r.initializationBinding.length) ) for (var l = 0; l < r.initializationBinding.length; ++l) s.onnx.StringStringEntryProto.encode( r.initializationBinding[l], a.uint32(26).fork() ).ldelim(); if (r.updateBinding != null && r.updateBinding.length) for (var l = 0; l < r.updateBinding.length; ++l) s.onnx.StringStringEntryProto.encode( r.updateBinding[l], a.uint32(34).fork() ).ldelim(); return a; }), (f.encodeDelimited = function (r, a) { return this.encode(r, a).ldelim(); }), (f.decode = function (r, a) { r instanceof i || (r = i.create(r)); for ( var l = a === void 0 ? r.len : r.pos + a, p = new s.onnx.TrainingInfoProto(); r.pos < l; ) { var m = r.uint32(); switch (m >>> 3) { case 1: { p.initialization = s.onnx.GraphProto.decode(r, r.uint32()); break; } case 2: { p.algorithm = s.onnx.GraphProto.decode(r, r.uint32()); break; } case 3: { (p.initializationBinding && p.initializationBinding.length) || (p.initializationBinding = []), p.initializationBinding.push( s.onnx.StringStringEntryProto.decode(r, r.uint32()) ); break; } case 4: { (p.updateBinding && p.updateBinding.length) || (p.updateBinding = []), p.updateBinding.push(s.onnx.StringStringEntryProto.decode(r, r.uint32())); break; } default: r.skipType(m & 7); break; } } return p; }), (f.decodeDelimited = function (r) { return r instanceof i || (r = new i(r)), this.decode(r, r.uint32()); }), (f.verify = function (r) { if (typeof r != 'object' || r === null) return 'object expected'; if (r.initialization != null && r.hasOwnProperty('initialization')) { var a = s.onnx.GraphProto.verify(r.initialization); if (a) return 'initialization.' + a; } if (r.algorithm != null && r.hasOwnProperty('algorithm')) { var a = s.onnx.GraphProto.verify(r.algorithm); if (a) return 'algorithm.' + a; } if (r.initializationBinding != null && r.hasOwnProperty('initializationBinding')) { if (!Array.isArray(r.initializationBinding)) return 'initializationBinding: array expected'; for (var l = 0; l < r.initializationBinding.length; ++l) { var a = s.onnx.StringStringEntryProto.verify(r.initializationBinding[l]); if (a) return 'initializationBinding.' + a; } } if (r.updateBinding != null && r.hasOwnProperty('updateBinding')) { if (!Array.isArray(r.updateBinding)) return 'updateBinding: array expected'; for (var l = 0; l < r.updateBinding.length; ++l) { var a = s.onnx.StringStringEntryProto.verify(r.updateBinding[l]); if (a) return 'updateBinding.' + a; } } return null; }), (f.fromObject = function (r) { if (r instanceof s.onnx.TrainingInfoProto) return r; var a = new s.onnx.TrainingInfoProto(); if (r.initialization != null) { if (typeof r.initialization != 'object') throw TypeError('.onnx.TrainingInfoProto.initialization: object expected'); a.initialization = s.onnx.GraphProto.fromObject(r.initialization); } if (r.algorithm != null) { if (typeof r.algorithm != 'object') throw TypeError('.onnx.TrainingInfoProto.algorithm: object expected'); a.algorithm = s.onnx.GraphProto.fromObject(r.algorithm); } if (r.initializationBinding) { if (!Array.isArray(r.initializationBinding)) throw TypeError('.onnx.TrainingInfoProto.initializationBinding: array expected'); a.initializationBinding = []; for (var l = 0; l < r.initializationBinding.length; ++l) { if (typeof r.initializationBinding[l] != 'object') throw TypeError( '.onnx.TrainingInfoProto.initializationBinding: object expected' ); a.initializationBinding[l] = s.onnx.StringStringEntryProto.fromObject( r.initializationBinding[l] ); } } if (r.updateBinding) { if (!Array.isArray(r.updateBinding)) throw TypeError('.onnx.TrainingInfoProto.updateBinding: array expected'); a.updateBinding = []; for (var l = 0; l < r.updateBinding.length; ++l) { if (typeof r.updateBinding[l] != 'object') throw TypeError('.onnx.TrainingInfoProto.updateBinding: object expected'); a.updateBinding[l] = s.onnx.StringStringEntryProto.fromObject(r.updateBinding[l]); } } return a; }), (f.toObject = function (r, a) { a || (a = {}); var l = {}; if ( ((a.arrays || a.defaults) && ((l.initializationBinding = []), (l.updateBinding = [])), a.defaults && ((l.initialization = null), (l.algorithm = null)), r.initialization != null && r.hasOwnProperty('initialization') && (l.initialization = s.onnx.GraphProto.toObject(r.initialization, a)), r.algorithm != null && r.hasOwnProperty('algorithm') && (l.algorithm = s.onnx.GraphProto.toObject(r.algorithm, a)), r.initializationBinding && r.initializationBinding.length) ) { l.initializationBinding = []; for (var p = 0; p < r.initializationBinding.length; ++p) l.initializationBinding[p] = s.onnx.StringStringEntryProto.toObject( r.initializationBinding[p], a ); } if (r.updateBinding && r.updateBinding.length) { l.updateBinding = []; for (var p = 0; p < r.updateBinding.length; ++p) l.updateBinding[p] = s.onnx.StringStringEntryProto.toObject(r.updateBinding[p], a); } return l; }), (f.prototype.toJSON = function () { return this.constructor.toObject(this, o.util.toJSONOptions); }), (f.getTypeUrl = function (r) { return r === void 0 && (r = 'type.googleapis.com'), r + '/onnx.TrainingInfoProto'; }), f ); })()), (d.ModelProto = (function () { function f(r) { if ( ((this.opsetImport = []), (this.metadataProps = []), (this.trainingInfo = []), (this.functions = []), r) ) for (var a = Object.keys(r), l = 0; l < a.length; ++l) r[a[l]] != null && (this[a[l]] = r[a[l]]); } return ( (f.prototype.irVersion = n.Long ? n.Long.fromBits(0, 0, !1) : 0), (f.prototype.opsetImport = n.emptyArray), (f.prototype.producerName = ''), (f.prototype.producerVersion = ''), (f.prototype.domain = ''), (f.prototype.modelVersion = n.Long ? n.Long.fromBits(0, 0, !1) : 0), (f.prototype.docString = ''), (f.prototype.graph = null), (f.prototype.metadataProps = n.emptyArray), (f.prototype.trainingInfo = n.emptyArray), (f.prototype.functions = n.emptyArray), (f.create = function (r) { return new f(r); }), (f.encode = function (r, a) { if ( (a || (a = u.create()), r.irVersion != null && Object.hasOwnProperty.call(r, 'irVersion') && a.uint32(8).int64(r.irVersion), r.producerName != null && Object.hasOwnProperty.call(r, 'producerName') && a.uint32(18).string(r.producerName), r.producerVersion != null && Object.hasOwnProperty.call(r, 'producerVersion') && a.uint32(26).string(r.producerVersion), r.domain != null && Object.hasOwnProperty.call(r, 'domain') && a.uint32(34).string(r.domain), r.modelVersion != null && Object.hasOwnProperty.call(r, 'modelVersion') && a.uint32(40).int64(r.modelVersion), r.docString != null && Object.hasOwnProperty.call(r, 'docString') && a.uint32(50).string(r.docString), r.graph != null && Object.hasOwnProperty.call(r, 'graph') && s.onnx.GraphProto.encode(r.graph, a.uint32(58).fork()).ldelim(), r.opsetImport != null && r.opsetImport.length) ) for (var l = 0; l < r.opsetImport.length; ++l) s.onnx.OperatorSetIdProto.encode(r.opsetImport[l], a.uint32(66).fork()).ldelim(); if (r.metadataProps != null && r.metadataProps.length) for (var l = 0; l < r.metadataProps.length; ++l) s.onnx.StringStringEntryProto.encode( r.metadataProps[l], a.uint32(114).fork() ).ldelim(); if (r.trainingInfo != null && r.trainingInfo.length) for (var l = 0; l < r.trainingInfo.length; ++l) s.onnx.TrainingInfoProto.encode(r.trainingInfo[l], a.uint32(162).fork()).ldelim(); if (r.functions != null && r.functions.length) for (var l = 0; l < r.functions.length; ++l) s.onnx.FunctionProto.encode(r.functions[l], a.uint32(202).fork()).ldelim(); return a; }), (f.encodeDelimited = function (r, a) { return this.encode(r, a).ldelim(); }), (f.decode = function (r, a) { r instanceof i || (r = i.create(r)); for (var l = a === void 0 ? r.len : r.pos + a, p = new s.onnx.ModelProto(); r.pos < l; ) { var m = r.uint32(); switch (m >>> 3) { case 1: { p.irVersion = r.int64(); break; } case 8: { (p.opsetImport && p.opsetImport.length) || (p.opsetImport = []), p.opsetImport.push(s.onnx.OperatorSetIdProto.decode(r, r.uint32())); break; } case 2: { p.producerName = r.string(); break; } case 3: { p.producerVersion = r.string(); break; } case 4: { p.domain = r.string(); break; } case 5: { p.modelVersion = r.int64(); break; } case 6: { p.docString = r.string(); break; } case 7: { p.graph = s.onnx.GraphProto.decode(r, r.uint32()); break; } case 14: { (p.metadataProps && p.metadataProps.length) || (p.metadataProps = []), p.metadataProps.push(s.onnx.StringStringEntryProto.decode(r, r.uint32())); break; } case 20: { (p.trainingInfo && p.trainingInfo.length) || (p.trainingInfo = []), p.trainingInfo.push(s.onnx.TrainingInfoProto.decode(r, r.uint32())); break; } case 25: { (p.functions && p.functions.length) || (p.functions = []), p.functions.push(s.onnx.FunctionProto.decode(r, r.uint32())); break; } default: r.skipType(m & 7); break; } } return p; }), (f.decodeDelimited = function (r) { return r instanceof i || (r = new i(r)), this.decode(r, r.uint32()); }), (f.verify = function (r) { if (typeof r != 'object' || r === null) return 'object expected'; if ( r.irVersion != null && r.hasOwnProperty('irVersion') && !n.isInteger(r.irVersion) && !(r.irVersion && n.isInteger(r.irVersion.low) && n.isInteger(r.irVersion.high)) ) return 'irVersion: integer|Long expected'; if (r.opsetImport != null && r.hasOwnProperty('opsetImport')) { if (!Array.isArray(r.opsetImport)) return 'opsetImport: array expected'; for (var a = 0; a < r.opsetImport.length; ++a) { var l = s.onnx.OperatorSetIdProto.verify(r.opsetImport[a]); if (l) return 'opsetImport.' + l; } } if ( r.producerName != null && r.hasOwnProperty('producerName') && !n.isString(r.producerName) ) return 'producerName: string expected'; if ( r.producerVersion != null && r.hasOwnProperty('producerVersion') && !n.isString(r.producerVersion) ) return 'producerVersion: string expected'; if (r.domain != null && r.hasOwnProperty('domain') && !n.isString(r.domain)) return 'domain: string expected'; if ( r.modelVersion != null && r.hasOwnProperty('modelVersion') && !n.isInteger(r.modelVersion) && !(r.modelVersion && n.isInteger(r.modelVersion.low) && n.isInteger(r.modelVersion.high)) ) return 'modelVersion: integer|Long expected'; if (r.docString != null && r.hasOwnProperty('docString') && !n.isString(r.docString)) return 'docString: string expected'; if (r.graph != null && r.hasOwnProperty('graph')) { var l = s.onnx.GraphProto.verify(r.graph); if (l) return 'graph.' + l; } if (r.metadataProps != null && r.hasOwnProperty('metadataProps')) { if (!Array.isArray(r.metadataProps)) return 'metadataProps: array expected'; for (var a = 0; a < r.metadataProps.length; ++a) { var l = s.onnx.StringStringEntryProto.verify(r.metadataProps[a]); if (l) return 'metadataProps.' + l; } } if (r.trainingInfo != null && r.hasOwnProperty('trainingInfo')) { if (!Array.isArray(r.trainingInfo)) return 'trainingInfo: array expected'; for (var a = 0; a < r.trainingInfo.length; ++a) { var l = s.onnx.TrainingInfoProto.verify(r.trainingInfo[a]); if (l) return 'trainingInfo.' + l; } } if (r.functions != null && r.hasOwnProperty('functions')) { if (!Array.isArray(r.functions)) return 'functions: array expected'; for (var a = 0; a < r.functions.length; ++a) { var l = s.onnx.FunctionProto.verify(r.functions[a]); if (l) return 'functions.' + l; } } return null; }), (f.fromObject = function (r) { if (r instanceof s.onnx.ModelProto) return r; var a = new s.onnx.ModelProto(); if ( (r.irVersion != null && (n.Long ? ((a.irVersion = n.Long.fromValue(r.irVersion)).unsigned = !1) : typeof r.irVersion == 'string' ? (a.irVersion = parseInt(r.irVersion, 10)) : typeof r.irVersion == 'number' ? (a.irVersion = r.irVersion) : typeof r.irVersion == 'object' && (a.irVersion = new n.LongBits( r.irVersion.low >>> 0, r.irVersion.high >>> 0 ).toNumber())), r.opsetImport) ) { if (!Array.isArray(r.opsetImport)) throw TypeError('.onnx.ModelProto.opsetImport: array expected'); a.opsetImport = []; for (var l = 0; l < r.opsetImport.length; ++l) { if (typeof r.opsetImport[l] != 'object') throw TypeError('.onnx.ModelProto.opsetImport: object expected'); a.opsetImport[l] = s.onnx.OperatorSetIdProto.fromObject(r.opsetImport[l]); } } if ( (r.producerName != null && (a.producerName = String(r.producerName)), r.producerVersion != null && (a.producerVersion = String(r.producerVersion)), r.domain != null && (a.domain = String(r.domain)), r.modelVersion != null && (n.Long ? ((a.modelVersion = n.Long.fromValue(r.modelVersion)).unsigned = !1) : typeof r.modelVersion == 'string' ? (a.modelVersion = parseInt(r.modelVersion, 10)) : typeof r.modelVersion == 'number' ? (a.modelVersion = r.modelVersion) : typeof r.modelVersion == 'object' && (a.modelVersion = new n.LongBits( r.modelVersion.low >>> 0, r.modelVersion.high >>> 0 ).toNumber())), r.docString != null && (a.docString = String(r.docString)), r.graph != null) ) { if (typeof r.graph != 'object') throw TypeError('.onnx.ModelProto.graph: object expected'); a.graph = s.onnx.GraphProto.fromObject(r.graph); } if (r.metadataProps) { if (!Array.isArray(r.metadataProps)) throw TypeError('.onnx.ModelProto.metadataProps: array expected'); a.metadataProps = []; for (var l = 0; l < r.metadataProps.length; ++l) { if (typeof r.metadataProps[l] != 'object') throw TypeError('.onnx.ModelProto.metadataProps: object expected'); a.metadataProps[l] = s.onnx.StringStringEntryProto.fromObject(r.metadataProps[l]); } } if (r.trainingInfo) { if (!Array.isArray(r.trainingInfo)) throw TypeError('.onnx.ModelProto.trainingInfo: array expected'); a.trainingInfo = []; for (var l = 0; l < r.trainingInfo.length; ++l) { if (typeof r.trainingInfo[l] != 'object') throw TypeError('.onnx.ModelProto.trainingInfo: object expected'); a.trainingInfo[l] = s.onnx.TrainingInfoProto.fromObject(r.trainingInfo[l]); } } if (r.functions) { if (!Array.isArray(r.functions)) throw TypeError('.onnx.ModelProto.functions: array expected'); a.functions = []; for (var l = 0; l < r.functions.length; ++l) { if (typeof r.functions[l] != 'object') throw TypeError('.onnx.ModelProto.functions: object expected'); a.functions[l] = s.onnx.FunctionProto.fromObject(r.functions[l]); } } return a; }), (f.toObject = function (r, a) { a || (a = {}); var l = {}; if ( ((a.arrays || a.defaults) && ((l.opsetImport = []), (l.metadataProps = []), (l.trainingInfo = []), (l.functions = [])), a.defaults) ) { if (n.Long) { var p = new n.Long(0, 0, !1); l.irVersion = a.longs === String ? p.toString() : a.longs === Number ? p.toNumber() : p; } else l.irVersion = a.longs === String ? '0' : 0; if (((l.producerName = ''), (l.producerVersion = ''), (l.domain = ''), n.Long)) { var p = new n.Long(0, 0, !1); l.modelVersion = a.longs === String ? p.toString() : a.longs === Number ? p.toNumber() : p; } else l.modelVersion = a.longs === String ? '0' : 0; (l.docString = ''), (l.graph = null); } if ( (r.irVersion != null && r.hasOwnProperty('irVersion') && (typeof r.irVersion == 'number' ? (l.irVersion = a.longs === String ? String(r.irVersion) : r.irVersion) : (l.irVersion = a.longs === String ? n.Long.prototype.toString.call(r.irVersion) : a.longs === Number ? new n.LongBits( r.irVersion.low >>> 0, r.irVersion.high >>> 0 ).toNumber() : r.irVersion)), r.producerName != null && r.hasOwnProperty('producerName') && (l.producerName = r.producerName), r.producerVersion != null && r.hasOwnProperty('producerVersion') && (l.producerVersion = r.producerVersion), r.domain != null && r.hasOwnProperty('domain') && (l.domain = r.domain), r.modelVersion != null && r.hasOwnProperty('modelVersion') && (typeof r.modelVersion == 'number' ? (l.modelVersion = a.longs === String ? String(r.modelVersion) : r.modelVersion) : (l.modelVersion = a.longs === String ? n.Long.prototype.toString.call(r.modelVersion) : a.longs === Number ? new n.LongBits( r.modelVersion.low >>> 0, r.modelVersion.high >>> 0 ).toNumber() : r.modelVersion)), r.docString != null && r.hasOwnProperty('docString') && (l.docString = r.docString), r.graph != null && r.hasOwnProperty('graph') && (l.graph = s.onnx.GraphProto.toObject(r.graph, a)), r.opsetImport && r.opsetImport.length) ) { l.opsetImport = []; for (var m = 0; m < r.opsetImport.length; ++m) l.opsetImport[m] = s.onnx.OperatorSetIdProto.toObject(r.opsetImport[m], a); } if (r.metadataProps && r.metadataProps.length) { l.metadataProps = []; for (var m = 0; m < r.metadataProps.length; ++m) l.metadataProps[m] = s.onnx.StringStringEntryProto.toObject(r.metadataProps[m], a); } if (r.trainingInfo && r.trainingInfo.length) { l.trainingInfo = []; for (var m = 0; m < r.trainingInfo.length; ++m) l.trainingInfo[m] = s.onnx.TrainingInfoProto.toObject(r.trainingInfo[m], a); } if (r.functions && r.functions.length) { l.functions = []; for (var m = 0; m < r.functions.length; ++m) l.functions[m] = s.onnx.FunctionProto.toObject(r.functions[m], a); } return l; }), (f.prototype.toJSON = function () { return this.constructor.toObject(this, o.util.toJSONOptions); }), (f.getTypeUrl = function (r) { return r === void 0 && (r = 'type.googleapis.com'), r + '/onnx.ModelProto'; }), f ); })()), (d.StringStringEntryProto = (function () { function f(r) { if (r) for (var a = Object.keys(r), l = 0; l < a.length; ++l) r[a[l]] != null && (this[a[l]] = r[a[l]]); } return ( (f.prototype.key = ''), (f.prototype.value = ''), (f.create = function (r) { return new f(r); }), (f.encode = function (r, a) { return ( a || (a = u.create()), r.key != null && Object.hasOwnProperty.call(r, 'key') && a.uint32(10).string(r.key), r.value != null && Object.hasOwnProperty.call(r, 'value') && a.uint32(18).string(r.value), a ); }), (f.encodeDelimited = function (r, a) { return this.encode(r, a).ldelim(); }), (f.decode = function (r, a) { r instanceof i || (r = i.create(r)); for ( var l = a === void 0 ? r.len : r.pos + a, p = new s.onnx.StringStringEntryProto(); r.pos < l; ) { var m = r.uint32(); switch (m >>> 3) { case 1: { p.key = r.string(); break; } case 2: { p.value = r.string(); break; } default: r.skipType(m & 7); break; } } return p; }), (f.decodeDelimited = function (r) { return r instanceof i || (r = new i(r)), this.decode(r, r.uint32()); }), (f.verify = function (r) { return typeof r != 'object' || r === null ? 'object expected' : r.key != null && r.hasOwnProperty('key') && !n.isString(r.key) ? 'key: string expected' : r.value != null && r.hasOwnProperty('value') && !n.isString(r.value) ? 'value: string expected' : null; }), (f.fromObject = function (r) { if (r instanceof s.onnx.StringStringEntryProto) return r; var a = new s.onnx.StringStringEntryProto(); return ( r.key != null && (a.key = String(r.key)), r.value != null && (a.value = String(r.value)), a ); }), (f.toObject = function (r, a) { a || (a = {}); var l = {}; return ( a.defaults && ((l.key = ''), (l.value = '')), r.key != null && r.hasOwnProperty('key') && (l.key = r.key), r.value != null && r.hasOwnProperty('value') && (l.value = r.value), l ); }), (f.prototype.toJSON = function () { return this.constructor.toObject(this, o.util.toJSONOptions); }), (f.getTypeUrl = function (r) { return r === void 0 && (r = 'type.googleapis.com'), r + '/onnx.StringStringEntryProto'; }), f ); })()), (d.TensorAnnotation = (function () { function f(r) { if (((this.quantParameterTensorNames = []), r)) for (var a = Object.keys(r), l = 0; l < a.length; ++l) r[a[l]] != null && (this[a[l]] = r[a[l]]); } return ( (f.prototype.tensorName = ''), (f.prototype.quantParameterTensorNames = n.emptyArray), (f.create = function (r) { return new f(r); }), (f.encode = function (r, a) { if ( (a || (a = u.create()), r.tensorName != null && Object.hasOwnProperty.call(r, 'tensorName') && a.uint32(10).string(r.tensorName), r.quantParameterTensorNames != null && r.quantParameterTensorNames.length) ) for (var l = 0; l < r.quantParameterTensorNames.length; ++l) s.onnx.StringStringEntryProto.encode( r.quantParameterTensorNames[l], a.uint32(18).fork() ).ldelim(); return a; }), (f.encodeDelimited = function (r, a) { return this.encode(r, a).ldelim(); }), (f.decode = function (r, a) { r instanceof i || (r = i.create(r)); for ( var l = a === void 0 ? r.len : r.pos + a, p = new s.onnx.TensorAnnotation(); r.pos < l; ) { var m = r.uint32(); switch (m >>> 3) { case 1: { p.tensorName = r.string(); break; } case 2: { (p.quantParameterTensorNames && p.quantParameterTensorNames.length) || (p.quantParameterTensorNames = []), p.quantParameterTensorNames.push( s.onnx.StringStringEntryProto.decode(r, r.uint32()) ); break; } default: r.skipType(m & 7); break; } } return p; }), (f.decodeDelimited = function (r) { return r instanceof i || (r = new i(r)), this.decode(r, r.uint32()); }), (f.verify = function (r) { if (typeof r != 'object' || r === null) return 'object expected'; if (r.tensorName != null && r.hasOwnProperty('tensorName') && !n.isString(r.tensorName)) return 'tensorName: string expected'; if (r.quantParameterTensorNames != null && r.hasOwnProperty('quantParameterTensorNames')) { if (!Array.isArray(r.quantParameterTensorNames)) return 'quantParameterTensorNames: array expected'; for (var a = 0; a < r.quantParameterTensorNames.length; ++a) { var l = s.onnx.StringStringEntryProto.verify(r.quantParameterTensorNames[a]); if (l) return 'quantParameterTensorNames.' + l; } } return null; }), (f.fromObject = function (r) { if (r instanceof s.onnx.TensorAnnotation) return r; var a = new s.onnx.TensorAnnotation(); if ( (r.tensorName != null && (a.tensorName = String(r.tensorName)), r.quantParameterTensorNames) ) { if (!Array.isArray(r.quantParameterTensorNames)) throw TypeError('.onnx.TensorAnnotation.quantParameterTensorNames: array expected'); a.quantParameterTensorNames = []; for (var l = 0; l < r.quantParameterTensorNames.length; ++l) { if (typeof r.quantParameterTensorNames[l] != 'object') throw TypeError( '.onnx.TensorAnnotation.quantParameterTensorNames: object expected' ); a.quantParameterTensorNames[l] = s.onnx.StringStringEntryProto.fromObject( r.quantParameterTensorNames[l] ); } } return a; }), (f.toObject = function (r, a) { a || (a = {}); var l = {}; if ( ((a.arrays || a.defaults) && (l.quantParameterTensorNames = []), a.defaults && (l.tensorName = ''), r.tensorName != null && r.hasOwnProperty('tensorName') && (l.tensorName = r.tensorName), r.quantParameterTensorNames && r.quantParameterTensorNames.length) ) { l.quantParameterTensorNames = []; for (var p = 0; p < r.quantParameterTensorNames.length; ++p) l.quantParameterTensorNames[p] = s.onnx.StringStringEntryProto.toObject( r.quantParameterTensorNames[p], a ); } return l; }), (f.prototype.toJSON = function () { return this.constructor.toObject(this, o.util.toJSONOptions); }), (f.getTypeUrl = function (r) { return r === void 0 && (r = 'type.googleapis.com'), r + '/onnx.TensorAnnotation'; }), f ); })()), (d.GraphProto = (function () { function f(r) { if ( ((this.node = []), (this.initializer = []), (this.sparseInitializer = []), (this.input = []), (this.output = []), (this.valueInfo = []), (this.quantizationAnnotation = []), r) ) for (var a = Object.keys(r), l = 0; l < a.length; ++l) r[a[l]] != null && (this[a[l]] = r[a[l]]); } return ( (f.prototype.node = n.emptyArray), (f.prototype.name = ''), (f.prototype.initializer = n.emptyArray), (f.prototype.sparseInitializer = n.emptyArray), (f.prototype.docString = ''), (f.prototype.input = n.emptyArray), (f.prototype.output = n.emptyArray), (f.prototype.valueInfo = n.emptyArray), (f.prototype.quantizationAnnotation = n.emptyArray), (f.create = function (r) { return new f(r); }), (f.encode = function (r, a) { if ((a || (a = u.create()), r.node != null && r.node.length)) for (var l = 0; l < r.node.length; ++l) s.onnx.NodeProto.encode(r.node[l], a.uint32(10).fork()).ldelim(); if ( (r.name != null && Object.hasOwnProperty.call(r, 'name') && a.uint32(18).string(r.name), r.initializer != null && r.initializer.length) ) for (var l = 0; l < r.initializer.length; ++l) s.onnx.TensorProto.encode(r.initializer[l], a.uint32(42).fork()).ldelim(); if ( (r.docString != null && Object.hasOwnProperty.call(r, 'docString') && a.uint32(82).string(r.docString), r.input != null && r.input.length) ) for (var l = 0; l < r.input.length; ++l) s.onnx.ValueInfoProto.encode(r.input[l], a.uint32(90).fork()).ldelim(); if (r.output != null && r.output.length) for (var l = 0; l < r.output.length; ++l) s.onnx.ValueInfoProto.encode(r.output[l], a.uint32(98).fork()).ldelim(); if (r.valueInfo != null && r.valueInfo.length) for (var l = 0; l < r.valueInfo.length; ++l) s.onnx.ValueInfoProto.encode(r.valueInfo[l], a.uint32(106).fork()).ldelim(); if (r.quantizationAnnotation != null && r.quantizationAnnotation.length) for (var l = 0; l < r.quantizationAnnotation.length; ++l) s.onnx.TensorAnnotation.encode( r.quantizationAnnotation[l], a.uint32(114).fork() ).ldelim(); if (r.sparseInitializer != null && r.sparseInitializer.length) for (var l = 0; l < r.sparseInitializer.length; ++l) s.onnx.SparseTensorProto.encode( r.sparseInitializer[l], a.uint32(122).fork() ).ldelim(); return a; }), (f.encodeDelimited = function (r, a) { return this.encode(r, a).ldelim(); }), (f.decode = function (r, a) { r instanceof i || (r = i.create(r)); for (var l = a === void 0 ? r.len : r.pos + a, p = new s.onnx.GraphProto(); r.pos < l; ) { var m = r.uint32(); switch (m >>> 3) { case 1: { (p.node && p.node.length) || (p.node = []), p.node.push(s.onnx.NodeProto.decode(r, r.uint32())); break; } case 2: { p.name = r.string(); break; } case 5: { (p.initializer && p.initializer.length) || (p.initializer = []), p.initializer.push(s.onnx.TensorProto.decode(r, r.uint32())); break; } case 15: { (p.sparseInitializer && p.sparseInitializer.length) || (p.sparseInitializer = []), p.sparseInitializer.push(s.onnx.SparseTensorProto.decode(r, r.uint32())); break; } case 10: { p.docString = r.string(); break; } case 11: { (p.input && p.input.length) || (p.input = []), p.input.push(s.onnx.ValueInfoProto.decode(r, r.uint32())); break; } case 12: { (p.output && p.output.length) || (p.output = []), p.output.push(s.onnx.ValueInfoProto.decode(r, r.uint32())); break; } case 13: { (p.valueInfo && p.valueInfo.length) || (p.valueInfo = []), p.valueInfo.push(s.onnx.ValueInfoProto.decode(r, r.uint32())); break; } case 14: { (p.quantizationAnnotation && p.quantizationAnnotation.length) || (p.quantizationAnnotation = []), p.quantizationAnnotation.push( s.onnx.TensorAnnotation.decode(r, r.uint32()) ); break; } default: r.skipType(m & 7); break; } } return p; }), (f.decodeDelimited = function (r) { return r instanceof i || (r = new i(r)), this.decode(r, r.uint32()); }), (f.verify = function (r) { if (typeof r != 'object' || r === null) return 'object expected'; if (r.node != null && r.hasOwnProperty('node')) { if (!Array.isArray(r.node)) return 'node: array expected'; for (var a = 0; a < r.node.length; ++a) { var l = s.onnx.NodeProto.verify(r.node[a]); if (l) return 'node.' + l; } } if (r.name != null && r.hasOwnProperty('name') && !n.isString(r.name)) return 'name: string expected'; if (r.initializer != null && r.hasOwnProperty('initializer')) { if (!Array.isArray(r.initializer)) return 'initializer: array expected'; for (var a = 0; a < r.initializer.length; ++a) { var l = s.onnx.TensorProto.verify(r.initializer[a]); if (l) return 'initializer.' + l; } } if (r.sparseInitializer != null && r.hasOwnProperty('sparseInitializer')) { if (!Array.isArray(r.sparseInitializer)) return 'sparseInitializer: array expected'; for (var a = 0; a < r.sparseInitializer.length; ++a) { var l = s.onnx.SparseTensorProto.verify(r.sparseInitializer[a]); if (l) return 'sparseInitializer.' + l; } } if (r.docString != null && r.hasOwnProperty('docString') && !n.isString(r.docString)) return 'docString: string expected'; if (r.input != null && r.hasOwnProperty('input')) { if (!Array.isArray(r.input)) return 'input: array expected'; for (var a = 0; a < r.input.length; ++a) { var l = s.onnx.ValueInfoProto.verify(r.input[a]); if (l) return 'input.' + l; } } if (r.output != null && r.hasOwnProperty('output')) { if (!Array.isArray(r.output)) return 'output: array expected'; for (var a = 0; a < r.output.length; ++a) { var l = s.onnx.ValueInfoProto.verify(r.output[a]); if (l) return 'output.' + l; } } if (r.valueInfo != null && r.hasOwnProperty('valueInfo')) { if (!Array.isArray(r.valueInfo)) return 'valueInfo: array expected'; for (var a = 0; a < r.valueInfo.length; ++a) { var l = s.onnx.ValueInfoProto.verify(r.valueInfo[a]); if (l) return 'valueInfo.' + l; } } if (r.quantizationAnnotation != null && r.hasOwnProperty('quantizationAnnotation')) { if (!Array.isArray(r.quantizationAnnotation)) return 'quantizationAnnotation: array expected'; for (var a = 0; a < r.quantizationAnnotation.length; ++a) { var l = s.onnx.TensorAnnotation.verify(r.quantizationAnnotation[a]); if (l) return 'quantizationAnnotation.' + l; } } return null; }), (f.fromObject = function (r) { if (r instanceof s.onnx.GraphProto) return r; var a = new s.onnx.GraphProto(); if (r.node) { if (!Array.isArray(r.node)) throw TypeError('.onnx.GraphProto.node: array expected'); a.node = []; for (var l = 0; l < r.node.length; ++l) { if (typeof r.node[l] != 'object') throw TypeError('.onnx.GraphProto.node: object expected'); a.node[l] = s.onnx.NodeProto.fromObject(r.node[l]); } } if ((r.name != null && (a.name = String(r.name)), r.initializer)) { if (!Array.isArray(r.initializer)) throw TypeError('.onnx.GraphProto.initializer: array expected'); a.initializer = []; for (var l = 0; l < r.initializer.length; ++l) { if (typeof r.initializer[l] != 'object') throw TypeError('.onnx.GraphProto.initializer: object expected'); a.initializer[l] = s.onnx.TensorProto.fromObject(r.initializer[l]); } } if (r.sparseInitializer) { if (!Array.isArray(r.sparseInitializer)) throw TypeError('.onnx.GraphProto.sparseInitializer: array expected'); a.sparseInitializer = []; for (var l = 0; l < r.sparseInitializer.length; ++l) { if (typeof r.sparseInitializer[l] != 'object') throw TypeError('.onnx.GraphProto.sparseInitializer: object expected'); a.sparseInitializer[l] = s.onnx.SparseTensorProto.fromObject( r.sparseInitializer[l] ); } } if ((r.docString != null && (a.docString = String(r.docString)), r.input)) { if (!Array.isArray(r.input)) throw TypeError('.onnx.GraphProto.input: array expected'); a.input = []; for (var l = 0; l < r.input.length; ++l) { if (typeof r.input[l] != 'object') throw TypeError('.onnx.GraphProto.input: object expected'); a.input[l] = s.onnx.ValueInfoProto.fromObject(r.input[l]); } } if (r.output) { if (!Array.isArray(r.output)) throw TypeError('.onnx.GraphProto.output: array expected'); a.output = []; for (var l = 0; l < r.output.length; ++l) { if (typeof r.output[l] != 'object') throw TypeError('.onnx.GraphProto.output: object expected'); a.output[l] = s.onnx.ValueInfoProto.fromObject(r.output[l]); } } if (r.valueInfo) { if (!Array.isArray(r.valueInfo)) throw TypeError('.onnx.GraphProto.valueInfo: array expected'); a.valueInfo = []; for (var l = 0; l < r.valueInfo.length; ++l) { if (typeof r.valueInfo[l] != 'object') throw TypeError('.onnx.GraphProto.valueInfo: object expected'); a.valueInfo[l] = s.onnx.ValueInfoProto.fromObject(r.valueInfo[l]); } } if (r.quantizationAnnotation) { if (!Array.isArray(r.quantizationAnnotation)) throw TypeError('.onnx.GraphProto.quantizationAnnotation: array expected'); a.quantizationAnnotation = []; for (var l = 0; l < r.quantizationAnnotation.length; ++l) { if (typeof r.quantizationAnnotation[l] != 'object') throw TypeError('.onnx.GraphProto.quantizationAnnotation: object expected'); a.quantizationAnnotation[l] = s.onnx.TensorAnnotation.fromObject( r.quantizationAnnotation[l] ); } } return a; }), (f.toObject = function (r, a) { a || (a = {}); var l = {}; if ( ((a.arrays || a.defaults) && ((l.node = []), (l.initializer = []), (l.input = []), (l.output = []), (l.valueInfo = []), (l.quantizationAnnotation = []), (l.sparseInitializer = [])), a.defaults && ((l.name = ''), (l.docString = '')), r.node && r.node.length) ) { l.node = []; for (var p = 0; p < r.node.length; ++p) l.node[p] = s.onnx.NodeProto.toObject(r.node[p], a); } if ( (r.name != null && r.hasOwnProperty('name') && (l.name = r.name), r.initializer && r.initializer.length) ) { l.initializer = []; for (var p = 0; p < r.initializer.length; ++p) l.initializer[p] = s.onnx.TensorProto.toObject(r.initializer[p], a); } if ( (r.docString != null && r.hasOwnProperty('docString') && (l.docString = r.docString), r.input && r.input.length) ) { l.input = []; for (var p = 0; p < r.input.length; ++p) l.input[p] = s.onnx.ValueInfoProto.toObject(r.input[p], a); } if (r.output && r.output.length) { l.output = []; for (var p = 0; p < r.output.length; ++p) l.output[p] = s.onnx.ValueInfoProto.toObject(r.output[p], a); } if (r.valueInfo && r.valueInfo.length) { l.valueInfo = []; for (var p = 0; p < r.valueInfo.length; ++p) l.valueInfo[p] = s.onnx.ValueInfoProto.toObject(r.valueInfo[p], a); } if (r.quantizationAnnotation && r.quantizationAnnotation.length) { l.quantizationAnnotation = []; for (var p = 0; p < r.quantizationAnnotation.length; ++p) l.quantizationAnnotation[p] = s.onnx.TensorAnnotation.toObject( r.quantizationAnnotation[p], a ); } if (r.sparseInitializer && r.sparseInitializer.length) { l.sparseInitializer = []; for (var p = 0; p < r.sparseInitializer.length; ++p) l.sparseInitializer[p] = s.onnx.SparseTensorProto.toObject( r.sparseInitializer[p], a ); } return l; }), (f.prototype.toJSON = function () { return this.constructor.toObject(this, o.util.toJSONOptions); }), (f.getTypeUrl = function (r) { return r === void 0 && (r = 'type.googleapis.com'), r + '/onnx.GraphProto'; }), f ); })()), (d.TensorProto = (function () { function f(r) { if ( ((this.dims = []), (this.floatData = []), (this.int32Data = []), (this.stringData = []), (this.int64Data = []), (this.externalData = []), (this.doubleData = []), (this.uint64Data = []), r) ) for (var a = Object.keys(r), l = 0; l < a.length; ++l) r[a[l]] != null && (this[a[l]] = r[a[l]]); } return ( (f.prototype.dims = n.emptyArray), (f.prototype.dataType = 0), (f.prototype.segment = null), (f.prototype.floatData = n.emptyArray), (f.prototype.int32Data = n.emptyArray), (f.prototype.stringData = n.emptyArray), (f.prototype.int64Data = n.emptyArray), (f.prototype.name = ''), (f.prototype.docString = ''), (f.prototype.rawData = n.newBuffer([])), (f.prototype.externalData = n.emptyArray), (f.prototype.dataLocation = 0), (f.prototype.doubleData = n.emptyArray), (f.prototype.uint64Data = n.emptyArray), (f.create = function (r) { return new f(r); }), (f.encode = function (r, a) { if ((a || (a = u.create()), r.dims != null && r.dims.length)) { a.uint32(10).fork(); for (var l = 0; l < r.dims.length; ++l) a.int64(r.dims[l]); a.ldelim(); } if ( (r.dataType != null && Object.hasOwnProperty.call(r, 'dataType') && a.uint32(16).int32(r.dataType), r.segment != null && Object.hasOwnProperty.call(r, 'segment') && s.onnx.TensorProto.Segment.encode(r.segment, a.uint32(26).fork()).ldelim(), r.floatData != null && r.floatData.length) ) { a.uint32(34).fork(); for (var l = 0; l < r.floatData.length; ++l) a.float(r.floatData[l]); a.ldelim(); } if (r.int32Data != null && r.int32Data.length) { a.uint32(42).fork(); for (var l = 0; l < r.int32Data.length; ++l) a.int32(r.int32Data[l]); a.ldelim(); } if (r.stringData != null && r.stringData.length) for (var l = 0; l < r.stringData.length; ++l) a.uint32(50).bytes(r.stringData[l]); if (r.int64Data != null && r.int64Data.length) { a.uint32(58).fork(); for (var l = 0; l < r.int64Data.length; ++l) a.int64(r.int64Data[l]); a.ldelim(); } if ( (r.name != null && Object.hasOwnProperty.call(r, 'name') && a.uint32(66).string(r.name), r.rawData != null && Object.hasOwnProperty.call(r, 'rawData') && a.uint32(74).bytes(r.rawData), r.doubleData != null && r.doubleData.length) ) { a.uint32(82).fork(); for (var l = 0; l < r.doubleData.length; ++l) a.double(r.doubleData[l]); a.ldelim(); } if (r.uint64Data != null && r.uint64Data.length) { a.uint32(90).fork(); for (var l = 0; l < r.uint64Data.length; ++l) a.uint64(r.uint64Data[l]); a.ldelim(); } if ( (r.docString != null && Object.hasOwnProperty.call(r, 'docString') && a.uint32(98).string(r.docString), r.externalData != null && r.externalData.length) ) for (var l = 0; l < r.externalData.length; ++l) s.onnx.StringStringEntryProto.encode( r.externalData[l], a.uint32(106).fork() ).ldelim(); return ( r.dataLocation != null && Object.hasOwnProperty.call(r, 'dataLocation') && a.uint32(112).int32(r.dataLocation), a ); }), (f.encodeDelimited = function (r, a) { return this.encode(r, a).ldelim(); }), (f.decode = function (r, a) { r instanceof i || (r = i.create(r)); for (var l = a === void 0 ? r.len : r.pos + a, p = new s.onnx.TensorProto(); r.pos < l; ) { var m = r.uint32(); switch (m >>> 3) { case 1: { if (((p.dims && p.dims.length) || (p.dims = []), (m & 7) === 2)) for (var y = r.uint32() + r.pos; r.pos < y; ) p.dims.push(r.int64()); else p.dims.push(r.int64()); break; } case 2: { p.dataType = r.int32(); break; } case 3: { p.segment = s.onnx.TensorProto.Segment.decode(r, r.uint32()); break; } case 4: { if (((p.floatData && p.floatData.length) || (p.floatData = []), (m & 7) === 2)) for (var y = r.uint32() + r.pos; r.pos < y; ) p.floatData.push(r.float()); else p.floatData.push(r.float()); break; } case 5: { if (((p.int32Data && p.int32Data.length) || (p.int32Data = []), (m & 7) === 2)) for (var y = r.uint32() + r.pos; r.pos < y; ) p.int32Data.push(r.int32()); else p.int32Data.push(r.int32()); break; } case 6: { (p.stringData && p.stringData.length) || (p.stringData = []), p.stringData.push(r.bytes()); break; } case 7: { if (((p.int64Data && p.int64Data.length) || (p.int64Data = []), (m & 7) === 2)) for (var y = r.uint32() + r.pos; r.pos < y; ) p.int64Data.push(r.int64()); else p.int64Data.push(r.int64()); break; } case 8: { p.name = r.string(); break; } case 12: { p.docString = r.string(); break; } case 9: { p.rawData = r.bytes(); break; } case 13: { (p.externalData && p.externalData.length) || (p.externalData = []), p.externalData.push(s.onnx.StringStringEntryProto.decode(r, r.uint32())); break; } case 14: { p.dataLocation = r.int32(); break; } case 10: { if ( ((p.doubleData && p.doubleData.length) || (p.doubleData = []), (m & 7) === 2) ) for (var y = r.uint32() + r.pos; r.pos < y; ) p.doubleData.push(r.double()); else p.doubleData.push(r.double()); break; } case 11: { if ( ((p.uint64Data && p.uint64Data.length) || (p.uint64Data = []), (m & 7) === 2) ) for (var y = r.uint32() + r.pos; r.pos < y; ) p.uint64Data.push(r.uint64()); else p.uint64Data.push(r.uint64()); break; } default: r.skipType(m & 7); break; } } return p; }), (f.decodeDelimited = function (r) { return r instanceof i || (r = new i(r)), this.decode(r, r.uint32()); }), (f.verify = function (r) { if (typeof r != 'object' || r === null) return 'object expected'; if (r.dims != null && r.hasOwnProperty('dims')) { if (!Array.isArray(r.dims)) return 'dims: array expected'; for (var a = 0; a < r.dims.length; ++a) if ( !n.isInteger(r.dims[a]) && !(r.dims[a] && n.isInteger(r.dims[a].low) && n.isInteger(r.dims[a].high)) ) return 'dims: integer|Long[] expected'; } if (r.dataType != null && r.hasOwnProperty('dataType') && !n.isInteger(r.dataType)) return 'dataType: integer expected'; if (r.segment != null && r.hasOwnProperty('segment')) { var l = s.onnx.TensorProto.Segment.verify(r.segment); if (l) return 'segment.' + l; } if (r.floatData != null && r.hasOwnProperty('floatData')) { if (!Array.isArray(r.floatData)) return 'floatData: array expected'; for (var a = 0; a < r.floatData.length; ++a) if (typeof r.floatData[a] != 'number') return 'floatData: number[] expected'; } if (r.int32Data != null && r.hasOwnProperty('int32Data')) { if (!Array.isArray(r.int32Data)) return 'int32Data: array expected'; for (var a = 0; a < r.int32Data.length; ++a) if (!n.isInteger(r.int32Data[a])) return 'int32Data: integer[] expected'; } if (r.stringData != null && r.hasOwnProperty('stringData')) { if (!Array.isArray(r.stringData)) return 'stringData: array expected'; for (var a = 0; a < r.stringData.length; ++a) if ( !( (r.stringData[a] && typeof r.stringData[a].length == 'number') || n.isString(r.stringData[a]) ) ) return 'stringData: buffer[] expected'; } if (r.int64Data != null && r.hasOwnProperty('int64Data')) { if (!Array.isArray(r.int64Data)) return 'int64Data: array expected'; for (var a = 0; a < r.int64Data.length; ++a) if ( !n.isInteger(r.int64Data[a]) && !( r.int64Data[a] && n.isInteger(r.int64Data[a].low) && n.isInteger(r.int64Data[a].high) ) ) return 'int64Data: integer|Long[] expected'; } if (r.name != null && r.hasOwnProperty('name') && !n.isString(r.name)) return 'name: string expected'; if (r.docString != null && r.hasOwnProperty('docString') && !n.isString(r.docString)) return 'docString: string expected'; if ( r.rawData != null && r.hasOwnProperty('rawData') && !((r.rawData && typeof r.rawData.length == 'number') || n.isString(r.rawData)) ) return 'rawData: buffer expected'; if (r.externalData != null && r.hasOwnProperty('externalData')) { if (!Array.isArray(r.externalData)) return 'externalData: array expected'; for (var a = 0; a < r.externalData.length; ++a) { var l = s.onnx.StringStringEntryProto.verify(r.externalData[a]); if (l) return 'externalData.' + l; } } if (r.dataLocation != null && r.hasOwnProperty('dataLocation')) switch (r.dataLocation) { default: return 'dataLocation: enum value expected'; case 0: case 1: break; } if (r.doubleData != null && r.hasOwnProperty('doubleData')) { if (!Array.isArray(r.doubleData)) return 'doubleData: array expected'; for (var a = 0; a < r.doubleData.length; ++a) if (typeof r.doubleData[a] != 'number') return 'doubleData: number[] expected'; } if (r.uint64Data != null && r.hasOwnProperty('uint64Data')) { if (!Array.isArray(r.uint64Data)) return 'uint64Data: array expected'; for (var a = 0; a < r.uint64Data.length; ++a) if ( !n.isInteger(r.uint64Data[a]) && !( r.uint64Data[a] && n.isInteger(r.uint64Data[a].low) && n.isInteger(r.uint64Data[a].high) ) ) return 'uint64Data: integer|Long[] expected'; } return null; }), (f.fromObject = function (r) { if (r instanceof s.onnx.TensorProto) return r; var a = new s.onnx.TensorProto(); if (r.dims) { if (!Array.isArray(r.dims)) throw TypeError('.onnx.TensorProto.dims: array expected'); a.dims = []; for (var l = 0; l < r.dims.length; ++l) n.Long ? ((a.dims[l] = n.Long.fromValue(r.dims[l])).unsigned = !1) : typeof r.dims[l] == 'string' ? (a.dims[l] = parseInt(r.dims[l], 10)) : typeof r.dims[l] == 'number' ? (a.dims[l] = r.dims[l]) : typeof r.dims[l] == 'object' && (a.dims[l] = new n.LongBits( r.dims[l].low >>> 0, r.dims[l].high >>> 0 ).toNumber()); } if ((r.dataType != null && (a.dataType = r.dataType | 0), r.segment != null)) { if (typeof r.segment != 'object') throw TypeError('.onnx.TensorProto.segment: object expected'); a.segment = s.onnx.TensorProto.Segment.fromObject(r.segment); } if (r.floatData) { if (!Array.isArray(r.floatData)) throw TypeError('.onnx.TensorProto.floatData: array expected'); a.floatData = []; for (var l = 0; l < r.floatData.length; ++l) a.floatData[l] = Number(r.floatData[l]); } if (r.int32Data) { if (!Array.isArray(r.int32Data)) throw TypeError('.onnx.TensorProto.int32Data: array expected'); a.int32Data = []; for (var l = 0; l < r.int32Data.length; ++l) a.int32Data[l] = r.int32Data[l] | 0; } if (r.stringData) { if (!Array.isArray(r.stringData)) throw TypeError('.onnx.TensorProto.stringData: array expected'); a.stringData = []; for (var l = 0; l < r.stringData.length; ++l) typeof r.stringData[l] == 'string' ? n.base64.decode( r.stringData[l], (a.stringData[l] = n.newBuffer(n.base64.length(r.stringData[l]))), 0 ) : r.stringData[l].length >= 0 && (a.stringData[l] = r.stringData[l]); } if (r.int64Data) { if (!Array.isArray(r.int64Data)) throw TypeError('.onnx.TensorProto.int64Data: array expected'); a.int64Data = []; for (var l = 0; l < r.int64Data.length; ++l) n.Long ? ((a.int64Data[l] = n.Long.fromValue(r.int64Data[l])).unsigned = !1) : typeof r.int64Data[l] == 'string' ? (a.int64Data[l] = parseInt(r.int64Data[l], 10)) : typeof r.int64Data[l] == 'number' ? (a.int64Data[l] = r.int64Data[l]) : typeof r.int64Data[l] == 'object' && (a.int64Data[l] = new n.LongBits( r.int64Data[l].low >>> 0, r.int64Data[l].high >>> 0 ).toNumber()); } if ( (r.name != null && (a.name = String(r.name)), r.docString != null && (a.docString = String(r.docString)), r.rawData != null && (typeof r.rawData == 'string' ? n.base64.decode( r.rawData, (a.rawData = n.newBuffer(n.base64.length(r.rawData))), 0 ) : r.rawData.length >= 0 && (a.rawData = r.rawData)), r.externalData) ) { if (!Array.isArray(r.externalData)) throw TypeError('.onnx.TensorProto.externalData: array expected'); a.externalData = []; for (var l = 0; l < r.externalData.length; ++l) { if (typeof r.externalData[l] != 'object') throw TypeError('.onnx.TensorProto.externalData: object expected'); a.externalData[l] = s.onnx.StringStringEntryProto.fromObject(r.externalData[l]); } } switch (r.dataLocation) { default: if (typeof r.dataLocation == 'number') { a.dataLocation = r.dataLocation; break; } break; case 'DEFAULT': case 0: a.dataLocation = 0; break; case 'EXTERNAL': case 1: a.dataLocation = 1; break; } if (r.doubleData) { if (!Array.isArray(r.doubleData)) throw TypeError('.onnx.TensorProto.doubleData: array expected'); a.doubleData = []; for (var l = 0; l < r.doubleData.length; ++l) a.doubleData[l] = Number(r.doubleData[l]); } if (r.uint64Data) { if (!Array.isArray(r.uint64Data)) throw TypeError('.onnx.TensorProto.uint64Data: array expected'); a.uint64Data = []; for (var l = 0; l < r.uint64Data.length; ++l) n.Long ? ((a.uint64Data[l] = n.Long.fromValue(r.uint64Data[l])).unsigned = !0) : typeof r.uint64Data[l] == 'string' ? (a.uint64Data[l] = parseInt(r.uint64Data[l], 10)) : typeof r.uint64Data[l] == 'number' ? (a.uint64Data[l] = r.uint64Data[l]) : typeof r.uint64Data[l] == 'object' && (a.uint64Data[l] = new n.LongBits( r.uint64Data[l].low >>> 0, r.uint64Data[l].high >>> 0 ).toNumber(!0)); } return a; }), (f.toObject = function (r, a) { a || (a = {}); var l = {}; if ( ((a.arrays || a.defaults) && ((l.dims = []), (l.floatData = []), (l.int32Data = []), (l.stringData = []), (l.int64Data = []), (l.doubleData = []), (l.uint64Data = []), (l.externalData = [])), a.defaults && ((l.dataType = 0), (l.segment = null), (l.name = ''), a.bytes === String ? (l.rawData = '') : ((l.rawData = []), a.bytes !== Array && (l.rawData = n.newBuffer(l.rawData))), (l.docString = ''), (l.dataLocation = a.enums === String ? 'DEFAULT' : 0)), r.dims && r.dims.length) ) { l.dims = []; for (var p = 0; p < r.dims.length; ++p) typeof r.dims[p] == 'number' ? (l.dims[p] = a.longs === String ? String(r.dims[p]) : r.dims[p]) : (l.dims[p] = a.longs === String ? n.Long.prototype.toString.call(r.dims[p]) : a.longs === Number ? new n.LongBits(r.dims[p].low >>> 0, r.dims[p].high >>> 0).toNumber() : r.dims[p]); } if ( (r.dataType != null && r.hasOwnProperty('dataType') && (l.dataType = r.dataType), r.segment != null && r.hasOwnProperty('segment') && (l.segment = s.onnx.TensorProto.Segment.toObject(r.segment, a)), r.floatData && r.floatData.length) ) { l.floatData = []; for (var p = 0; p < r.floatData.length; ++p) l.floatData[p] = a.json && !isFinite(r.floatData[p]) ? String(r.floatData[p]) : r.floatData[p]; } if (r.int32Data && r.int32Data.length) { l.int32Data = []; for (var p = 0; p < r.int32Data.length; ++p) l.int32Data[p] = r.int32Data[p]; } if (r.stringData && r.stringData.length) { l.stringData = []; for (var p = 0; p < r.stringData.length; ++p) l.stringData[p] = a.bytes === String ? n.base64.encode(r.stringData[p], 0, r.stringData[p].length) : a.bytes === Array ? Array.prototype.slice.call(r.stringData[p]) : r.stringData[p]; } if (r.int64Data && r.int64Data.length) { l.int64Data = []; for (var p = 0; p < r.int64Data.length; ++p) typeof r.int64Data[p] == 'number' ? (l.int64Data[p] = a.longs === String ? String(r.int64Data[p]) : r.int64Data[p]) : (l.int64Data[p] = a.longs === String ? n.Long.prototype.toString.call(r.int64Data[p]) : a.longs === Number ? new n.LongBits( r.int64Data[p].low >>> 0, r.int64Data[p].high >>> 0 ).toNumber() : r.int64Data[p]); } if ( (r.name != null && r.hasOwnProperty('name') && (l.name = r.name), r.rawData != null && r.hasOwnProperty('rawData') && (l.rawData = a.bytes === String ? n.base64.encode(r.rawData, 0, r.rawData.length) : a.bytes === Array ? Array.prototype.slice.call(r.rawData) : r.rawData), r.doubleData && r.doubleData.length) ) { l.doubleData = []; for (var p = 0; p < r.doubleData.length; ++p) l.doubleData[p] = a.json && !isFinite(r.doubleData[p]) ? String(r.doubleData[p]) : r.doubleData[p]; } if (r.uint64Data && r.uint64Data.length) { l.uint64Data = []; for (var p = 0; p < r.uint64Data.length; ++p) typeof r.uint64Data[p] == 'number' ? (l.uint64Data[p] = a.longs === String ? String(r.uint64Data[p]) : r.uint64Data[p]) : (l.uint64Data[p] = a.longs === String ? n.Long.prototype.toString.call(r.uint64Data[p]) : a.longs === Number ? new n.LongBits( r.uint64Data[p].low >>> 0, r.uint64Data[p].high >>> 0 ).toNumber(!0) : r.uint64Data[p]); } if ( (r.docString != null && r.hasOwnProperty('docString') && (l.docString = r.docString), r.externalData && r.externalData.length) ) { l.externalData = []; for (var p = 0; p < r.externalData.length; ++p) l.externalData[p] = s.onnx.StringStringEntryProto.toObject(r.externalData[p], a); } return ( r.dataLocation != null && r.hasOwnProperty('dataLocation') && (l.dataLocation = a.enums === String ? s.onnx.TensorProto.DataLocation[r.dataLocation] === void 0 ? r.dataLocation : s.onnx.TensorProto.DataLocation[r.dataLocation] : r.dataLocation), l ); }), (f.prototype.toJSON = function () { return this.constructor.toObject(this, o.util.toJSONOptions); }), (f.getTypeUrl = function (r) { return r === void 0 && (r = 'type.googleapis.com'), r + '/onnx.TensorProto'; }), (f.DataType = (function () { var r = {}, a = Object.create(r); return ( (a[(r[0] = 'UNDEFINED')] = 0), (a[(r[1] = 'FLOAT')] = 1), (a[(r[2] = 'UINT8')] = 2), (a[(r[3] = 'INT8')] = 3), (a[(r[4] = 'UINT16')] = 4), (a[(r[5] = 'INT16')] = 5), (a[(r[6] = 'INT32')] = 6), (a[(r[7] = 'INT64')] = 7), (a[(r[8] = 'STRING')] = 8), (a[(r[9] = 'BOOL')] = 9), (a[(r[10] = 'FLOAT16')] = 10), (a[(r[11] = 'DOUBLE')] = 11), (a[(r[12] = 'UINT32')] = 12), (a[(r[13] = 'UINT64')] = 13), (a[(r[14] = 'COMPLEX64')] = 14), (a[(r[15] = 'COMPLEX128')] = 15), (a[(r[16] = 'BFLOAT16')] = 16), (a[(r[17] = 'FLOAT8E4M3FN')] = 17), (a[(r[18] = 'FLOAT8E4M3FNUZ')] = 18), (a[(r[19] = 'FLOAT8E5M2')] = 19), (a[(r[20] = 'FLOAT8E5M2FNUZ')] = 20), a ); })()), (f.Segment = (function () { function r(a) { if (a) for (var l = Object.keys(a), p = 0; p < l.length; ++p) a[l[p]] != null && (this[l[p]] = a[l[p]]); } return ( (r.prototype.begin = n.Long ? n.Long.fromBits(0, 0, !1) : 0), (r.prototype.end = n.Long ? n.Long.fromBits(0, 0, !1) : 0), (r.create = function (a) { return new r(a); }), (r.encode = function (a, l) { return ( l || (l = u.create()), a.begin != null && Object.hasOwnProperty.call(a, 'begin') && l.uint32(8).int64(a.begin), a.end != null && Object.hasOwnProperty.call(a, 'end') && l.uint32(16).int64(a.end), l ); }), (r.encodeDelimited = function (a, l) { return this.encode(a, l).ldelim(); }), (r.decode = function (a, l) { a instanceof i || (a = i.create(a)); for ( var p = l === void 0 ? a.len : a.pos + l, m = new s.onnx.TensorProto.Segment(); a.pos < p; ) { var y = a.uint32(); switch (y >>> 3) { case 1: { m.begin = a.int64(); break; } case 2: { m.end = a.int64(); break; } default: a.skipType(y & 7); break; } } return m; }), (r.decodeDelimited = function (a) { return a instanceof i || (a = new i(a)), this.decode(a, a.uint32()); }), (r.verify = function (a) { return typeof a != 'object' || a === null ? 'object expected' : a.begin != null && a.hasOwnProperty('begin') && !n.isInteger(a.begin) && !(a.begin && n.isInteger(a.begin.low) && n.isInteger(a.begin.high)) ? 'begin: integer|Long expected' : a.end != null && a.hasOwnProperty('end') && !n.isInteger(a.end) && !(a.end && n.isInteger(a.end.low) && n.isInteger(a.end.high)) ? 'end: integer|Long expected' : null; }), (r.fromObject = function (a) { if (a instanceof s.onnx.TensorProto.Segment) return a; var l = new s.onnx.TensorProto.Segment(); return ( a.begin != null && (n.Long ? ((l.begin = n.Long.fromValue(a.begin)).unsigned = !1) : typeof a.begin == 'string' ? (l.begin = parseInt(a.begin, 10)) : typeof a.begin == 'number' ? (l.begin = a.begin) : typeof a.begin == 'object' && (l.begin = new n.LongBits( a.begin.low >>> 0, a.begin.high >>> 0 ).toNumber())), a.end != null && (n.Long ? ((l.end = n.Long.fromValue(a.end)).unsigned = !1) : typeof a.end == 'string' ? (l.end = parseInt(a.end, 10)) : typeof a.end == 'number' ? (l.end = a.end) : typeof a.end == 'object' && (l.end = new n.LongBits( a.end.low >>> 0, a.end.high >>> 0 ).toNumber())), l ); }), (r.toObject = function (a, l) { l || (l = {}); var p = {}; if (l.defaults) { if (n.Long) { var m = new n.Long(0, 0, !1); p.begin = l.longs === String ? m.toString() : l.longs === Number ? m.toNumber() : m; } else p.begin = l.longs === String ? '0' : 0; if (n.Long) { var m = new n.Long(0, 0, !1); p.end = l.longs === String ? m.toString() : l.longs === Number ? m.toNumber() : m; } else p.end = l.longs === String ? '0' : 0; } return ( a.begin != null && a.hasOwnProperty('begin') && (typeof a.begin == 'number' ? (p.begin = l.longs === String ? String(a.begin) : a.begin) : (p.begin = l.longs === String ? n.Long.prototype.toString.call(a.begin) : l.longs === Number ? new n.LongBits( a.begin.low >>> 0, a.begin.high >>> 0 ).toNumber() : a.begin)), a.end != null && a.hasOwnProperty('end') && (typeof a.end == 'number' ? (p.end = l.longs === String ? String(a.end) : a.end) : (p.end = l.longs === String ? n.Long.prototype.toString.call(a.end) : l.longs === Number ? new n.LongBits(a.end.low >>> 0, a.end.high >>> 0).toNumber() : a.end)), p ); }), (r.prototype.toJSON = function () { return this.constructor.toObject(this, o.util.toJSONOptions); }), (r.getTypeUrl = function (a) { return a === void 0 && (a = 'type.googleapis.com'), a + '/onnx.TensorProto.Segment'; }), r ); })()), (f.DataLocation = (function () { var r = {}, a = Object.create(r); return (a[(r[0] = 'DEFAULT')] = 0), (a[(r[1] = 'EXTERNAL')] = 1), a; })()), f ); })()), (d.SparseTensorProto = (function () { function f(r) { if (((this.dims = []), r)) for (var a = Object.keys(r), l = 0; l < a.length; ++l) r[a[l]] != null && (this[a[l]] = r[a[l]]); } return ( (f.prototype.values = null), (f.prototype.indices = null), (f.prototype.dims = n.emptyArray), (f.create = function (r) { return new f(r); }), (f.encode = function (r, a) { if ( (a || (a = u.create()), r.values != null && Object.hasOwnProperty.call(r, 'values') && s.onnx.TensorProto.encode(r.values, a.uint32(10).fork()).ldelim(), r.indices != null && Object.hasOwnProperty.call(r, 'indices') && s.onnx.TensorProto.encode(r.indices, a.uint32(18).fork()).ldelim(), r.dims != null && r.dims.length) ) { a.uint32(26).fork(); for (var l = 0; l < r.dims.length; ++l) a.int64(r.dims[l]); a.ldelim(); } return a; }), (f.encodeDelimited = function (r, a) { return this.encode(r, a).ldelim(); }), (f.decode = function (r, a) { r instanceof i || (r = i.create(r)); for ( var l = a === void 0 ? r.len : r.pos + a, p = new s.onnx.SparseTensorProto(); r.pos < l; ) { var m = r.uint32(); switch (m >>> 3) { case 1: { p.values = s.onnx.TensorProto.decode(r, r.uint32()); break; } case 2: { p.indices = s.onnx.TensorProto.decode(r, r.uint32()); break; } case 3: { if (((p.dims && p.dims.length) || (p.dims = []), (m & 7) === 2)) for (var y = r.uint32() + r.pos; r.pos < y; ) p.dims.push(r.int64()); else p.dims.push(r.int64()); break; } default: r.skipType(m & 7); break; } } return p; }), (f.decodeDelimited = function (r) { return r instanceof i || (r = new i(r)), this.decode(r, r.uint32()); }), (f.verify = function (r) { if (typeof r != 'object' || r === null) return 'object expected'; if (r.values != null && r.hasOwnProperty('values')) { var a = s.onnx.TensorProto.verify(r.values); if (a) return 'values.' + a; } if (r.indices != null && r.hasOwnProperty('indices')) { var a = s.onnx.TensorProto.verify(r.indices); if (a) return 'indices.' + a; } if (r.dims != null && r.hasOwnProperty('dims')) { if (!Array.isArray(r.dims)) return 'dims: array expected'; for (var l = 0; l < r.dims.length; ++l) if ( !n.isInteger(r.dims[l]) && !(r.dims[l] && n.isInteger(r.dims[l].low) && n.isInteger(r.dims[l].high)) ) return 'dims: integer|Long[] expected'; } return null; }), (f.fromObject = function (r) { if (r instanceof s.onnx.SparseTensorProto) return r; var a = new s.onnx.SparseTensorProto(); if (r.values != null) { if (typeof r.values != 'object') throw TypeError('.onnx.SparseTensorProto.values: object expected'); a.values = s.onnx.TensorProto.fromObject(r.values); } if (r.indices != null) { if (typeof r.indices != 'object') throw TypeError('.onnx.SparseTensorProto.indices: object expected'); a.indices = s.onnx.TensorProto.fromObject(r.indices); } if (r.dims) { if (!Array.isArray(r.dims)) throw TypeError('.onnx.SparseTensorProto.dims: array expected'); a.dims = []; for (var l = 0; l < r.dims.length; ++l) n.Long ? ((a.dims[l] = n.Long.fromValue(r.dims[l])).unsigned = !1) : typeof r.dims[l] == 'string' ? (a.dims[l] = parseInt(r.dims[l], 10)) : typeof r.dims[l] == 'number' ? (a.dims[l] = r.dims[l]) : typeof r.dims[l] == 'object' && (a.dims[l] = new n.LongBits( r.dims[l].low >>> 0, r.dims[l].high >>> 0 ).toNumber()); } return a; }), (f.toObject = function (r, a) { a || (a = {}); var l = {}; if ( ((a.arrays || a.defaults) && (l.dims = []), a.defaults && ((l.values = null), (l.indices = null)), r.values != null && r.hasOwnProperty('values') && (l.values = s.onnx.TensorProto.toObject(r.values, a)), r.indices != null && r.hasOwnProperty('indices') && (l.indices = s.onnx.TensorProto.toObject(r.indices, a)), r.dims && r.dims.length) ) { l.dims = []; for (var p = 0; p < r.dims.length; ++p) typeof r.dims[p] == 'number' ? (l.dims[p] = a.longs === String ? String(r.dims[p]) : r.dims[p]) : (l.dims[p] = a.longs === String ? n.Long.prototype.toString.call(r.dims[p]) : a.longs === Number ? new n.LongBits(r.dims[p].low >>> 0, r.dims[p].high >>> 0).toNumber() : r.dims[p]); } return l; }), (f.prototype.toJSON = function () { return this.constructor.toObject(this, o.util.toJSONOptions); }), (f.getTypeUrl = function (r) { return r === void 0 && (r = 'type.googleapis.com'), r + '/onnx.SparseTensorProto'; }), f ); })()), (d.TensorShapeProto = (function () { function f(r) { if (((this.dim = []), r)) for (var a = Object.keys(r), l = 0; l < a.length; ++l) r[a[l]] != null && (this[a[l]] = r[a[l]]); } return ( (f.prototype.dim = n.emptyArray), (f.create = function (r) { return new f(r); }), (f.encode = function (r, a) { if ((a || (a = u.create()), r.dim != null && r.dim.length)) for (var l = 0; l < r.dim.length; ++l) s.onnx.TensorShapeProto.Dimension.encode(r.dim[l], a.uint32(10).fork()).ldelim(); return a; }), (f.encodeDelimited = function (r, a) { return this.encode(r, a).ldelim(); }), (f.decode = function (r, a) { r instanceof i || (r = i.create(r)); for ( var l = a === void 0 ? r.len : r.pos + a, p = new s.onnx.TensorShapeProto(); r.pos < l; ) { var m = r.uint32(); switch (m >>> 3) { case 1: { (p.dim && p.dim.length) || (p.dim = []), p.dim.push(s.onnx.TensorShapeProto.Dimension.decode(r, r.uint32())); break; } default: r.skipType(m & 7); break; } } return p; }), (f.decodeDelimited = function (r) { return r instanceof i || (r = new i(r)), this.decode(r, r.uint32()); }), (f.verify = function (r) { if (typeof r != 'object' || r === null) return 'object expected'; if (r.dim != null && r.hasOwnProperty('dim')) { if (!Array.isArray(r.dim)) return 'dim: array expected'; for (var a = 0; a < r.dim.length; ++a) { var l = s.onnx.TensorShapeProto.Dimension.verify(r.dim[a]); if (l) return 'dim.' + l; } } return null; }), (f.fromObject = function (r) { if (r instanceof s.onnx.TensorShapeProto) return r; var a = new s.onnx.TensorShapeProto(); if (r.dim) { if (!Array.isArray(r.dim)) throw TypeError('.onnx.TensorShapeProto.dim: array expected'); a.dim = []; for (var l = 0; l < r.dim.length; ++l) { if (typeof r.dim[l] != 'object') throw TypeError('.onnx.TensorShapeProto.dim: object expected'); a.dim[l] = s.onnx.TensorShapeProto.Dimension.fromObject(r.dim[l]); } } return a; }), (f.toObject = function (r, a) { a || (a = {}); var l = {}; if (((a.arrays || a.defaults) && (l.dim = []), r.dim && r.dim.length)) { l.dim = []; for (var p = 0; p < r.dim.length; ++p) l.dim[p] = s.onnx.TensorShapeProto.Dimension.toObject(r.dim[p], a); } return l; }), (f.prototype.toJSON = function () { return this.constructor.toObject(this, o.util.toJSONOptions); }), (f.getTypeUrl = function (r) { return r === void 0 && (r = 'type.googleapis.com'), r + '/onnx.TensorShapeProto'; }), (f.Dimension = (function () { function r(l) { if (l) for (var p = Object.keys(l), m = 0; m < p.length; ++m) l[p[m]] != null && (this[p[m]] = l[p[m]]); } (r.prototype.dimValue = null), (r.prototype.dimParam = null), (r.prototype.denotation = ''); var a; return ( Object.defineProperty(r.prototype, 'value', { get: n.oneOfGetter((a = ['dimValue', 'dimParam'])), set: n.oneOfSetter(a), }), (r.create = function (l) { return new r(l); }), (r.encode = function (l, p) { return ( p || (p = u.create()), l.dimValue != null && Object.hasOwnProperty.call(l, 'dimValue') && p.uint32(8).int64(l.dimValue), l.dimParam != null && Object.hasOwnProperty.call(l, 'dimParam') && p.uint32(18).string(l.dimParam), l.denotation != null && Object.hasOwnProperty.call(l, 'denotation') && p.uint32(26).string(l.denotation), p ); }), (r.encodeDelimited = function (l, p) { return this.encode(l, p).ldelim(); }), (r.decode = function (l, p) { l instanceof i || (l = i.create(l)); for ( var m = p === void 0 ? l.len : l.pos + p, y = new s.onnx.TensorShapeProto.Dimension(); l.pos < m; ) { var T = l.uint32(); switch (T >>> 3) { case 1: { y.dimValue = l.int64(); break; } case 2: { y.dimParam = l.string(); break; } case 3: { y.denotation = l.string(); break; } default: l.skipType(T & 7); break; } } return y; }), (r.decodeDelimited = function (l) { return l instanceof i || (l = new i(l)), this.decode(l, l.uint32()); }), (r.verify = function (l) { if (typeof l != 'object' || l === null) return 'object expected'; var p = {}; if ( l.dimValue != null && l.hasOwnProperty('dimValue') && ((p.value = 1), !n.isInteger(l.dimValue) && !( l.dimValue && n.isInteger(l.dimValue.low) && n.isInteger(l.dimValue.high) )) ) return 'dimValue: integer|Long expected'; if (l.dimParam != null && l.hasOwnProperty('dimParam')) { if (p.value === 1) return 'value: multiple values'; if (((p.value = 1), !n.isString(l.dimParam))) return 'dimParam: string expected'; } return l.denotation != null && l.hasOwnProperty('denotation') && !n.isString(l.denotation) ? 'denotation: string expected' : null; }), (r.fromObject = function (l) { if (l instanceof s.onnx.TensorShapeProto.Dimension) return l; var p = new s.onnx.TensorShapeProto.Dimension(); return ( l.dimValue != null && (n.Long ? ((p.dimValue = n.Long.fromValue(l.dimValue)).unsigned = !1) : typeof l.dimValue == 'string' ? (p.dimValue = parseInt(l.dimValue, 10)) : typeof l.dimValue == 'number' ? (p.dimValue = l.dimValue) : typeof l.dimValue == 'object' && (p.dimValue = new n.LongBits( l.dimValue.low >>> 0, l.dimValue.high >>> 0 ).toNumber())), l.dimParam != null && (p.dimParam = String(l.dimParam)), l.denotation != null && (p.denotation = String(l.denotation)), p ); }), (r.toObject = function (l, p) { p || (p = {}); var m = {}; return ( p.defaults && (m.denotation = ''), l.dimValue != null && l.hasOwnProperty('dimValue') && (typeof l.dimValue == 'number' ? (m.dimValue = p.longs === String ? String(l.dimValue) : l.dimValue) : (m.dimValue = p.longs === String ? n.Long.prototype.toString.call(l.dimValue) : p.longs === Number ? new n.LongBits( l.dimValue.low >>> 0, l.dimValue.high >>> 0 ).toNumber() : l.dimValue), p.oneofs && (m.value = 'dimValue')), l.dimParam != null && l.hasOwnProperty('dimParam') && ((m.dimParam = l.dimParam), p.oneofs && (m.value = 'dimParam')), l.denotation != null && l.hasOwnProperty('denotation') && (m.denotation = l.denotation), m ); }), (r.prototype.toJSON = function () { return this.constructor.toObject(this, o.util.toJSONOptions); }), (r.getTypeUrl = function (l) { return ( l === void 0 && (l = 'type.googleapis.com'), l + '/onnx.TensorShapeProto.Dimension' ); }), r ); })()), f ); })()), (d.TypeProto = (function () { function f(a) { if (a) for (var l = Object.keys(a), p = 0; p < l.length; ++p) a[l[p]] != null && (this[l[p]] = a[l[p]]); } (f.prototype.tensorType = null), (f.prototype.sequenceType = null), (f.prototype.mapType = null), (f.prototype.optionalType = null), (f.prototype.sparseTensorType = null), (f.prototype.denotation = ''); var r; return ( Object.defineProperty(f.prototype, 'value', { get: n.oneOfGetter( (r = ['tensorType', 'sequenceType', 'mapType', 'optionalType', 'sparseTensorType']) ), set: n.oneOfSetter(r), }), (f.create = function (a) { return new f(a); }), (f.encode = function (a, l) { return ( l || (l = u.create()), a.tensorType != null && Object.hasOwnProperty.call(a, 'tensorType') && s.onnx.TypeProto.Tensor.encode(a.tensorType, l.uint32(10).fork()).ldelim(), a.sequenceType != null && Object.hasOwnProperty.call(a, 'sequenceType') && s.onnx.TypeProto.Sequence.encode(a.sequenceType, l.uint32(34).fork()).ldelim(), a.mapType != null && Object.hasOwnProperty.call(a, 'mapType') && s.onnx.TypeProto.Map.encode(a.mapType, l.uint32(42).fork()).ldelim(), a.denotation != null && Object.hasOwnProperty.call(a, 'denotation') && l.uint32(50).string(a.denotation), a.sparseTensorType != null && Object.hasOwnProperty.call(a, 'sparseTensorType') && s.onnx.TypeProto.SparseTensor.encode( a.sparseTensorType, l.uint32(66).fork() ).ldelim(), a.optionalType != null && Object.hasOwnProperty.call(a, 'optionalType') && s.onnx.TypeProto.Optional.encode(a.optionalType, l.uint32(74).fork()).ldelim(), l ); }), (f.encodeDelimited = function (a, l) { return this.encode(a, l).ldelim(); }), (f.decode = function (a, l) { a instanceof i || (a = i.create(a)); for (var p = l === void 0 ? a.len : a.pos + l, m = new s.onnx.TypeProto(); a.pos < p; ) { var y = a.uint32(); switch (y >>> 3) { case 1: { m.tensorType = s.onnx.TypeProto.Tensor.decode(a, a.uint32()); break; } case 4: { m.sequenceType = s.onnx.TypeProto.Sequence.decode(a, a.uint32()); break; } case 5: { m.mapType = s.onnx.TypeProto.Map.decode(a, a.uint32()); break; } case 9: { m.optionalType = s.onnx.TypeProto.Optional.decode(a, a.uint32()); break; } case 8: { m.sparseTensorType = s.onnx.TypeProto.SparseTensor.decode(a, a.uint32()); break; } case 6: { m.denotation = a.string(); break; } default: a.skipType(y & 7); break; } } return m; }), (f.decodeDelimited = function (a) { return a instanceof i || (a = new i(a)), this.decode(a, a.uint32()); }), (f.verify = function (a) { if (typeof a != 'object' || a === null) return 'object expected'; var l = {}; if (a.tensorType != null && a.hasOwnProperty('tensorType')) { l.value = 1; { var p = s.onnx.TypeProto.Tensor.verify(a.tensorType); if (p) return 'tensorType.' + p; } } if (a.sequenceType != null && a.hasOwnProperty('sequenceType')) { if (l.value === 1) return 'value: multiple values'; l.value = 1; { var p = s.onnx.TypeProto.Sequence.verify(a.sequenceType); if (p) return 'sequenceType.' + p; } } if (a.mapType != null && a.hasOwnProperty('mapType')) { if (l.value === 1) return 'value: multiple values'; l.value = 1; { var p = s.onnx.TypeProto.Map.verify(a.mapType); if (p) return 'mapType.' + p; } } if (a.optionalType != null && a.hasOwnProperty('optionalType')) { if (l.value === 1) return 'value: multiple values'; l.value = 1; { var p = s.onnx.TypeProto.Optional.verify(a.optionalType); if (p) return 'optionalType.' + p; } } if (a.sparseTensorType != null && a.hasOwnProperty('sparseTensorType')) { if (l.value === 1) return 'value: multiple values'; l.value = 1; { var p = s.onnx.TypeProto.SparseTensor.verify(a.sparseTensorType); if (p) return 'sparseTensorType.' + p; } } return a.denotation != null && a.hasOwnProperty('denotation') && !n.isString(a.denotation) ? 'denotation: string expected' : null; }), (f.fromObject = function (a) { if (a instanceof s.onnx.TypeProto) return a; var l = new s.onnx.TypeProto(); if (a.tensorType != null) { if (typeof a.tensorType != 'object') throw TypeError('.onnx.TypeProto.tensorType: object expected'); l.tensorType = s.onnx.TypeProto.Tensor.fromObject(a.tensorType); } if (a.sequenceType != null) { if (typeof a.sequenceType != 'object') throw TypeError('.onnx.TypeProto.sequenceType: object expected'); l.sequenceType = s.onnx.TypeProto.Sequence.fromObject(a.sequenceType); } if (a.mapType != null) { if (typeof a.mapType != 'object') throw TypeError('.onnx.TypeProto.mapType: object expected'); l.mapType = s.onnx.TypeProto.Map.fromObject(a.mapType); } if (a.optionalType != null) { if (typeof a.optionalType != 'object') throw TypeError('.onnx.TypeProto.optionalType: object expected'); l.optionalType = s.onnx.TypeProto.Optional.fromObject(a.optionalType); } if (a.sparseTensorType != null) { if (typeof a.sparseTensorType != 'object') throw TypeError('.onnx.TypeProto.sparseTensorType: object expected'); l.sparseTensorType = s.onnx.TypeProto.SparseTensor.fromObject(a.sparseTensorType); } return a.denotation != null && (l.denotation = String(a.denotation)), l; }), (f.toObject = function (a, l) { l || (l = {}); var p = {}; return ( l.defaults && (p.denotation = ''), a.tensorType != null && a.hasOwnProperty('tensorType') && ((p.tensorType = s.onnx.TypeProto.Tensor.toObject(a.tensorType, l)), l.oneofs && (p.value = 'tensorType')), a.sequenceType != null && a.hasOwnProperty('sequenceType') && ((p.sequenceType = s.onnx.TypeProto.Sequence.toObject(a.sequenceType, l)), l.oneofs && (p.value = 'sequenceType')), a.mapType != null && a.hasOwnProperty('mapType') && ((p.mapType = s.onnx.TypeProto.Map.toObject(a.mapType, l)), l.oneofs && (p.value = 'mapType')), a.denotation != null && a.hasOwnProperty('denotation') && (p.denotation = a.denotation), a.sparseTensorType != null && a.hasOwnProperty('sparseTensorType') && ((p.sparseTensorType = s.onnx.TypeProto.SparseTensor.toObject( a.sparseTensorType, l )), l.oneofs && (p.value = 'sparseTensorType')), a.optionalType != null && a.hasOwnProperty('optionalType') && ((p.optionalType = s.onnx.TypeProto.Optional.toObject(a.optionalType, l)), l.oneofs && (p.value = 'optionalType')), p ); }), (f.prototype.toJSON = function () { return this.constructor.toObject(this, o.util.toJSONOptions); }), (f.getTypeUrl = function (a) { return a === void 0 && (a = 'type.googleapis.com'), a + '/onnx.TypeProto'; }), (f.Tensor = (function () { function a(l) { if (l) for (var p = Object.keys(l), m = 0; m < p.length; ++m) l[p[m]] != null && (this[p[m]] = l[p[m]]); } return ( (a.prototype.elemType = 0), (a.prototype.shape = null), (a.create = function (l) { return new a(l); }), (a.encode = function (l, p) { return ( p || (p = u.create()), l.elemType != null && Object.hasOwnProperty.call(l, 'elemType') && p.uint32(8).int32(l.elemType), l.shape != null && Object.hasOwnProperty.call(l, 'shape') && s.onnx.TensorShapeProto.encode(l.shape, p.uint32(18).fork()).ldelim(), p ); }), (a.encodeDelimited = function (l, p) { return this.encode(l, p).ldelim(); }), (a.decode = function (l, p) { l instanceof i || (l = i.create(l)); for ( var m = p === void 0 ? l.len : l.pos + p, y = new s.onnx.TypeProto.Tensor(); l.pos < m; ) { var T = l.uint32(); switch (T >>> 3) { case 1: { y.elemType = l.int32(); break; } case 2: { y.shape = s.onnx.TensorShapeProto.decode(l, l.uint32()); break; } default: l.skipType(T & 7); break; } } return y; }), (a.decodeDelimited = function (l) { return l instanceof i || (l = new i(l)), this.decode(l, l.uint32()); }), (a.verify = function (l) { if (typeof l != 'object' || l === null) return 'object expected'; if (l.elemType != null && l.hasOwnProperty('elemType') && !n.isInteger(l.elemType)) return 'elemType: integer expected'; if (l.shape != null && l.hasOwnProperty('shape')) { var p = s.onnx.TensorShapeProto.verify(l.shape); if (p) return 'shape.' + p; } return null; }), (a.fromObject = function (l) { if (l instanceof s.onnx.TypeProto.Tensor) return l; var p = new s.onnx.TypeProto.Tensor(); if ((l.elemType != null && (p.elemType = l.elemType | 0), l.shape != null)) { if (typeof l.shape != 'object') throw TypeError('.onnx.TypeProto.Tensor.shape: object expected'); p.shape = s.onnx.TensorShapeProto.fromObject(l.shape); } return p; }), (a.toObject = function (l, p) { p || (p = {}); var m = {}; return ( p.defaults && ((m.elemType = 0), (m.shape = null)), l.elemType != null && l.hasOwnProperty('elemType') && (m.elemType = l.elemType), l.shape != null && l.hasOwnProperty('shape') && (m.shape = s.onnx.TensorShapeProto.toObject(l.shape, p)), m ); }), (a.prototype.toJSON = function () { return this.constructor.toObject(this, o.util.toJSONOptions); }), (a.getTypeUrl = function (l) { return l === void 0 && (l = 'type.googleapis.com'), l + '/onnx.TypeProto.Tensor'; }), a ); })()), (f.Sequence = (function () { function a(l) { if (l) for (var p = Object.keys(l), m = 0; m < p.length; ++m) l[p[m]] != null && (this[p[m]] = l[p[m]]); } return ( (a.prototype.elemType = null), (a.create = function (l) { return new a(l); }), (a.encode = function (l, p) { return ( p || (p = u.create()), l.elemType != null && Object.hasOwnProperty.call(l, 'elemType') && s.onnx.TypeProto.encode(l.elemType, p.uint32(10).fork()).ldelim(), p ); }), (a.encodeDelimited = function (l, p) { return this.encode(l, p).ldelim(); }), (a.decode = function (l, p) { l instanceof i || (l = i.create(l)); for ( var m = p === void 0 ? l.len : l.pos + p, y = new s.onnx.TypeProto.Sequence(); l.pos < m; ) { var T = l.uint32(); switch (T >>> 3) { case 1: { y.elemType = s.onnx.TypeProto.decode(l, l.uint32()); break; } default: l.skipType(T & 7); break; } } return y; }), (a.decodeDelimited = function (l) { return l instanceof i || (l = new i(l)), this.decode(l, l.uint32()); }), (a.verify = function (l) { if (typeof l != 'object' || l === null) return 'object expected'; if (l.elemType != null && l.hasOwnProperty('elemType')) { var p = s.onnx.TypeProto.verify(l.elemType); if (p) return 'elemType.' + p; } return null; }), (a.fromObject = function (l) { if (l instanceof s.onnx.TypeProto.Sequence) return l; var p = new s.onnx.TypeProto.Sequence(); if (l.elemType != null) { if (typeof l.elemType != 'object') throw TypeError('.onnx.TypeProto.Sequence.elemType: object expected'); p.elemType = s.onnx.TypeProto.fromObject(l.elemType); } return p; }), (a.toObject = function (l, p) { p || (p = {}); var m = {}; return ( p.defaults && (m.elemType = null), l.elemType != null && l.hasOwnProperty('elemType') && (m.elemType = s.onnx.TypeProto.toObject(l.elemType, p)), m ); }), (a.prototype.toJSON = function () { return this.constructor.toObject(this, o.util.toJSONOptions); }), (a.getTypeUrl = function (l) { return l === void 0 && (l = 'type.googleapis.com'), l + '/onnx.TypeProto.Sequence'; }), a ); })()), (f.Map = (function () { function a(l) { if (l) for (var p = Object.keys(l), m = 0; m < p.length; ++m) l[p[m]] != null && (this[p[m]] = l[p[m]]); } return ( (a.prototype.keyType = 0), (a.prototype.valueType = null), (a.create = function (l) { return new a(l); }), (a.encode = function (l, p) { return ( p || (p = u.create()), l.keyType != null && Object.hasOwnProperty.call(l, 'keyType') && p.uint32(8).int32(l.keyType), l.valueType != null && Object.hasOwnProperty.call(l, 'valueType') && s.onnx.TypeProto.encode(l.valueType, p.uint32(18).fork()).ldelim(), p ); }), (a.encodeDelimited = function (l, p) { return this.encode(l, p).ldelim(); }), (a.decode = function (l, p) { l instanceof i || (l = i.create(l)); for ( var m = p === void 0 ? l.len : l.pos + p, y = new s.onnx.TypeProto.Map(); l.pos < m; ) { var T = l.uint32(); switch (T >>> 3) { case 1: { y.keyType = l.int32(); break; } case 2: { y.valueType = s.onnx.TypeProto.decode(l, l.uint32()); break; } default: l.skipType(T & 7); break; } } return y; }), (a.decodeDelimited = function (l) { return l instanceof i || (l = new i(l)), this.decode(l, l.uint32()); }), (a.verify = function (l) { if (typeof l != 'object' || l === null) return 'object expected'; if (l.keyType != null && l.hasOwnProperty('keyType') && !n.isInteger(l.keyType)) return 'keyType: integer expected'; if (l.valueType != null && l.hasOwnProperty('valueType')) { var p = s.onnx.TypeProto.verify(l.valueType); if (p) return 'valueType.' + p; } return null; }), (a.fromObject = function (l) { if (l instanceof s.onnx.TypeProto.Map) return l; var p = new s.onnx.TypeProto.Map(); if ((l.keyType != null && (p.keyType = l.keyType | 0), l.valueType != null)) { if (typeof l.valueType != 'object') throw TypeError('.onnx.TypeProto.Map.valueType: object expected'); p.valueType = s.onnx.TypeProto.fromObject(l.valueType); } return p; }), (a.toObject = function (l, p) { p || (p = {}); var m = {}; return ( p.defaults && ((m.keyType = 0), (m.valueType = null)), l.keyType != null && l.hasOwnProperty('keyType') && (m.keyType = l.keyType), l.valueType != null && l.hasOwnProperty('valueType') && (m.valueType = s.onnx.TypeProto.toObject(l.valueType, p)), m ); }), (a.prototype.toJSON = function () { return this.constructor.toObject(this, o.util.toJSONOptions); }), (a.getTypeUrl = function (l) { return l === void 0 && (l = 'type.googleapis.com'), l + '/onnx.TypeProto.Map'; }), a ); })()), (f.Optional = (function () { function a(l) { if (l) for (var p = Object.keys(l), m = 0; m < p.length; ++m) l[p[m]] != null && (this[p[m]] = l[p[m]]); } return ( (a.prototype.elemType = null), (a.create = function (l) { return new a(l); }), (a.encode = function (l, p) { return ( p || (p = u.create()), l.elemType != null && Object.hasOwnProperty.call(l, 'elemType') && s.onnx.TypeProto.encode(l.elemType, p.uint32(10).fork()).ldelim(), p ); }), (a.encodeDelimited = function (l, p) { return this.encode(l, p).ldelim(); }), (a.decode = function (l, p) { l instanceof i || (l = i.create(l)); for ( var m = p === void 0 ? l.len : l.pos + p, y = new s.onnx.TypeProto.Optional(); l.pos < m; ) { var T = l.uint32(); switch (T >>> 3) { case 1: { y.elemType = s.onnx.TypeProto.decode(l, l.uint32()); break; } default: l.skipType(T & 7); break; } } return y; }), (a.decodeDelimited = function (l) { return l instanceof i || (l = new i(l)), this.decode(l, l.uint32()); }), (a.verify = function (l) { if (typeof l != 'object' || l === null) return 'object expected'; if (l.elemType != null && l.hasOwnProperty('elemType')) { var p = s.onnx.TypeProto.verify(l.elemType); if (p) return 'elemType.' + p; } return null; }), (a.fromObject = function (l) { if (l instanceof s.onnx.TypeProto.Optional) return l; var p = new s.onnx.TypeProto.Optional(); if (l.elemType != null) { if (typeof l.elemType != 'object') throw TypeError('.onnx.TypeProto.Optional.elemType: object expected'); p.elemType = s.onnx.TypeProto.fromObject(l.elemType); } return p; }), (a.toObject = function (l, p) { p || (p = {}); var m = {}; return ( p.defaults && (m.elemType = null), l.elemType != null && l.hasOwnProperty('elemType') && (m.elemType = s.onnx.TypeProto.toObject(l.elemType, p)), m ); }), (a.prototype.toJSON = function () { return this.constructor.toObject(this, o.util.toJSONOptions); }), (a.getTypeUrl = function (l) { return l === void 0 && (l = 'type.googleapis.com'), l + '/onnx.TypeProto.Optional'; }), a ); })()), (f.SparseTensor = (function () { function a(l) { if (l) for (var p = Object.keys(l), m = 0; m < p.length; ++m) l[p[m]] != null && (this[p[m]] = l[p[m]]); } return ( (a.prototype.elemType = 0), (a.prototype.shape = null), (a.create = function (l) { return new a(l); }), (a.encode = function (l, p) { return ( p || (p = u.create()), l.elemType != null && Object.hasOwnProperty.call(l, 'elemType') && p.uint32(8).int32(l.elemType), l.shape != null && Object.hasOwnProperty.call(l, 'shape') && s.onnx.TensorShapeProto.encode(l.shape, p.uint32(18).fork()).ldelim(), p ); }), (a.encodeDelimited = function (l, p) { return this.encode(l, p).ldelim(); }), (a.decode = function (l, p) { l instanceof i || (l = i.create(l)); for ( var m = p === void 0 ? l.len : l.pos + p, y = new s.onnx.TypeProto.SparseTensor(); l.pos < m; ) { var T = l.uint32(); switch (T >>> 3) { case 1: { y.elemType = l.int32(); break; } case 2: { y.shape = s.onnx.TensorShapeProto.decode(l, l.uint32()); break; } default: l.skipType(T & 7); break; } } return y; }), (a.decodeDelimited = function (l) { return l instanceof i || (l = new i(l)), this.decode(l, l.uint32()); }), (a.verify = function (l) { if (typeof l != 'object' || l === null) return 'object expected'; if (l.elemType != null && l.hasOwnProperty('elemType') && !n.isInteger(l.elemType)) return 'elemType: integer expected'; if (l.shape != null && l.hasOwnProperty('shape')) { var p = s.onnx.TensorShapeProto.verify(l.shape); if (p) return 'shape.' + p; } return null; }), (a.fromObject = function (l) { if (l instanceof s.onnx.TypeProto.SparseTensor) return l; var p = new s.onnx.TypeProto.SparseTensor(); if ((l.elemType != null && (p.elemType = l.elemType | 0), l.shape != null)) { if (typeof l.shape != 'object') throw TypeError('.onnx.TypeProto.SparseTensor.shape: object expected'); p.shape = s.onnx.TensorShapeProto.fromObject(l.shape); } return p; }), (a.toObject = function (l, p) { p || (p = {}); var m = {}; return ( p.defaults && ((m.elemType = 0), (m.shape = null)), l.elemType != null && l.hasOwnProperty('elemType') && (m.elemType = l.elemType), l.shape != null && l.hasOwnProperty('shape') && (m.shape = s.onnx.TensorShapeProto.toObject(l.shape, p)), m ); }), (a.prototype.toJSON = function () { return this.constructor.toObject(this, o.util.toJSONOptions); }), (a.getTypeUrl = function (l) { return ( l === void 0 && (l = 'type.googleapis.com'), l + '/onnx.TypeProto.SparseTensor' ); }), a ); })()), f ); })()), (d.OperatorSetIdProto = (function () { function f(r) { if (r) for (var a = Object.keys(r), l = 0; l < a.length; ++l) r[a[l]] != null && (this[a[l]] = r[a[l]]); } return ( (f.prototype.domain = ''), (f.prototype.version = n.Long ? n.Long.fromBits(0, 0, !1) : 0), (f.create = function (r) { return new f(r); }), (f.encode = function (r, a) { return ( a || (a = u.create()), r.domain != null && Object.hasOwnProperty.call(r, 'domain') && a.uint32(10).string(r.domain), r.version != null && Object.hasOwnProperty.call(r, 'version') && a.uint32(16).int64(r.version), a ); }), (f.encodeDelimited = function (r, a) { return this.encode(r, a).ldelim(); }), (f.decode = function (r, a) { r instanceof i || (r = i.create(r)); for ( var l = a === void 0 ? r.len : r.pos + a, p = new s.onnx.OperatorSetIdProto(); r.pos < l; ) { var m = r.uint32(); switch (m >>> 3) { case 1: { p.domain = r.string(); break; } case 2: { p.version = r.int64(); break; } default: r.skipType(m & 7); break; } } return p; }), (f.decodeDelimited = function (r) { return r instanceof i || (r = new i(r)), this.decode(r, r.uint32()); }), (f.verify = function (r) { return typeof r != 'object' || r === null ? 'object expected' : r.domain != null && r.hasOwnProperty('domain') && !n.isString(r.domain) ? 'domain: string expected' : r.version != null && r.hasOwnProperty('version') && !n.isInteger(r.version) && !(r.version && n.isInteger(r.version.low) && n.isInteger(r.version.high)) ? 'version: integer|Long expected' : null; }), (f.fromObject = function (r) { if (r instanceof s.onnx.OperatorSetIdProto) return r; var a = new s.onnx.OperatorSetIdProto(); return ( r.domain != null && (a.domain = String(r.domain)), r.version != null && (n.Long ? ((a.version = n.Long.fromValue(r.version)).unsigned = !1) : typeof r.version == 'string' ? (a.version = parseInt(r.version, 10)) : typeof r.version == 'number' ? (a.version = r.version) : typeof r.version == 'object' && (a.version = new n.LongBits( r.version.low >>> 0, r.version.high >>> 0 ).toNumber())), a ); }), (f.toObject = function (r, a) { a || (a = {}); var l = {}; if (a.defaults) if (((l.domain = ''), n.Long)) { var p = new n.Long(0, 0, !1); l.version = a.longs === String ? p.toString() : a.longs === Number ? p.toNumber() : p; } else l.version = a.longs === String ? '0' : 0; return ( r.domain != null && r.hasOwnProperty('domain') && (l.domain = r.domain), r.version != null && r.hasOwnProperty('version') && (typeof r.version == 'number' ? (l.version = a.longs === String ? String(r.version) : r.version) : (l.version = a.longs === String ? n.Long.prototype.toString.call(r.version) : a.longs === Number ? new n.LongBits(r.version.low >>> 0, r.version.high >>> 0).toNumber() : r.version)), l ); }), (f.prototype.toJSON = function () { return this.constructor.toObject(this, o.util.toJSONOptions); }), (f.getTypeUrl = function (r) { return r === void 0 && (r = 'type.googleapis.com'), r + '/onnx.OperatorSetIdProto'; }), f ); })()), (d.OperatorStatus = (function () { var f = {}, r = Object.create(f); return (r[(f[0] = 'EXPERIMENTAL')] = 0), (r[(f[1] = 'STABLE')] = 1), r; })()), (d.FunctionProto = (function () { function f(r) { if ( ((this.input = []), (this.output = []), (this.attribute = []), (this.attributeProto = []), (this.node = []), (this.opsetImport = []), r) ) for (var a = Object.keys(r), l = 0; l < a.length; ++l) r[a[l]] != null && (this[a[l]] = r[a[l]]); } return ( (f.prototype.name = ''), (f.prototype.input = n.emptyArray), (f.prototype.output = n.emptyArray), (f.prototype.attribute = n.emptyArray), (f.prototype.attributeProto = n.emptyArray), (f.prototype.node = n.emptyArray), (f.prototype.docString = ''), (f.prototype.opsetImport = n.emptyArray), (f.prototype.domain = ''), (f.create = function (r) { return new f(r); }), (f.encode = function (r, a) { if ( (a || (a = u.create()), r.name != null && Object.hasOwnProperty.call(r, 'name') && a.uint32(10).string(r.name), r.input != null && r.input.length) ) for (var l = 0; l < r.input.length; ++l) a.uint32(34).string(r.input[l]); if (r.output != null && r.output.length) for (var l = 0; l < r.output.length; ++l) a.uint32(42).string(r.output[l]); if (r.attribute != null && r.attribute.length) for (var l = 0; l < r.attribute.length; ++l) a.uint32(50).string(r.attribute[l]); if (r.node != null && r.node.length) for (var l = 0; l < r.node.length; ++l) s.onnx.NodeProto.encode(r.node[l], a.uint32(58).fork()).ldelim(); if ( (r.docString != null && Object.hasOwnProperty.call(r, 'docString') && a.uint32(66).string(r.docString), r.opsetImport != null && r.opsetImport.length) ) for (var l = 0; l < r.opsetImport.length; ++l) s.onnx.OperatorSetIdProto.encode(r.opsetImport[l], a.uint32(74).fork()).ldelim(); if ( (r.domain != null && Object.hasOwnProperty.call(r, 'domain') && a.uint32(82).string(r.domain), r.attributeProto != null && r.attributeProto.length) ) for (var l = 0; l < r.attributeProto.length; ++l) s.onnx.AttributeProto.encode(r.attributeProto[l], a.uint32(90).fork()).ldelim(); return a; }), (f.encodeDelimited = function (r, a) { return this.encode(r, a).ldelim(); }), (f.decode = function (r, a) { r instanceof i || (r = i.create(r)); for ( var l = a === void 0 ? r.len : r.pos + a, p = new s.onnx.FunctionProto(); r.pos < l; ) { var m = r.uint32(); switch (m >>> 3) { case 1: { p.name = r.string(); break; } case 4: { (p.input && p.input.length) || (p.input = []), p.input.push(r.string()); break; } case 5: { (p.output && p.output.length) || (p.output = []), p.output.push(r.string()); break; } case 6: { (p.attribute && p.attribute.length) || (p.attribute = []), p.attribute.push(r.string()); break; } case 11: { (p.attributeProto && p.attributeProto.length) || (p.attributeProto = []), p.attributeProto.push(s.onnx.AttributeProto.decode(r, r.uint32())); break; } case 7: { (p.node && p.node.length) || (p.node = []), p.node.push(s.onnx.NodeProto.decode(r, r.uint32())); break; } case 8: { p.docString = r.string(); break; } case 9: { (p.opsetImport && p.opsetImport.length) || (p.opsetImport = []), p.opsetImport.push(s.onnx.OperatorSetIdProto.decode(r, r.uint32())); break; } case 10: { p.domain = r.string(); break; } default: r.skipType(m & 7); break; } } return p; }), (f.decodeDelimited = function (r) { return r instanceof i || (r = new i(r)), this.decode(r, r.uint32()); }), (f.verify = function (r) { if (typeof r != 'object' || r === null) return 'object expected'; if (r.name != null && r.hasOwnProperty('name') && !n.isString(r.name)) return 'name: string expected'; if (r.input != null && r.hasOwnProperty('input')) { if (!Array.isArray(r.input)) return 'input: array expected'; for (var a = 0; a < r.input.length; ++a) if (!n.isString(r.input[a])) return 'input: string[] expected'; } if (r.output != null && r.hasOwnProperty('output')) { if (!Array.isArray(r.output)) return 'output: array expected'; for (var a = 0; a < r.output.length; ++a) if (!n.isString(r.output[a])) return 'output: string[] expected'; } if (r.attribute != null && r.hasOwnProperty('attribute')) { if (!Array.isArray(r.attribute)) return 'attribute: array expected'; for (var a = 0; a < r.attribute.length; ++a) if (!n.isString(r.attribute[a])) return 'attribute: string[] expected'; } if (r.attributeProto != null && r.hasOwnProperty('attributeProto')) { if (!Array.isArray(r.attributeProto)) return 'attributeProto: array expected'; for (var a = 0; a < r.attributeProto.length; ++a) { var l = s.onnx.AttributeProto.verify(r.attributeProto[a]); if (l) return 'attributeProto.' + l; } } if (r.node != null && r.hasOwnProperty('node')) { if (!Array.isArray(r.node)) return 'node: array expected'; for (var a = 0; a < r.node.length; ++a) { var l = s.onnx.NodeProto.verify(r.node[a]); if (l) return 'node.' + l; } } if (r.docString != null && r.hasOwnProperty('docString') && !n.isString(r.docString)) return 'docString: string expected'; if (r.opsetImport != null && r.hasOwnProperty('opsetImport')) { if (!Array.isArray(r.opsetImport)) return 'opsetImport: array expected'; for (var a = 0; a < r.opsetImport.length; ++a) { var l = s.onnx.OperatorSetIdProto.verify(r.opsetImport[a]); if (l) return 'opsetImport.' + l; } } return r.domain != null && r.hasOwnProperty('domain') && !n.isString(r.domain) ? 'domain: string expected' : null; }), (f.fromObject = function (r) { if (r instanceof s.onnx.FunctionProto) return r; var a = new s.onnx.FunctionProto(); if ((r.name != null && (a.name = String(r.name)), r.input)) { if (!Array.isArray(r.input)) throw TypeError('.onnx.FunctionProto.input: array expected'); a.input = []; for (var l = 0; l < r.input.length; ++l) a.input[l] = String(r.input[l]); } if (r.output) { if (!Array.isArray(r.output)) throw TypeError('.onnx.FunctionProto.output: array expected'); a.output = []; for (var l = 0; l < r.output.length; ++l) a.output[l] = String(r.output[l]); } if (r.attribute) { if (!Array.isArray(r.attribute)) throw TypeError('.onnx.FunctionProto.attribute: array expected'); a.attribute = []; for (var l = 0; l < r.attribute.length; ++l) a.attribute[l] = String(r.attribute[l]); } if (r.attributeProto) { if (!Array.isArray(r.attributeProto)) throw TypeError('.onnx.FunctionProto.attributeProto: array expected'); a.attributeProto = []; for (var l = 0; l < r.attributeProto.length; ++l) { if (typeof r.attributeProto[l] != 'object') throw TypeError('.onnx.FunctionProto.attributeProto: object expected'); a.attributeProto[l] = s.onnx.AttributeProto.fromObject(r.attributeProto[l]); } } if (r.node) { if (!Array.isArray(r.node)) throw TypeError('.onnx.FunctionProto.node: array expected'); a.node = []; for (var l = 0; l < r.node.length; ++l) { if (typeof r.node[l] != 'object') throw TypeError('.onnx.FunctionProto.node: object expected'); a.node[l] = s.onnx.NodeProto.fromObject(r.node[l]); } } if ((r.docString != null && (a.docString = String(r.docString)), r.opsetImport)) { if (!Array.isArray(r.opsetImport)) throw TypeError('.onnx.FunctionProto.opsetImport: array expected'); a.opsetImport = []; for (var l = 0; l < r.opsetImport.length; ++l) { if (typeof r.opsetImport[l] != 'object') throw TypeError('.onnx.FunctionProto.opsetImport: object expected'); a.opsetImport[l] = s.onnx.OperatorSetIdProto.fromObject(r.opsetImport[l]); } } return r.domain != null && (a.domain = String(r.domain)), a; }), (f.toObject = function (r, a) { a || (a = {}); var l = {}; if ( ((a.arrays || a.defaults) && ((l.input = []), (l.output = []), (l.attribute = []), (l.node = []), (l.opsetImport = []), (l.attributeProto = [])), a.defaults && ((l.name = ''), (l.docString = ''), (l.domain = '')), r.name != null && r.hasOwnProperty('name') && (l.name = r.name), r.input && r.input.length) ) { l.input = []; for (var p = 0; p < r.input.length; ++p) l.input[p] = r.input[p]; } if (r.output && r.output.length) { l.output = []; for (var p = 0; p < r.output.length; ++p) l.output[p] = r.output[p]; } if (r.attribute && r.attribute.length) { l.attribute = []; for (var p = 0; p < r.attribute.length; ++p) l.attribute[p] = r.attribute[p]; } if (r.node && r.node.length) { l.node = []; for (var p = 0; p < r.node.length; ++p) l.node[p] = s.onnx.NodeProto.toObject(r.node[p], a); } if ( (r.docString != null && r.hasOwnProperty('docString') && (l.docString = r.docString), r.opsetImport && r.opsetImport.length) ) { l.opsetImport = []; for (var p = 0; p < r.opsetImport.length; ++p) l.opsetImport[p] = s.onnx.OperatorSetIdProto.toObject(r.opsetImport[p], a); } if ( (r.domain != null && r.hasOwnProperty('domain') && (l.domain = r.domain), r.attributeProto && r.attributeProto.length) ) { l.attributeProto = []; for (var p = 0; p < r.attributeProto.length; ++p) l.attributeProto[p] = s.onnx.AttributeProto.toObject(r.attributeProto[p], a); } return l; }), (f.prototype.toJSON = function () { return this.constructor.toObject(this, o.util.toJSONOptions); }), (f.getTypeUrl = function (r) { return r === void 0 && (r = 'type.googleapis.com'), r + '/onnx.FunctionProto'; }), f ); })()), d ); })()), (e.exports = s); }); function Cr(t, e) { if (!t) throw new Error(typeof e == 'string' ? e : e()); } function sn(t) { return new TextDecoder().decode(t); } var ye, cr, hi, Xe, Xn, Ve, nt, U, an, pr, dr, hr, fe = L(() => { Wn(), ei(), (ye = Er($r())), mr(), (cr = class { static arraysEqual(t, e) { if (t.length !== e.length) return !1; for (let o = 0; o < t.length; o++) if (t[o] !== e[o]) return !1; return !0; } }), (hi = class { static preprocessInputShapes(t, e) { let o = t.length === 1 ? [1, t[0]] : t, i = e.length === 1 ? [e[0], 1] : e; return [o, i]; } static postprocessOutputShape(t, e, o) { e === 1 && t.splice(t.length - 2, 1), o === 1 && t.pop(); } static calcMatMulShape(t, e) { return t[1] !== e[0] ? void 0 : [t[0], e[1]]; } }), (Xe = class fr { static calcShape(e, o, i = !1) { let u = e.length, n = o.length; if (u === 0) return o; if (n === 0) return e; let s = Math.max(e.length, o.length), d = new Array(s); if (i) { if (u < 2 || n < 2) return; let f = hi.calcMatMulShape([e[u - 2], e[u - 1]], [o[n - 2], o[n - 1]]); if (f === void 0) return; [d[s - 2], d[s - 1]] = f; } for (let f = i ? 3 : 1; f <= s; f++) { let r = u - f < 0 ? 1 : e[u - f], a = n - f < 0 ? 1 : o[n - f]; if (r !== a && r > 1 && a > 1) return; d[s - f] = Math.max(r, a); } return d; } static index(e, o) { let i = new Array(o.length); return fr.fillIndex(e, o, i), i; } static fillIndex(e, o, i) { let u = e.length - o.length; for (let n = 0; n < o.length; n++) i[n] = e[u + n] % o[n]; } static calc(e, o, i, u, n) { let s = fr.calcShape(e.dims, o.dims); if (s) { if (u && !U.areEqual(s, e.dims)) return; let d = U.size(s), f = u ? e : new Fe(s, n || e.type); if (s.length === 0) f.set([], i(e.get([]), o.get([]))); else { let r = new Array(s.length), a = new Array(e.dims.length), l = new Array(o.dims.length), p = 0, m = 0, y = !1, T = !1; e.dims.length === 0 && ((p = e.get([])), (y = !0)), o.dims.length === 0 && ((m = o.get([])), (T = !0)); let v; for (let S = 0; S < d; S++) { v = S; for (let E = s.length - 1; E >= 0; E--) (r[E] = v % s[E]), (v = Math.floor(v / s[E])); y || (fr.fillIndex(r, e.dims, a), (p = e.get(a))), T || (fr.fillIndex(r, o.dims, l), (m = o.get(l))), f.set(r, i(p, m)); } } return f; } } static isValidBroadcast(e, o) { let i = e.length, u = o.length; if (i > u) return !1; for (let n = 1; n <= i; n++) if (e[i - n] !== 1 && e[i - n] !== o[u - n]) return !1; return !0; } static getBroadcastDims(e, o) { let i = e.length, u = []; for (let n = 0; n < i; n++) { let s = i - 1 - n, d = e[s] || 1; (o[o.length - 1 - n] || 1) > 1 && d === 1 && u.unshift(s); } return u; } }), (Xn = class { static getShapeOfGemmResult(t, e, o, i, u) { if (t.length !== 2 || o.length !== 2) throw new Error('shape need to be of size 2'); let n, s, d; e ? ((n = t[1]), (s = t[0])) : ((n = t[0]), (s = t[1])); let f = -1; if ((i ? ((d = o[0]), (f = 1)) : ((d = o[1]), (f = 0)), o[f] !== s)) throw new Error('dimension mismatch'); if (n <= 0 || d <= 0 || s <= 0) throw new Error('invalid shape specified'); if (u && !Xe.isValidBroadcast(u, [n, d])) throw new Error('gemm: invalid bias shape for broadcast'); return [n, d, s]; } }), (Ve = class Sn { static tensorDataTypeFromProto(e) { switch (e) { case ye.onnx.TensorProto.DataType.INT8: return 'int8'; case ye.onnx.TensorProto.DataType.UINT8: return 'uint8'; case ye.onnx.TensorProto.DataType.BOOL: return 'bool'; case ye.onnx.TensorProto.DataType.INT16: return 'int16'; case ye.onnx.TensorProto.DataType.UINT16: return 'uint16'; case ye.onnx.TensorProto.DataType.INT32: return 'int32'; case ye.onnx.TensorProto.DataType.UINT32: return 'uint32'; case ye.onnx.TensorProto.DataType.FLOAT: return 'float32'; case ye.onnx.TensorProto.DataType.DOUBLE: return 'float64'; case ye.onnx.TensorProto.DataType.STRING: return 'string'; case ye.onnx.TensorProto.DataType.INT64: return 'int32'; case ye.onnx.TensorProto.DataType.UINT64: return 'uint32'; default: throw new Error(`unsupported data type: ${ye.onnx.TensorProto.DataType[e]}`); } } static tensorDataTypeStringToEnum(e) { switch (e) { case 'int8': return ye.onnx.TensorProto.DataType.INT8; case 'uint8': return ye.onnx.TensorProto.DataType.UINT8; case 'bool': return ye.onnx.TensorProto.DataType.BOOL; case 'int16': return ye.onnx.TensorProto.DataType.INT16; case 'uint16': return ye.onnx.TensorProto.DataType.UINT16; case 'int32': return ye.onnx.TensorProto.DataType.INT32; case 'uint32': return ye.onnx.TensorProto.DataType.UINT32; case 'float32': return ye.onnx.TensorProto.DataType.FLOAT; case 'float64': return ye.onnx.TensorProto.DataType.DOUBLE; case 'string': return ye.onnx.TensorProto.DataType.STRING; case 'int64': return ye.onnx.TensorProto.DataType.INT64; case 'uint64': return ye.onnx.TensorProto.DataType.UINT64; default: throw new Error(`unsupported data type: ${e}`); } } static tensorDimsFromProto(e) { return e.map((o) => (zt.isLong(o) ? o.toNumber() : o)); } static tensorValueTypeFromProto(e) { return { tensorType: Sn.tensorDataTypeFromProto(e.elemType), shape: { dims: Sn.tensorDimsFromProto(e.shape.dim.map((o) => o.dimValue)) }, }; } static tensorDimsFromORTFormat(e) { let o = []; for (let i = 0; i < e.dimsLength(); i++) o.push(nt.longToNumber(e.dims(i))); return o; } static tensorAttributesFromORTFormat(e) { let o = []; for (let i = 0; i < e.attributesLength(); i++) o.push(e.attributes(i)); return o; } }), (nt = class { static longToNumber(t, e) { return zt.isLong(t) ? t.toNumber() : t instanceof _.Long ? zt.fromValue({ low: t.low, high: t.high, unsigned: e ?? !1 }).toNumber() : t; } static isLong(t) { return zt.isLong(t) || t instanceof _.Long; } }), (U = class Pt { static size(e) { return Pt.getSizeFromDimensionRange(e, 0, e.length); } static sizeFromDimension(e, o) { if (o < 0 || o > e.length) throw new Error( `invalid dimension of ${o} for sizeFromDimension as Tensor has ${e.length} dimensions.` ); return Pt.getSizeFromDimensionRange(e, o, e.length); } static sizeToDimension(e, o) { if (o < 0 || o > e.length) throw new Error( `invalid dimension of ${o} for sizeToDimension as Tensor has ${e.length} dimensions.` ); return Pt.getSizeFromDimensionRange(e, 0, o); } static getSizeFromDimensionRange(e, o, i) { let u = 1; for (let n = o; n < i; n++) { if (e[n] <= 0) throw new Error( 'cannot get valid size from specified dimension range. Most likely the range contains 0 or negative values in them.' ); u *= e[n]; } return u; } static computeStrides(e) { let o = e.length; if (o === 0) return []; if (o === 1) return [1]; let i = new Array(o); (i[o - 1] = 1), (i[o - 2] = e[o - 1]); for (let u = o - 3; u >= 0; --u) i[u] = i[u + 1] * e[u + 1]; return i; } static transpose(e) { return e.slice().reverse(); } static indicesToOffset(e, o, i) { i === void 0 && (i = e.length); let u = 0; for (let n = 0; n < i; ++n) u += o[n] * e[n]; return u; } static offsetToIndices(e, o) { let i = o.length; if (i === 0) return []; if (i === 1) return [e * o[0]]; let u = new Array(o.length); for (let n = 0; n < u.length - 1; ++n) (u[n] = Math.floor(e / o[n])), (e -= u[n] * o[n]); return (u[u.length - 1] = e), u; } static normalizeAxis(e, o) { if (e < -o && e >= o) throw new Error('unsupported axis for this operation.'); return e < 0 ? e + o : e; } static normalizeAxes(e, o) { return e.map((i) => this.normalizeAxis(i, o)); } static incrementIndex(e, o, i) { if (o.length === 0 || e.length === 0) throw new Error('Index incrementing unsupported for scalar Tensor'); if (i === void 0) i = o.length; else if (i <= 0 || i > o.length) throw new Error('Incorrect axis to increment on'); for (let u = i - 1; u >= 0 && (e[u]++, !(e[u] < o[u])); --u) e[u] = 0; } static calculateReshapedDims(e, o) { if (o.length === 0) { if (e.length === 0 || Pt.size(e) === 1) return []; throw new Error('cannot reshape to a scalar Tensor'); } let i = o.length, u = new Array(i), n = -1, s = 1; for (let f = 0; f < i; f++) { if (o[f] < -1) throw new Error('a dimension in shape hints cannot be less than -1'); if (o[f] === -1) { if (n !== -1) throw new Error('at most one dimension in shape hints can be -1'); n = f; } else { if (o[f] === 0) { if (f >= e.length) throw new Error( 'the dimension with value zero exceeds the dimension size of the input tensor' ); u[f] = e[f]; } else u[f] = o[f]; s *= u[f]; } } let d = Pt.size(e); if (n !== -1) { if (d % s !== 0) throw new Error( `the input tensor cannot be reshaped to the requested shape. Input shape: [${e}] Output shape: [${o}]` ); u[n] = d / s; } else if (s !== d) throw new Error("reshapedDims and originalDims don't have matching sizes"); return u; } static sortBasedOnPerm(e, o) { return o ? o.map((i) => e[i]) : e.slice().reverse(); } static padShape(e, o) { let i = e.length; return e.map((u, n) => u + o[n] + o[n + i]); } static areEqual(e, o) { return e.length !== o.length ? !1 : e.every((i, u) => i === o[u]); } static validateDimsAndCalcSize(e) { if (e.length > 6) throw new TypeError('Only rank 0 to 6 is supported for tensor shape.'); let o = 1; for (let i of e) { if (!Number.isInteger(i)) throw new TypeError(`Invalid shape: ${i} is not an integer`); if (i < 0 || i > 2147483647) throw new TypeError(`Invalid shape: length ${i} is not allowed`); o *= i; } return o; } static flattenShape(e, o) { o < 0 && (o += e.length); let i = e.reduce((n, s) => n * s, 1), u = e.slice(o).reduce((n, s) => n * s, 1); return [i / u, u]; } static squeezeShape(e, o) { let i = new Array(); o = Pt.normalizeAxes(o, e.length); for (let u = 0; u < e.length; u++) { let n = o.indexOf(u) >= 0; if (n && e[u] !== 1) throw new Error('squeeze an axis of size different than 1'); ((o.length === 0 && e[u] > 1) || (o.length > 0 && !n)) && i.push(e[u]); } return i; } static unsqueezeShape(e, o) { let i = new Array(e.length + o.length); i.fill(0); for (let n = 0; n < o.length; n++) { let s = Pt.normalizeAxis(o[n], i.length); if (s >= i.length) throw new Error("'axes' has an out of range axis"); if (i[s] !== 0) throw new Error("'axes' has a duplicate axis"); i[s] = 1; } let u = 0; for (let n = 0; n < i.length; n++) i[n] === 0 && (i[n] = e[u++]); if (u !== e.length) throw new Error('the unsqueezed dimension could not be established'); return i; } }), (an = class js { static splitShape(e, o, i, u) { if (i.length === 0) { if (!u) throw new Error( "need to know number of outputs when the 'split' attribute is not specified" ); js.determineSplit(e[o], u, i); } let n = [], s = [0]; for (let d = 0; d < i.length; ++d) { d !== 0 && s.push(s[d - 1] + i[d - 1]); let f = e.slice(); (f[o] = i[d]), n.push(f); } return [n, s]; } static determineSplit(e, o, i) { if (e % o !== 0) throw new Error('cannot split tensor to equal sized parts'); for (let u = 0; u < o; ++u) i.push(e / o); } }), (pr = class _r { static adjustPoolAttributes(e, o, i, u, n, s) { if (!e && i.length !== o.length - 2) throw new Error( 'length of specified kernel shapes should be 2 less than length of input dimensions' ); if (e) for (let d = 0; d < o.length - 2; d++) d >= i.length ? i.push(o[d + 2]) : (i[d] = o[d + 2]); for (let d = 0; d < i.length; d++) if (d < u.length) { if (u[d] < 0) throw new Error('strides should be greater than or equal to 1'); } else u.push(1); for (let d = 0; d < i.length; d++) if (d < n.length) { if (n[d] < 0) throw new Error('dilations should be greater than or equal to 1'); } else n.push(1); for (let d = 0; d < i.length * 2; d++) if (d < s.length) { if (s[d] < 0) throw new Error('pad should be greater than or equal to 1'); } else s.push(0); for (let d = 0; d < i.length; d++) { if (i[d] <= 0) throw new Error('kernel shapes need to be greater than 0'); if (s[d] >= i[d] || s[d + i.length] >= i[d]) throw new Error('pads should be smaller than kernel'); } } static adjustPadsBasedOnAutoPad(e, o, i, u, n, s) { if (s) { if (n.length !== 2 * (e.length - 2)) throw new Error('length of pads should be twice the length of data dimensions'); if (o.length !== e.length - 2) throw new Error('length of strides should be the length of data dimensions'); if (u.length !== e.length - 2) throw new Error('length of kernel shapes should be the length of data dimensions'); for (let d = 0; d < e.length - 2; d++) _r.adjustPadAndReturnShape(e[d + 2], o[d], i[d], u[d], n, d, d + e.length - 2, s); } } static computePoolOutputShape(e, o, i, u, n, s, d) { if (o.length <= 0) throw new Error('input shape must be of size greater than 0'); let f = [o[0], o[1]]; return _r.computeShapeHelper(e, o, f, i, u, n, s, d), f; } static computeConvOutputShape(e, o, i, u, n, s, d) { if (e.length <= 0 || o.length <= 0) throw new Error('invalid input tensor dims or invalid filter tensor dims'); let f = [e[0], o[0]]; return _r.computeShapeHelper(!1, e, f, i, u, n, s, d), f; } static computeShapeHelper(e, o, i, u, n, s, d, f) { if (e) for (let r = 0; r < o.length - 2; r++) i.push(1); else for (let r = 0; r < o.length - 2; r++) i.push(_r.adjustPadAndReturnShape(o[r + 2], u[r], n[r], s[r], d, r, r + o.length - 2, f)); } static adjustPadAndReturnShape(e, o, i, u, n, s, d, f) { let r = i * (u - 1) + 1; if (f && f !== 'NOTSET') switch (f) { case 'VALID': return (n[s] = 0), (n[d] = 0), Math.floor((e - r) / o + 1); case 'SAME_LOWER': case 'SAME_UPPER': if (i !== 1) throw new Error('Dilation not supported for SAME_UPPER or SAME_LOWER'); { let a = ((e + o - 1) / o - 1) * o + u - e; return ( (n[s] = Math.floor(f === 'SAME_LOWER' ? (a + 1) / 2 : a / 2)), (n[d] = a - n[s]), Math.floor((e + a - u) / o + 1) ); } default: throw new Error('Unsupported AutoPad type'); } else return Math.floor((e + n[s] + n[d] - r) / o + 1); } }), (dr = -34028234663852886e22), (hr = 34028234663852886e22); }); function Vd(t) { switch (t) { case 'bool': case 'int8': case 'uint8': return 1; case 'int16': case 'uint16': return 2; case 'int32': case 'uint32': case 'float32': return 4; case 'float64': return 8; default: throw new Error(`cannot calculate sizeof() on type ${t}`); } } function Fu(t) { switch (t) { case te.onnx.TensorProto.DataType.UINT8: case te.onnx.TensorProto.DataType.INT8: case te.onnx.TensorProto.DataType.BOOL: return 1; case te.onnx.TensorProto.DataType.UINT16: case te.onnx.TensorProto.DataType.INT16: return 2; case te.onnx.TensorProto.DataType.FLOAT: case te.onnx.TensorProto.DataType.INT32: case te.onnx.TensorProto.DataType.UINT32: return 4; case te.onnx.TensorProto.DataType.INT64: case te.onnx.TensorProto.DataType.DOUBLE: case te.onnx.TensorProto.DataType.UINT64: return 8; default: throw new Error(`cannot calculate sizeof() on type ${te.onnx.TensorProto.DataType[t]}`); } } function Wd(t, e) { return new (ku(e))(t); } function ku(t) { switch (t) { case 'bool': case 'uint8': return Uint8Array; case 'int8': return Int8Array; case 'int16': return Int16Array; case 'uint16': return Uint16Array; case 'int32': return Int32Array; case 'uint32': return Uint32Array; case 'int64': return BigInt64Array; case 'float32': return Float32Array; case 'float64': return Float64Array; default: throw new Error('unspecified error'); } } function bi(t, e) { if (e === te.onnx.TensorProto.DataType.INT64 || e === mi.TensorDataType.INT64) { if (t.greaterThanOrEqual(2147483648) || t.lessThan(-2147483648)) throw new TypeError('int64 is not supported'); } else if ( e === te.onnx.TensorProto.DataType.UINT32 || e === mi.TensorDataType.UINT32 || e === te.onnx.TensorProto.DataType.UINT64 || e === mi.TensorDataType.UINT64 ) { if (t.greaterThanOrEqual(4294967296) || t.lessThan(0)) throw new TypeError('uint64 is not supported'); } else throw new TypeError(`not a LONG type: ${te.onnx.TensorProto.DataType[e]}`); return t.toNumber(); } function $u(t, e, o) { switch (e) { case te.onnx.TensorProto.DataType.BOOL: case te.onnx.TensorProto.DataType.UINT8: return t.getUint8(o); case te.onnx.TensorProto.DataType.INT8: return t.getInt8(o); case te.onnx.TensorProto.DataType.UINT16: return t.getUint16(o, !0); case te.onnx.TensorProto.DataType.INT16: return t.getInt16(o, !0); case te.onnx.TensorProto.DataType.FLOAT: return t.getFloat32(o, !0); case te.onnx.TensorProto.DataType.INT32: return t.getInt32(o, !0); case te.onnx.TensorProto.DataType.UINT32: return t.getUint32(o, !0); case te.onnx.TensorProto.DataType.INT64: return bi(zt.fromBits(t.getUint32(o, !0), t.getUint32(o + 4, !0), !1), e); case te.onnx.TensorProto.DataType.DOUBLE: return t.getFloat64(o, !0); case te.onnx.TensorProto.DataType.UINT64: return bi(zt.fromBits(t.getUint32(o, !0), t.getUint32(o + 4, !0), !0), e); default: throw new Error(`cannot read from DataView for type ${te.onnx.TensorProto.DataType[e]}`); } } var Cu, te, mi, Fe, mr = L(() => { (Cu = Er(_s())), ei(), tn(), (te = Er($r())), fe(), (mi = W.experimental.fbs), (Fe = class Kr { constructor(e, o, i, u, n, s = Cu.Guid.create()) { (this.dims = e), (this.type = o), (this.dataProvider = i), (this.asyncDataProvider = u), (this.cache = n), (this.dataId = s), (this.size = U.validateDimsAndCalcSize(e)); let d = this.size, f = i === void 0 && u === void 0 && n === void 0; if (n !== void 0 && n.length !== d) throw new RangeError("Input dims doesn't match data length."); if (o === 'string') { if (n !== void 0 && (!Array.isArray(n) || !n.every((r) => typeof r == 'string'))) throw new TypeError('cache should be a string array'); f && (this.cache = new Array(d)); } else { if (n !== void 0) { let r = ku(o); if (!(n instanceof r)) throw new TypeError(`cache should be type ${r.name}`); } if (f) { let r = new ArrayBuffer(d * Vd(o)); this.cache = Wd(r, o); } } } get data() { if (this.cache === void 0) { let e = this.dataProvider(this.dataId); if (e.length !== this.size) throw new Error( 'Length of data provided by the Data Provider is inconsistent with the dims of this Tensor.' ); this.cache = e; } return this.cache; } get stringData() { if (this.type !== 'string') throw new TypeError('data type is not string'); return this.data; } get integerData() { switch (this.type) { case 'uint8': case 'int8': case 'uint16': case 'int16': case 'int32': case 'uint32': case 'bool': return this.data; default: throw new TypeError( 'data type is not integer (uint8, int8, uint16, int16, int32, uint32, bool)' ); } } get floatData() { switch (this.type) { case 'float32': case 'float64': return this.data; default: throw new TypeError('data type is not float (float32, float64)'); } } get numberData() { if (this.type !== 'string') return this.data; throw new TypeError('type cannot be non-number (string)'); } get(e) { return this.data[U.indicesToOffset(e, this.strides)]; } set(e, o) { this.data[U.indicesToOffset(e, this.strides)] = o; } async getData() { return ( this.cache === void 0 && (this.cache = await this.asyncDataProvider(this.dataId)), this.cache ); } get strides() { return this._strides || (this._strides = U.computeStrides(this.dims)), this._strides; } static fromProto(e) { if (!e) throw new Error('cannot construct Value from an empty tensor'); let o = Ve.tensorDataTypeFromProto(e.dataType), i = Ve.tensorDimsFromProto(e.dims), u = new Kr(i, o); if (o === 'string') e.stringData.forEach((n, s) => { u.data[s] = sn(n); }); else if (e.rawData && typeof e.rawData.byteLength == 'number' && e.rawData.byteLength > 0) { let n = u.data, s = new DataView(e.rawData.buffer, e.rawData.byteOffset, e.rawData.byteLength), d = Fu(e.dataType), f = e.rawData.byteLength / d; if (e.rawData.byteLength % d !== 0) throw new Error('invalid buffer length'); if (n.length !== f) throw new Error('buffer length mismatch'); for (let r = 0; r < f; r++) { let a = $u(s, e.dataType, r * d); n[r] = a; } } else { let n; switch (e.dataType) { case te.onnx.TensorProto.DataType.FLOAT: n = e.floatData; break; case te.onnx.TensorProto.DataType.INT32: case te.onnx.TensorProto.DataType.INT16: case te.onnx.TensorProto.DataType.UINT16: case te.onnx.TensorProto.DataType.INT8: case te.onnx.TensorProto.DataType.UINT8: case te.onnx.TensorProto.DataType.BOOL: n = e.int32Data; break; case te.onnx.TensorProto.DataType.INT64: n = e.int64Data; break; case te.onnx.TensorProto.DataType.DOUBLE: n = e.doubleData; break; case te.onnx.TensorProto.DataType.UINT32: case te.onnx.TensorProto.DataType.UINT64: n = e.uint64Data; break; default: throw new Error('unspecific error'); } if (n == null) throw new Error('failed to populate data from a tensorproto value'); let s = u.data; if (s.length !== n.length) throw new Error('array length mismatch'); for (let d = 0; d < n.length; d++) { let f = n[d]; zt.isLong(f) ? (s[d] = bi(f, e.dataType)) : (s[d] = f); } } return u; } static fromData(e, o, i) { return new Kr(o, i, void 0, void 0, e); } static fromOrtTensor(e) { if (!e) throw new Error('cannot construct Value from an empty tensor'); let o = Ve.tensorDimsFromORTFormat(e), i = Ve.tensorDataTypeFromProto(e.dataType()), u = new Kr(o, i); if (i === 'string') for (let n = 0; n < e.stringDataLength(); n++) u.data[n] = e.stringData(n); else if (e.rawDataArray() && typeof e.rawDataLength() == 'number' && e.rawDataLength() > 0) { let n = u.data, s = new DataView(e.rawDataArray().buffer, e.rawDataArray().byteOffset, e.rawDataLength()), d = Fu(e.dataType()), f = e.rawDataLength() / d; if (e.rawDataLength() % d !== 0) throw new Error('invalid buffer length'); if (n.length !== f) throw new Error('buffer length mismatch'); for (let r = 0; r < f; r++) { let a = $u(s, e.dataType(), r * d); n[r] = a; } } return u; } }); }); function q(t) { return t === 1 ? Hd : qd; } function Bu(t) { let e = q(t); return `${e.version} precision highp float; ${e.attribute} vec3 position; ${e.attribute} vec2 textureCoord; ${e.varyingVertex} vec2 TexCoords; void main() { gl_Position = vec4(position, 1.0); TexCoords = textureCoord; }`; } function Nu(t) { let e = q(t); return `${e.version} precision highp float; precision highp int; precision highp sampler2D; ${e.varyingFrag} vec2 TexCoords; ${e.outputDeclaration} const vec2 halfCR = vec2(0.5, 0.5); // Custom vector types to handle higher dimenalities. struct ivec5 { int x; int y; int z; int w; int u; }; struct ivec6 { int x; int y; int z; int w; int u; int v; }; int imod(int x, int y) { return x - y * (x / y); } `; } function Ru(t, e) { let o = q(t); return ` void main() { int indices[${e}]; toVec(TexCoords, indices); vec4 result = vec4(process(indices)); ${o.output} = result; } `; } var Hd, qd, xe = L(() => { (Hd = { version: '', attribute: 'attribute', varyingVertex: 'varying', varyingFrag: 'varying', texture2D: 'texture2D', output: 'gl_FragColor', outputDeclaration: '', }), (qd = { version: '#version 300 es', attribute: 'in', varyingVertex: 'out', varyingFrag: 'in', texture2D: 'texture', output: 'outputColor', outputDeclaration: 'out vec4 outputColor;', }); }), ae = L(() => {}); async function gi(t, e = (i) => 0, o) { return new Promise((i, u) => { let n = 0, s = () => { if (t()) { i(); return; } n++; let d = e(n); if (o != null && n >= o) { u(); return; } setTimeout(s, d); }; s(); }); } function Kn(t) { return ( Cr(typeof t < 'u' && t.length !== 0, () => 'empty string found for sampler name'), 'get' + t.charAt(0).toUpperCase() + t.slice(1) ); } function Mu(t) { return ( Cr(typeof t < 'u' && t.length !== 0, () => 'empty string found for sampler name'), 'get' + t.charAt(0).toUpperCase() + t.slice(1) + 'AtOutCoords' ); } function kr(t, e) { let o = JSON.parse(JSON.stringify(t)); return (o = e), o; } function Br(t, e) { return e.map((o) => t[o]).join(', '); } function Ke(t) { if (t <= 1) return 'int'; if (t === 2) return 'ivec2'; if (t === 3) return 'ivec3'; if (t === 4) return 'ivec4'; if (t === 5) return 'ivec5'; if (t === 6) return 'ivec6'; throw Error(`GPU for rank ${t} is not yet supported`); } function St(t = 6) { return ['x', 'y', 'z', 'w', 'u', 'v'].slice(0, t); } var Ft = L(() => { fe(); }); function jd(t, e) { return St(e).map((o) => `${t}.${o}`); } function Nr(t, e) { return e === 1 ? [t] : jd(t, e); } function $t() { return ` float getChannel(vec4 frag, int dim) { int modCoord = imod(dim, 2); return modCoord == 0 ? frag.r : frag.g; } float getChannel(vec4 frag, vec2 innerDims) { vec2 modCoord = mod(innerDims, 2.); return modCoord.x == 0. ? (modCoord.y == 0. ? frag.r : frag.g) : (modCoord.y == 0. ? frag.b : frag.a); } `; } var br = L(() => { Ft(); }); function Xd(t, e, o) { if (t === 0) return 'false'; if (t === 1) return `rc > ${e[0]}`; let i = ''; for (let u = t - 2; u < t; u++) (i += `${o[u]} >= ${e[u - t + 2]}`), u < t - 1 && (i += '||'); return i; } function Kd(t, e) { let o = t.length; if (o === 0) return 'getA(), 0, 0, 0'; if (o === 1) return `getA(rc), rc + 1 >= ${t[0]} ? 0. : getA(rc + 1), 0, 0`; let i = 'r, c', u = 'r, cp1', n = 'rp1, c', s = 'rp1, cp1', d = ''; if (o > 2) for (let f = 0; f < o - 2; ++f) d = d + `${e[f]},`; return `getA(${d}${i}), rEdge ? 0. : getA(${d}${n}), cEdge ? 0. : getA(${d}${u}), rEdge || cEdge ? 0. : getA(${d}${s})`; } function Jd(t, e, o, i) { return t === 0 || t === 1 ? '' : ` int r = ${e[t - 2]}; int c = ${e[t - 1]}; int rp1 = ${e[t - 2]} + 1; int cp1 = ${e[t - 1]} + 1; bool rEdge = rp1 >= ${i}; bool cEdge = cp1 >= ${o}; `; } var Gu, Yd, Uu, zu = L(() => { xe(), ae(), Ft(), br(), (Gu = { name: 'pack', inputNames: ['A'], inputTypes: [1] }), (Yd = (t, e) => { let o = q(t.session.backend.glContext.version), i = e.dims, u = i.length, n = e.dims.length, s = Ke(n), d = Nr('rc', n), f = Jd(n, d, i[i.length - 2], i[i.length - 1]), r; u === 0 ? (r = [1, 1]) : u === 1 ? (r = [i[0], 1]) : (r = [i[n - 1], i[n - 2]]); let a = Xd(n, r, d), l = Kd(i, d), p = ` void main() { ${s} rc = getOutputCoords(); if(${a}) { ${o.output} = vec4(0); } else { ${f} ${o.output} = vec4(${l}); } } `; return { ...Gu, hasMain: !0, output: { dims: e.dims, type: e.type, textureType: 2 }, shaderSource: p }; }), (Uu = (t, e) => ({ ...Gu, get: () => Yd(t, e) })); }); function yi(t) { if (t.length === 0) return [1, 1, 1]; let e = 1; for (let o = 0; o < t.length - 2; ++o) e *= t[o]; return [e, t.length > 1 ? t[t.length - 2] : 1, t[t.length - 1]]; } function Wu(t, e) { let o = !1; return ( t.length === 0 || e.length === 0 ? (o = !0) : t.length < 2 || e.length < 2 ? (o = t[t.length - 1] === e[e.length - 1]) : (o = t[t.length - 1] === e[e.length - 1] && t[t.length - 2] === e[e.length - 2]), o ); } function eh(t) { let e = U.computeStrides(t), o = ['b', 'r', 'c'], i = 'index'; return ` ivec3 inputCoordsFromReshapedOutCoords(int index) { ${e .map((u, n) => { let s = `int ${o[n]} = ${i} / ${u}`, d = n === e.length - 1 ? `int ${o[n + 1]} = ${i} - ${o[n]} * ${u}` : `index -= ${o[n]} * ${u}`; return `${s}; ${d};`; }) .join('')} return ivec3(b, r, c); } `; } function th(t) { let e = U.computeStrides(t); return ` int getFlattenedIndex(ivec3 coords) { // reverse y, z order return coords.x * ${e[0]} + coords.z * ${e[1]} + coords.y; } `; } var Zd, Qd, Vu, Hu = L(() => { fe(), xe(), ae(), br(), (Zd = (t) => ({ name: 'Reshape (packed)', inputTypes: [2], inputNames: ['A'], cacheHint: `${t}` })), (Qd = (t, e, o, i) => { let u = e.dims, n = i, s = ''; for (let r = 0; r < 4; r++) { let a = ''; switch (r) { case 0: a = 'outputCoords = rc;'; break; case 1: a = 'outputCoords = ivec3(rc.x, rc.y+1, rc.z);'; break; case 2: a = 'outputCoords = ivec3(rc.x, rc.y, rc.z+1);'; break; case 3: a = 'outputCoords = ivec3(rc.x, rc.y+1, rc.z+1);'; break; default: throw new Error(); } s += ` ${a} ${r > 0 ? 'if(outputCoords.y < rows && outputCoords.z < cols){' : ''} int flattenedIndex = getFlattenedIndex(outputCoords); ivec3 inputRC = inputCoordsFromReshapedOutCoords(flattenedIndex); vec2 innerDims = vec2(float(inputRC.y),float(inputRC.z)); result[${r}] = getChannel(getA(inputRC.x, inputRC.y, inputRC.z), innerDims); ${r > 0 ? '}' : ''} `; } let d = q(t.session.backend.glContext.version), f = ` ${eh(u)} ${th(n)} ${$t()} void main() { ivec3 rc = getOutputCoords(); vec4 result = vec4(0.0); ivec3 outputCoords; int rows = ${n[2]}; int cols = ${n[1]}; ${s} ${d.output} = result; } `; return { ...o, output: { dims: n, type: e.type, textureType: 2 }, shaderSource: f, hasMain: !0 }; }), (Vu = (t, e, o) => { let i = Zd(o); return { ...i, get: () => Qd(t, e, i, o) }; }); }), Ti, qu = L(() => { xe(), ae(), (Ti = (t, e) => { let o = e.shape, i = q(t.session.backend.glContext.version), u = ` const float FLOAT_MAX = 1.70141184e38; const float FLOAT_MIN = 1.17549435e-38; bool isNaN(float val) { return (val < 1.0 || 0.0 < val || val == 0.0) ? false : true; } highp vec4 encodeAsUint8(highp float v) { if (isNaN(v)) { return vec4(255, 255, 255, 255); } highp float av = abs(v); if(av < FLOAT_MIN) { return vec4(0.0, 0.0, 0.0, 0.0); } else if(v > FLOAT_MAX) { return vec4(0.0, 0.0, 128.0, 127.0) / 255.0; } else if(v < -FLOAT_MAX) { return vec4(0.0, 0.0, 128.0, 255.0) / 255.0; } highp vec4 c = vec4(0,0,0,0); highp float e = floor(log2(av)); highp float m = exp2(fract(log2(av))) - 1.0; c[2] = floor(128.0 * m); m -= c[2] / 128.0; c[1] = floor(32768.0 * m); m -= c[1] / 32768.0; c[0] = floor(8388608.0 * m); highp float ebias = e + 127.0; c[3] = floor(ebias / 2.0); ebias -= c[3] * 2.0; c[2] += floor(ebias) * 128.0; c[3] += 128.0 * step(0.0, -v); return c / 255.0; } void main() { float value = ${i.texture2D}(X,TexCoords).r; ${i.output} = encodeAsUint8(value); }`, n = { name: 'Uint8Encode', inputTypes: [0], inputNames: ['X'], output: { dims: o, type: e.tensor.type, textureType: 3 }, shaderSource: u, hasMain: !0, }; return t.executeProgram(n, [e.tensor]); }); }); function nh(t, e) { if (t === 1) return 'rc'; let o = ''; for (let i = 0; i < t; i++) (o += e[i]), i < t - 1 && (o += ','); return o; } var ju, rh, Yu, Xu = L(() => { xe(), ae(), Ft(), br(), (ju = { name: 'unpack', inputNames: ['A'], inputTypes: [2] }), (rh = (t, e) => { let o = e.dims.length, i = Nr('rc', o), u = i.slice(-2), n = Ke(o), s = $t(), d = e.dims.length === 0 ? '' : nh(o, i), f = o <= 1 ? 'rc' : `vec2(${u.join(',')})`, r = q(t.session.backend.glContext.version), a = ` ${s} void main() { ${n} rc = getOutputCoords(); // Sample the texture with the coords to get the rgba channel value. vec4 packedInput = getA(${d}); ${r.output} = vec4(getChannel(packedInput, ${f}), 0, 0, 0); } `; return { ...ju, hasMain: !0, output: { dims: e.dims, type: e.type, textureType: 0 }, shaderSource: a }; }), (Yu = (t, e) => ({ ...ju, get: () => rh(t, e) })); }), Jn, un, Zn, ln = L(() => { ut(), (Jn = class { constructor(t, e = 1) { if (e === 1) (this.internalFormat = t.R32F), (this.format = t.RED), (this.textureType = t.FLOAT), (this.channelSize = e); else if (e === 4) (this.internalFormat = t.RGBA32F), (this.format = t.RGBA), (this.textureType = t.FLOAT), (this.channelSize = e); else throw new Error(`Invalid number of channels: ${e}`); } encode(t, e) { let o, i; return ( t.constructor !== Float32Array && (ce.warning('Encoder', 'data was not of type Float32; creating new Float32Array'), (i = new Float32Array(t))), e * this.channelSize > t.length ? (ce.warning('Encoder', 'Source data too small. Allocating larger array'), (i = t), (o = this.allocate(e * this.channelSize)), i.forEach((u, n) => (o[n] = u))) : ((i = t), (o = i)), o ); } allocate(t) { return new Float32Array(t * 4); } decode(t, e) { return this.channelSize === 1 ? t.filter((o, i) => i % 4 === 0).subarray(0, e) : t.subarray(0, e); } }), (un = class { constructor(t, e = 1, o) { if (e !== 1 && e !== 4) throw new Error(`Invalid number of channels: ${e}`); (this.internalFormat = t.RGBA), (this.format = t.RGBA), (this.channelSize = e), (this.textureType = o || t.FLOAT); } encode(t, e) { let o = t; return ( this.channelSize === 1 && (ce.verbose('Encoder', 'Exploding into a larger array'), (o = this.allocate(e)), t.forEach((i, u) => (o[u * 4] = i))), o ); } allocate(t) { return new Float32Array(t * 4); } decode(t, e) { return this.channelSize === 1 ? t.filter((o, i) => i % 4 === 0).subarray(0, e) : t.subarray(0, e); } }), (Zn = class { constructor(t, e = 1) { if (((this.channelSize = 4), e === 1)) (this.internalFormat = t.ALPHA), (this.format = t.ALPHA), (this.textureType = t.UNSIGNED_BYTE), (this.channelSize = e); else if (e === 4) (this.internalFormat = t.RGBA), (this.format = t.RGBA), (this.textureType = t.UNSIGNED_BYTE), (this.channelSize = e); else throw new Error(`Invalid number of channels: ${e}`); } encode(t, e) { return new Uint8Array(t.buffer, t.byteOffset, t.byteLength); } allocate(t) { return new Uint8Array(t * this.channelSize); } decode(t, e) { if (t instanceof Uint8Array) return t.subarray(0, e); throw new Error(`Invalid array type: ${t.constructor}`); } }); }), fn, Ku, xi, Ju = L(() => { fe(), ae(), (fn = (t, e, o) => { let i = o === 0 || o === 1 ? 1 : 4, u = o === 2, n = o === 1 || o === 2, s = o === 4 ? e.length - 1 : void 0, d = o === 4 ? e.map((f, r) => (r === e.length - 1 ? f * 4 : f)) : void 0; return xi(t, e, i, d, { isPacked: u, reverseWH: n, breakAxis: s }); }), (Ku = (t, e, o) => { let i = fn(t, e, o); return [i.width, i.height]; }), (xi = (t, e, o = 1, i, u) => { let n = !!(u && u.isPacked), [s, d] = t.computeTextureWH((n && i) || e, u), f = e.length, r = e.slice(0); if ((f === 0 && (r = [1]), o === 1)) i = e; else if (n) { if (o !== 4) throw new Error('a packed texture must be 4-channel'); (i = e), f > 0 && (r[f - 1] = Math.ceil(r[f - 1] / 2)), f > 1 && (r[f - 2] = Math.ceil(r[f - 2] / 2)); } else if (!i) throw new Error('Unpacked shape is needed when using channels > 1'); return { width: s, height: d, channels: o, isPacked: n, shape: r, strides: U.computeStrides(r), unpackedShape: i, reversedWH: u && u.reverseWH, }; }); }), ih, Qn, Qu = L(() => { ut(), mr(), fe(), zu(), Hu(), qu(), Xu(), ln(), Ju(), ae(), (ih = (t, e) => { let o = e.map((u) => `${u.unpackedShape.join(',')};${u.width}x${u.height}`).join('_'), i = t.name; return t.cacheHint && (i += '[' + t.cacheHint + ']'), (i += ':' + o), i; }), (Qn = class { constructor(t) { (this.session = t), (this.packedTextureDataCache = new Map()), (this.unpackedTextureDataCache = new Map()); } calculateTextureWidthAndHeight(t, e) { return Ku(this.session.layoutStrategy, t, e); } executeProgram(t, e) { if (e.length < t.inputNames.length) throw new Error(`Input size mustn't be less than ${t.inputNames.length}.`); if (t.inputNames.length !== t.inputTypes.length) throw new Error('input names size does not match input types'); let o = []; for (let f = 0; f < t.inputNames.length; ++f) o[f] = this.getOrCreateTextureData(e[f], t.inputTypes[f]); let i = ih(t, o), u = this.session.programManager.getArtifact(i), n = u ? u.programInfo : typeof t.get == 'function' ? t.get() : t, s = fn(this.session.layoutStrategy, n.output.dims, n.output.textureType), d = this.createTextureData(s, n.output.type); return ( u || ((u = this.session.programManager.build(n, o, d)), this.session.programManager.setArtifact(i, u)), this.runProgram(u, o, d), d ); } run(t, e) { return this.executeProgram(t, e).tensor; } runProgram(t, e, o) { for (let i = 0; i < e.length; ++i) if (!!e[i].isPacked != (t.programInfo.inputTypes[i] === 2)) throw new Error(`input[${i}] property packed inconsistent`); if (!!o.isPacked != (t.programInfo.output.textureType === 2)) throw new Error('output property packed inconsistent'); this.session.programManager.run(t, e, o); } getOrCreateTextureData(t, e) { let o = this.getTextureData(t.dataId, e === 2); if (!o && ((o = this.getTextureData(t.dataId, e !== 2)), o)) return e === 2 ? this.pack(o) : this.unpack(o); if (!o) { let i = fn(this.session.layoutStrategy, t.dims, e); if (e === 4) { let u = t.dims; if (u.length === 4) { let n = [u[0], Math.ceil((u[1] * u[2] * u[3]) / 4)], s = fn(this.session.layoutStrategy, n, e), d = t.numberData; if ((u[1] * u[2] * u[3]) % 4 !== 0) { let f = u[0], r = u[1] * u[2] * u[3], a = Math.ceil((r * 1) / 4) * 4, l = f * a; d = new Float32Array(l); for (let p = 0; p < f; ++p) { let m = p * r, y = p * a + (p % 1) * r; d.set(t.numberData.subarray(m, m + r), y); } } return this.createTextureData(s, t.type, d, t, 1); } } if (e === 2) { let u = xi(this.session.layoutStrategy, t.dims, 1, [], { reverseWH: !0 }), n = this.createTextureData(u, t.type, t.numberData, t, 1); o = this.pack(n); } else o = this.createTextureData(i, t.type, t.numberData, t, 1); } return o; } createTextureDataFromLayoutBindTensor(t, e, o, i) { return this.createTextureData(t, e, o, i, 1); } createTextureData(t, e, o, i, u) { ce.verbose('InferenceHandler', `Creating TextureData: layout:[${JSON.stringify(t)}]`); let n = this.session.textureManager.createTextureFromLayout(e, t, o, u); return this.createTextureDataFromTexture(t, e, n, i); } reshapeUnpacked(t, e) { let o = this.getOrCreateTextureData(t, 0), i = { channels: o.channels, height: o.height, width: o.width, shape: e.length !== 0 ? e : [1], strides: U.computeStrides(e), unpackedShape: e, }; return this.createTextureDataFromTexture(i, t.type, o.texture).tensor; } reshapePacked(t, e) { let o = this.getOrCreateTextureData(t, 2); if (Wu(t.dims, e)) { let d = { channels: o.channels, height: o.height, width: o.width, shape: e.length !== 0 ? e : [1], strides: U.computeStrides(e), unpackedShape: e, isPacked: !0, }; return this.createTextureDataFromTexture(d, t.type, o.texture).tensor; } let i = yi(t.dims), u = yi(e), n = this.reshapePacked(t, i), s = this.run(Vu(this, n, u), [n]); return this.reshapePacked(s, e); } cast(t, e) { let o = this.getOrCreateTextureData(t, 0); return this.createTextureDataFromTexture(o, e, o.texture).tensor; } createTextureDataFromTexture(t, e, o, i, u) { let n = { ...t, tensor: i || new Fe( t.unpackedShape, e, (s) => this.readTexture(n), async (s) => this.readTextureAsync(n), void 0, u ), texture: o, }; return this.setTextureData(n.tensor.dataId, n, t.isPacked), n; } getTextureData(t, e = !1) { return this.session.isInitializer(t) ? this.session.getTextureData(t, e) : e ? this.packedTextureDataCache.get(t) : this.unpackedTextureDataCache.get(t); } setTextureData(t, e, o = !1) { this.session.isInitializer(t) ? this.session.setTextureData(t, e, o) : (o ? this.packedTextureDataCache : this.unpackedTextureDataCache).set(t, e); } isTextureLayoutCached(t, e = !1) { return !!this.getTextureData(t.dataId, e); } dispose() { this.session.textureManager.clearActiveTextures(), this.packedTextureDataCache.forEach((t) => this.session.textureManager.releaseTexture(t)), (this.packedTextureDataCache = new Map()), this.unpackedTextureDataCache.forEach((t) => this.session.textureManager.releaseTexture(t)), (this.unpackedTextureDataCache = new Map()); } readTexture(t) { return t.isPacked ? this.readTexture(this.unpack(t)) : this.session.backend.glContext.isFloat32DownloadSupported ? this.session.textureManager.readTexture(t, t.tensor.type, t.channels) : this.session.textureManager.readUint8TextureAsFloat(Ti(this, t)); } async readTextureAsync(t) { return t.isPacked ? this.readTextureAsync(this.unpack(t)) : this.session.backend.glContext.isFloat32DownloadSupported ? this.session.textureManager.readTextureAsync(t, t.tensor.type, t.channels) : this.session.textureManager.readUint8TextureAsFloat(Ti(this, t)); } pack(t) { return this.executeProgram(Uu(this, t.tensor), [t.tensor]); } unpack(t) { return this.executeProgram(Yu(this, t.tensor), [t.tensor]); } }); }), vi, ee, Ge = L(() => { (vi = class { constructor(t) { Object.assign(this, t); } get cacheKey() { return ( this.key || (this.key = Object.getOwnPropertyNames(this) .sort() .map((t) => `${this[t]}`) .join(';')), this.key ); } }), (ee = (t) => new vi(t)); }), el, tl, rl, ah, sh, nl = L(() => { Ge(), xe(), ae(), (el = { name: 'BatchNormalization', inputNames: ['A', 'Scale', 'B', 'Mean', 'Variance'], inputTypes: [0, 0, 0, 0, 0], }), (tl = (t, e, o) => (sh(e), [t.run({ ...el, cacheHint: o.cacheKey, get: () => ah(t, e, o) }, e)])), (rl = (t) => { let e = t.attributes.getFloat('epsilon', 1e-5), o = t.attributes.getFloat('momentum', 0.9), i = t.attributes.getInt('spatial', 1); return ee({ epsilon: e, momentum: o, spatial: i }); }), (ah = (t, e, o) => { let i = q(t.session.backend.glContext.version), u = e[0].dims.length, [n, s] = t.calculateTextureWidthAndHeight(e[1].dims, 0), d = ` float process(int[${u}] indices) { vec2 position = offsetToCoords(indices[1], ${n}, ${s}); float scale = getColorAsFloat(${i.texture2D}(Scale, position)); float mean = getColorAsFloat(${i.texture2D}(Mean, position)); float variance = getColorAsFloat(${i.texture2D}(Variance, position)); float b = getColorAsFloat(${i.texture2D}(B, position)); return scale * ( (_A(indices) - mean) / sqrt(variance + float(${o.epsilon})) ) + b; }`; return { ...el, output: { dims: e[0].dims, type: e[0].type, textureType: 0 }, shaderSource: d }; }), (sh = (t) => { if (!t || t.length !== 5) throw new Error('BatchNormalization requires 5 inputs.'); let e = t[0], o = t[1], i = t[2], u = t[3], n = t[4]; if ( e.dims.length < 3 || o.dims.length !== 1 || i.dims.length !== 1 || u.dims.length !== 1 || n.dims.length !== 1 ) throw new Error('invalid input shape.'); if ( o.dims[0] !== e.dims[1] || i.dims[0] !== e.dims[1] || u.dims[0] !== e.dims[1] || n.dims[0] !== e.dims[1] ) throw new Error('invalid input shape.'); if ( (e.type !== 'float32' && e.type !== 'float64') || (o.type !== 'float32' && o.type !== 'float64') || (i.type !== 'float32' && i.type !== 'float64') || (u.type !== 'float32' && u.type !== 'float64') || (n.type !== 'float32' && n.type !== 'float64') ) throw new Error('invalid input tensor types.'); }); }), eo, pt, R, cn, to, Vt = L(() => { (eo = class { constructor(t, e, o, i) { (this.glContext = t), (this.programInfo = e), (this.inputTextureLayouts = o), (this.outputTextureLayout = i); } }), (pt = class { constructor(t) { this.context = t; } }), (R = class { constructor(t, e) { (this.routineBody = t), (this.dependencies = e); } }), (cn = class { constructor(t, e, o) { (this.name = t), o ? (this.dependencies = o) : (this.dependencies = []), e && (this.routineBody = e); } addDependency(t) { t && this.dependencies.push(t); } }), (to = class { static returnOrderedNodes(t) { if (!t || t.length === 0) return []; if (t.length === 1) return t; let e = new Set(), o = new Set(), i = new Array(); return this.createOrderedNodes(t, e, o, i), i; } static createOrderedNodes(t, e, o, i) { for (let u = 0; u < t.length; ++u) this.dfsTraverse(t[u], e, o, i); } static dfsTraverse(t, e, o, i) { if (!t || o.has(t.name)) return; if (e.has(t.name)) throw new Error( "Cyclic dependency detected. Can't topologically sort routines needed for shader." ); e.add(t.name); let u = t.dependencies; if (u && u.length > 0) for (let n = 0; n < u.length; ++n) this.dfsTraverse(u[n], e, o, i); i.push(t), o.add(t.name), e.delete(t.name); } }); }); function lh() { let t = 'add_'; return { body: ` float ${t}(float a, float b) { return a + b; } vec4 ${t}(vec4 v1, vec4 v2) { return v1 + v2; } `, name: t, type: 0, }; } function fh() { let t = 'div_'; return { body: ` float ${t}(float a, float b) { return a / b; } vec4 ${t}(vec4 v1, vec4 v2) { return v1 / v2; } `, name: t, type: 0, }; } function ch() { let t = 'mul_'; return { body: ` float ${t}(float a, float b) { return a * b; } vec4 ${t}(vec4 v1, vec4 v2) { return v1 * v2; } `, name: t, type: 0, }; } function ph() { let t = 'sub_'; return { body: ` float ${t}(float a, float b) { return a - b; } vec4 ${t}(vec4 v1, vec4 v2) { return v1 - v2; } `, name: t, type: 0, }; } function dh() { let t = 'equal_'; return { body: ` float ${t}(float a, float b) { return float(a == b); } vec4 ${t}(vec4 v1, vec4 v2) { return vec4(equal(v1, v2)); } `, name: t, type: 0, }; } function hh() { let t = 'greater_'; return { body: ` float ${t}(float a, float b) { return float(a > b); } vec4 ${t}(vec4 v1, vec4 v2) { return vec4( v1.r > v2.r , v1.g > v2.g, v1.b > v2.b, v1.a > v2.a ); } `, name: t, type: 0, }; } function mh() { let t = 'less_'; return { body: ` float ${t}(float a, float b) { return float(a < b); } vec4 ${t}(vec4 v1, vec4 v2) { return vec4( v1.r < v2.r , v1.g < v2.g, v1.b < v2.b, v1.a < v2.a ); } `, name: t, type: 0, }; } function bh() { let t = 'and_'; return { body: ` float ${t}(float a, float b) { return float( bool(a) && bool(b) ); } vec4 ${t}(vec4 v1, vec4 v2) { bvec4 b1 = bvec4(v1); bvec4 b2 = bvec4(v2); return vec4( b1.r && b2.r , b1.g && b2.g, b1.b && b2.b, b1.a && b2.a ); } `, name: t, type: 0, }; } function gh() { let t = 'or_'; return { body: ` float ${t}(float a, float b) { return float( bool(a) || bool(b) ); } vec4 ${t}(vec4 v1, vec4 v2) { bvec4 b1 = bvec4(v1); bvec4 b2 = bvec4(v2); return vec4( b1.r || b2.r , b1.g || b2.g, b1.b || b2.b, b1.a || b2.a ); } `, name: t, type: 0, }; } function yh() { let t = 'xor_'; return { body: ` float ${t}(float a, float b) { return float( bool(a) ^^ bool(b) ); } vec4 ${t}(vec4 v1, vec4 v2) { bvec4 b1 = bvec4(v1); bvec4 b2 = bvec4(v2); return vec4( b1.r ^^ b2.r , b1.g ^^ b2.g, b1.b ^^ b2.b, b1.a ^^ b2.a ); } `, name: t, type: 0, }; } function Th() { return vh('pow'); } function xh() { let t = 'prelu_'; return { body: ` float ${t}(float a, float b) { return a < 0.0 ? a * b: a; } vec4 ${t}(vec4 v1, vec4 v2) { return vec4( v1.r < 0.0 ? v1.r * v2.r: v1.r, v1.g < 0.0 ? v1.g * v2.g: v1.g, v1.b < 0.0 ? v1.b * v2.b: v1.b, v1.a < 0.0 ? v1.a * v2.a: v1.a ); } `, name: t, type: 0, }; } function vh(t) { let e = `${t}_`; return { body: ` float ${e}(float a, float b) { return ${t}(a, b); } vec4 ${e}(vec4 v1, vec4 v2) { return ${t}(v1, v2); } `, name: e, type: 0, }; } var dt, wh, ol, il, al, sl, ul, ll, fl, cl, pl, dl, hl, ml, bl = L(() => { fe(), Vt(), xe(), ae(), (dt = (t, e, o, i = e[0].type, u) => { let n = t.session.pack ? 2 : 0; return { name: o.name, inputNames: ['A', 'B'], inputTypes: [n, n], cacheHint: u, get: () => wh(t, e, o, i), }; }), (wh = (t, e, o, i = e[0].type) => { let u = t.session.pack ? 2 : 0, n = !U.areEqual(e[0].dims, e[1].dims), s = e[0].dims, d = t.session.pack; if (n) { let a = Xe.calcShape(e[0].dims, e[1].dims, !1); if (!a) throw new Error("Can't perform binary op on the given tensors"); s = a; let l = s.length, p = e[0].dims.length !== 0 ? e[0].dims.length : 1, m = e[1].dims.length !== 0 ? e[1].dims.length : 1, y = e[0].dims.length !== 0 ? 'bcastIndices_A(indices, aindices);' : 'aindices[0] = 0;', T = e[1].dims.length !== 0 ? 'bcastIndices_B(indices, bindices);' : 'bindices[0] = 0;', v = q(t.session.backend.glContext.version), S = d ? ` ${o.body} void main() { vec4 a = getAAtOutCoords(); vec4 b = getBAtOutCoords(); vec4 result = ${o.name}(a, b); ${v.output} = result; }` : ` ${o.body} float process(int indices[${l}]) { int aindices[${p}]; int bindices[${m}]; ${y} ${T} return ${o.name}(_A(aindices), _B(bindices)); }`; return { name: o.name, inputNames: ['A', 'B'], inputTypes: [u, u], output: { dims: s, type: i, textureType: u }, shaderSource: S, hasMain: d, }; } let f = q(t.session.backend.glContext.version), r = ` ${o.body} void main() { vec4 v1 = ${f.texture2D}(A, TexCoords); vec4 v2 = ${f.texture2D}(B, TexCoords); vec4 result = ${o.name}(v1, v2); ${f.output} = result; } `; return { name: o.name, inputNames: ['A', 'B'], inputTypes: [u, u], output: { dims: e[0].dims, type: i, textureType: u }, shaderSource: r, hasMain: !0, }; }), (ol = (t, e) => [t.run(dt(t, e, lh()), e)]), (il = (t, e) => [t.run(dt(t, e, bh(), 'bool'), e)]), (al = (t, e) => [t.run(dt(t, e, fh()), e)]), (sl = (t, e) => [t.run(dt(t, e, dh(), 'bool'), e)]), (ul = (t, e) => [t.run(dt(t, e, hh(), 'bool'), e)]), (ll = (t, e) => [t.run(dt(t, e, mh(), 'bool'), e)]), (fl = (t, e) => [t.run(dt(t, e, ch()), e)]), (cl = (t, e) => [t.run(dt(t, e, gh(), 'bool'), e)]), (pl = (t, e) => [t.run(dt(t, e, Th()), e)]), (dl = (t, e) => [t.run(dt(t, e, xh()), e)]), (hl = (t, e) => [t.run(dt(t, e, ph()), e)]), (ml = (t, e) => [t.run(dt(t, e, yh(), 'bool'), e)]); }), gl, yl, Oh, Tl = L(() => { fe(), (gl = (t, e, o) => (Oh(e), [t.cast(e[0], o)])), (yl = (t) => Ve.tensorDataTypeFromProto(t.attributes.getInt('to'))), (Oh = (t) => { if (!t || t.length !== 1) throw new Error('Cast requires 1 input.'); if (t[0].type === 'string') throw new Error('Invalid input type.'); }); }), Ih, Sh, xl, ro, vl = L(() => { xe(), ae(), Ft(), br(), (Ih = (t, e) => ({ name: 'Concat (packed)', inputNames: Array.from({ length: t }, (o, i) => `X${i}`), inputTypes: Array(t).fill(2), cacheHint: e, })), (Sh = (t, e, o, i) => { let u = o[0].dims.slice(); if (i >= u.length || i < -1 * u.length) throw new Error("axis specified for concat doesn't match input dimensionality"); i < 0 && (i = u.length + i); let n = u.slice(0); for (let B = 1; B < o.length; B++) { let J = o[B].dims.slice(); for (let Q = 0; Q < u.length; Q++) if (Q === i) n[i] += J[Q]; else if (u[Q] !== J[Q]) throw new Error('non concat dimensions must match'); } let s = n.length, d = Nr('coords', s), f = Ke(s), r = $t(), a = o.map((B) => B.dims), l = St(s), p = new Array(a.length - 1); p[0] = a[0][i]; for (let B = 1; B < p.length; B++) p[B] = p[B - 1] + a[B][i]; let m = l[i], y = l.slice(-2), T = l.join(), v = `if (${m} < ${p[0]}) { return getChannel( getX0(${T}), vec2(${y.join()})); }`; for (let B = 1; B < p.length; B++) { let J = p[B - 1]; v += ` if (${m} < ${p[B]} && ${m} >= ${p[B - 1]}) { return getChannel( getX${B}(${ro(l, m, J)}), vec2(${ro(y, m, J)})); }`; } let S = p.length, E = p[p.length - 1]; v += ` return getChannel( getX${S}(${ro(l, m, E)}), vec2(${ro(y, m, E)}));`; let A = q(t.session.backend.glContext.version), F = ` ${r} float getValue(${l.map((B) => 'int ' + B)}) { ${v} } void main() { ${f} coords = getOutputCoords(); int lastDim = coords.${l[s - 1]}; coords.${l[s - 1]} = coords.${l[s - 2]}; coords.${l[s - 2]} = lastDim; vec4 result = vec4(getValue(${d}), 0., 0., 0.); ${d[s - 1]} = ${d[s - 1]} + 1; if (${d[s - 1]} < ${n[s - 1]}) { result.g = getValue(${d}); } ${d[s - 2]} = ${d[s - 2]} + 1; if (${d[s - 2]} < ${n[s - 2]}) { result.a = getValue(${d}); } ${d[s - 1]} = ${d[s - 1]} - 1; if (${d[s - 2]} < ${n[s - 2]} && ${d[s - 1]} < ${n[s - 1]}) { result.b = getValue(${d}); } ${A.output} = result; } `; return { ...e, output: { dims: n, type: o[0].type, textureType: 2 }, shaderSource: F, hasMain: !0 }; }), (xl = (t, e, o) => { let i = Ih(e.length, o.cacheKey); return { ...i, get: () => Sh(t, i, e, o.axis) }; }), (ro = (t, e, o) => { let i = t.indexOf(e); return t.map((u, n) => (n === i ? `${u} - ${o}` : u)).join(); }); }), wl, Ah, Ph, Eh, _l, Dh, Lh, Fh, Ol, $h, Il = L(() => { Ge(), ae(), vl(), (wl = (t, e, o) => ( $h(e), t.session.pack && e[0].dims.length > 1 ? [t.run(xl(t, e, o), e)] : [t.run(Eh(t, e, o), e)] )), (Ah = (t, e) => ({ name: 'Concat', inputNames: Array.from({ length: t }, (o, i) => `X${i}`), inputTypes: Array(t).fill(0), cacheHint: e, })), (Ph = (t, e, o, i) => { let u = o[0].dims.slice(); if (i >= u.length || i < -1 * u.length) throw new Error("axis specified for concat doesn't match input dimensionality"); i < 0 && (i = u.length + i); let n = u.slice(0); for (let m = 1; m < o.length; m++) { let y = o[m].dims.slice(); for (let T = 0; T < u.length; T++) if (T === i) n[i] += y[T]; else if (u[T] !== y[T]) throw new Error('non concat dimensions must match'); } let s = n.length, d = new Array(o.length), f = 0; for (let m = 0; m < d.length; ++m) (f += o[m].dims[i]), (d[m] = f); let r = ''; o.length < 5 ? (r = _l(d)) : (r = Dh(d)); let a = Lh(o.length, s), l = Fh(d), p = ` ${a} ${l} ${r} float process(int indices[${s}]) { int textureIndex = getTextureWhereDataResides (indices[${i}]); if(textureIndex != 0) { indices[${i}] = indices[${i}] - int(getSizeInConcatAxisValueFromIndex(textureIndex-int(1))); } return fetchDataFromCorrectTexture(textureIndex, indices); }`; return { ...e, output: { dims: n, type: o[0].type, textureType: 0 }, shaderSource: p }; }), (Eh = (t, e, o) => { let i = Ah(e.length, o.cacheKey); return { ...i, get: () => Ph(t, i, e, o.axis) }; }), (_l = (t) => `int getTextureWhereDataResides(int index) { ${t .map( (e, o) => `if(index<${e}) {return ${o};} ` ) .join('')} }`), (Dh = (t) => _l(t)), (Lh = (t, e) => { let o = [`float fetchDataFromCorrectTexture(int textureIndex, int indices[${e}]) {`]; for (let i = 0; i < t; ++i) i === 0 ? o.push(` if (textureIndex == ${i}) { return _X${i}(indices); }`) : i === t - 1 ? o.push(` else { return _X${i}(indices); }`) : o.push(` else if (textureIndex == ${i}) { return _X${i}(indices); }`); return ( o.push(' }'), o.join(` `) ); }), (Fh = (t) => { let e = ['int getSizeInConcatAxisValueFromIndex(int index) {']; for (let o = 0; o < t.length; ++o) o === 0 ? e.push(` if (index == ${o}) { return ${t[o]}; }`) : o === t.length - 1 ? e.push(` else { return ${t[o]}; }`) : e.push(` else if (index == ${o}) { return ${t[o]}; }`); return ( e.push(' }'), e.join(` `) ); }), (Ol = (t) => ee({ axis: t.attributes.getInt('axis') })), ($h = (t) => { if (!t || t.length < 1) throw new Error('too few inputs'); let e = t[0].type, o = t[0].dims.length; if (e === 'string') throw new Error('string tensor is not supported yet'); for (let i of t) { if (i.type !== e) throw new Error('input tensors should be one type'); if (i.dims.length !== o) throw new Error('input tensors should have the same shape'); } }); }); function Ch() { return ht('abs'); } function kh() { return ht('acos'); } function Bh() { return ht('asin'); } function Nh() { return ht('atan'); } function Rh() { return ht('ceil'); } function Mh() { return ht('cos'); } function Gh(t) { let e = 'elu'; return { body: ` const float alpha = float(${t}); float ${e}_(float a) { return a >= 0.0 ? a: (exp(a) - 1.0) * alpha; } vec4 ${e}_(vec4 v) { return vec4(${e}_(v.x), ${e}_(v.y), ${e}_(v.z), ${e}_(v.w)); } `, name: e, type: 0, }; } function Uh() { return ht('exp'); } function zh() { return ht('floor'); } function wi(t, e) { let o = 'clip'; return { body: ` const float min = float(${t}); const float max = float(${e}); float ${o}_(float a) { return clamp(a, min, max); } vec4 ${o}_(vec4 v) { return clamp(v, min, max); } `, name: o, type: 0, }; } function Vh() { let t = 'indentity'; return { body: ` float ${t}_(float a) { return a; } vec4 ${t}_(vec4 v) { return v; } `, name: t, type: 0, }; } function Wh(t) { let e = 'leakyRelu'; return { body: ` const float alpha = float(${t}); float ${e}_(float a) { return a < 0.0 ? a * alpha : a; } vec4 ${e}_(vec4 v) { return vec4(${e}_(v.x), ${e}_(v.y), ${e}_(v.z), ${e}_(v.w)); } `, name: e, type: 0, }; } function Hh() { return ht('log'); } function qh() { let t = 'neg'; return { body: ` float ${t}_(float a) { return -a; } vec4 ${t}_(vec4 v) { return -v; } `, name: t, type: 0, }; } function jh() { let t = 'not'; return { body: ` float ${t}_(float a) { return float( ! bool(a) ); } bool ${t}_(bool a) { return !a; } vec4 ${t}_(vec4 v) { return vec4(!bool(v.x), !bool(v.y), !bool(v.z), !bool(v.w)); } bvec4 ${t}_(bvec4 v) { return bvec4(!v.x, !v.y, !v.z, !v.w); } `, name: t, type: 0, }; } function Yh() { return ht('sin'); } function _i() { let t = 'relu'; return { body: ` float ${t}_(float a) { return max( a, 0.0 ); } vec4 ${t}_(vec4 v) { return max( v, 0.0 ); } `, name: t, type: 0, }; } function Oi() { let t = 'sigmoid'; return { body: ` float ${t}_(float a) { return 1.0 / (1.0 + exp(-a)); } vec4 ${t}_(vec4 v) { return 1.0 / (1.0 + exp(-v)); } `, name: t, type: 0, }; } function Xh() { return ht('sqrt'); } function Kh() { return ht('tan'); } function Jh() { let t = 'tanh'; return { body: ` float ${t}_(float a) { a = clamp(a, -10., 10.); a = exp(2.*a); return (a - 1.) / (a + 1.); } vec4 ${t}_(vec4 v) { v = clamp(v, -10., 10.); v = exp(2.*v); return (v - 1.) / (v + 1.); } `, name: t, type: 0, }; } function ht(t) { return { body: ` float ${t}_(float a) { return ${t}(a); } vec4 ${t}_(vec4 v) { return ${t}(v); } `, name: t, type: 0, }; } var Zh, Pe, Sl, Al, Pl, El, Ii, Dl, Ll, Qh, Fl, $l, Cl, kl, Bl, Nl, Si, Rl, Ml, Gl, Ul, zl, Vl, Wl, Hl, ql, jl, Yl, Ai = L(() => { Ge(), fe(), Vt(), xe(), ae(), (Zh = (t, e, o, i) => { let u = t.session.pack ? 2 : 0, n = q(t.session.backend.glContext.version); return { ...e, output: { dims: o.dims, type: o.type, textureType: u }, shaderSource: ` ${i.body} void main() { vec4 v = ${n.texture2D}(A, TexCoords); v = ${i.name}_(v); ${n.output} = v; } `, hasMain: !0, }; }), (Pe = (t, e, o, i) => { let u = t.session.pack ? 2 : 0, n = { name: o.name, inputTypes: [u], inputNames: ['A'], cacheHint: i }; return { ...n, get: () => Zh(t, n, e, o) }; }), (Sl = (t, e) => [t.run(Pe(t, e[0], Ch()), e)]), (Al = (t, e) => [t.run(Pe(t, e[0], kh()), e)]), (Pl = (t, e) => [t.run(Pe(t, e[0], Bh()), e)]), (El = (t, e) => [t.run(Pe(t, e[0], Nh()), e)]), (Ii = (t, e, o) => [t.run(Pe(t, e[0], wi(o.min, o.max), o.cacheKey), e)]), (Dl = (t) => ee({ min: t.attributes.getFloat('min', dr), max: t.attributes.getFloat('max', hr) })), (Ll = (t, e) => { let o = Qh(t, e); return Ii(t, [e[0]], o); }), (Qh = (t, e) => { if (e.length >= 3 && (!t.session.isInitializer(e[1].dataId) || !t.session.isInitializer(e[2].dataId))) throw new Error('dynamic clip attributes are not allowed'); let o = e.length >= 3 ? e[1].numberData[0] : dr, i = e.length >= 3 ? e[2].numberData[0] : hr; return ee({ min: o, max: i }); }), (Fl = (t, e) => [t.run(Pe(t, e[0], Rh()), e)]), ($l = (t, e) => [t.run(Pe(t, e[0], Mh()), e)]), (Cl = (t, e, o) => [t.run(Pe(t, e[0], Gh(o.alpha), o.cacheKey), e)]), (kl = (t) => ee({ alpha: t.attributes.getFloat('alpha', 1) })), (Bl = (t, e) => [t.run(Pe(t, e[0], Uh()), e)]), (Nl = (t, e) => [t.run(Pe(t, e[0], zh()), e)]), (Si = (t, e) => [t.run(Pe(t, e[0], Vh()), e)]), (Rl = (t, e, o) => [t.run(Pe(t, e[0], Wh(o.alpha), o.cacheKey), e)]), (Ml = (t) => ee({ alpha: t.attributes.getFloat('alpha', 0.01) })), (Gl = (t, e) => [t.run(Pe(t, e[0], Hh()), e)]), (Ul = (t, e) => [t.run(Pe(t, e[0], qh()), e)]), (zl = (t, e) => [t.run(Pe(t, e[0], jh()), e)]), (Vl = (t, e) => [t.run(Pe(t, e[0], _i()), e)]), (Wl = (t, e) => [t.run(Pe(t, e[0], Oi()), e)]), (Hl = (t, e) => [t.run(Pe(t, e[0], Yh()), e)]), (ql = (t, e) => [t.run(Pe(t, e[0], Xh()), e)]), (jl = (t, e) => [t.run(Pe(t, e[0], Kh()), e)]), (Yl = (t, e) => [t.run(Pe(t, e[0], Jh()), e)]); }); function Ct(t) { let e; switch (t.activation) { case 'Relu': e = _i(); break; case 'Sigmoid': e = Oi(); break; case 'Clip': e = wi(t.clipMin, t.clipMax); break; default: return { activationFunction: '', applyActivation: '' }; } let o = e.name, i = e.body, u = `value = ${o}_(value);`; return { activationFunction: i, applyActivation: u }; } var Rr, gr = L(() => { fe(), Ai(), (Rr = (t) => { let e = t.getString('activation', ''); if (e === 'Clip') { let [o, i] = t.getFloats('activation_params', [dr, hr]); return { activation: e, clipMax: i, clipMin: o, activationCacheKey: `${e}:${o},${i}` }; } return { activation: e, activationCacheKey: e }; }); }), tm, rm, Xl, Kl = L(() => { ut(), xe(), ae(), no(), gr(), (tm = (t, e) => ({ name: 'GroupedConv', inputNames: t ? ['X', 'W', 'Bias'] : ['X', 'W'], inputTypes: t ? [0, 0, 0] : [0, 0], cacheHint: e, })), (rm = (t, e, o, i) => { let u = e.length > 2 ? 'value += getBias(output_channel);' : '', n = e[0].dims.slice(), s = e[1].dims.slice(), d = s[0] / i.group; ce.verbose( 'GroupedConv', `autpPad:${i.autoPad}, dilations:${i.dilations}, group:${i.group}, kernelShape:${i.kernelShape}, pads:${i.pads}, strides:${i.strides}` ); let f = Mr(n, s, i.dilations, i.pads, i.strides), r = q(t.session.backend.glContext.version), { activationFunction: a, applyActivation: l } = Ct(i), p = ` const ivec2 strides = ivec2(${i.strides[0]}, ${i.strides[1]}); const ivec2 pads = ivec2(${i.pads[0]}, ${i.pads[1]}); ${a} void main() { ivec4 coords = getOutputCoords(); int batch = coords.x; int output_channel = coords.y; ivec2 xRCCorner = coords.zw * strides - pads; int group_id = output_channel / ${d}; float value = 0.0; for (int wInChannel = 0; wInChannel < ${s[1]}; wInChannel++) { int input_channel = group_id * ${s[1]} + wInChannel; for (int wHeight = 0; wHeight < ${s[2]}; wHeight++) { int xHeight = xRCCorner.x + wHeight * ${i.dilations[0]}; if (xHeight < 0 || xHeight >= ${n[2]}) { continue; } for (int wWidth = 0; wWidth < ${s[3]}; wWidth++) { int xWidth = xRCCorner.y + wWidth * ${i.dilations[1]}; if (xWidth < 0 || xWidth >= ${n[3]}) { continue; } float xVal = getX(batch, input_channel, xWidth, xHeight); float wVal = getW(output_channel, wInChannel, wWidth, wHeight); value += xVal*wVal; } } } ${u} ${l} ${r.output} = vec4(value, .0, .0, .0); } `; return { ...o, output: { dims: f, type: e[0].type, textureType: 0 }, shaderSource: p, hasMain: !0 }; }), (Xl = (t, e, o) => { let i = tm(e.length > 2, o.cacheKey); return { ...i, get: () => rm(t, e, i, o) }; }); }), nm, om, Jl, Zl = L(() => { xe(), ae(), br(), (nm = (t) => ({ name: 'Im2Col (packed)', inputNames: ['A'], inputTypes: [2], cacheHint: t })), (om = (t, e, o, i, u, n) => { let s = o.dims, d = i.dims, f = 2, r = 3, a = u.length, l = [d[1] * d[2] * d[3], u[2] * u[3]], p = d[2] * d[3], m = $t(), y = q(t.session.backend.glContext.version), T = ''; for (let S = 0; S <= 1; S++) for (let E = 0; E <= 1; E++) T += ` blockIndex = rc.x + ${E}; pos = rc.y + ${S}; if(blockIndex < ${l[1]} && pos < ${l[0]}) { offsetY = int(blockIndex / (${u[a - 1]})) * ${n.strides[0]} - ${n.pads[0]}; d0 = offsetY + ${n.dilations[0]} * (imod(pos, ${p}) / ${d[2]}); if(d0 < ${s[f]} && d0 >= 0) { offsetX = imod(blockIndex, ${u[a - 1]}) * ${n.strides[1]} - ${n.pads[1]}; d1 = offsetX + ${n.dilations[1]} * imod(imod(pos, ${p}), ${d[2]}); if(d1 < ${s[r]} && d1 >= 0) { ch = int(float(pos)/ ${p}.); innerDims = vec2(d0, d1); result[${S * 2 + E}] = getChannel( getA(0, ch, int(innerDims.x), int(innerDims.y)), innerDims); } } } `; let v = ` ${m} void main() { ivec2 rc = getOutputCoords(); vec4 result = vec4(0.0); int blockIndex, pos, offsetY, d0, offsetX, d1, ch; vec2 innerDims; ${T} ${y.output} = result; } `; return { ...e, output: { dims: l, type: o.type, textureType: 2 }, shaderSource: v, hasMain: !0 }; }), (Jl = (t, e, o, i, u) => { let n = nm(u.cacheKey); return { ...n, get: () => om(t, n, e, o, i, u) }; }); }); function am(t, e, o) { let i = e[0].dims, u = e[1].dims, n = Xe.calcShape(i, u, !0); if (!n) throw new Error("Can't use matmul on the given tensors"); let s = Ke(n.length), d = St(), { activationFunction: f, applyActivation: r } = Ct(o), a = e.length > 2, l = a ? 'value += getBiasForMatmul();' : '', p = a ? `${Ei(s, d, e[2].dims, n, !1)}` : '', m = n.length, y = i.length, T = u.length, v = i[i.length - 1], S = ` ${f} ${p} float process(int indices[${m}]) { int a[${y}]; int b[${T}]; bcastMatmulIndices_A(indices, a); bcastMatmulIndices_B(indices, b); float value; for (int k=0; k<${v}; ++k) { a[${y - 1}] = k; b[${T - 2}] = k; value += _A(a) * _B(b); } ${l} ${r} return value; }`; return { ...t, output: { dims: n, type: e[0].type, textureType: 0 }, shaderSource: S }; } function Pi(t, e) { let o = im(t.length > 2, e.activationCacheKey); return { ...o, get: () => am(o, t, e) }; } function Ei(t, e, o, i, u) { let n = '', s = o.length, d = i.length, f = d - s; d < 2 && s > 0 ? (n = 'coords') : (n = o.map((p, m) => `coords.${e[m + f]}`).join(', ')); let r = Xe.getBroadcastDims(o, i).map((p) => `coords.${e[p + f]} = 0;`).join(` `), a = U.size(o) === 1, l = 'vec4(outputValue.xx, outputValue.yy)'; return ( a && (l = 'vec4(outputValue.x)'), u ? ` vec4 getBiasForMatmul() { ${t} coords = getOutputCoords(); ${r} vec4 outputValue = getBias(${n}); return ${l}; }` : ` float getBiasForMatmul() { ${t} coords = getOutputCoords(); ${r} return getBias(coords.x); }` ); } var Ql, ef, im, sm, oo = L(() => { fe(), ae(), Ft(), gr(), Di(), (Ql = (t, e, o) => (sm(e), t.session.pack ? [t.run(io(t, e, o), e)] : [t.run(Pi(e, o), e)])), (ef = (t) => Rr(t.attributes)), (im = (t, e) => ({ name: 'MatMul', inputNames: t ? ['A', 'B', 'Bias'] : ['A', 'B'], inputTypes: t ? [0, 0, 0] : [0, 0], cacheHint: e, })), (sm = (t) => { if (!t || t.length !== 2) throw new Error('MatMul requires 2 inputs.'); if (t[0].dims[t[0].dims.length - 1] !== t[1].dims[t[1].dims.length - 2]) throw new Error('shared dimension does not match.'); if ( (t[0].type !== 'float32' && t[0].type !== 'float64') || (t[1].type !== 'float32' && t[1].type !== 'float64') ) throw new Error('inputs should be float type'); if (t[0].type !== t[1].type) throw new Error('inputs types should match'); }); }); function fm(t, e, o, i) { let u = [], n = [], s = o[0].dims, d = o[1].dims, f = s.length, r = d.length, a = i.length, l = a - f, p = a - r; (u = s.map((E, A) => `coords.${e[A + l]}`)), (u[f - 1] = 'i*2'), u.join(', '), (n = d.map((E, A) => `coords.${e[A + p]}`)), (n[r - 2] = 'i*2'), n.join(', '); let m = Xe.getBroadcastDims(s, i), y = Xe.getBroadcastDims(d, i), T = m.map((E) => `coords.${e[E + l]} = 0;`).join(` `), v = y.map((E) => `coords.${e[E + p]} = 0;`).join(` `), S = `int lastDim = coords.${e[a - 1]}; coords.${e[a - 1]} = coords.${e[a - 2]}; coords.${e[a - 2]} = lastDim;`; return ` vec4 getAAtOutCoordsMatmul(int i) { ${t} coords = getOutputCoords(); ${S} ${T} vec4 outputValue = getA(${u}); return outputValue; } vec4 getBAtOutCoordsMatmul(int i) { ${t} coords = getOutputCoords(); ${S} ${v} vec4 outputValue = getB(${n}); return outputValue; }`; } function cm(t, e) { let o = ''; for (let i = 0; i < e - 2; i++) o += `rc.${t[i]}, `; return (o += `rc.${t[e - 2]}, i*2`), o; } function pm(t, e) { let o = ''; for (let i = 0; i < e - 2; i++) o += `rc.${t[i]}, `; return (o += `i*2, rc.${t[e - 1]}`), o; } var um, lm, io, Di = L(() => { fe(), xe(), ae(), Ft(), gr(), oo(), (um = (t, e) => ({ name: 'MatMul (packed)', inputNames: t ? ['A', 'B', 'Bias'] : ['A', 'B'], inputTypes: t ? [2, 2, 2] : [2, 2], cacheHint: e, })), (lm = (t, e, o, i) => { let u = o.length > 2, n = u ? 'value += getBiasForMatmul();' : '', s = o[0].dims, d = o[1].dims, f = Xe.calcShape(s, d, !0), r = !U.areEqual(o[0].dims, o[1].dims); if (!f) throw new Error("Can't use matmul on the given tensors"); let a = s[s.length - 1], l = Math.ceil(a / 2), p = s.length, m = d.length, y = q(t.session.backend.glContext.version), T = Ke(f.length), v = f.length, S = St(), { activationFunction: E, applyActivation: A } = Ct(i), F = u ? `${Ei(T, S, o[2].dims, f, !0)}` : '', B = r ? `${fm(T, S, o, f)}` : '', J = r ? 'getAAtOutCoordsMatmul(i)' : `getA(${cm(S, p)})`, Q = r ? 'getBAtOutCoordsMatmul(i)' : `getB(${pm(S, m)})`, re = r ? '' : `${T} rc = getOutputCoords(); int lastDim = rc.${S[v - 1]}; rc.${S[v - 1]} = rc.${S[v - 2]}; rc.${S[v - 2]} = lastDim; `, V = ` ${B} ${F} ${E} void main() { ${re} vec4 value = vec4(0); for (int i = 0; i < ${l}; i++) { vec4 a = ${J}; vec4 b = ${Q}; value += (a.rrbb * b.rgrg); value += (a.ggaa * b.baba); } ${n} ${A} ${y.output} = value; }`; return { ...e, output: { dims: f, type: o[0].type, textureType: 2 }, shaderSource: V, hasMain: !0 }; }), (io = (t, e, o) => { let i = um(e.length > 2, o.activationCacheKey); return { ...i, get: () => lm(t, i, e, o) }; }); }), tf, rf = L(() => { no(), Zl(), Di(), (tf = (t, e, o) => { let i = e[0].dims, u = e[1].dims, n = Mr(i, u, o.dilations, o.pads, o.strides), s = t.run(Jl(t, e[0], e[1], n, o), [e[0]]), d = t.reshapePacked(e[1], [u[0], u[1] * u[2] * u[3]]), f = e.length === 3 ? [d, s, e[2]] : [d, s], r = t.run(io(t, f, o), f); return t.reshapePacked(r, n); }); }), dm, hm, nf, Li, Fi = L(() => { ae(), (dm = (t) => ({ name: 'Im2Col', inputNames: ['X'], inputTypes: [0], cacheHint: t })), (hm = (t, e, o, i, u, n) => { let s = o.dims, d = i.dims, f = u.length, r = Li(s, d, u, 4), a = ` const int XC = ${s[1]}; const int XH = ${s[2]}; const int XW = ${s[3]}; const int KH = ${n.kernelShape[0]}; const int KW = ${n.kernelShape[1]}; const int dilationH = ${n.dilations[0]}; const int dilationW = ${n.dilations[1]}; const int strideH = ${n.strides[0]}; const int strideW = ${n.strides[1]}; const int padH = ${n.pads[0]}; const int padW = ${n.pads[1]}; const int KHKW = KH*KW; const int XCKHKW = XC * KHKW; const int outputChannels = 4; vec4 process(int indices[${f}]) { int b = indices[0]; // batch size int oh = indices[1] * strideH - padH; //output height int ow = indices[2] * strideW - padW; //output width int p = indices[3] * outputChannels; //patch vec4 value = vec4(0.0); for(int i=0; i < outputChannels; ++i) { if(p < XCKHKW) { int patchC = p / KHKW; int patchH = (p - patchC*KHKW) / KW; int patchW = (p - patchC*KHKW) - patchH * KW; int xh2 = oh + patchH * dilationH; int xw2 = ow + patchW * dilationW; int x[${s.length}]; x[0] = b; x[1] = patchC; x[2] = xh2; x[3] = xw2; if(xh2 >= 0 && xh2 < XH && xw2 >= 0 && xw2 < XW) { value[i] = _X(x); } } ++p; } return value; } `; return { ...e, output: { dims: r, type: o.type, textureType: 4 }, shaderSource: a }; }), (nf = (t, e, o, i, u) => { let n = dm(u.cacheKey); return { ...n, get: () => hm(t, n, e, o, i, u) }; }), (Li = (t, e, o, i = 4) => [o[0], o[2], o[3], Math.ceil((t[1] * e[2] * e[3]) / i)]); }), mm, bm, of, af = L(() => { fe(), xe(), ae(), gr(), Fi(), (mm = (t, e) => ({ name: 'ConvDotProduct', inputNames: t ? ['Im2Col', 'K', 'B'] : ['Im2Col', 'K'], inputTypes: t ? [0, 4, 0] : [0, 4], cacheKey: e.activationCacheKey, })), (bm = (t, e, o, i, u) => { let n = o[0].dims, s = o[1].dims, d = [s[0], Math.ceil((n[1] * s[2] * s[3]) / 4)], f = Li(n, s, i), [r, a] = t.calculateTextureWidthAndHeight(d, 4), l = U.computeStrides(f), [p, m] = t.calculateTextureWidthAndHeight(f, 4), y = i.length, T = o.length < 3 ? '0.0' : '_B(b)', v = Math.ceil((n[1] * s[2] * s[3]) / 4), { activationFunction: S, applyActivation: E } = Ct(u), A = q(t.session.backend.glContext.version), F = ` ${S} float process(int indices[${y}]) { int b[1]; b[0] = indices[1]; int im2col[4]; im2col[0] = indices[0]; im2col[1] = indices[2]; im2col[2] = indices[3]; int im2colOffset = im2col[0] * ${l[0]} + im2col[1] * ${l[1]} + im2col[2] * ${l[2]}; int kernelOffset = indices[1] * ${d[1]}; float value = ${T}; for (int i = 0; i < ${v}; ++i) { vec2 im2colCoords = offsetToCoords(im2colOffset, ${p}, ${m}); vec2 kernelCoords = offsetToCoords(kernelOffset, ${r}, ${a}); value += dot(${A.texture2D}(Im2Col, im2colCoords), ${A.texture2D}(K, kernelCoords)); ++im2colOffset; ++kernelOffset; } ${E} return value; }`; return { ...e, output: { dims: i, type: o[0].type, textureType: 0 }, shaderSource: F }; }), (of = (t, e, o, i) => { let u = mm(e.length > 2, i); return { ...u, get: () => bm(t, u, e, o, i) }; }); }), Mr, $i, gm, ym, Tm, xm, Ci, vm, no = L(() => { Ge(), fe(), Kl(), rf(), af(), gr(), Fi(), oo(), (Mr = (t, e, o, i, u) => { let n = t[0], s = t.slice(2), d = s.length, f = e[0], r = e.slice(2).map((l, p) => l + (l - 1) * (o[p] - 1)), a = s.map((l, p) => l + i[p] + i[p + d]).map((l, p) => Math.floor((l - r[p] + u[p]) / u[p])); return [n, f].concat(...a); }), ($i = (t, e, o) => (vm(e, o), gm(t, e, o))), (gm = (t, e, o) => { let i = xm(o, e), u = t.session.pack, n = i.kernelShape[0] === 1 && i.kernelShape[1] === 1; return i.group > 1 ? [t.run(Xl(t, e, i), e)] : n && u ? [ym(t, e, i)] : u && e[0].dims.length === 4 && e[0].dims[0] === 1 && !n ? [tf(t, e, i)] : [Tm(t, e, i)]; }), (ym = (t, e, o) => { let i = e[0].dims, u = e[1].dims, n = Mr(i, u, o.dilations, o.pads, o.strides), s = t.reshapeUnpacked(e[0], [i[1], i[2] * i[3]]), d = t.reshapeUnpacked(e[1], [u[0], u[1]]), f = e.length > 2 ? [d, s, e[2]] : [d, s], r = t.run(Pi(f, o), f); return t.reshapeUnpacked(r, n); }), (Tm = (t, e, o) => { let i = e[0].dims, u = e[1].dims, n = Mr(i, u, o.dilations, o.pads, o.strides), s = t.run(nf(t, e[0], e[1], n, o), [e[0]]), d = e.length === 3 ? [s, e[1], e[2]] : [s, e[1]]; return t.run(of(t, e, n, o), d); }), (xm = (t, e) => { let o = t.kernelShape.slice(); if (t.kernelShape.length === 0) for (let n = 2; n < e[1].dims.length; ++n) o.push(e[1].dims[n]); let i = t.pads.slice(); pr.adjustPadsBasedOnAutoPad(e[0].dims, t.strides, t.dilations, o, i, t.autoPad); let u = Object.assign({}, t); return Object.assign(u, { kernelShape: o, pads: i, cacheKey: t.cacheKey }), u; }), (Ci = (t) => { let e = t.attributes, o = Rr(e), i = e.getString('auto_pad', 'NOTSET'), u = e.getInts('dilations', [1, 1]), n = e.getInt('group', 1), s = e.getInts('kernel_shape', []), d = e.getInts('pads', [0, 0, 0, 0]), f = e.getInts('strides', [1, 1]); return ee({ autoPad: i, dilations: u, group: n, kernelShape: s, pads: d, strides: f, ...o }); }), (vm = (t, e) => { if (!t || (t.length !== 2 && t.length !== 3)) throw new Error('Conv requires 2 or 3 inputs'); if (t[0].dims.length !== 4 || t[1].dims.length !== 4) throw new Error('currently only support 2-dimensional conv'); let o = t[0].dims[1], i = t[1].dims[1] * e.group; if (o !== i) throw new Error('FILTER_IN_CHANNEL should be equal to DATA_CHANNEL'); if (t.length === 3 && (t[2].dims.length !== 1 || t[1].dims[0] !== t[2].dims[0])) throw new Error('invalid bias'); let u = t[0].dims.length - 2; if (e.dilations.length !== u) throw new Error(`dilations should be ${u}D`); if (e.strides.length !== u) throw new Error(`strides should be ${u}D`); if (e.pads.length !== u * 2) throw new Error(`pads should be ${u * 2}D`); if (e.kernelShape.length !== 0 && e.kernelShape.length !== t[1].dims.length - 2) throw new Error('invalid kernel shape'); if (t[0].type !== 'float32' || t[1].type !== 'float32') throw new Error('Conv input(X,W) should be float tensor'); if (t.length === 3 && t[2].type !== 'float32') throw new Error('Conv input(bias) should be float tensor'); }); }), wm, _m, Om, sf, Im, Sm, Am, Pm, Em, Dm, uf, Lm, lf = L(() => { Ge(), xe(), ae(), gr(), (wm = (t, e, o, i, u, n) => (t - 1) * e + o + (i - 1) * u + 1 - n), (_m = (t, e, o, i, u) => { let n = Math.floor(t / 2); e === 'SAME_UPPER' ? ((o[i] = n), (o[u] = t - n)) : e === 'SAME_LOWER' && ((o[i] = t - n), (o[u] = n)); }), (Om = (t, e, o, i, u, n, s, d) => { let f = t.length - 2, r = d.length === 0; for (let a = 0; a < f; ++a) { let l = r ? t[a + 2] * n[a] : d[a], p = wm(t[a + 2], n[a], u[a], e[a], o[a], l); _m(p, i, u, a, a + f), r && d.push(n[a] * (t[a + 2] - 1) + s[a] + (e[a] - 1) * o[a] + 1 - u[a] - u[a + f]); } }), (sf = (t, e, o) => (Lm(e, o), Im(t, e, o))), (Im = (t, e, o) => { let i = Dm(o, e); return [Em(t, e, i)]; }), (Sm = (t, e) => ({ name: 'ConvTranspose', inputNames: t ? ['X', 'W', 'B'] : ['X', 'W'], inputTypes: t ? [0, 0, 0] : [0, 0], cacheHint: e, })), (Am = (t, e, o, i) => { let u = e.length > 2 ? 'getB(output_channel)' : '0.0', n = e[0].dims, s = e[1].dims, d = s[1], f = s[0] / i.group, r = [e[0].dims[0], e[1].dims[1] * i.group, ...i.outputShape], a = q(t.session.backend.glContext.version), { activationFunction: l, applyActivation: p } = Ct(i), m = ` const ivec2 strides = ivec2(${i.strides[0]}, ${i.strides[1]}); const ivec2 pads = ivec2(${i.pads[0]}, ${i.pads[1]}); ${l} void main() { ivec4 coords = getOutputCoords(); int batch = coords.x; int output_channel = coords.y; ivec2 loc = coords.zw + pads; int group_id = output_channel / ${d}; int wOutChannel = output_channel - group_id * ${d}; float value = ${u}; for (int inChannelOffset = 0; inChannelOffset < ${f}; inChannelOffset++) { int input_channel = group_id * ${f} + inChannelOffset; for (int wWOff = 0; wWOff < ${s[2]}; wWOff++) { for (int wHOff = 0; wHOff < ${s[3]}; wHOff++) { ivec2 wOff = ivec2(wWOff * ${i.dilations[0]}, wHOff * ${i.dilations[1]}); ivec2 wLoc = loc - wOff; ivec2 wLocIn = wLoc / strides; if ( wLocIn * strides == wLoc && wLocIn.x >= 0 && wLocIn.x < ${n[2]} && wLocIn.y >= 0 && wLocIn.y < ${n[3]} ) { float xVal = getX(batch, input_channel, wLocIn.y, wLocIn.x); float wVal = getW(input_channel, wOutChannel, wHOff, wWOff); value += xVal * wVal; } } } } ${p} ${a.output} = vec4(value, .0, .0, .0); } `; return { ...o, output: { dims: r, type: e[0].type, textureType: 0 }, shaderSource: m, hasMain: !0 }; }), (Pm = (t, e, o) => { let i = Sm(e.length > 2, o.cacheKey); return { ...i, get: () => Am(t, e, i, o) }; }), (Em = (t, e, o) => t.run(Pm(t, e, o), e)), (Dm = (t, e) => { let o = t.kernelShape.slice(); if (t.kernelShape.length === 0) for (let d = 2; d < e[1].dims.length; ++d) o.push(e[1].dims[d]); let i = t.pads.slice(), u = t.outputShape.slice(), n = e[0].dims; Om(n, o, t.dilations, t.autoPad, i, t.strides, t.outputPadding, u); let s = Object.assign({}, t); return Object.assign(s, { kernelShape: o, pads: i, outputShape: u, cacheKey: t.cacheKey }), s; }), (uf = (t) => { let e = t.attributes, o = Rr(e), i = e.getString('auto_pad', 'NOTSET'), u = e.getInts('dilations', [1, 1]), n = e.getInt('group', 1), s = e.getInts('kernel_shape', []), d = e.getInts('output_padding', [0, 0]), f = e.getInts('output_shape', []), r = e.getInts('pads', [0, 0, 0, 0]), a = e.getInts('strides', [1, 1]); return ee({ autoPad: i, dilations: u, group: n, kernelShape: s, outputPadding: d, outputShape: f, pads: r, strides: a, ...o, }); }), (Lm = (t, e) => { if (!t || (t.length !== 2 && t.length !== 3)) throw new Error('Conv requires 2 or 3 inputs'); if (t[0].dims.length !== 4 || t[1].dims.length !== 4) throw new Error('currently only support 2-dimensional conv'); let o = t[0].dims[1], i = t[1].dims[0]; if (o !== i) throw new Error('FILTER_IN_CHANNEL should be equal to DATA_CHANNEL'); let u = t[1].dims[1] * e.group; if (t.length === 3 && (t[2].dims.length !== 1 || t[2].dims[0] !== u)) throw new Error('invalid bias'); let n = t[0].dims.length - 2; if (e.dilations.length !== n) throw new Error(`dilations should be ${n}D`); if (e.strides.length !== n) throw new Error(`strides should be ${n}D`); if (e.pads.length !== n * 2) throw new Error(`pads should be ${n * 2}D`); if (e.outputPadding.length !== n) throw new Error(`output_padding should be ${n}D`); if (e.kernelShape.length !== 0 && e.kernelShape.length !== t[1].dims.length - 2) throw new Error('invalid kernel shape'); if (e.outputShape.length !== 0 && e.outputShape.length !== t[0].dims.length - 2) throw new Error('invalid output shape'); if (t[0].type !== 'float32' || t[1].type !== 'float32') throw new Error('ConvTranspose input(X,W) should be float tensor'); if (t.length === 3 && t[2].type !== 'float32') throw new Error('ConvTranspose input(bias) should be float tensor'); }); }), ff, yr, cf, Fm, pf, $m, Cm, km, ao = L(() => { Ge(), fe(), ae(), (ff = { name: 'Transpose', inputNames: ['A'], inputTypes: [0] }), (yr = (t, e, o) => (km(e), [t.run({ ...ff, cacheHint: o.cacheKey, get: () => Fm(t, e[0], o.perm) }, e)])), (cf = (t) => ee({ perm: t.attributes.getInts('perm', []) })), (Fm = (t, e, o) => { let i = e.dims; o = pf(i, o); let u = $m(i, o), n = i.length, s = ` ${Cm('perm', o, n)} float process(int indices[${n}]) { int a[${n}]; perm(a, indices); return _A(a); }`; return { ...ff, output: { dims: u, type: e.type, textureType: 0 }, shaderSource: s }; }), (pf = (t, e) => (e && e.length !== t.length && (e = [...t.keys()].reverse()), e)), ($m = (t, e) => ((e = pf(t, e)), U.sortBasedOnPerm(t, e))), (Cm = (t, e, o) => { let i = []; i.push(`void ${t}(out int a[${o}], int src[${o}]) {`); for (let u = 0; u < o; ++u) i.push(` a[${e[u]}]=src[${u}];`); return ( i.push(' }'), i.join(` `) ); }), (km = (t) => { if (!t || t.length !== 1) throw new Error('Transpose requires 1 input.'); if (t[0].type !== 'float32' && t[0].type !== 'float64') throw new Error('input should be float tensor'); }); }), df, hf, Bm, mf = L(() => { ao(), (df = (t, e, o) => { Bm(e); let i = o.blocksize, u = i * i, n = o.mode === 'DCR' ? [0, 3, 4, 1, 5, 2] : [0, 1, 4, 2, 5, 3], s = o.mode === 'DCR' ? [e[0].dims[0], i, i, e[0].dims[1] / u, e[0].dims[2], e[0].dims[3]] : [e[0].dims[0], e[0].dims[1] / u, i, i, e[0].dims[2], e[0].dims[3]], d = t.reshapeUnpacked(e[0], s), f = { perm: n, cacheKey: `${n}` }, [r] = yr(t, [d], f), a = [e[0].dims[0], e[0].dims[1] / u, e[0].dims[2] * i, e[0].dims[3] * i]; return [t.reshapeUnpacked(r, a)]; }), (hf = (t) => { let e = t.attributes.getInt('blocksize'); if (e < 1) throw new Error(`blocksize must be >= 1, but got : ${e} for DepthToSpace`); let o = t.attributes.getString('mode', 'DCR'); if (o !== 'DCR' && o !== 'CRD') throw new Error(`unrecognized mode: ${o} for DepthToSpace`); return { mode: o, blocksize: e }; }), (Bm = (t) => { if (t.length !== 1) throw new Error(`DepthToSpace expect 1 inputs, but got ${t.length}`); if (t[0].type === 'string' || t[0].dims.length !== 4) throw new TypeError('DepthToSpace input should be a 4-D numeric tensor'); }); }), bf, gf, Nm, yf = L(() => { fe(), (bf = (t, e, o) => { Nm(e, o); let i = U.flattenShape(e[0].dims, o); return [t.reshapeUnpacked(e[0], i)]; }), (gf = (t) => t.attributes.getInt('axis', 1)), (Nm = (t, e) => { if (!t || t.length !== 1) throw new Error('Flatten requires 1 input.'); let o = t[0].dims.length; if (o === 0) throw new Error('scalar tensor is not supported.'); if (e < -o || e > o) throw new Error('Invalid axis'); if (t[0].type === 'string') throw new Error('string tensor is not supported.'); }); }), Jt, pn = L(() => { Jt = ['float32', 'float64', 'int32', 'int16', 'int8', 'uint16', 'uint32', 'uint8']; }), Tf, xf, Rm, Mm, Gm, Um, vf = L(() => { Ge(), pn(), fe(), ae(), (Tf = (t, e, o) => (Um(e, o.axis), [t.run(Gm(t, e, o), e)])), (xf = (t) => ee({ axis: t.attributes.getInt('axis', 0) })), (Rm = { name: 'Gather', inputNames: ['A', 'B'], inputTypes: [0, 0] }), (Mm = (t, e, o, i) => { let u = o[0].dims.slice(), n = o[1].dims.slice(), s = new Array(u.length + n.length - 1); i = U.normalizeAxis(i, u.length); let d = []; for (let p = 0; p < s.length; p++) p < i ? ((s[p] = u[p]), d.push(`inputIdx[${p}] = outputIdx[${p}];`)) : p < i + n.length ? ((s[p] = n[p - i]), d.push(`indexDataIdx[${p - i}] = outputIdx[${p}];`)) : ((s[p] = u[p - n.length + 1]), d.push(`inputIdx[${p - n.length + 1}] = outputIdx[${p}];`)); let f = s.length || 1, r = u.length, a = n.length || 1, l = ` float process(int outputIdx[${f}]) { int inputIdx[${r}]; int indexDataIdx[${a}]; indexDataIdx[0] = 0; ${d.join(` `)} int idx = int(_B(indexDataIdx)); inputIdx[${i}] = idx < 0 ? idx + ${u[i]} : idx; return _A(inputIdx); }`; return { ...e, output: { dims: s, type: o[0].type, textureType: 0 }, shaderSource: l }; }), (Gm = (t, e, o) => { let i = { ...Rm, cacheHint: o.cacheKey }; return { ...i, get: () => Mm(t, i, e, o.axis) }; }), (Um = (t, e) => { if (!t || t.length !== 2) throw new Error('Gather requires 2 inputs.'); let o = t[0].dims.length; if (o < 1) throw new Error('Invalid input shape.'); if (e < -o || e > o - 1) throw new Error('Invalid axis.'); if (Jt.indexOf(t[0].type) === -1) throw new Error('Invaid input type.'); if (t[1].type !== 'int32' && t[1].type !== 'int16') throw new Error('Invaid input type.'); }); }), ki, wf, _f, Of, zm, Vm, Wm, If = L(() => { Ge(), fe(), ae(), (ki = (t, e, o) => (Wm(e, o), [t.run(zm(e, o), e)])), (wf = (t, e) => { let o = t.attributes.getInt('transA', 0) !== 0, i = t.attributes.getInt('transB', 0) !== 0, u = t.attributes.getFloat('alpha', 1), n = t.attributes.getFloat('beta', 1); return ee({ transA: o, transB: i, alpha: u, beta: n, isOptionalC: e }); }), (_f = (t) => wf(t, !1)), (Of = (t) => wf(t, !0)), (zm = (t, e) => { let o = { name: 'Gemm', inputNames: t.length === 3 ? ['A', 'B', 'C'] : ['A', 'B'], inputTypes: t.length === 3 ? [0, 0, 0] : [0, 0], key: e.cacheKey, }; return { ...o, get: () => Vm(o, t, e) }; }), (Vm = (t, e, o) => { let i = e[0].dims.slice(), u = e[1].dims.slice(), [n, s] = Xn.getShapeOfGemmResult(i, o.transA, u, o.transB, e.length === 3 ? e[2].dims : void 0), d = [n, s]; if (!d) throw new Error("Can't use gemm on the given tensors"); let f = i[i.length - 1], r = ''; o.transA && (f = i[0]), o.transA && o.transB ? (r = 'value += _A_T(a) * _B_T(b);') : o.transA && !o.transB ? (r = 'value += _A_T(a) * _B(b);') : !o.transA && o.transB ? (r = 'value += _A(a) * _B_T(b);') : !o.transA && !o.transB && (r = 'value += _A(a) * _B(b);'); let a = d.length, l = e.length === 3 ? `int c[${e[2].dims.length}];` : '', p = e.length === 3 ? 'bcastIndices_C(indices, c);' : '', m = e.length === 3 ? 'value += beta * _C(c);' : '', y = ` float process(int indices[${a}]) { int a[${a}]; int b[${a}]; ${l} copyVec(indices, a); copyVec(indices, b); ${p} float value = 0.0; for (int k=0; k<${f}; ++k) { a[${a - 1}] = k; b[${a - 2}] = k; ${r} } value = value * alpha; ${m} return value; }`; return { ...t, output: { dims: d, type: e[0].type, textureType: 0 }, variables: [ { name: 'alpha', type: 'float', data: o.alpha }, { name: 'beta', type: 'float', data: o.beta }, ], shaderSource: y, }; }), (Wm = (t, e) => { if (!t) throw new Error('Input is missing'); if (e.isOptionalC && (t.length < 2 || t.length > 3)) throw new Error('Invaid input shape.'); if (!e.isOptionalC && t.length !== 3) throw new Error('Gemm requires 3 inputs'); if (t.length === 3 && t[2].dims.length !== 1 && t[2].dims.length !== 2) throw new Error('Invalid input shape of C'); if ( (t[0].type !== 'float32' && t[0].type !== 'float64') || (t[1].type !== 'float32' && t[1].type !== 'float64') || (t.length === 3 && t[2].type !== 'float32' && t[2].type !== 'float64') ) throw new Error('Invalid input type.'); if (t[0].type !== t[1].type || (t.length === 3 && t[0].type !== t[2].type)) throw new Error('Input types are mismatched'); }); }), Sf, Af, Hm, qm, jm, Ym, Xm, Pf = L(() => { Ge(), ae(), (Sf = (t, e, o) => (Xm(e), [t.run(jm(t, e, o), e)])), (Af = (t) => { let e = t.attributes.getFloat('scale'), o = t.attributes.getFloats('bias'); return ee({ scale: e, bias: o }); }), (Hm = { name: 'ImageScaler', inputNames: ['X'], inputTypes: [0] }), (qm = (t, e, o, i) => { let u = o[0].dims.slice(), n = u.length, s = ` ${Ym(i.bias.length)} float process(int indices[${n}]) { return _X(indices) * scale + getBias(bias, indices[1]); }`; return { ...e, output: { dims: u, type: o[0].type, textureType: 0 }, variables: [ { name: 'bias', type: 'float', arrayLength: i.bias.length, data: i.bias }, { name: 'scale', type: 'float', data: i.scale }, ], shaderSource: s, }; }), (jm = (t, e, o) => { let i = { ...Hm, cacheHint: o.cacheKey }; return { ...i, get: () => qm(t, i, e, o) }; }), (Ym = (t) => { let e = [`float getBias(float bias[${t}], int channel) {`]; for (let o = 0; o < t; ++o) o === 0 ? e.push(` if (channel == ${o}) { return bias[${o}]; }`) : o === t - 1 ? e.push(` else { return bias[${o}]; }`) : e.push(` else if (channel == ${o}) { return bias[${o}]; }`); return ( e.push(' }'), e.join(` `) ); }), (Xm = (t) => { if (!t || t.length !== 1) throw new Error('ImageScaler requires 1 input.'); if (t[0].dims.length !== 4) throw new Error('Invalid input shape.'); if (t[0].type !== 'float32' && t[0].type !== 'float64') throw new Error('Invalid input type.'); }); }), Df, Lf, Ef, Km, Jm, Zm, Qm, eb, tb, Ff = L(() => { xe(), ae(), (Df = (t, e, o) => { tb(e); let i = t.run(Jm(e[0]), e); return [t.run(eb(t, e[0], o, i.dims), [e[0], i, e[1], e[2]])]; }), (Lf = (t) => t.attributes.getFloat('epsilon', 1e-5)), (Ef = { name: 'InstanceNormalization_MeanAndVariance', inputNames: ['X'], inputTypes: [0] }), (Km = (t, e) => { let o = e.dims.slice(), i = o[1], u = o[2] * o[3], n = [o[0], i], s = ` vec4 process(int[2] indices) { vec4 v = vec4(0.0); int a[4]; a[0] = indices[0]; a[1] = indices[1]; float temp = 0.0; for(int a2=0; a2<${o[2]}; a2++) { a[2] = a2; for(int a3=0; a3<${o[3]}; a3++) { a[3] = a3; float x = _X(a); temp += x; } } float mean = temp / float(${u}); temp = 0.0; for(int a2=0; a2<${o[2]}; a2++) { a[2] = a2; for(int a3=0; a3<${o[3]}; a3++) { a[3] = a3; float x = _X(a); temp += (x - mean) * (x - mean); } } v.r = mean; v.g = temp / float(${u}); return v; }`; return { ...t, output: { dims: n, type: e.type, textureType: 4 }, shaderSource: s }; }), (Jm = (t) => ({ ...Ef, get: () => Km(Ef, t) })), (Zm = { name: 'InstanceNormalization_ComputeOutput', inputNames: ['X', 'MeanAndVariance', 'Scale', 'B'], inputTypes: [0, 4, 0, 0], }), (Qm = (t, e, o, i, u) => { let n = q(t.session.backend.glContext.version), [s, d] = t.calculateTextureWidthAndHeight(u, 4), [f, r] = [s / 4, d], a = ` vec4 get_MeanAndVariance(int[2] mv) { int offset = indicesToOffset_MeanAndVariance(mv); vec2 coords = offsetToCoords(offset, ${f}, ${r}); return ${n.texture2D}(MeanAndVariance, coords); } float process(int[4] indices) { int mv[2]; mv[0] = indices[0]; mv[1] = indices[1]; vec4 mean_and_variance = get_MeanAndVariance(mv); float mean = mean_and_variance.r; float variance = mean_and_variance.g; int sb[1]; sb[0] = indices[1]; float scale = _Scale(sb); float b = _B(sb); return scale * (_X(indices) - mean) / sqrt(variance + epsilon) + b; }`; return { ...e, output: { dims: o.dims, type: o.type, textureType: 0 }, variables: [{ name: 'epsilon', type: 'float', data: i }], shaderSource: a, }; }), (eb = (t, e, o, i) => { let u = { ...Zm, cacheHint: `${o}` }; return { ...u, get: () => Qm(t, u, e, o, i) }; }), (tb = (t) => { if (!t || t.length !== 3) throw new Error('InstanceNormalization requires 3 inputs.'); let e = t[0], o = t[1], i = t[2]; if (e.dims.length < 3 || o.dims.length !== 1 || i.dims.length !== 1) throw new Error('Invalid input shape.'); if (o.dims[0] !== e.dims[1] || i.dims[0] !== e.dims[1]) throw new Error('Input shapes are mismatched.'); if ( (e.type !== 'float32' && e.type !== 'float64') || (o.type !== 'float32' && o.type !== 'float64') || (i.type !== 'float32' && i.type !== 'float64') ) throw new Error('Invalid input type.'); if (t[0].dims.length !== 4) throw new Error('Only support 4-D input shape.'); }); }); function rb(t, e) { let o = t[0].dims[1], i = t[0].dims.length, u = -Math.floor((e.size - 1) / 2), n = Math.ceil((e.size - 1) / 2), s = `float(${e.alpha}) / float(${e.size})`, d = `float(${e.bias})`, f = `float(${e.beta})`, r = ` float process(int indices[${i}]) { int c = indices[1]; float x = _X(indices); float square_sum = 0.0; for (int i = ${u}; i <= ${n}; i++) { int idx = c + i; if (c >= 0 && c < ${o}) { indices[1] = idx; float j = _X(indices); square_sum += j * j; } } return x / pow(${d} + ${s} * square_sum, ${f}); }`; return { ...kf, cacheHint: e.cacheKey, output: { dims: t[0].dims, type: t[0].type, textureType: 0 }, shaderSource: r, }; } function nb(t, e) { return { ...kf, cacheHint: e.cacheKey, get: () => rb(t, e) }; } var $f, Cf, kf, ob, Bf = L(() => { Ge(), ae(), ($f = (t, e, o) => (ob(e), [t.run(nb(e, o), e)])), (Cf = (t) => { let e = t.attributes.getFloat('alpha', 1e-4), o = t.attributes.getFloat('beta', 0.75), i = t.attributes.getFloat('bias', 1), u = t.attributes.getInt('size'); return ee({ alpha: e, beta: o, bias: i, size: u }); }), (kf = { name: 'LRN', inputNames: ['X'], inputTypes: [0] }), (ob = (t) => { if (!t || t.length !== 1) throw new Error('LRN requires 1 input.'); if (t[0].dims.length !== 4) throw new Error('currently only support LRN for input with "NCHW" format'); if (t[0].type !== 'float32') throw new Error('input should be float type'); }); }), ib, Bi, Nf, Rf, Mf, ab, sb, ub, lb, fb, cb, pb, db, Gf = L(() => { Ge(), fe(), xe(), ae(), (ib = { name: 'Pad', inputNames: ['A'], inputTypes: [0] }), (Bi = (t, e, o) => (ub(e), [t.run({ ...ib, cacheHint: o.cacheKey, get: () => sb(t, e[0], o) }, e)])), (Nf = (t) => { let e = t.attributes.getString('mode', 'constant'), o = t.attributes.getFloat('value', 0), i = t.attributes.getInts('pads'); return ee({ mode: e, value: o, pads: i }); }), (Rf = (t, e, o) => { lb(e); let i = ab(t, e, o); return Bi(t, [e[0]], i); }), (Mf = (t) => t.attributes.getString('mode', 'constant')), (ab = (t, e, o) => { if (!t.session.isInitializer(e[1].dataId) || (e.length >= 3 && !t.session.isInitializer(e[2].dataId))) throw new Error('dynamic pad attributes are not allowed'); let i = Array.from(e[1].integerData), u = e.length >= 3 ? e[2].floatData[0] : 0; return ee({ mode: o, pads: i, value: u }); }), (sb = (t, e, o) => { let i = U.padShape(e.dims.slice(), o.pads), u = i.length, n = ` ${fb(t, e, o)} float process(int[${u}] indices) { return padA(indices); }`; return { name: 'Pad', inputNames: ['A'], inputTypes: [0], output: { dims: i, type: e.type, textureType: 0 }, shaderSource: n, }; }), (ub = (t) => { if (!t || t.length !== 1) throw new Error('Pad requires 1 input'); if (t[0].type !== 'float32' && t[0].type !== 'float64') throw new Error('Invalid input type.'); }), (lb = (t) => { if (!t || (t.length !== 2 && t.length !== 3)) throw new Error('Pad requires 2 or 3 inputs'); if (t[1].type !== 'int32') throw new Error('Invalid input type.'); if (t.length >= 3 && t[2].type === 'string') throw new Error('Invalid input type.'); }), (fb = (t, e, o) => { let i = q(t.session.backend.glContext.version), [u, n] = t.calculateTextureWidthAndHeight(e.dims, 0), s = U.computeStrides(e.dims); switch (o.mode) { case 'constant': return cb(i, e.dims, s, u, n, o.pads, o.value); case 'reflect': return pb(i, e.dims, s, u, n, o.pads); case 'edge': return db(i, e.dims, s, u, n, o.pads); default: throw new Error('Invalid mode'); } }), (cb = (t, e, o, i, u, n, s) => { let d = e.length, f = ''; for (let r = d - 1; r >= 0; --r) f += ` k = m[${r}] - ${n[r]}; if (k < 0) return constant; if (k >= ${e[r]}) return constant; offset += k * ${o[r]}; `; return ` float padA(int m[${d}]) { const float constant = float(${s}); int offset = 0; int k = 0; ${f} vec2 coords = offsetToCoords(offset, ${i}, ${u}); float value = getColorAsFloat(${t.texture2D}(A, coords)); return value; } `; }), (pb = (t, e, o, i, u, n) => { let s = e.length, d = ''; for (let f = s - 1; f >= 0; --f) d += ` k = m[${f}] - ${n[f]}; if (k < 0) { k = -k; } { const int _2n_1 = ${2 * (e[f] - 1)}; k = int( mod( float(k), float(_2n_1) ) ) ; if(k >= ${e[f]}) { k = _2n_1 - k; } } offset += k * ${o[f]}; `; return ` float padA(int m[${s}]) { int offset = 0; int k = 0; ${d} vec2 coords = offsetToCoords(offset, ${i}, ${u}); float value = getColorAsFloat(${t.texture2D}(A, coords)); return value; } `; }), (db = (t, e, o, i, u, n) => { let s = e.length, d = ''; for (let f = s - 1; f >= 0; --f) d += ` k = m[${f}] - ${n[f]}; if (k < 0) k = 0; if (k >= ${e[f]}) k = ${e[f] - 1}; offset += k * ${o[f]}; `; return ` float padA(int m[${s}]) { int offset = 0; int k = 0; ${d} vec2 coords = offsetToCoords(offset, ${i}, ${u}); float value = getColorAsFloat(${t.texture2D}(A, coords)); return value; } `; }); }), zf, Vf, Wf, Hf, qf, jf, Yf, Xf, Kf, hb, Uf, Jf, uo, Zf, so, mb, Qf = L(() => { Ge(), fe(), ae(), (zf = (t, e, o) => { uo(e); let i = { name: 'AveragePool', inputNames: ['X'], inputTypes: [0], cacheHint: o.cacheKey }; return [t.run({ ...i, get: () => Wf(e, i, !1, o) }, e)]; }), (Vf = (t) => { let e = t.attributes.getString('auto_pad', 'NOTSET'), o = t.attributes.getInt('ceil_mode', 0), i = t.attributes.getInt('count_include_pad', 0) !== 0, u = t.attributes.getInts('kernel_shape'), n = t.attributes.getInts('strides', []), s = t.attributes.getInts('pads', []); if (o !== 0) throw new Error('using ceil() in shape computation is not yet supported for AveragePool'); return ee({ autoPad: e, ceilMode: o, countIncludePad: i, kernelShape: u, strides: n, pads: s }); }), (Wf = (t, e, o, i) => { let [u, n] = Kf(t, i, o), s = U.size(u.kernelShape), d = 'value += _X(x);', f = ''; u.countIncludePad ? (f += `value /= float(${s});`) : (f += `value /= float(${s} - pad);`); let r = ` ${Zf(t[0].dims, u, d, f, '0.0')} `; return { ...e, output: { dims: n, type: t[0].type, textureType: 0 }, shaderSource: r }; }), (Hf = (t, e, o) => { uo(e); let i = { name: 'GlobalAveragePool', inputNames: ['X'], inputTypes: [0], cacheHint: `${o.countIncludePad}`, }; return [t.run({ ...i, get: () => Wf(e, i, !0, o) }, e)]; }), (qf = (t) => { let e = t.attributes.getInt('count_include_pad', 0) !== 0; return ee({ autoPad: '', ceilMode: 0, countIncludePad: e, kernelShape: [], strides: [], pads: [] }); }), (jf = (t, e, o) => { uo(e); let i = { name: 'MaxPool', inputNames: ['X'], inputTypes: [0], cacheHint: o.cacheKey }; return [t.run({ ...i, get: () => Xf(e, i, !1, o) }, e)]; }), (Yf = (t) => { let e = t.attributes.getString('auto_pad', 'NOTSET'), o = t.attributes.getInt('ceil_mode', 0), i = t.attributes.getInts('kernel_shape'), u = t.attributes.getInts('strides', []), n = t.attributes.getInts('pads', []), s = t.attributes.getInt('storage_order', 0), d = t.attributes.getInts('dilations', []); if (s !== 0) throw new Error('column major storage order is not yet supported for MaxPool'); if (o !== 0) throw new Error('using ceil() in shape computation is not yet supported for MaxPool'); return ee({ autoPad: e, ceilMode: o, countIncludePad: !1, kernelShape: i, strides: u, pads: n, storageOrder: s, dilations: d, }); }), (Xf = (t, e, o, i) => { let [u, n] = Kf(t, i, o), s = ` value = max(_X(x), value); `, d = '', f = ` ${Zf(t[0].dims, u, s, d, '-1e5')} `; return { ...e, output: { dims: n, type: t[0].type, textureType: 0 }, shaderSource: f }; }), (Kf = (t, e, o) => { let i = t[0].dims.slice(), u = Object.hasOwnProperty.call(e, 'dilations'), n = e.kernelShape.slice(), s = e.strides.slice(), d = u ? e.dilations.slice() : [], f = e.pads.slice(); pr.adjustPoolAttributes(o, i, n, s, d, f); let r = pr.computePoolOutputShape(o, i, s, d, n, f, e.autoPad), a = Object.assign({}, e); return ( u ? Object.assign(a, { kernelShape: n, strides: s, pads: f, dilations: d, cacheKey: e.cacheKey }) : Object.assign(a, { kernelShape: n, strides: s, pads: f, cacheKey: e.cacheKey }), [a, r] ); }), (hb = { autoPad: '', ceilMode: 0, countIncludePad: !1, kernelShape: [], strides: [], pads: [], storageOrder: 0, dilations: [], cacheKey: '', }), (Uf = { name: 'GlobalMaxPool', inputNames: ['X'], inputTypes: [0] }), (Jf = (t, e) => (uo(e), [t.run({ ...Uf, get: () => Xf(e, Uf, !0, hb) }, e)])), (uo = (t) => { if (!t || t.length !== 1) throw new Error('Pool ops requires 1 input.'); if (t[0].type !== 'float32' && t[0].type !== 'float64') throw new Error('Invalid input type.'); }), (Zf = (t, e, o, i, u) => { let n = t.length; if (e.kernelShape.length <= 2) { let s = e.kernelShape[e.kernelShape.length - 1], d = e.strides[e.strides.length - 1], f = e.pads[e.pads.length / 2 - 1], r = e.pads[e.pads.length - 1], a = t[n - 1], l = '', p = '', m = ''; if ( (f + r !== 0 ? (l = ` for (int i = 0; i < ${s}; i++) { x[${n} - 1] = indices[${n} - 1] * ${d} - ${f} + i; if (x[${n} - 1] < 0 || x[${n} - 1] >= ${a}) { pad++; continue; } ${o} }`) : (l = ` for (int i = 0; i < ${s}; i++) { x[${n} - 1] = indices[${n} - 1] * ${d} - ${f} + i; ${o} }`), e.kernelShape.length === 2) ) { let y = e.kernelShape[e.kernelShape.length - 2], T = e.strides[e.strides.length - 2], v = e.pads[e.pads.length / 2 - 2], S = e.pads[e.pads.length - 2], E = t[n - 2]; v + S !== 0 ? (p = ` for (int j = 0; j < ${y}; j++) { x[${n} - 2] = indices[${n} - 2] * ${T} - ${v} + j; if (x[${n} - 2] < 0 || x[${n} - 2] >= ${E}) { pad+= ${s}; continue; } `) : (p = ` for (int j = 0; j < ${y}; j++) { x[${n} - 2] = indices[${n} - 2] * ${T} - ${v} + j; `), (m = ` } `); } return ` float process(int indices[${n}]) { int x[${n}]; copyVec(indices, x); float value = ${u}; int pad = 0; ${p} ${l} ${m} ${i} return value; } `; } else { let s = U.size(e.kernelShape), d = U.computeStrides(e.kernelShape), f = d.length, r = e.pads.length, a = mb(f), l = so(t, 'inputDims'), p = so(e.pads, 'pads'), m = so(d, 'kernelStrides'), y = so(e.strides, 'strides'), T = e.pads.reduce((S, E) => S + E), v = ''; return ( T ? (v = ` if (x[j] >= inputDims[j] || x[j] < 0) { pad++; isPad = true; break; } } if (!isPad) { ${o} }`) : (v = ` } ${o} `), ` ${a} float process(int indices[${n}]) { int x[${n}]; copyVec(indices, x); int offset[${f}]; int pads[${r}]; int inputDims[${n}]; int kernelStrides[${f}]; int strides[${f}]; ${p} ${l} ${y} ${m} float value = ${u}; int pad = 0; bool isPad = false; for (int i = 0; i < ${s}; i++) { offsetToIndices(i, kernelStrides, offset); isPad = false; for (int j = ${n} - ${f}; j < ${n}; j++) { x[j] = indices[j] * strides[j - ${n} + ${f}] + offset[j - ${n} + ${f}] - pads[j - 2]; ${v} } ${i} return value; } ` ); } }), (so = (t, e) => { let o = ''; for (let i = 0; i < t.length; i++) o += ` ${e}[${i}] = ${t[i]}; `; return o; }), (mb = (t) => ` void offsetToIndices(int offset, int[${t}] strides, out int[${t}] indices) { if (${t} == 0) { return; } for (int i = 0; i < ${t} - 1; ++i) { indices[i] = offset / strides[i]; offset -= indices[i] * strides[i]; } indices[${t} - 1] = offset; }`); }), Tr, Zt, bb, gb, ec, tc, rc, nc, oc, ic, ac, sc = L(() => { Ge(), pn(), fe(), ae(), (Tr = (t, e, o, i, u) => { gb(e); let n = { name: i, inputNames: ['A'], inputTypes: [0] }; return [t.run({ ...n, cacheHint: o.cacheKey, get: () => bb(t, e, o, i, u, n) }, e)]; }), (Zt = (t) => { let e = t.attributes.getInts('axes', []), o = t.attributes.getInt('keepdims', 1) === 1; return ee({ axes: e, keepDims: o }); }), (bb = (t, e, o, i, u, n) => { let s = [], d = e[0].dims.length || 1, f = [], r = U.normalizeAxes(o.axes, e[0].dims.length), a = u(e, r), l = a[1]; for (let m = 0; m < e[0].dims.length; m++) r.indexOf(m) >= 0 || r.length === 0 ? (o.keepDims && s.push(1), (l = ` for(int j${m} = 0; j${m} < ${e[0].dims[m]}; j${m}++) { inputIdx[${m}] = j${m}; ${l} }`)) : (f.push(`inputIdx[${m}] = outputIdx[${s.length}];`), s.push(e[0].dims[m])); let p = ` float process(int outputIdx[${s.length || 1}]) { float value; // final result int inputIdx[${d}]; // addressing input data ${f.join(` `)} ${a[0]} // init ops for reduce max/min ${l} ${a[2]} // final computation for reduce mean return value; }`; return { ...n, output: { dims: s, type: e[0].type, textureType: 0 }, shaderSource: p }; }), (gb = (t) => { if (!t || t.length !== 1) throw new Error('Reduce op requires 1 input.'); if (Jt.indexOf(t[0].type) === -1) throw new Error('Invalid input type.'); }), (ec = (t, e, o) => Tr(t, e, o, 'ReduceSum', () => ['value = 0.0;', 'value += _A(inputIdx);', ''])), (tc = (t, e, o) => Tr(t, e, o, 'ReduceMean', (i, u) => { let n = 1; for (let s = 0; s < i[0].dims.length; s++) (u.indexOf(s) >= 0 || u.length === 0) && (n *= i[0].dims[s]); return ['value = 0.0;', 'value += _A(inputIdx);', `value /= ${n}.;`]; })), (rc = (t, e, o) => Tr(t, e, o, 'ReduceMax', (i, u) => { let n = []; for (let s = 0; s < i[0].dims.length; s++) (u.indexOf(s) >= 0 || u.length === 0) && n.push(`inputIdx[${s}] = 0;`); return [ `${n.join(` `)} value = _A(inputIdx);`, 'value = max(value, _A(inputIdx));', '', ]; })), (nc = (t, e, o) => Tr(t, e, o, 'ReduceMin', (i, u) => { let n = []; for (let s = 0; s < i[0].dims.length; s++) (u.indexOf(s) >= 0 || u.length === 0) && n.push(`inputIdx[${s}] = 0;`); return [ `${n.join(` `)} value = _A(inputIdx);`, 'value = min(value, _A(inputIdx));', '', ]; })), (oc = (t, e, o) => Tr(t, e, o, 'ReduceProd', () => ['value = 1.0;', 'value *= _A(inputIdx);', ''])), (ic = (t, e, o) => Tr(t, e, o, 'ReduceLogSum', () => ['value = 0.0;', 'value += _A(inputIdx);', 'value = log(value);'])), (ac = (t, e, o) => Tr(t, e, o, 'ReduceLogSumSquare', () => [ 'float t; value = 0.0;', 't = _A(inputIdx); value += t * t;', '', ])); }), uc, lc = L(() => { fe(), (uc = (t, e) => { let o = U.calculateReshapedDims(e[0].dims, e[1].integerData); return t.session.pack ? [t.reshapePacked(e[0], o)] : [t.reshapeUnpacked(e[0], o)]; }); }), fc, Ni, cc, pc, dn, yb, Ri, lo, Mi = L(() => { Ge(), xe(), ae(), (fc = { name: 'Upsample', inputNames: ['X'], inputTypes: [0] }), (Ni = (t, e, o) => (Ri(e, o), [t.run({ ...fc, cacheHint: o.cacheKey, get: () => yb(t, e, o) }, e)])), (cc = (t) => dn(t, 7)), (pc = (t) => dn(t, 9)), (dn = (t, e) => { let o = e >= 10, i = t.attributes.getString('mode', 'nearest'); if (i !== 'nearest' && i !== 'linear' && (e < 11 || i !== 'cubic')) throw new Error(`unrecognized mode: ${i}`); let u = []; e < 9 && ((u = t.attributes.getFloats('scales')), lo(u, i, o)); let n = t.attributes.getFloat('extrapolation_value', 0), s = e > 10 ? t.attributes.getString('coordinate_transformation_mode', 'half_pixel') : 'asymmetric'; if ( [ 'asymmetric', 'pytorch_half_pixel', 'tf_half_pixel_for_nn', 'align_corners', 'tf_crop_and_resize', 'half_pixel', ].indexOf(s) === -1 ) throw new Error(`coordinate_transform_mode '${s}' is not supported`); let d = s === 'tf_crop_and_resize', f = d, r = i === 'nearest' && e >= 11 ? t.attributes.getString('nearest_mode', 'round_prefer_floor') : ''; if (['round_prefer_floor', 'round_prefer_ceil', 'floor', 'ceil', ''].indexOf(r) === -1) throw new Error(`nearest_mode '${r}' is not supported`); let a = t.attributes.getFloat('cubic_coeff_a', -0.75), l = t.attributes.getInt('exclude_outside', 0) !== 0; if (l && i !== 'cubic') throw new Error('exclude_outside can be set to 1 only when mode is CUBIC.'); let p = e < 11 ? !0 : i === 'nearest' && s === 'asymmetric' && r === 'floor', m = 0, y = 0, T = 0; return ( e > 10 ? t.inputs.length > 2 ? ((m = 1), (y = 2), (T = 3)) : ((y = 1), (T = 2)) : e === 9 && (y = 1), ee({ opset: e, isResize: o, mode: i, scales: u, extrapolationValue: n, coordinateTransformMode: s, useExtrapolation: f, needRoiInput: d, nearestMode: r, cubicCoefficientA: a, excludeOutside: l, useNearest2xOptimization: p, roiInputIdx: m, scalesInputIdx: y, sizesInputIdx: T, }) ); }), (yb = (t, e, o) => { let i = q(t.session.backend.glContext.version), [u, n] = t.calculateTextureWidthAndHeight(e[0].dims, 0), s = e[0].dims.map((T, v) => Math.floor(T * o.scales[v])), [d, f] = t.calculateTextureWidthAndHeight(s, 0), r = s.length, a = new Array(r), l = new Array(r), p = ` int output_pitches[${r}]; int input_pitches[${r}]; `; for (let T = r - 1; T >= 0; T--) (a[T] = T === r - 1 ? 1 : a[T + 1] * s[T + 1]), (l[T] = T === r - 1 ? 1 : l[T + 1] * e[0].dims[T + 1]), (p += ` output_pitches[${T}] = ${a[T]}; input_pitches[${T}] = ${l[T]}; `); let m = ` float getInputFloat(int index) { vec2 coords = offsetToCoords(index, ${u}, ${n}); float value = getColorAsFloat(${i.texture2D}(X, coords)); return value; } `, y = o.mode === 'nearest' ? ` ${m} float process(int indices[${r}]) { int input_index = 0; int output_index = coordsToOffset(TexCoords, ${d}, ${f}); ${p} int d, m; for (int dim = 0; dim < ${r}; ++dim) { d = output_index / output_pitches[dim]; m = output_index - d * output_pitches[dim]; output_index = m; if (scales[dim] != 1 && d > 0) { int d2 = d / scales[dim]; m = d - d2 * scales[dim]; d = d2; } input_index += input_pitches[dim] * d; } return getInputFloat(input_index); }` : r === 4 ? ` ${m} float process(int indices[4]) { int input_index = 0; int output_index = coordsToOffset(TexCoords, ${d}, ${f}); ${p} int m; int index_of_dim0, index_of_dim1, index_of_dim2, index_of_dim3; index_of_dim0 = output_index / output_pitches[0]; m = output_index - index_of_dim0 * output_pitches[0]; index_of_dim1 = m / output_pitches[1]; m = m - index_of_dim1 * output_pitches[1]; index_of_dim2 = m / output_pitches[2]; m = m - index_of_dim2 * output_pitches[2]; index_of_dim3 = m; int index_of_input_dim2, index_of_input_dim3, x_offset, y_offset; index_of_input_dim2 = index_of_dim2 / scales[2]; y_offset = index_of_dim2 - index_of_input_dim2 * scales[2]; index_of_input_dim3 = index_of_dim3 / scales[3]; x_offset = index_of_dim3 - index_of_input_dim3 * scales[3]; input_index = index_of_dim0 * input_pitches[0] + index_of_dim1 * input_pitches[1] + index_of_input_dim2 * input_pitches[2] + index_of_input_dim3; float x00 = getInputFloat(input_index); float x10, x01, x11; bool end_of_dim2 = false; if (index_of_input_dim2 == (${e[0].dims[2]} - 1)) { // It's the end in dimension 2 x01 = x00; end_of_dim2 = true; } else { x01 = getInputFloat(input_index + input_pitches[2]); } if (index_of_input_dim3 == (input_pitches[2] - 1)) { // It's the end in dimension 3 x10 = x00; x11 = x01; } else { x10 = getInputFloat(input_index + 1); x11 = end_of_dim2 ? x10 : getInputFloat(input_index + input_pitches[2] + 1); } float y0 = x00 + float(y_offset) * (x01 - x00) / float(scales[2]); float y1 = x10 + float(y_offset) * (x11 - x10) / float(scales[2]); return y0 + float(x_offset) * (y1 - y0) / float(scales[3]); }` : ` ${m} float process(int indices[2]) { int input_index = 0; int output_index = coordsToOffset(TexCoords, ${d}, ${f}); ${p} int m; int index_of_dim0, index_of_dim1; index_of_dim0 = output_index / output_pitches[0]; m = output_index - index_of_dim0 * output_pitches[0]; index_of_dim1 = m; int index_of_input_dim0, index_of_input_dim1, x_offset, y_offset; index_of_input_dim0 = index_of_dim0 / scales[0]; y_offset = index_of_dim0 - index_of_input_dim0 * scales[0]; index_of_input_dim1 = index_of_dim1 / scales[1]; x_offset = index_of_dim1 - index_of_input_dim1 * scales[1]; input_index = index_of_input_dim0 * input_pitches[0] + index_of_input_dim1; float x00 = getInputFloat(input_index); float x10, x01, x11; bool end_of_dim0 = false; if (index_of_input_dim0 == (${e[0].dims[0]} - 1)) { // It's the end in dimension 0 x01 = x00; end_of_dim0 = true; } else { x01 = getInputFloat(input_index + input_pitches[0]); } if (index_of_input_dim1 == (input_pitches[0] - 1)) { // It's the end in dimension 1 x10 = x00; x11 = x01; } else { x10 = getInputFloat(input_index + 1); x11 = end_of_dim0 ? x10 : getInputFloat(input_index + input_pitches[0] + 1); } float y0 = x00 + float(y_offset) * (x01 - x00) / float(scales[0]); float y1 = x10 + float(y_offset) * (x11 - x10) / float(scales[0]); return y0 + float(x_offset) * (y1 - y0) / float(scales[1]); }`; return { ...fc, output: { dims: s, type: e[0].type, textureType: 0 }, shaderSource: y, variables: [ { name: 'scales', type: 'int', arrayLength: o.scales.length, data: o.scales.map((T) => Math.ceil(T)), }, ], }; }), (Ri = (t, e) => { if ( !t || (e.opset < 9 && t.length !== 1) || (e.opset >= 9 && e.opset < 11 && t.length !== 2) || (e.opset >= 11 && t.length < 2) ) throw new Error('invalid inputs.'); if (e.scales.length > 0 && t[0].dims.length !== e.scales.length) throw new Error('Invalid input shape.'); if (t[0].type === 'string') throw new Error('Invalid input tensor types.'); }), (lo = (t, e, o) => { if (o) { for (let i of t) if (i <= 0) throw new Error('Scale value should be greater than 0.'); } else for (let i of t) if (i < 1) throw new Error('Scale value should be greater than or equal to 1.'); if ((e === 'linear' || e === 'cubic') && t.length !== 2 && (t.length !== 4 || t[0] !== 1 || t[1] !== 1)) throw new Error( `'Linear' mode and 'Cubic' mode only support 2-D inputs ('Bilinear', 'Bicubic') or 4-D inputs with the corresponding outermost 2 scale values being 1 in the ${ o ? 'Resize' : 'Upsample' } opeartor.` ); }); }), Gi, Ui, dc, hc, Tb, xb, vb, wb, mc = L(() => { xe(), ae(), Ft(), br(), Mi(), (Gi = { name: 'Resize', inputNames: ['A'], inputTypes: [2] }), (Ui = (t, e, o) => (Ri(e, o), [t.run({ ...Gi, cacheHint: o.cacheKey, get: () => Tb(t, e, o) }, e)])), (dc = (t) => dn(t, 10)), (hc = (t) => dn(t, 11)), (Tb = (t, e, o) => { let i = q(t.session.backend.glContext.version), [u, n] = xb(e, o); if (u.every((E) => E === 1) && o.coordinateTransformMode !== 'tf_crop_and_resize') return { ...Gi, output: { dims: n, type: e[0].type, textureType: 2 }, hasMain: !0, shaderSource: `void main() { vec4 v = ${i.texture2D}(X, TexCoords); ${i.output} = v; }`, }; let s = n.length; if (s < 2) throw new Error(`output dimension should be at least 2, but got ${s}`); let d = n[s - 2], f = n[s - 1], r = e[0].dims; if (s !== r.length) throw new Error(`output dimension should match input ${r.length}, but got ${s}`); let a = r[s - 2], l = r[s - 1], p = u[s - 2], m = u[s - 1], y = ''; if (o.mode !== 'linear') throw new Error(`resize (packed) does not support mode: '${o.mode}'`); switch (o.coordinateTransformMode) { case 'asymmetric': y = ` vec4 getSourceFracIndex(ivec4 coords) { return vec4(coords) / scaleWHWH; } `; break; case 'half_pixel': y = ` vec4 getSourceFracIndex(ivec4 coords) { return (vec4(coords) + 0.5) / scaleWHWH - 0.5; } `; break; case 'pytorch_half_pixel': y = ` vec4 getSourceFracIndex(ivec4 coords) { vec4 fcoords = vec4(coords); return vec4( ${f}.0 > 1.0 ? (fcoords.x + 0.5) / scaleWHWH.x - 0.5 : 0.0, ${d}.0 > 1.0 ? (fcoords.y + 0.5) / scaleWHWH.y - 0.5 : 0.0, ${f}.0 > 1.0 ? (fcoords.z + 0.5) / scaleWHWH.z - 0.5 : 0.0, ${d}.0 > 1.0 ? (fcoords.w + 0.5) / scaleWHWH.w - 0.5 : 0.0 ); } `; break; case 'align_corners': y = ` vec4 getSourceFracIndex(ivec4 coords) { vec4 resized = vec4(${f}.0 - 1.0, ${d}.0 - 1.0, ${f}.0 - 1.0, ${d}.0 - 1.0); vec4 original = vec4(${l}.0 - 1.0, ${a}.0 - 1.0, ${l}.0 - 1.0, ${a}.0 - 1.0); vec4 new_scale = original / resized; return vec4(coords) * new_scale; } `; break; default: throw new Error( `resize (packed) does not support coordinateTransformMode: '${o.coordinateTransformMode}'` ); } let T = Ke(s), v = $t(), S = ` const vec2 inputWH = vec2(${a}.0, ${l}.0); const vec4 scaleWHWH = vec4(float(${p}), float(${m}), float(${p}), float(${m})); ${v} ${y} float getAValue(int x10, int r, int c, int d) { return getChannel(getA(x10, r, c, d), vec2(c, d)); } void main() { ${T} rc = getOutputCoords(); int batch = rc[0]; int depth = rc[1]; // retrieve the 4 coordinates that is used in the 4 packed output values. ivec4 coords = ivec4(rc.wz, rc.w + 1, rc.z + 1); // calculate the source index in fraction vec4 sourceFrac = getSourceFracIndex(coords); // get the lower and upper bound of the 4 values that will be packed into one texel. ivec4 x00 = ivec4(max(sourceFrac.xy, vec2(0.0)), min(inputWH - 1.0, ceil(sourceFrac.xy))); ivec4 x01 = ivec4(max(sourceFrac.xw, vec2(0.0)), min(inputWH - 1.0, ceil(sourceFrac.xw))); ivec4 x10 = ivec4(max(sourceFrac.zy, vec2(0.0)), min(inputWH - 1.0, ceil(sourceFrac.zy))); ivec4 x11 = ivec4(max(sourceFrac.zw, vec2(0.0)), min(inputWH - 1.0, ceil(sourceFrac.zw))); bool hasNextRow = rc.w < ${d - 1}; bool hasNextCol = rc.z < ${f - 1}; // pack x00, x01, x10, x11's top-left corner into one vec4 structure vec4 topLeft = vec4( getAValue(batch, depth, x00.x, x00.y), hasNextCol ? getAValue(batch, depth, x01.x, x01.y) : 0.0, hasNextRow ? getAValue(batch, depth, x10.x, x10.y) : 0.0, (hasNextRow && hasNextCol) ? getAValue(batch, depth, x11.x, x11.y) : 0.0); // pack x00, x01, x10, x11's top-right corner into one vec4 structure vec4 topRight = vec4( getAValue(batch, depth, x00.x, x00.w), hasNextCol ? getAValue(batch, depth, x01.x, x01.w) : 0.0, hasNextRow ? getAValue(batch, depth, x10.x, x10.w) : 0.0, (hasNextRow && hasNextCol) ? getAValue(batch, depth, x11.x, x11.w) : 0.0); // pack x00, x01, x10, x11's bottom-left corner into one vec4 structure vec4 bottomLeft = vec4( getAValue(batch, depth, x00.z, x00.y), hasNextCol ? getAValue(batch, depth, x01.z, x01.y) : 0.0, hasNextRow ? getAValue(batch, depth, x10.z, x10.y) : 0.0, (hasNextRow && hasNextCol) ? getAValue(batch, depth, x11.z, x11.y) : 0.0); // pack x00, x01, x10, x11's bottom-right corner into one vec4 structure vec4 bottomRight = vec4( getAValue(batch, depth, x00.z, x00.w), hasNextCol ? getAValue(batch, depth, x01.z, x01.w) : 0.0, hasNextRow ? getAValue(batch, depth, x10.z, x10.w) : 0.0, (hasNextRow && hasNextCol) ? getAValue(batch, depth, x11.z, x11.w) : 0.0); // calculate the interpolation fraction on u and v direction vec4 frac = vec4(sourceFrac) - floor(sourceFrac); vec4 clampFrac = clamp(frac, vec4(0.0), vec4(1.0)); vec4 top = mix(topLeft, topRight, clampFrac.ywyw); vec4 bottom = mix(bottomLeft, bottomRight, clampFrac.ywyw); vec4 newValue = mix(top, bottom, clampFrac.xxzz); ${i.output} = vec4(newValue); } `; return { ...Gi, output: { dims: n, type: e[0].type, textureType: 2 }, hasMain: !0, shaderSource: S }; }), (xb = (t, e) => { let o = t[0].dims, i = e.scales, u; if (i.length === 0) { let s = t[e.scalesInputIdx]; if (s && s.size !== 0) { if (t[e.sizesInputIdx]) throw new Error('Only one of scales or sizes must be provided as input.'); i = vb(s, e.mode, e.isResize); } else { let d = t[e.sizesInputIdx]; if (!d || d.size === 0) throw new Error('Either scales or sizes MUST be provided as input.'); (u = Array.from(d.integerData)), (i = wb(u, o, e.mode, e.isResize)); } } else if (t[e.sizesInputIdx]) throw new Error('Only one of scales or sizes must be provided as input.'); let n = u || o.map((s, d) => Math.floor(s * i[d])); return [i, n]; }), (vb = (t, e, o) => { let i = Array.from(t.floatData); return lo(i, e, o), i; }), (wb = (t, e, o, i) => { let u = e.length, n = new Array(u); for (let s = 0, d = u; s < d; s++) if (e[s] === 0) { if (t[s] !== 0) throw new Error('Input dim is zero but required output dim is non-zero.'); n[s] = 1; } else n[s] = t[s] / e[s]; return lo(n, o, i), n; }); }), bc, _b, gc = L(() => { mr(), (bc = (t, e) => (_b(e), [new Fe([e[0].dims.length], 'int32', void 0, void 0, new Int32Array(e[0].dims))])), (_b = (t) => { if (!t || t.length !== 1) throw new Error('Shape requires 1 input.'); }); }), zi, yc, Tc, xc, Ob, vc, Ib, Sb, wc = L(() => { Ge(), pn(), fe(), ae(), (zi = { name: 'Slice', inputNames: ['A'], inputTypes: [0] }), (yc = (t, e, o) => (Ob(e), [t.run({ ...zi, cacheHint: o.cacheKey, get: () => xc(t, e[0], o) }, e)])), (Tc = (t) => { let e = t.attributes.getInts('starts'), o = t.attributes.getInts('ends'), i = t.attributes.getInts('axes', []); return ee({ starts: e, ends: o, axes: i }); }), (xc = (t, e, o) => { let i = o.axes.length === 0 ? e.dims.slice(0).map((a, l) => l) : o.axes, u = U.normalizeAxes(i, e.dims.length), n = o.starts.map((a, l) => a > e.dims[u[l]] - 1 ? e.dims[u[l]] : U.normalizeAxis(a, e.dims[u[l]]) ), s = o.ends.map((a, l) => (a > e.dims[u[l]] - 1 ? e.dims[u[l]] : U.normalizeAxis(a, e.dims[u[l]]))), d = e.dims.slice(), f = []; for (let a = 0; a < u.length; a++) (d[u[a]] = s[a] - n[a]), n[a] > 0 && f.push(`outputIdx[${u[a]}] += ${n[a]};`); let r = ` float process(int outputIdx[${d.length}]) { ${f.join(` `)} return _A(outputIdx); }`; return { ...zi, output: { dims: d, type: e.type, textureType: 0 }, shaderSource: r }; }), (Ob = (t) => { if (!t || t.length !== 1) throw new Error('Slice requires 1 input.'); if (Jt.indexOf(t[0].type) === -1) throw new Error('Invalid input type.'); }), (vc = (t, e) => { Sb(e); let o = Ib(t, e); return [t.run({ ...zi, cacheHint: o.cacheKey, get: () => xc(t, e[0], o) }, [e[0]])]; }), (Ib = (t, e) => { if ( !t.session.isInitializer(e[1].dataId) || !t.session.isInitializer(e[2].dataId) || (e.length >= 4 && !t.session.isInitializer(e[3].dataId)) || (e.length >= 5 && !t.session.isInitializer(e[4].dataId)) ) throw new Error('dynamic slice attributes are not allowed'); if (e.length >= 5 && e[4].integerData.some((s) => s !== 1)) throw new Error('currently non-1 steps is not supported for Slice'); let o = Array.from(e[1].integerData), i = Array.from(e[2].integerData), u = e.length >= 4 ? Array.from(e[3].integerData) : [], n = `${u};${o};${i}`; return { starts: o, ends: i, axes: u, cacheKey: n }; }), (Sb = (t) => { if (!t || t.length < 3 || t.length > 5) throw new Error('Invalid input number.'); if (t[1].type !== 'int32' || t[1].dims.length !== 1) throw new Error('Invalid input type.'); if (t[2].type !== 'int32' || t[2].dims.length !== 1) throw new Error('Invalid input type.'); if (t.length >= 4 && (t[3].type !== 'int32' || t[3].dims.length !== 1)) throw new Error('Invalid input type.'); if (t.length >= 5 && (t[4].type !== 'int32' || t[4].dims.length !== 1)) throw new Error('Invalid input type.'); }); }), _c, Oc, Ic, Sc, Ac, Pc, Ec, Dc, Ab, Pb, Eb, Lc, Fc = L(() => { Ge(), fe(), xe(), ae(), ao(), (_c = { name: 'SoftmaxComputeMax', inputNames: ['A'], inputTypes: [0] }), (Oc = { name: 'SoftmaxComputeScale', inputNames: ['A', 'Max'], inputTypes: [0, 0] }), (Ic = { name: 'SoftMax', inputNames: ['A', 'Max', 'Norm'], inputTypes: [0, 0, 0] }), (Sc = (t, e, o) => { Lc(e); let i = e[0].dims.slice(), u = U.normalizeAxis(o.axis, i.length), n = U.sizeToDimension(i, u), s = U.sizeFromDimension(i, u); return Dc(t, e, o, n, s); }), (Ac = (t) => ee({ axis: t.attributes.getInt('axis', 1) })), (Pc = (t) => ee({ axis: t.attributes.getInt('axis', -1) })), (Ec = (t, e, o) => { Lc(e); let i = e[0].dims.slice(), u = U.normalizeAxis(o.axis, i.length), n = i.length, s = u !== n - 1, d = [], f = [], r = [], a; s && ((f = Array.from({ length: n }).map((y, T) => T)), (f[u] = n - 1), (f[n - 1] = u), f.map((y) => d.push(i[y])), (a = ee({ perm: f })), (r = yr(t, e, a))); let l = s ? U.sizeToDimension(d, n - 1) : U.sizeToDimension(i, n - 1), p = s ? U.sizeFromDimension(d, n - 1) : U.sizeFromDimension(i, n - 1), m = Dc(t, s ? r : e, o, l, p); return s ? yr(t, m, a) : m; }), (Dc = (t, e, o, i, u) => { let n = Ab(t, e[0], i, u, [i]), s = t.run({ ..._c, cacheHint: o.cacheKey, get: () => n }, e), d = Pb(t, e[0], i, u, n.output.dims, [i]), f = t.run({ ...Oc, cacheHint: o.cacheKey, get: () => d }, [e[0], s]), r = Eb(t, e[0], i, u, n.output.dims, d.output.dims); return [t.run({ ...Ic, cacheHint: o.cacheKey, get: () => r }, [e[0], s, f])]; }), (Ab = (t, e, o, i, u) => { let [n, s] = t.calculateTextureWidthAndHeight(e.dims, 0), d = u.length; if (o < 1 || i < 1) throw new Error('Logical row count N and feature count D must be greater than or equal to 1'); if (u.length !== 1) throw new Error('Dimensionality of the output should be 1'); if (u[0] !== o) throw new Error('Shape of the output should be equal to logical row count'); let f = q(t.session.backend.glContext.version), r = ` float process(int[${d}] indices) { int logical_row_start_offset = indices[0] * ${i}; float max = getColorAsFloat(${f.texture2D}(A, offsetToCoords(logical_row_start_offset, ${n}, ${s} ))); for(int i=1; i<${i}; ++i) { float current = getColorAsFloat(${f.texture2D}(A, offsetToCoords(logical_row_start_offset + i, ${n}, ${s}))); if(current > max) max = current; } return max; }`; return { ..._c, output: { dims: u, type: e.type, textureType: 0 }, shaderSource: r }; }), (Pb = (t, e, o, i, u, n) => { let [s, d] = t.calculateTextureWidthAndHeight(e.dims, 0), f = n.length; if (o < 1 || i < 1) throw new Error('Logical row count N and feature count D must be greater than or equal to 1'); if (n.length !== 1) throw new Error('Dimensionality of the output should be 1'); if (n[0] !== o) throw new Error('Shape of the output should be equal to logical row count'); if (u.length !== 1) throw new Error('Dimensionality of the intermediate results should be 1'); if (u[0] !== o) throw new Error('Shape of the intermediate results should be equal to logical row count'); let r = q(t.session.backend.glContext.version), a = ` float process(int[${f}] indices) { int logical_row_start_offset = indices[0] * ${i}; float norm_factor = 0.0; float max = _Max(indices); for(int i=0; i<${i}; ++i) { norm_factor += exp(getColorAsFloat(${r.texture2D}(A, offsetToCoords(logical_row_start_offset + i, ${s}, ${d}))) - max); } return norm_factor; }`; return { ...Oc, output: { dims: n, type: e.type, textureType: 0 }, shaderSource: a }; }), (Eb = (t, e, o, i, u, n) => { let [s, d] = t.calculateTextureWidthAndHeight(e.dims, 0), f = e.dims.length; if (o < 1 || i < 1) throw new Error('Logical row count N and feature count D must be greater than or equal to 1'); if (u.length !== 1 || n.length !== 1) throw new Error('Dimensionality of the intermediate results should be 1'); if (u[0] !== o || n[0] !== o) throw new Error('Shape of the intermediate results should be equal to logical row count'); let r = ` float process(int[${f}] indices) { // get offset of current logical tensor index from the 2-D texture coordinates (TexCoords) int offset = coordsToOffset(TexCoords, ${s}, ${d}); //determine the logical row for this index int logical_row_index[1]; logical_row_index[0] = offset / ${i}; float norm_factor = _Norm(logical_row_index); // avoid possible division by 0 // if norm_facor is 0, all elements are zero // if so, return 0 if(norm_factor == 0.0) return 0.0; return exp(_A(indices) - _Max(logical_row_index)) / norm_factor; }`; return { ...Ic, output: { dims: e.dims, type: e.type, textureType: 0 }, shaderSource: r }; }), (Lc = (t) => { if (!t || t.length !== 1) throw new Error('Softmax requires 1 input.'); if (t[0].type !== 'float32' && t[0].type !== 'float64') throw new Error('Invalid input type'); }); }), $c, Cc, kc, Db, Lb, Fb, Bc = L(() => { Ge(), fe(), ae(), ($c = { name: 'Split', inputNames: ['A'], inputTypes: [0] }), (Cc = (t, e, o) => { Fb(e); let i = U.normalizeAxis(o.axis, e[0].dims.length), u = Db(t, e, i, o), n = []; for (let s = 0; s < u; ++s) n.push(t.run({ ...$c, cacheHint: `${o.cacheKey};${s}`, get: () => Lb(t, e[0], o, i, s) }, e)); return n; }), (kc = (t) => { let e = t.attributes.getInt('axis', 0), o = t.attributes.getInts('split', []), i = t.outputs.length; return ee({ axis: e, split: o, numOutputs: i }); }), (Db = (t, e, o, i) => { let [, u] = an.splitShape(e[0].dims, o, i.split, i.numOutputs); return u.length; }), (Lb = (t, e, o, i, u) => { let [n, s] = an.splitShape(e.dims, i, o.split, o.numOutputs), d = s[u], f = n[u], r = ` float process(int indices[${f.length}]) { indices[${i}] += ${d}; return _A(indices); } `; return { ...$c, cacheHint: `${o.cacheKey}:${u}`, output: { dims: f, type: e.type, textureType: 0 }, shaderSource: r, }; }), (Fb = (t) => { if (!t || t.length !== 1) throw new Error('Split requires one input.'); if ( t[0].type !== 'int8' && t[0].type !== 'uint8' && t[0].type !== 'int16' && t[0].type !== 'uint16' && t[0].type !== 'int32' && t[0].type !== 'uint32' && t[0].type !== 'float32' && t[0].type !== 'float64' && t[0].type !== 'bool' ) throw new Error('Invalid input type.'); }); }), Vi, Nc, Rc, $b, Cb, Mc = L(() => { fe(), (Vi = (t, e, o) => { $b(e); let i = U.squeezeShape(e[0].dims, o); return [t.reshapeUnpacked(e[0], i)]; }), (Nc = (t, e) => (Cb(e), Vi(t, [e[0]], Array.from(e[1].integerData)))), (Rc = (t) => t.attributes.getInts('axes')), ($b = (t) => { if (!t || t.length !== 1) throw new Error('Squeeze requires 1 input.'); if (t[0].type === 'string') throw new Error('invalid input tensor types.'); }), (Cb = (t) => { if (!t || t.length !== 2) throw new Error('Squeeze requires 2 inputs.'); if (t[1].type !== 'int32') throw new Error('Invalid input type.'); }); }), Gc, kb, Bb, Uc = L(() => { xe(), ae(), (Gc = (t, e) => { Bb(e); let o = { name: 'Sum', inputNames: e.map((i, u) => `X${u}`), inputTypes: new Array(e.length).fill(0) }; return [t.run({ ...o, get: () => kb(t, e, o) }, e)]; }), (kb = (t, e, o) => { let i = q(t.session.backend.glContext.version), u = e[0].dims.slice(), n = ` void main() { vec4 result = ${e.map((s, d) => `${i.texture2D}(X${d},TexCoords)`).join(' + ')}; ${i.output} = result; } `; return { ...o, output: { dims: u, type: e[0].type, textureType: 0 }, hasMain: !0, shaderSource: n }; }), (Bb = (t) => { if (!t || t.length === 0) throw new Error('Sum requires inputs.'); let e = t[0].dims.length; for (let o = 1; o < t.length; o++) { if (e !== t[o].dims.length) throw new Error('Input shapes are mismatched.'); for (let i = 0; i < e; i++) if (t[0].dims[i] !== t[o].dims[i]) throw new Error('Input shapes are not matched.'); } if (t[0].type !== 'float32' && t[0].type !== 'float64') throw new Error('Invalid input type.'); for (let o = 1; o < t.length; o++) if (t[0].type !== t[o].type) throw new Error('Input types are not matched.'); }); }), zc, Nb, Rb, Vc = L(() => { pn(), ae(), (zc = (t, e) => { Rb(e); let o = { name: 'Tile', inputNames: ['A'], inputTypes: [0] }; return [t.run({ ...o, get: () => Nb(t, e, o) }, e)]; }), (Nb = (t, e, o) => { let i = e[0].dims.slice(), u = new Array(i.length), n = []; for (let f = 0; f < i.length; f++) (u[f] = i[f] * e[1].numberData[f]), n.push(`inputIdx[${f}] = int(mod(float(outputIdx[${f}]), ${i[f]}.));`); let s = u.length, d = ` float process(int outputIdx[${s}]) { int inputIdx[${s}]; ${n.join(` `)} return _A(inputIdx); } `; return { ...o, output: { dims: u, type: e[0].type, textureType: 0 }, shaderSource: d }; }), (Rb = (t) => { if (!t || t.length !== 2) throw new Error('Tile requires 2 input.'); if (t[1].dims.length !== 1) throw new Error('The second input shape must 1 dimension.'); if (t[1].dims[0] !== t[0].dims.length) throw new Error('Invalid input shape.'); if (Jt.indexOf(t[0].type) === -1) throw new Error('Invalid input type.'); if (t[1].type !== 'int32' && t[1].type !== 'int16') throw new Error('Invalid repeat type.'); }); }), Wi, Wc, Hc, Mb, Gb, qc = L(() => { fe(), (Wi = (t, e, o) => { Mb(e); let i = U.unsqueezeShape(e[0].dims, o); return [t.reshapeUnpacked(e[0], i)]; }), (Wc = (t, e) => (Gb(e), Wi(t, [e[0]], Array.from(e[1].integerData)))), (Hc = (t) => t.attributes.getInts('axes')), (Mb = (t) => { if (!t || t.length !== 1) throw new Error('Unsqueeze requires 1 input.'); if (t[0].type === 'string') throw new Error('invalid input tensor types.'); }), (Gb = (t) => { if (!t || t.length !== 2) throw new Error('Unsqueeze requires 2 inputs.'); if (t[1].type !== 'int32') throw new Error('Invalid input type.'); }); }), jc, Yc = L(() => { nl(), bl(), Tl(), Il(), no(), lf(), mf(), yf(), vf(), If(), Pf(), Ff(), Bf(), oo(), Gf(), Qf(), sc(), lc(), mc(), gc(), wc(), Fc(), Bc(), Mc(), Uc(), Vc(), ao(), Ai(), qc(), Mi(), (jc = [ ['Abs', '', '6+', Sl], ['Acos', '', '7+', Al], ['Add', '', '7+', ol], ['And', '', '7+', il], ['Asin', '', '7+', Pl], ['Atan', '', '7+', El], ['AveragePool', '', '7+', zf, Vf], ['BatchNormalization', '', '7+', tl, rl], ['Cast', '', '6+', gl, yl], ['Ceil', '', '6+', Fl], ['Clip', '', '6-10', Ii, Dl], ['Clip', '', '11+', Ll], ['Concat', '', '4+', wl, Ol], ['Conv', '', '1+', $i, Ci], ['ConvTranspose', '', '1+', sf, uf], ['Cos', '', '7+', $l], ['Div', '', '7+', al], ['Dropout', '', '7+', Si], ['DepthToSpace', '', '1+', df, hf], ['Equal', '', '7+', sl], ['Elu', '', '6+', Cl, kl], ['Exp', '', '6+', Bl], ['Flatten', '', '1+', bf, gf], ['Floor', '', '6+', Nl], ['FusedConv', 'com.microsoft', '1+', $i, Ci], ['Gather', '', '1+', Tf, xf], ['Gemm', '', '7-10', ki, _f], ['Gemm', '', '11+', ki, Of], ['GlobalAveragePool', '', '1+', Hf, qf], ['GlobalMaxPool', '', '1+', Jf], ['Greater', '', '7+', ul], ['Identity', '', '1+', Si], ['ImageScaler', '', '1+', Sf, Af], ['InstanceNormalization', '', '6+', Df, Lf], ['LeakyRelu', '', '6+', Rl, Ml], ['Less', '', '7+', ll], ['LRN', '', '1+', $f, Cf], ['Log', '', '6+', Gl], ['MatMul', '', '1+', Ql, ef], ['MaxPool', '', '1+', jf, Yf], ['Mul', '', '7+', fl], ['Neg', '', '6+', Ul], ['Not', '', '1+', zl], ['Or', '', '7+', cl], ['Pad', '', '2-10', Bi, Nf], ['Pad', '', '11+', Rf, Mf], ['Pow', '', '7+', pl], ['PRelu', '', '7+', dl], ['ReduceLogSum', '', '1+', ic, Zt], ['ReduceMax', '', '1+', rc, Zt], ['ReduceMean', '', '1+', tc, Zt], ['ReduceMin', '', '1+', nc, Zt], ['ReduceProd', '', '1+', oc, Zt], ['ReduceSum', '', '1-12', ec, Zt], ['ReduceSumSquare', '', '1+', ac, Zt], ['Relu', '', '6+', Vl], ['Reshape', '', '5+', uc], ['Resize', '', '10', Ui, dc], ['Resize', '', '11+', Ui, hc], ['Shape', '', '1+', bc], ['Sigmoid', '', '6+', Wl], ['Sin', '', '7+', Hl], ['Slice', '', '10+', vc], ['Slice', '', '1-9', yc, Tc], ['Softmax', '', '1-12', Sc, Ac], ['Softmax', '', '13+', Ec, Pc], ['Split', '', '2-12', Cc, kc], ['Sqrt', '', '6+', ql], ['Squeeze', '', '1-12', Vi, Rc], ['Squeeze', '', '13+', Nc], ['Sub', '', '7+', hl], ['Sum', '', '6+', Gc], ['Tan', '', '7+', jl], ['Tanh', '', '6+', Yl], ['Tile', '', '6+', zc], ['Transpose', '', '1+', yr, cf], ['Upsample', '', '7-8', Ni, cc], ['Upsample', '', '9', Ni, pc], ['Unsqueeze', '', '1-12', Wi, Hc], ['Unsqueeze', '', '13+', Wc], ['Xor', '', '7+', ml], ]); }); function Kc(t) { let e = {}, o; for (; (o = Xc.exec(t)) !== null; ) { let i = o[3] .split(',') .map((u) => { let n = u.trim().split(' '); return n && n.length === 2 ? { type: n[0], name: n[1] } : null; }) .filter((u) => u !== null); e[o[2]] = { params: i, body: o[4] }; } for (let i in e) { let u = Ub.replace('__FUNC__', i), n = new RegExp(u, 'gm'); for (; (o = n.exec(t)) !== null; ) { let s = o[1], d = o[2], f = o[3].split(','), r = s ? `${s} ${d};` : '', a = e[i].body, l = ''; e[i].params.forEach((m, y) => { m && (l += `${m.type} ${m.name} = ${f[y]}; `); }), (a = `${l} ${a}`), (a = a.replace('return', `${d} = `)); let p = ` ${r} { ${a} } `; t = t.replace(o[0], p); } } return (t = t.replace(Xc, '')), t; } var Xc, Ub, Jc = L(() => { (Xc = /@inline[\s\n\r]+(\w+)[\s\n\r]+([0-9a-zA-Z_]+)\s*\(([^)]*)\)\s*{(([^}]|[\n\r])*)}/gm), (Ub = '(\\w+)?\\s+([_0-9a-zA-Z]+)\\s+=\\s+__FUNC__\\((.*)\\)\\s*;'); }); function Gr(t, e) { let o = [], i = [], u = e != null && Array.isArray(e) && e.length === 0, n = e == null || u ? null : zb(e, t).sort(), s = 0; for (let d = 0; d < t.length; ++d) { if (n != null) { if (n[s] === d && t[d] !== 1) throw new Error(`Can't squeeze axis ${d} since its dim '${t[d]}' is not 1`); (n[s] == null || n[s] > d) && t[d] === 1 && (o.push(t[d]), i.push(d)), n[s] <= d && s++; } t[d] !== 1 && (o.push(t[d]), i.push(d)); } return { newShape: o, keptDims: i }; } function zb(t, e) { let o = e.length; return ( (t = t == null ? e.map((i, u) => u) : [].concat(t)), Cr( t.every((i) => i >= -o && i < o), () => `All values in axis param must be in range [-${o}, ${o}) but got axis ${t}` ), Cr(t.every(Vb), () => `All values in axis param must be integers but got axis ${t}`), t.map((i) => (i < 0 ? o + i : i)) ); } function Vb(t) { return t % 1 === 0; } function Wb(t) { if (t.length === 0) return 1; let e = t[0]; for (let o = 1; o < t.length; o++) e *= t[o]; return e; } function Zc(t) { let e = Math.ceil(Math.sqrt(t)); return [e, Math.ceil(t / e)]; } var fo, Hi = L(() => { ut(), fe(), (fo = class { constructor(t) { this.maxTextureSize = t; } computeTextureWH(t, e) { let o = this.computeTexture(t, e); return e && e.isPacked && ((o[0] /= 2), (o[1] /= 2)), e && e.reverseWH ? [o[1], o[0]] : o; } computeTexture(t, e) { let o = e && e.isPacked; if (t.length === 0) return o ? [2, 2] : [1, 1]; let i = this.maxTextureSize; if (e && e.breakAxis !== void 0) { let s = e.breakAxis >= t.length ? 1 : t.slice(e.breakAxis).reduce((f, r) => f * r), d = e.breakAxis <= 0 ? 1 : t.slice(0, e.breakAxis).reduce((f, r) => f * r); if (s > i || d > i) ce.verbose( 'TextureLayout', `Given width/height preferences were unattainable: shape:${t}, breakAxis:${e.breakAxis}` ); else return [s, d]; } let u = t.slice(0); o && ((i = i * 2), (u = u.map((s, d) => (d >= u.length - 2 ? (u[d] % 2 === 0 ? u[d] : u[d] + 1) : u[d]))), u.length === 1 && (u = [2, u[0]])), u.length !== 2 && (u = Gr(u).newShape); let n = Wb(u); return u.length <= 1 && n <= i ? [1, n] : u.length === 2 && u[0] <= i && u[1] <= i ? u : u.length === 3 && u[0] * u[1] <= i && u[2] <= i ? [u[0] * u[1], u[2]] : u.length === 3 && u[0] <= i && u[1] * u[2] <= i ? [u[0], u[1] * u[2]] : u.length === 4 && u[0] * u[1] * u[2] <= i && u[3] <= i ? [u[0] * u[1] * u[2], u[3]] : u.length === 4 && u[0] <= i && u[1] * u[2] * u[3] <= i ? [u[0], u[1] * u[2] * u[3]] : o ? Zc(n / 4).map((s) => s * 2) : Zc(n); } }); }), co, Qc = L(() => { fe(), Vt(), xe(), Hi(), Ft(), (co = class extends pt { constructor(t) { super(t); } getFunctions() { return { ...this.offsetToCoords(), ...this.coordsToOffset(), ...this.toVec(), ...this.valueFrom(), ...this.getCommonUtilFuncs(), ...this.getInputsSamplingSnippets(), ...this.getOutputSamplingSnippet(), }; } getCustomTypes() { return {}; } offsetToCoords() { let t = 'offsetToCoords'; return { offsetToCoords: new R(` vec2 ${t}(int offset, int width, int height) { int t = offset / width; int s = offset - t*width; vec2 coords = (vec2(s,t) + vec2(0.5,0.5)) / vec2(width, height); return coords; } `), }; } coordsToOffset() { let t = 'coordsToOffset'; return { coordsToOffset: new R(` int ${t}(vec2 coords, int width, int height) { float s = coords.s * float(width); float t = coords.t * float(height); int offset = int(t) * width + int(s); return offset; } `), }; } getOutputSamplingSnippet() { let t = this.context.outputTextureLayout; return t.isPacked ? this.getPackedOutputSamplingSnippet(t) : this.getUnpackedOutputSamplingSnippet(t); } getPackedOutputSamplingSnippet(t) { let e = t.unpackedShape, o = [t.width, t.height], i = {}, u = 'getOutputCoords'; switch (e.length) { case 0: i[u] = this.getOutputScalarCoords(); break; case 1: i[u] = this.getOutputPacked1DCoords(e, o); break; case 2: i[u] = this.getOutputPacked2DCoords(e, o); break; case 3: i[u] = this.getOutputPacked3DCoords(e, o); break; default: i[u] = this.getOutputPackedNDCoords(e, o); } let n = ` void setOutput(vec4 val) { ${q(this.context.glContext.version).output} = val; } `, s = 'floatTextureSetRGBA'; return (i[s] = new R(n)), i; } getUnpackedOutputSamplingSnippet(t) { let e = t.unpackedShape, o = [t.width, t.height], i = {}, u = 'getOutputCoords'; switch (e.length) { case 0: i[u] = this.getOutputScalarCoords(); break; case 1: i[u] = this.getOutputUnpacked1DCoords(e, o); break; case 2: i[u] = this.getOutputUnpacked2DCoords(e, o); break; case 3: i[u] = this.getOutputUnpacked3DCoords(e, o); break; case 4: i[u] = this.getOutputUnpacked4DCoords(e, o); break; case 5: i[u] = this.getOutputUnpacked5DCoords(e, o); break; case 6: i[u] = this.getOutputUnpacked6DCoords(e, o); break; default: throw new Error(`Unsupported output dimensionality: ${e.length}`); } let n = ` void setOutput(float val) { ${q(this.context.glContext.version).output} = vec4(val, 0, 0, 0); } `, s = 'floatTextureSetR'; return (i[s] = new R(n)), i; } getOutputScalarCoords() { return new R(` int getOutputCoords() { return 0; } `); } getOutputPacked1DCoords(t, e) { let o = e, i = ''; return o[0] === 1 ? ((i = ` int getOutputCoords() { return 2 * int(TexCoords.y * ${o[1]}.0); } `), new R(i)) : o[1] === 1 ? ((i = ` int getOutputCoords() { return 2 * int(TexCoords.x * ${o[0]}.0); } `), new R(i)) : ((i = ` int getOutputCoords() { ivec2 resTexRC = ivec2(TexCoords.xy * vec2(${o[0]}, ${o[1]})); return 2 * (resTexRC.y * ${o[0]} + resTexRC.x); } `), new R(i)); } getOutputPacked2DCoords(t, e) { let o = ''; if (cr.arraysEqual(t, e)) return ( (o = ` ivec2 getOutputCoords() { return 2 * ivec2(TexCoords.xy * vec2(${e[0]}, ${e[1]})); } `), new R(o) ); let i = e, u = Math.ceil(t[1] / 2); return ( (o = ` ivec2 getOutputCoords() { ivec2 resTexRC = ivec2(TexCoords.xy * vec2(${i[0]}, ${i[1]})); int index = resTexRC.y * ${i[0]} + resTexRC.x; // reverse r and c order for packed texture int r = imod(index, ${u}) * 2; int c = 2 * (index / ${u}); return ivec2(r, c); } `), new R(o) ); } getOutputPacked3DCoords(t, e) { let o = [e[0], e[1]], i = Math.ceil(t[2] / 2), u = i * Math.ceil(t[1] / 2), n = ` ivec3 getOutputCoords() { ivec2 resTexRC = ivec2(TexCoords.xy * vec2(${o[0]}, ${o[1]})); int index = resTexRC.y * ${o[0]} + resTexRC.x; int b = index / ${u}; index -= b * ${u}; // reverse r and c order for packed texture int r = imod(index, ${i}) * 2; int c = 2 * (index / ${i}); return ivec3(b, r, c); } `; return new R(n); } getOutputPackedNDCoords(t, e) { let o = [e[0], e[1]], i = Math.ceil(t[t.length - 1] / 2), u = i * Math.ceil(t[t.length - 2] / 2), n = u, s = '', d = 'b, r, c'; for (let r = 2; r < t.length - 1; r++) (n *= t[t.length - r - 1]), (s = ` int b${r} = index / ${n}; index -= b${r} * ${n}; ` + s), (d = `b${r}, ` + d); let f = ` ivec${t.length} getOutputCoords() { ivec2 resTexRC = ivec2(TexCoords.xy * vec2(${o[0]}, ${o[1]})); int index = resTexRC.y * ${o[0]} + resTexRC.x; ${s} int b = index / ${u}; index -= b * ${u}; // reverse r and c order for packed texture int r = imod(index, ${i}) * 2; int c = 2 * (index / ${i}); return ivec${t.length}(${d}); } `; return new R(f); } getOutputUnpacked1DCoords(t, e) { let o = ` int getOutputCoords() { ivec2 resTexRC = ivec2(TexCoords.xy * vec2(${e[0]}, ${e[1]})); return resTexRC.y * ${e[0]} + resTexRC.x; } `; return new R(o); } getOutputUnpacked2DCoords(t, e) { let o = ` ivec2 getOutputCoords() { ivec2 resTexRC = ivec2(TexCoords.xy * vec2(${e[0]}, ${e[1]})); int index = resTexRC.y * ${e[0]} + resTexRC.x; int r = index / ${t[1]}; int c = index - r * ${t[1]}; return ivec2(r, c); } `; return new R(o); } getOutputUnpacked3DCoords(t, e) { let o = '', i = t.length, u = null; i < 2 && (u = []), (u = new Array(i - 1)), (u[i - 2] = t[i - 1]); for (let d = i - 3; d >= 0; --d) u[d] = u[d + 1] * t[d + 1]; let n = ['r', 'c', 'd'], s = u .map((d, f) => { let r = `int ${n[f]} = index / ${d}`, a = f === u.length - 1 ? `int ${n[f + 1]} = index - ${n[f]} * ${d}` : `index -= ${n[f]} * ${d}`; return `${r}; ${a};`; }) .join(''); return ( (o = ` ivec3 getOutputCoords() { ivec2 resTexRC = ivec2(TexCoords.xy * vec2(${e[0]}, ${e[1]})); int index = resTexRC.y * ${e[0]} + resTexRC.x; ${s} return ivec3(r, c, d); } `), new R(o) ); } getOutputUnpacked4DCoords(t, e) { let o = '', i = t.length, u = null; i < 2 && (u = []), (u = new Array(i - 1)), (u[i - 2] = t[i - 1]); for (let d = i - 3; d >= 0; --d) u[d] = u[d + 1] * t[d + 1]; let n = ['r', 'c', 'd', 'd2'], s = u .map((d, f) => { let r = `int ${n[f]} = index / ${d}`, a = f === u.length - 1 ? `int ${n[f + 1]} = index - ${n[f]} * ${d}` : `index -= ${n[f]} * ${d}`; return `${r}; ${a};`; }) .join(''); return ( (o = ` ivec4 getOutputCoords() { ivec2 resTexRC = ivec2(TexCoords.xy * vec2(${e[0]}, ${e[1]})); int index = resTexRC.y * ${e[0]} + resTexRC.x; ${s} return ivec4(r, c, d, d2); } `), new R(o) ); } getOutputUnpacked5DCoords(t, e) { let o = '', i = t.length, u = null; i < 2 && (u = []), (u = new Array(i - 1)), (u[i - 2] = t[i - 1]); for (let d = i - 3; d >= 0; --d) u[d] = u[d + 1] * t[d + 1]; let n = ['r', 'c', 'd', 'd2', 'd3'], s = u .map((d, f) => { let r = `int ${n[f]} = index / ${d}`, a = f === u.length - 1 ? `int ${n[f + 1]} = index - ${n[f]} * ${d}` : `index -= ${n[f]} * ${d}`; return `${r}; ${a};`; }) .join(''); return ( (o = ` ivec5 getOutputCoords() { ivec2 resTexRC = ivec2(TexCoords.xy * vec2(${e[0]}, ${e[1]})); int index = resTexRC.y * ${e[0]} + resTexRC.x; ${s} return ivec5(r, c, d, d2, d3); } `), new R(o) ); } getOutputUnpacked6DCoords(t, e) { let o = '', i = t.length, u = null; i < 2 && (u = []), (u = new Array(i - 1)), (u[i - 2] = t[i - 1]); for (let d = i - 3; d >= 0; --d) u[d] = u[d + 1] * t[d + 1]; let n = ['r', 'c', 'd', 'd2', 'd3', 'd4'], s = u .map((d, f) => { let r = `int ${n[f]} = index / ${d}`, a = f === u.length - 1 ? `int ${n[f + 1]} = index - ${n[f]} * ${d}` : `index -= ${n[f]} * ${d}`; return `${r}; ${a};`; }) .join(''); return ( (o = ` ivec6 getOutputCoords() { ivec2 resTexRC = ivec2(TexCoords.xy * vec2(${e[0]}, ${e[1]})); int index = resTexRC.y * ${e[0]} + resTexRC.x; ${s} return ivec6(r, c, d, d2, d3, d4); } `), new R(o) ); } getCommonUtilFuncs() { let t = {}, e = 'uvFromFlat'; (t[e] = new R(` vec2 uvFromFlat(int texNumR, int texNumC, int index) { int texC = index / texNumR; int texR = index - texC * texNumR; // TODO: swap texR, texC order in following function so row is corresponding to u and column is corresponding to // v. return (vec2(texR, texC) + halfCR) / vec2(texNumR, texNumC); } `)), (e = 'packedUVfrom1D'), (t[e] = new R(` vec2 packedUVfrom1D(int texNumR, int texNumC, int index) { int texelIndex = index / 2; int texR = texelIndex / texNumC; int texC = texelIndex - texR * texNumC; return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR); } `)), (e = 'packedUVfrom2D'), (t[e] = new R(` vec2 packedUVfrom2D(int texNumR, int texNumC, int texelsInLogicalRow, int row, int col) { int texelIndex = (row / 2) * texelsInLogicalRow + (col / 2); int texR = texelIndex / texNumC; int texC = texelIndex - texR * texNumC; return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR); } `)), (e = 'packedUVfrom3D'), (t[e] = new R(` vec2 packedUVfrom3D(int texNumR, int texNumC, int texelsInBatch, int texelsInLogicalRow, int b, int row, int col) { int index = b * texelsInBatch + (row / 2) * texelsInLogicalRow + (col / 2); int texR = index / texNumC; int texC = index - texR * texNumC; return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR); } `)), (e = 'sampleTexture'); let o = q(this.context.glContext.version); return ( (t[e] = new R(` float sampleTexture(sampler2D textureSampler, vec2 uv) { return ${o.texture2D}(textureSampler, uv).r; }`)), t ); } getInputsSamplingSnippets() { let t = {}, e = this.context.outputTextureLayout; return ( this.context.programInfo.inputNames.forEach((o, i) => { let u = this.context.inputTextureLayouts[i], n = Kn(o); u.isPacked ? (t[n] = this.getPackedSamplerFromInput(n, o, u)) : (t[n] = this.getUnpackedSamplerFromInput(n, o, u)); let s = Mu(o); u.unpackedShape.length <= e.unpackedShape.length && (u.isPacked ? (t[s] = this.getPackedSamplerAtOutputCoords(s, u, e, o)) : (t[s] = this.getUnpackedSamplerAtOutputCoords(s, u, e, o))); }), t ); } getPackedSamplerAtOutputCoords(t, e, o, i) { let u = e.unpackedShape, n = o.unpackedShape, s = Kn(i), d = u.length, f = n.length, r = Xe.getBroadcastDims(u, n), a = Ke(f), l = f - d, p, m = St(); d === 0 ? (p = '') : f < 2 && r.length >= 1 ? (p = 'coords = 0;') : (p = r.map((F) => `coords.${m[F + l]} = 0;`).join(` `)); let y = ''; f < 2 && d > 0 ? (y = 'coords') : (y = u.map((F, B) => `coords.${m[B + l]}`).join(', ')); let T = 'return outputValue;', v = U.size(u) === 1, S = U.size(n) === 1; if (d === 1 && !v && !S) T = ` return vec4(outputValue.xy, outputValue.xy); `; else if (v && !S) f === 1 ? (T = ` return vec4(outputValue.x, outputValue.x, 0., 0.); `) : (T = ` return vec4(outputValue.x); `); else if (r.length) { let F = d - 2, B = d - 1; r.indexOf(F) > -1 && r.indexOf(B) > -1 ? (T = 'return vec4(outputValue.x);') : r.indexOf(F) > -1 ? (T = 'return vec4(outputValue.x, outputValue.y, outputValue.x, outputValue.y);') : r.indexOf(B) > -1 && (T = 'return vec4(outputValue.xx, outputValue.zz);'); } let E = ` int lastDim = coords.${m[f - 1]}; coords.${m[f - 1]} = coords.${m[f - 2]}; coords.${m[f - 2]} = lastDim; `, A = ` vec4 ${t}() { ${a} coords = getOutputCoords(); ${E} ${p} vec4 outputValue = ${s}(${y}); ${T} } `; return new R(A, ['coordinates.getOutputCoords']); } getUnpackedSamplerAtOutputCoords(t, e, o, i) { let u = [o.width, o.height], n = [e.width, e.height], s = e.unpackedShape.length, d = o.unpackedShape.length, f = e.unpackedShape, r = o.unpackedShape, a = Kn(i); if (s === d && cr.arraysEqual(n, u)) { let E = ` float ${t}() { return sampleTexture(${i}, TexCoords); } `; return new R(E, ['coordinates.sampleTexture']); } let l = Ke(d), p = Xe.getBroadcastDims(f, r), m = d - s, y, T = St(); s === 0 ? (y = '') : d < 2 && p.length >= 1 ? (y = 'coords = 0;') : (y = p.map((E) => `coords.${T[E + m]} = 0;`).join(` `)); let v = ''; d < 2 && s > 0 ? (v = 'coords') : (v = e.unpackedShape.map((E, A) => `coords.${T[A + m]}`).join(', ')); let S = ` float ${t}() { ${l} coords = getOutputCoords(); ${y} return ${a}(${v}); } `; return new R(S, ['coordinates.getOutputCoords']); } getPackedSamplerFromInput(t, e, o) { switch (o.unpackedShape.length) { case 0: return this.getPackedSamplerScalar(t, e); case 1: return this.getPackedSampler1D(t, e, o); case 2: return this.getPackedSampler2D(t, e, o); case 3: return this.getPackedSampler3D(t, e, o); default: return this.getPackedSamplerND(t, e, o); } } getUnpackedSamplerFromInput(t, e, o) { let i = o.unpackedShape; switch (i.length) { case 0: return this.getUnpackedSamplerScalar(t, e, o); case 1: return this.getUnpackedSampler1D(t, e, o); case 2: return this.getUnpackedSampler2D(t, e, o); case 3: return this.getUnpackedSampler3D(t, e, o); case 4: return this.getUnpackedSampler4D(t, e, o); case 5: return this.getUnpackedSampler5D(t, e, o); case 6: return this.getUnpackedSampler6D(t, e, o); default: throw new Error(`Unsupported dimension ${i.length}-D`); } } getPackedSamplerScalar(t, e) { let o = q(this.context.glContext.version), i = ` vec4 ${t}() { return ${o.texture2D}(${e}, halfCR); } `; return new R(i); } getPackedSampler1D(t, e, o) { let i = [o.width, o.height], u = [i[1], i[0]], n = q(this.context.glContext.version), s = `vec4 ${t}(int index) { vec2 uv = packedUVfrom1D( ${u[0]}, ${u[1]}, index); return ${n.texture2D}(${e}, uv); }`; return new R(s, ['coordinates.packedUVfrom1D']); } getPackedSampler2D(t, e, o) { let i = o.unpackedShape, u = [o.width, o.height], n = q(this.context.glContext.version), s = u[0], d = u[1]; if (u != null && cr.arraysEqual(i, u)) { let l = `vec4 ${t}(int row, int col) { vec2 uv = (vec2(col, row) + halfCR) / vec2(${d}.0, ${s}.0); return ${n.texture2D}(${e}, uv); }`; return new R(l); } let f = u, r = Math.ceil(i[1] / 2), a = `vec4 ${t}(int row, int col) { vec2 uv = packedUVfrom2D(${f[1]}, ${f[0]}, ${r}, row, col); return ${n.texture2D}(${e}, uv); }`; return new R(a, ['coordinates.packedUVfrom2D']); } getPackedSampler3D(t, e, o) { let i = o.unpackedShape, u = [o.width, o.height], n = [u[0], u[1]], s = q(this.context.glContext.version); if (i[0] === 1) { let p = i.slice(1), m = [1, 2], y = kr(i, p), T = ['b', 'row', 'col'], v = JSON.parse(JSON.stringify(o)); v.unpackedShape = y; let S = this.getPackedSamplerFromInput(t, e, v), E = `${S.routineBody} vec4 ${t}(int b, int row, int col) { return ${t}(${Br(T, m)}); } `; return new R(E, S.dependencies); } let d = n[0], f = n[1], r = Math.ceil(i[2] / 2), a = r * Math.ceil(i[1] / 2), l = `vec4 ${t}(int b, int row, int col) { vec2 uv = packedUVfrom3D( ${f}, ${d}, ${a}, ${r}, b, row, col); return ${s.texture2D}(${e}, uv);}`; return new R(l, ['coordinates.packedUVfrom3D']); } getPackedSamplerND(t, e, o) { let i = o.unpackedShape, u = i.length, n = [o.width, o.height], s = q(this.context.glContext.version), d = [n[0], n[1]], f = d[1], r = d[0], a = Math.ceil(i[u - 1] / 2), l = a * Math.ceil(i[u - 2] / 2), p = 'int b, int row, int col', m = `b * ${l} + (row / 2) * ${a} + (col / 2)`; for (let T = 2; T < u - 1; T++) (p = `int b${T}, ` + p), (l *= i[u - T - 1]), (m = `b${T} * ${l} + ` + m); let y = `vec4 ${t}(${p}) { int index = ${m}; int texR = index / ${r}; int texC = index - texR * ${r}; vec2 uv = (vec2(texC, texR) + halfCR) / vec2(${r}, ${f}); return ${s.texture2D}(${e}, uv); }`; return new R(y); } getUnpackedSamplerScalar(t, e, o) { let [i, u] = [o.width, o.height]; if (i === 1 && u === 1) { let s = ` float ${t}() { return sampleTexture(${e}, halfCR); } `; return new R(s, ['coordinates.sampleTexture']); } let n = ` float ${t}() { int offset_${e} = coordsToOffset(TexCoords, ${i}, ${u}); vec2 uv = uvFromFlat(${i}, ${u}, offset_${e}); return sampleTexture(${e}, uv); } `; return new R(n, [ 'coordinates.uvFromFlat', 'coordinates.sampleTexture', 'coordinates.coordsToOffset', ]); } getUnpackedSampler1D(t, e, o) { let i = o.width, u = o.height; if (u === 1 && i === 1) { let s = ` float ${t}(int index) { return sampleTexture(${e}, halfCR); } `; return new R(s, ['coordinates.sampleTexture']); } if (u === 1) { let s = ` float ${t}(int index) { vec2 uv = vec2((float(index) + 0.5) / ${i}.0, 0.5); return sampleTexture(${e}, uv); } `; return new R(s, ['coordinates.sampleTexture']); } if (i === 1) { let s = ` float ${t}(int index) { vec2 uv = vec2(0.5, (float(index) + 0.5) / ${u}.0); return sampleTexture(${e}, uv); } `; return new R(s, ['coordinates.sampleTexture']); } let n = ` float ${t}(int index) { vec2 uv = uvFromFlat(${i}, ${u}, index); return sampleTexture(${e}, uv); } `; return new R(n, ['coordinates.uvFromFlat', 'coordinates.sampleTexture']); } getUnpackedSampler2D(t, e, o) { let i = o.unpackedShape, u = [o.height, o.width]; if (u != null && cr.arraysEqual(i, u)) { let l = u[1], p = u[0], m = ` float ${t}(int row, int col) { vec2 uv = (vec2(row, col) + halfCR) / vec2(${l}.0, ${p}.0); return sampleTexture(${e}, uv); } `; return new R(m, ['coordinates.sampleTexture']); } let { newShape: n, keptDims: s } = Gr(i), d = n; if (d.length < i.length) { let l = kr(i, d), p = JSON.parse(JSON.stringify(o)); p.unpackedShape = l; let m = ['col', 'row'], y = ` ${this.getUnpackedSamplerFromInput(t, e, p).routineBody} float ${t}(int row, int col) { return ${t}(${Br(m, s)}); } `; return new R(y, ['coordinates.sampleTexture']); } let f = u[1], r = u[0]; if (r === 1) { let l = ` float ${t}(int row, int col) { int offset_${e} = coordsToOffset(TexCoords, ${f}, ${r}); float index = dot(vec3(row, col, offset_${e}), vec3(${i[1]}, 1, 1)); vec2 uv = vec2(0.5, (index + 0.5) / ${f}.0); return sampleTexture(${e}, uv); } `; return new R(l, ['coordinates.sampleTexture', 'coordinates.coordsToOffset']); } if (f === 1) { let l = ` float ${t}(int row, int col) { int offset_${e} = coordsToOffset(TexCoords, ${f}, ${r}); float index = dot(vec3(row, col, offset_${e}), vec3(${i[1]}, 1, 1)); vec2 uv = vec2((index + 0.5) / ${r}.0, 0.5); return sampleTexture(${e}, uv); } `; return new R(l, ['coordinates.sampleTexture', 'coordinates.coordsToOffset']); } let a = ` float ${t}(int row, int col) { int index = col * ${i[1]} + row; vec2 uv = uvFromFlat(${f}, ${r}, index); return sampleTexture(${e}, uv); } `; return new R(a, [ 'coordinates.uvFromFlat', 'coordinates.sampleTexture', 'coordinates.coordsToOffset', ]); } getUnpackedSampler3D(t, e, o) { let i = o.unpackedShape, u = i[1] * i[2], n = i[2], { newShape: s, keptDims: d } = Gr(i), f = s; if (f.length < i.length) { let p = kr(i, f), m = ['batch', 'col', 'row'], y = JSON.parse(JSON.stringify(o)); y.unpackedShape = p; let T = this.getUnpackedSamplerFromInput(t, e, y), v = d.reverse(), S = ` ${T.routineBody} float ${t}(int batch, int row, int col) { return ${t}(${Br(m, v)}); } `; return new R(S, T.dependencies); } let r = o.width, a = o.height, l = ` float ${t}(int depth, int row, int col) { // Explicitly use integer operations as dot() only works on floats. int index = depth * ${u} + col * ${n} + row; vec2 uv = uvFromFlat(${r}, ${a}, index); return sampleTexture(${e}, uv); } `; return new R(l, [ 'coordinates.uvFromFlat', 'coordinates.sampleTexture', 'coordinates.coordsToOffset', ]); } getUnpackedSampler4D(t, e, o) { let i = o.unpackedShape, u = i[3], n = i[2] * u, s = i[1] * n, d = o.width, f = o.height, r = ` float ${t}(int row, int col, int depth, int depth2) { int index = row * ${s} + col * ${n} + depth2 * ${u} + depth; vec2 uv = uvFromFlat(${d}, ${f}, index); return sampleTexture(${e}, uv); } `; return new R(r, ['coordinates.uvFromFlat', 'coordinates.sampleTexture']); } getUnpackedSampler5D(t, e, o) { let i = o.unpackedShape, u = i[4], n = i[3] * u, s = i[2] * n, d = i[1] * s, { newShape: f, keptDims: r } = Gr(i); if (f.length < i.length) { let m = kr(i, f), y = ['row', 'col', 'depth', 'depth2', 'depth3'], T = JSON.parse(JSON.stringify(o)); T.unpackedShape = m; let v = ` ${this.getUnpackedSamplerFromInput(t, e, T).routineBody} float ${t}(int row, int col, int depth, int depth2, int depth3) { return ${t}(${Br(y, r)}); } `; return new R(v, ['coordinates.sampleTexture', 'coordinates.uvFromFlat']); } let a = o.width, l = o.height, p = ` float ${t}(int row, int col, int depth, int depth2, int depth3) { int index = row * ${d} + col * ${s} + depth * ${n} + depth3 * ${u} + depth2; vec2 uv = uvFromFlat(${a}, ${l}, index); return sampleTexture(${e}, uv); } `; return new R(p, ['coordinates.sampleTexture', 'coordinates.uvFromFlat']); } getUnpackedSampler6D(t, e, o) { let i = o.unpackedShape, u = i[5], n = i[4] * u, s = i[3] * n, d = i[2] * s, f = i[1] * d, { newShape: r, keptDims: a } = Gr(i); if (r.length < i.length) { let y = kr(i, r), T = ['row', 'col', 'depth', 'depth2', 'depth3', 'depth4'], v = JSON.parse(JSON.stringify(o)); v.unpackedShape = y; let S = ` ${this.getUnpackedSamplerFromInput(t, e, v).routineBody} float ${t}(int row, int col, int depth, int depth2, int depth3, int depth4) { return ${t}(${Br(T, a)}); } `; return new R(S, ['coordinates.sampleTexture', 'coordinates.uvFromFlat']); } let l = o.width, p = o.height, m = ` float ${t}(int row, int col, int depth, int depth2, int depth3, int depth4) { int index = row * ${f} + col * ${d} + depth * ${s} + depth2 * ${n} + depth3 * ${u} + depth4; vec2 uv = uvFromFlat(${l}, ${p}, index); return sampleTexture(${e}, uv); } `; return new R(m, [ 'coordinates.uvFromFlat', 'coordinates.sampleTexture', 'coordinates.coordsToOffset', ]); } toVec() { let t = this.context.outputTextureLayout, e = t.shape.length, o = t.strides, i = t.width, u = t.height, n = []; for (let d = 0; d < e - 1; ++d) n.push(` c[${d}] = offset / ${o[d]};`), n.push(` offset -= c[${d}] * ${o[d]};`); n.push(` c[${e - 1}] = offset;`); let s = ` void toVec(vec2 texCoords, out int c[${e}]) { int offset = coordsToOffset(texCoords, ${i}, ${u}); ${n.join('')} } void toVec(int offset, out int c[${e}]) { ${n.join('')} } `; return { toVec: new R(s, ['coordinates.coordsToOffset']) }; } valueFrom() { let t = {}; return ( this.context.programInfo.inputNames.forEach((e, o) => { let i = this.context.inputTextureLayouts[o], u = (i.unpackedShape.length > 0 ? i.unpackedShape : i.shape).length, n = `_${e}`; (t[n] = new R(this.getValueFromSingle(e, u, i.width, i.height, !1), [ `shapeUtils.indicesToOffset${n}`, 'coordinates.offsetToCoords', 'fragcolor.getColorAsFloat', ])), (n = n + '_T'), (t[n] = new R(this.getValueFromSingle(e, u, i.width, i.height, !0), [ `shapeUtils.indicesToOffset${n}`, 'coordinates.offsetToCoords', 'fragcolor.getColorAsFloat', ])); }), t ); } getValueFromSingle(t, e, o, i, u) { let n = `_${t}`; u && (n = n + '_T'); let s = q(this.context.glContext.version); return ` float ${n}(int m[${e}]) { int offset = indicesToOffset${n}(m); vec2 coords = offsetToCoords(offset, ${o}, ${i}); float value = getColorAsFloat(${s.texture2D}(${t}, coords)); return value; } `; } getPackedValueFrom(t, e, o, i, u) { let n = `_${t}_Pack`; u && (n = n + '_T'); let s = q(this.context.glContext.version); return ` vec4 ${n}(int m[${e}]) { int offset = indicesToOffset_${t}(m); vec2 coords = offsetToCoords(offset, ${o}, ${i}); return ${s.texture2D}(${t}, coords); } `; } }); }), po, ep = L(() => { Vt(), (po = class Pn extends pt { constructor(e) { super(e); } getFunctions() { return { ...this.encodeFloat32(), ...this.decodeFloat32() }; } getCustomTypes() { return {}; } encodeFloat32() { return { encode: new R(`highp vec4 encode(highp float f) { return vec4(f, 0.0, 0.0, 0.0); } `), }; } decodeFloat32() { return { decode: new R(`highp float decode(highp vec4 rgba) { return rgba.r; } `), }; } encodeUint8() { let e = Pn.isLittleEndian() ? 'rgba.rgba=rgba.abgr;' : ''; return { encode: new R(` highp vec4 encode(highp float f) { highp float F = abs(f); highp float Sign = step(0.0,-f); highp float Exponent = floor(log2(F)); highp float Mantissa = (exp2(- Exponent) * F); Exponent = floor(log2(F) + 127.0) + floor(log2(Mantissa)); highp vec4 rgba; rgba[0] = 128.0 * Sign + floor(Exponent*exp2(-1.0)); rgba[1] = 128.0 * mod(Exponent,2.0) + mod(floor(Mantissa*128.0),128.0); rgba[2] = floor(mod(floor(Mantissa*exp2(23.0 -8.0)),exp2(8.0))); rgba[3] = floor(exp2(23.0)*mod(Mantissa,exp2(-15.0))); ${e} rgba = rgba / 255.0; // values need to be normalized to [0,1] return rgba; } `), }; } decodeUint8() { let e = Pn.isLittleEndian() ? 'rgba.rgba=rgba.abgr;' : ''; return { decode: new R(` highp float decode(highp vec4 rgba) { rgba = rgba * 255.0; // values need to be de-normalized from [0,1] to [0,255] ${e} highp float Sign = 1.0 - step(128.0,rgba[0])*2.0; highp float Exponent = 2.0 * mod(rgba[0],128.0) + step(128.0,rgba[1]) - 127.0; highp float Mantissa = mod(rgba[1],128.0)*65536.0 + rgba[2]*256.0 +rgba[3] + float(0x800000); highp float Result = Sign * exp2(Exponent) * (Mantissa * exp2(-23.0 )); return Result; } `), }; } static isLittleEndian() { let e = new ArrayBuffer(4), o = new Uint32Array(e), i = new Uint8Array(e); if (((o[0] = 3735928559), i[0] === 239)) return !0; if (i[0] === 222) return !1; throw new Error('unknown endianness'); } }); }), ho, tp = L(() => { Vt(), xe(), (ho = class extends pt { constructor(t) { super(t); } getFunctions() { return { ...this.setFragColor(), ...this.getColorAsFloat() }; } getCustomTypes() { return {}; } setFragColor() { let t = q(this.context.glContext.version); return { setFragColor: new R( ` void setFragColor(float value) { ${t.output} = encode(value); } `, ['encoding.encode'] ), }; } getColorAsFloat() { return { getColorAsFloat: new R( ` float getColorAsFloat(vec4 color) { return decode(color); } `, ['encoding.decode'] ), }; } }); }), mo, rp = L(() => { Vt(), (mo = class wr extends pt { constructor(e) { super(e); } getFunctions() { return { ...this.bcastIndex(), ...this.bcastMatmulIndex(), ...this.offsetToIndices(), ...this.indicesToOffset(), ...this.incrementIndices(), }; } getCustomTypes() { return {}; } bcastIndex() { let e = this.context.outputTextureLayout.shape.length, o = {}; return ( this.context.programInfo.inputNames.forEach((i, u) => { let n = this.context.inputTextureLayouts[u].unpackedShape; if (n.length <= e) { let s = n.length, d = e - s, f = `bcastIndices_${i}`, r = ''; for (let l = 0; l < s; ++l) r += ` realIndices[${l}] = int( mod(float(bcastedIndices[${d + l}]), ${n[l]}.0) ); `; let a = ` void ${f} (int bcastedIndices[${e}], out int realIndices[${s}]) { ${r} } `; o[f] = new R(a); } }), o ); } bcastMatmulIndex() { let e = this.context.outputTextureLayout.shape.length, o = {}; return ( this.context.programInfo.inputNames.forEach((i, u) => { let n = this.context.inputTextureLayouts[u].shape; if (!(n.length < 2 || n.length > e)) { let s = n.length, d = e - s, f = `bcastMatmulIndices_${i}`, r = ''; for (let l = 0; l < s - 2; ++l) r += ` realIndices[${l}] = int( mod(float(bcastedIndices[${d + l}]), ${n[l]}.0) ); `; let a = ` void ${f}(int bcastedIndices[${e}], out int realIndices[${s}]) { ${r} realIndices[${s - 1}] = bcastedIndices[${e - 1}]; realIndices[${s - 2}] = bcastedIndices[${e - 2}]; } `; o[f] = new R(a); } }), o ); } indicesToOffset() { let e = {}; return ( this.context.programInfo.inputNames.forEach((o, i) => { let u = this.context.inputTextureLayouts[i].shape, n = this.context.inputTextureLayouts[i].strides, s = u.length, d = `indicesToOffset_${o}`; (e[d] = new R(wr.indexToOffsetSingle(d, s, n))), (d = `indicesToOffset_${o}_T`), (e[d] = new R(wr.indexToOffsetSingle(d, s, n.slice().reverse()))); }), e ); } static indexToOffsetSingle(e, o, i) { let u = ''; for (let n = o - 1; n >= 0; --n) u += ` offset += indices[${n}] * ${i[n]}; `; return ` int ${e}(int indices[${o}]) { int offset = 0; ${u} return offset; } `; } offsetToIndices() { let e = {}; return ( this.context.programInfo.inputNames.forEach((o, i) => { let u = this.context.inputTextureLayouts[i].shape, n = this.context.inputTextureLayouts[i].strides, s = u.length, d = `offsetToIndices_${o}`; (e[d] = new R(wr.offsetToIndicesSingle(d, s, n))), (d = `offsetToIndices_${o}_T`), (e[d] = new R(wr.offsetToIndicesSingle(d, s, n.slice().reverse()))); }), e ); } static offsetToIndicesSingle(e, o, i) { let u = []; for (let n = 0; n < o - 1; ++n) u.push(` indices[${n}] = offset / ${i[n]};`), u.push(` offset -= indices[${n}] * ${i[n]};`); return ( u.push(` indices[${o - 1}] = offset;`), ` void ${e}(int offset, out int indices[${o}]) { ${u.join('')} } ` ); } incrementIndices() { let e = {}; return ( this.context.programInfo.inputNames.forEach((o, i) => { let u = this.context.inputTextureLayouts[i].shape, n = u.length, s = `incrementIndices_${o}`, d = ''; for (let r = 0; r < n; ++r) d += ` shape[${r}] = ${u[r]};`; let f = ` void ${s}(int axis, out int indices[${n}]) { int shape[${n}]; ${d}; for(int i = ${n} -1 ; i >= 0; --i) { if(i > axis) continue; indices[i] += 1; if(indices[i] < shape[i]) { break; } indices[i] = 0; } } `; e[s] = new R(f); }), e ); } }); }), bo, np = L(() => { Vt(), (bo = class extends pt { constructor(t) { super(t); } getCustomTypes() { return {}; } getFunctions() { return { ...this.binaryVecFunctions(), ...this.copyVec(), ...this.setVecItem(), ...this.getVecItem(), }; } binaryVecFunctions() { let t = this.context.outputTextureLayout.shape.length, e = { add: '+=', sub: '-=', mul: '*=', div: '/=' }, o = {}; for (let i in e) { let u = `${i}Vec`, n = ''; for (let d = 0; d < t; ++d) n += ` dest[${d}] ${e[i]} src[${d}]; `; let s = ` void ${u}(int src[${t}], out int dest[${t}]) { ${n} } `; o[u] = new R(s); } return o; } copyVec() { let t = this.context.outputTextureLayout.shape.length, e = ''; for (let i = 0; i < t; ++i) e += ` dest[${i}] = src[${i}]; `; let o = ` void copyVec(int src[${t}], out int dest[${t}]) { ${e} } `; return { copyVec: new R(o) }; } setVecItem() { let t = this.context.outputTextureLayout.shape.length, e = ` if(index < 0) index =${t} + index; if (index == 0) m[0] = value; `; for (let i = 1; i < t - 1; ++i) e += ` else if (index == ${i}) m[${i}] = value; `; e += ` else m[${t - 1}] = value; `; let o = ` void setVecItem(out int m[${t}], int index, int value) { ${e} } `; return { setVecItem: new R(o) }; } getVecItem() { let t = this.context.outputTextureLayout.shape.length, e = ` if(index < 0) index = ${t} + index; if (index == 0) return m[0]; `; for (let i = 1; i < t - 1; ++i) e += ` else if (index == ${i}) return m[${i}]; `; e += ` else return m[${t - 1}]; `; let o = ` int getVecItem(int m[${t}], int index) { ${e} } `; return { getVecItem: new R(o) }; } }); }), qi, op = L(() => { Qc(), ep(), tp(), rp(), np(), (qi = { encoding: po, fragcolor: ho, vec: bo, shapeUtils: mo, coordinates: co }); }), go, ip = L(() => { Vt(), Jc(), op(), xe(), (go = class { constructor(t, e, o, i) { (this.libs = {}), (this.glslLibRoutineDependencyGraph = {}), (this.context = new eo(t, e, o, i)), Object.keys(qi).forEach((n) => { let s = new qi[n](this.context); this.libs[n] = s; }); let u = this.glslLibRoutineDependencyGraph; for (let n in this.libs) { let s = this.libs[n].getFunctions(); for (let d in s) { let f = n + '.' + d, r; u[f] ? ((r = u[f]), (r.routineBody = s[d].routineBody)) : ((r = new cn(f, s[d].routineBody)), (u[f] = r)); let a = s[d].dependencies; if (a) for (let l = 0; l < a.length; ++l) if (u[a[l]]) r.addDependency(u[a[l]]); else { let p = new cn(a[l]); (u[a[l]] = p), r.addDependency(p); } } } } preprocess() { let t = this.context.programInfo, e = t.shaderSource; return ( this.context.programInfo.hasMain || (e = `${e} ${Ru(this.context.glContext.version, this.context.outputTextureLayout.shape.length)}`), (e = Kc(e)), `${Nu(this.context.glContext.version)} ${this.getUniforms(t.inputNames, t.variables)} ${this.getImports(e)} ${e}` ); } getImports(t) { let e = this.selectGlslLibRoutinesToBeIncluded(t); if (e.length === 0) return ''; let o = ''; for (let i = 0; i < e.length; ++i) if (e[i].routineBody) o += e[i].routineBody + ` `; else throw new Error(`Missing body for the Glsl Library routine: ${e[i].name}`); return o; } selectGlslLibRoutinesToBeIncluded(t) { let e = []; return ( Object.keys(this.glslLibRoutineDependencyGraph).forEach((o) => { let i = o.split('.')[1]; t.indexOf(i) !== -1 && e.push(this.glslLibRoutineDependencyGraph[o]); }), to.returnOrderedNodes(e) ); } getUniforms(t, e) { let o = []; if (t) for (let i of t) o.push(`uniform sampler2D ${i};`); if (e) for (let i of e) o.push(`uniform ${i.type} ${i.name}${i.arrayLength ? `[${i.arrayLength}]` : ''};`); return o.join(` `); } }); }), yo, ap = L(() => { vt(), ut(), ip(), xe(), (yo = class { constructor(t, e, o) { (this.profiler = t), (this.glContext = e), (this.textureLayoutStrategy = o), (this.repo = new Map()), (this.attributesBound = !1); } getArtifact(t) { return this.repo.get(t); } setArtifact(t, e) { this.repo.set(t, e); } run(t, e, o) { this.profiler.event( 'op', `ProgramManager.run ${t.programInfo.name ?? 'unknown kernel'}`, () => { let i = this.glContext.gl, u = t.program; i.useProgram(u); try { this.bindOutput(o), this.attributesBound || this.bindAttributes(t.attribLocations), this.bindUniforms(t.uniformLocations, t.programInfo.variables ?? [], e); } catch (n) { throw (ce.error('ProgramManager', t.programInfo.shaderSource), n); } this.profiler.event('backend', 'GlContext.draw()', () => { this.glContext.draw(); }); }, this.glContext ); } dispose() { this.vertexShader && this.glContext.deleteShader(this.vertexShader), this.repo.forEach((t) => this.glContext.deleteProgram(t.program)); } build(t, e, o) { return this.profiler.event('backend', 'ProgramManager.build', () => { let i = new go(this.glContext, t, e, o), u = i.preprocess(), n = this.compile(u); return { programInfo: t, program: n, uniformLocations: this.getUniformLocations( n, i.context.programInfo.inputNames, i.context.programInfo.variables ), attribLocations: this.getAttribLocations(n), }; }); } compile(t) { if (!this.vertexShader) { ce.verbose('ProrgramManager', 'Compiling and caching Vertex shader for the first time'); let i = Bu(this.glContext.version); this.vertexShader = this.glContext.compileShader(i, this.glContext.gl.VERTEX_SHADER); } Z.debug && ce.verbose( 'ProrgramManager', `FragShader: ${t} ` ); let e = this.glContext.compileShader(t, this.glContext.gl.FRAGMENT_SHADER), o = this.glContext.createProgram(this.vertexShader, e); return this.glContext.deleteShader(e), o; } bindOutput(t) { let e = t.width, o = t.height; ce.verbose( 'ProrgramManager', `Binding output texture to Framebuffer: w/h=${e}/${o}, shape=${t.shape}, type=${t.tensor.type}` ), this.glContext.attachFramebuffer(t.texture, e, o); } bindAttributes(t) { let e = t.position, o = t.textureCoord; this.glContext.setVertexAttributes(e, o), (this.attributesBound = !0); } bindUniforms(t, e, o) { let i = this.glContext.gl, u = 0; for (let { name: n, type: s, location: d, arrayLength: f } of t) { let r = e.find((a) => a.name === n)?.data; if (s !== 'sampler2D' && !r) throw new Error(`variable '${n}' does not have data defined in program info`); switch (s) { case 'sampler2D': this.bindTexture(o[u], d, u), u++; break; case 'float': f ? i.uniform1fv(d, r) : i.uniform1f(d, r); break; case 'int': f ? i.uniform1iv(d, r) : i.uniform1i(d, r); break; default: throw new Error(`Uniform not implemented: ${s}`); } } } bindTexture(t, e, o) { this.glContext.bindTextureToUniform(t.texture, o, e); } getAttribLocations(t) { return { position: this.getAttribLocation(t, 'position'), textureCoord: this.getAttribLocation(t, 'textureCoord'), }; } getUniformLocations(t, e, o) { let i = []; if (e) for (let u of e) i.push({ name: u, type: 'sampler2D', location: this.getUniformLocation(t, u) }); if (o) for (let u of o) i.push({ ...u, location: this.getUniformLocation(t, u.name) }); return i; } getUniformLocation(t, e) { let o = this.glContext.gl.getUniformLocation(t, e); if (o === null) throw new Error(`Uniform ${e} not found.`); return o; } getAttribLocation(t, e) { return this.glContext.gl.getAttribLocation(t, e); } }); }), To, sp = L(() => { ut(), ln(), (To = class { constructor(t, e, o, i) { (this.glContext = t), (this.layoutStrategy = e), (this.profiler = o), (this.config = i), (this.pendingRead = new Map()), i.reuseTextures && ((this.inUseTextures = new Map()), (this.idleTextures = new Map()), (this.textureLookup = new Map())); } createTextureFromLayout(t, e, o, i) { let u = this.toEncoderType(t), n = this.glContext.getEncoder(u, e.channels || 1, i); if (e.isPacked && i === 1) throw new Error('not implemented'); let s = e.width, d = e.height, f, r; if (this.config.reuseTextures) { (f = `${s}x${d}_${n.format}_${n.internalFormat}_${n.textureType}`), (r = this.inUseTextures.get(f)), r || ((r = []), this.inUseTextures.set(f, r)); let l = this.idleTextures.get(f); if (l && l.length > 0) { let p = l.pop(); return ( r.push(p), i === 1 && this.glContext.updateTexture(p, s, d, n, this.toTextureData(t, o)), p ); } } ce.verbose('TextureManager', `Creating new texture of size ${e.width}x${e.height}`); let a = this.glContext.allocateTexture(s, d, n, this.toTextureData(t, o)); return this.config.reuseTextures && (r.push(a), this.textureLookup.set(a, f)), a; } readTexture(t, e, o) { return ( o || (o = 1), this.profiler.event('backend', 'TextureManager.readTexture', () => { let i = t.shape.reduce((n, s) => n * s) * o, u = this.glContext.readTexture( t.texture, t.width, t.height, i, this.toEncoderType(e), o ); return this.toTensorData(e, u); }) ); } async readTextureAsync(t, e, o) { let i = t.tensor.dataId; if ((o || (o = 1), this.pendingRead.has(i))) { let u = this.pendingRead.get(i); return new Promise((n) => u?.push(n)); } return this.profiler.event('backend', 'TextureManager.readTextureAsync', async () => { this.pendingRead.set(i, []); let u = t.shape.reduce((f, r) => f * r) * o; await this.glContext.createAndWaitForFence(); let n = this.glContext.readTexture(t.texture, t.width, t.height, u, this.toEncoderType(e), o), s = this.toTensorData(e, n), d = this.pendingRead.get(i); return this.pendingRead.delete(i), d?.forEach((f) => f(s)), s; }); } readUint8TextureAsFloat(t) { return this.profiler.event('backend', 'TextureManager.readUint8TextureAsFloat', () => { let e = t.shape.reduce((i, u) => i * u), o = this.glContext.readTexture(t.texture, t.width, t.height, e * 4, 'byte', 4); return new Float32Array(o.buffer, o.byteOffset, e); }); } releaseTexture(t, e) { let o; if (this.config.reuseTextures && ((o = this.textureLookup.get(t.texture)), o)) { e && this.textureLookup.delete(o); let i = this.inUseTextures.get(o); if (i) { let u = i.indexOf(t.texture); if (u !== -1) { i.splice(u, 1); let n = this.idleTextures.get(o); n || ((n = []), this.idleTextures.set(o, n)), n.push(t.texture); } } } (!o || e) && (ce.verbose('TextureManager', `Deleting texture of size ${t.width}x${t.height}`), this.glContext.deleteTexture(t.texture)); } toTensorData(t, e) { switch (t) { case 'int16': return e instanceof Int16Array ? e : Int16Array.from(e); case 'int32': return e instanceof Int32Array ? e : Int32Array.from(e); case 'int8': return e instanceof Int8Array ? e : Int8Array.from(e); case 'uint16': return e instanceof Uint16Array ? e : Uint16Array.from(e); case 'uint32': return e instanceof Uint32Array ? e : Uint32Array.from(e); case 'uint8': case 'bool': return e instanceof Uint8Array ? e : Uint8Array.from(e); case 'float32': return e instanceof Float32Array ? e : Float32Array.from(e); case 'float64': return e instanceof Float64Array ? e : Float64Array.from(e); default: throw new Error(`TensorData type ${t} is not supported`); } } toTextureData(t, e) { if (e) return e instanceof Float32Array ? e : new Float32Array(e); } toEncoderType(t) { return 'float'; } clearActiveTextures() { this.glContext.clearActiveTextures(); } }); }), xo, up = L(() => { ut(), ws(), Qu(), Yc(), ap(), Hi(), sp(), (xo = class { constructor(t, e) { (this.backend = t), (this.context = e), (this.layoutStrategy = new fo(t.glContext.maxTextureSize)), (this.programManager = new yo(this.context.profiler, t.glContext, this.layoutStrategy)), (this.textureManager = new To(t.glContext, this.layoutStrategy, this.context.profiler, { reuseTextures: t.textureCacheMode === 'full', })), (this.packedTextureDataCache = new Map()), (this.unpackedTextureDataCache = new Map()), (this.pack = t.pack), (this.pack2unpackMap = new Map()), (this.unpack2packMap = new Map()); } createInferenceHandler() { return new Qn(this); } onGraphInitialized(t) { let e = t .getValues() .filter((o) => o.from === -1 && o.tensor) .map((o) => o.tensor.dataId); this.initializers = new Set(e); } isInitializer(t) { return this.initializers ? this.initializers.has(t) : !1; } addInitializer(t) { this.initializers.add(t); } getTextureData(t, e) { return e ? this.packedTextureDataCache.get(t) : this.unpackedTextureDataCache.get(t); } setTextureData(t, e, o = !1) { ce.verbose('WebGLSessionHandler', 'Storing Texture data in cache'), o ? this.packedTextureDataCache.set(t, e) : this.unpackedTextureDataCache.set(t, e); } dispose() { this.programManager.dispose(), this.textureManager.clearActiveTextures(), this.packedTextureDataCache.forEach((t) => this.textureManager.releaseTexture(t, !0)), (this.packedTextureDataCache = new Map()), this.unpackedTextureDataCache.forEach((t) => this.textureManager.releaseTexture(t, !0)), (this.unpackedTextureDataCache = new Map()); } resolve(t, e, o) { let i = vs(t, e, jc); return { impl: i.opImpl, context: i.opInit ? i.opInit(t, o) : t }; } }); }); function Hb(t) { let e = 0; for (; e < t.length && t[e](); ++e); return e - 1; } var hn, lp = L(() => { vt(), ln(), ln(), Ft(), (hn = class { constructor(t, e) { (this.frameBufferBound = !1), (this.itemsToPoll = []), (this.gl = t), (this.version = e), this.getExtensions(), (this.vertexbuffer = this.createVertexbuffer()), (this.framebuffer = this.createFramebuffer()), this.queryVitalParameters(); } allocateTexture(t, e, o, i) { let u = this.gl, n = u.createTexture(); u.bindTexture(u.TEXTURE_2D, n), u.texParameteri(u.TEXTURE_2D, u.TEXTURE_MIN_FILTER, u.NEAREST), u.texParameteri(u.TEXTURE_2D, u.TEXTURE_MAG_FILTER, u.NEAREST), u.texParameteri(u.TEXTURE_2D, u.TEXTURE_WRAP_S, u.CLAMP_TO_EDGE), u.texParameteri(u.TEXTURE_2D, u.TEXTURE_WRAP_T, u.CLAMP_TO_EDGE); let s = i ? o.encode(i, t * e) : null; return ( u.texImage2D(u.TEXTURE_2D, 0, o.internalFormat, t, e, 0, o.format, o.textureType, s), this.checkError(), n ); } updateTexture(t, e, o, i, u) { let n = this.gl; n.bindTexture(n.TEXTURE_2D, t); let s = i.encode(u, e * o); n.texSubImage2D(n.TEXTURE_2D, 0, 0, 0, e, o, i.format, i.textureType, s), this.checkError(); } attachFramebuffer(t, e, o) { let i = this.gl; i.bindTexture(i.TEXTURE_2D, t), i.bindFramebuffer(i.FRAMEBUFFER, this.framebuffer), i.framebufferTexture2D(i.FRAMEBUFFER, i.COLOR_ATTACHMENT0, i.TEXTURE_2D, t, 0), this.checkError(), i.viewport(0, 0, e, o), i.scissor(0, 0, e, o); } readTexture(t, e, o, i, u, n) { let s = this.gl; n || (n = 1), this.frameBufferBound || this.attachFramebuffer(t, e, o); let d = this.getEncoder(u, n), f = d.allocate(e * o); return ( s.bindTexture(s.TEXTURE_2D, t), s.framebufferTexture2D(s.FRAMEBUFFER, s.COLOR_ATTACHMENT0, s.TEXTURE_2D, t, 0), s.readPixels(0, 0, e, o, s.RGBA, d.textureType, f), this.checkError(), d.decode(f, i) ); } isFramebufferReady() { return !0; } getActiveTexture() { let t = this.gl; return `TEXTURE${t.getParameter(this.gl.ACTIVE_TEXTURE) - t.TEXTURE0}`; } getTextureBinding() { return this.gl.getParameter(this.gl.TEXTURE_BINDING_2D); } getFramebufferBinding() { return this.gl.getParameter(this.gl.FRAMEBUFFER_BINDING); } setVertexAttributes(t, e) { let o = this.gl; o.vertexAttribPointer(t, 3, o.FLOAT, !1, 20, 0), o.enableVertexAttribArray(t), e !== -1 && (o.vertexAttribPointer(e, 2, o.FLOAT, !1, 20, 12), o.enableVertexAttribArray(e)), this.checkError(); } createProgram(t, e) { let o = this.gl, i = o.createProgram(); return o.attachShader(i, t), o.attachShader(i, e), o.linkProgram(i), i; } compileShader(t, e) { let o = this.gl, i = o.createShader(e); if (!i) throw new Error(`createShader() returned null with type ${e}`); if ((o.shaderSource(i, t), o.compileShader(i), o.getShaderParameter(i, o.COMPILE_STATUS) === !1)) throw new Error(`Failed to compile shader: ${o.getShaderInfoLog(i)} Shader source: ${t}`); return i; } deleteShader(t) { this.gl.deleteShader(t); } bindTextureToUniform(t, e, o) { let i = this.gl; i.activeTexture(i.TEXTURE0 + e), this.checkError(), i.bindTexture(i.TEXTURE_2D, t), this.checkError(), i.uniform1i(o, e), this.checkError(); } draw() { this.gl.drawArrays(this.gl.TRIANGLE_STRIP, 0, 4), this.checkError(); } checkError() { if (Z.debug) { let t = this.gl, e = t.getError(), o = ''; switch (e) { case t.NO_ERROR: return; case t.INVALID_ENUM: o = 'INVALID_ENUM'; break; case t.INVALID_VALUE: o = 'INVALID_VALUE'; break; case t.INVALID_OPERATION: o = 'INVALID_OPERATION'; break; case t.INVALID_FRAMEBUFFER_OPERATION: o = 'INVALID_FRAMEBUFFER_OPERATION'; break; case t.OUT_OF_MEMORY: o = 'OUT_OF_MEMORY'; break; case t.CONTEXT_LOST_WEBGL: o = 'CONTEXT_LOST_WEBGL'; break; default: o = `Unknown WebGL Error: ${e.toString(16)}`; } throw new Error(o); } } deleteTexture(t) { this.gl.deleteTexture(t); } deleteProgram(t) { this.gl.deleteProgram(t); } getEncoder(t, e, o = 0) { if (this.version === 2) return new Jn(this.gl, e); switch (t) { case 'float': return o === 1 || this.isRenderFloat32Supported ? new un(this.gl, e) : new un(this.gl, e, this.textureHalfFloatExtension.HALF_FLOAT_OES); case 'int': throw new Error('not implemented'); case 'byte': return new Zn(this.gl, e); default: throw new Error(`Invalid dataType: ${t}`); } } clearActiveTextures() { let t = this.gl; for (let e = 0; e < this.maxTextureImageUnits; ++e) t.activeTexture(t.TEXTURE0 + e), t.bindTexture(t.TEXTURE_2D, null); } dispose() { if (this.disposed) return; let t = this.gl; t.bindFramebuffer(t.FRAMEBUFFER, null), t.deleteFramebuffer(this.framebuffer), t.bindBuffer(t.ARRAY_BUFFER, null), t.deleteBuffer(this.vertexbuffer), t.bindBuffer(t.ELEMENT_ARRAY_BUFFER, null), t.finish(), (this.disposed = !0); } createDefaultGeometry() { return new Float32Array([-1, 1, 0, 0, 1, -1, -1, 0, 0, 0, 1, 1, 0, 1, 1, 1, -1, 0, 1, 0]); } createVertexbuffer() { let t = this.gl, e = t.createBuffer(); if (!e) throw new Error('createBuffer() returned null'); let o = this.createDefaultGeometry(); return ( t.bindBuffer(t.ARRAY_BUFFER, e), t.bufferData(t.ARRAY_BUFFER, o, t.STATIC_DRAW), this.checkError(), e ); } createFramebuffer() { let t = this.gl.createFramebuffer(); if (!t) throw new Error('createFramebuffer returned null'); return t; } queryVitalParameters() { let t = this.gl; if ( ((this.isFloatTextureAttachableToFrameBuffer = this.checkFloatTextureAttachableToFrameBuffer()), (this.isRenderFloat32Supported = this.checkRenderFloat32()), (this.isFloat32DownloadSupported = this.checkFloat32Download()), this.version === 1 && !this.textureHalfFloatExtension && !this.isRenderFloat32Supported) ) throw new Error('both float32 and float16 TextureType are not supported'); (this.isBlendSupported = !this.isRenderFloat32Supported || this.checkFloat32Blend()), (this.maxTextureSize = t.getParameter(t.MAX_TEXTURE_SIZE)), (this.maxTextureImageUnits = t.getParameter(t.MAX_TEXTURE_IMAGE_UNITS)), this.version; } getExtensions() { this.version === 2 ? ((this.colorBufferFloatExtension = this.gl.getExtension('EXT_color_buffer_float')), (this.disjointTimerQueryWebgl2Extension = this.gl.getExtension( 'EXT_disjoint_timer_query_webgl2' ))) : ((this.textureFloatExtension = this.gl.getExtension('OES_texture_float')), (this.textureHalfFloatExtension = this.gl.getExtension('OES_texture_half_float'))); } checkFloatTextureAttachableToFrameBuffer() { let t = this.gl, e = t.createTexture(); t.bindTexture(t.TEXTURE_2D, e); let o = this.version === 2 ? t.RGBA32F : t.RGBA; t.texImage2D(t.TEXTURE_2D, 0, o, 1, 1, 0, t.RGBA, t.FLOAT, null); let i = t.createFramebuffer(); t.bindFramebuffer(t.FRAMEBUFFER, i), t.framebufferTexture2D(t.FRAMEBUFFER, t.COLOR_ATTACHMENT0, t.TEXTURE_2D, e, 0); let u = t.checkFramebufferStatus(t.FRAMEBUFFER) === t.FRAMEBUFFER_COMPLETE; return ( t.bindTexture(t.TEXTURE_2D, null), t.bindFramebuffer(t.FRAMEBUFFER, null), t.deleteTexture(e), t.deleteFramebuffer(i), u ); } checkRenderFloat32() { if (this.version === 2) { if (!this.colorBufferFloatExtension) return !1; } else if (!this.textureFloatExtension) return !1; return this.isFloatTextureAttachableToFrameBuffer; } checkFloat32Download() { if (this.version === 2) { if (!this.colorBufferFloatExtension) return !1; } else if (!this.textureFloatExtension || !this.gl.getExtension('WEBGL_color_buffer_float')) return !1; return this.isFloatTextureAttachableToFrameBuffer; } checkFloat32Blend() { let t = this.gl, e, o, i, u, n; try { (e = t.createTexture()), (o = t.createFramebuffer()), t.bindTexture(t.TEXTURE_2D, e); let s = this.version === 2 ? t.RGBA32F : t.RGBA; return ( t.texImage2D(t.TEXTURE_2D, 0, s, 1, 1, 0, t.RGBA, t.FLOAT, null), t.bindFramebuffer(t.FRAMEBUFFER, o), t.framebufferTexture2D(t.FRAMEBUFFER, t.COLOR_ATTACHMENT0, t.TEXTURE_2D, e, 0), t.enable(t.BLEND), (i = t.createShader(t.VERTEX_SHADER)), !i || (t.shaderSource(i, 'void main(){}'), t.compileShader(i), (u = t.createShader(t.FRAGMENT_SHADER)), !u) || (t.shaderSource(u, 'precision highp float;void main(){gl_FragColor=vec4(0.5);}'), t.compileShader(u), (n = t.createProgram()), !n) ? !1 : (t.attachShader(n, i), t.attachShader(n, u), t.linkProgram(n), t.useProgram(n), t.drawArrays(t.POINTS, 0, 1), t.getError() === t.NO_ERROR) ); } finally { t.disable(t.BLEND), n && t.deleteProgram(n), i && t.deleteShader(i), u && t.deleteShader(u), o && (t.bindFramebuffer(t.FRAMEBUFFER, null), t.deleteFramebuffer(o)), e && (t.bindTexture(t.TEXTURE_2D, null), t.deleteTexture(e)); } } beginTimer() { if (this.version === 2 && this.disjointTimerQueryWebgl2Extension) { let t = this.gl, e = this.disjointTimerQueryWebgl2Extension, o = t.createQuery(); return t.beginQuery(e.TIME_ELAPSED_EXT, o), o; } else throw new Error('WebGL1 profiling currently not supported.'); } endTimer() { if (this.version === 2 && this.disjointTimerQueryWebgl2Extension) { let t = this.gl, e = this.disjointTimerQueryWebgl2Extension; t.endQuery(e.TIME_ELAPSED_EXT); return; } else throw new Error('WebGL1 profiling currently not supported'); } isTimerResultAvailable(t) { let e = !1, o = !1; if (this.version === 2 && this.disjointTimerQueryWebgl2Extension) { let i = this.gl, u = this.disjointTimerQueryWebgl2Extension; (e = i.getQueryParameter(t, i.QUERY_RESULT_AVAILABLE)), (o = i.getParameter(u.GPU_DISJOINT_EXT)); } else throw new Error('WebGL1 profiling currently not supported'); return e && !o; } getTimerResult(t) { let e = 0; if (this.version === 2) { let o = this.gl; (e = o.getQueryParameter(t, o.QUERY_RESULT)), o.deleteQuery(t); } else throw new Error('WebGL1 profiling currently not supported'); return e / 1e6; } async waitForQueryAndGetTime(t) { return await gi(() => this.isTimerResultAvailable(t)), this.getTimerResult(t); } async createAndWaitForFence() { let t = this.createFence(this.gl); return this.pollFence(t); } createFence(t) { let e, o = t, i = o.fenceSync(o.SYNC_GPU_COMMANDS_COMPLETE, 0); return ( t.flush(), i === null ? (e = () => !0) : (e = () => { let u = o.clientWaitSync(i, 0, 0); return u === o.ALREADY_SIGNALED || u === o.CONDITION_SATISFIED; }), { query: i, isFencePassed: e } ); } async pollFence(t) { return new Promise((e) => { this.addItemToPoll( () => t.isFencePassed(), () => e() ); }); } pollItems() { let t = Hb(this.itemsToPoll.map((e) => e.isDoneFn)); for (let e = 0; e <= t; ++e) { let { resolveFn: o } = this.itemsToPoll[e]; o(); } this.itemsToPoll = this.itemsToPoll.slice(t + 1); } async addItemToPoll(t, e) { this.itemsToPoll.push({ isDoneFn: t, resolveFn: e }), !(this.itemsToPoll.length > 1) && (await gi(() => (this.pollItems(), this.itemsToPoll.length === 0))); } }); }); function ji(t) { let e; if ( ((!t || t === 'webgl2') && 'webgl2' in Ur ? (e = Ur.webgl2) : (!t || t === 'webgl') && 'webgl' in Ur && (e = Ur.webgl), !e) ) try { let i = jb(); e = fp(i, t); } catch { let i = qb(); e = fp(i, t); } t = t || e.version === 1 ? 'webgl' : 'webgl2'; let o = e.gl; return ( (Ur[t] = e), o.isContextLost() ? (delete Ur[t], ji(t)) : (o.disable(o.DEPTH_TEST), o.disable(o.STENCIL_TEST), o.disable(o.BLEND), o.disable(o.DITHER), o.disable(o.POLYGON_OFFSET_FILL), o.disable(o.SAMPLE_COVERAGE), o.enable(o.SCISSOR_TEST), o.enable(o.CULL_FACE), o.cullFace(o.BACK), e) ); } function fp(t, e) { let o = { alpha: !1, depth: !1, antialias: !1, stencil: !1, preserveDrawingBuffer: !1, premultipliedAlpha: !1, failIfMajorPerformanceCaveat: !1, }, i, u = o; if ((!e || e === 'webgl2') && ((i = t.getContext('webgl2', u)), i)) try { return new hn(i, 2); } catch (n) { ce.warning('GlContextFactory', `failed to create WebGLContext using contextId 'webgl2'. Error: ${n}`); } if ((!e || e === 'webgl') && ((i = t.getContext('webgl', u) || t.getContext('experimental-webgl', u)), i)) try { return new hn(i, 1); } catch (n) { ce.warning( 'GlContextFactory', `failed to create WebGLContext using contextId 'webgl' or 'experimental-webgl'. Error: ${n}` ); } throw new Error('WebGL is not supported'); } function qb() { if (typeof document > 'u') throw new TypeError('failed to create canvas: document is not supported'); let t = document.createElement('canvas'); return (t.width = 1), (t.height = 1), t; } function jb() { if (typeof OffscreenCanvas > 'u') throw new TypeError('failed to create offscreen canvas: OffscreenCanvas is not supported'); return new OffscreenCanvas(1, 1); } var Ur, cp = L(() => { ut(), lp(), (Ur = {}); }), vo, pp = L(() => { vt(), ut(), up(), cp(), (vo = class { get contextId() { return Z.webgl.contextId; } set contextId(t) { Z.webgl.contextId = t; } get matmulMaxBatchSize() { return Z.webgl.matmulMaxBatchSize; } set matmulMaxBatchSize(t) { Z.webgl.matmulMaxBatchSize = t; } get textureCacheMode() { return Z.webgl.textureCacheMode; } set textureCacheMode(t) { Z.webgl.textureCacheMode = t; } get pack() { return Z.webgl.pack; } set pack(t) { Z.webgl.pack = t; } get async() { return Z.webgl.async; } set async(t) { Z.webgl.async = t; } initialize() { try { return ( (this.glContext = ji(this.contextId)), typeof this.matmulMaxBatchSize != 'number' && (this.matmulMaxBatchSize = 16), typeof this.textureCacheMode != 'string' && (this.textureCacheMode = 'full'), typeof this.pack != 'boolean' && (this.pack = !1), typeof this.async != 'boolean' && (this.async = !1), ce.setWithEnv(Z), Z.webgl.context || Object.defineProperty(Z.webgl, 'context', { value: this.glContext.gl }), ce.verbose( 'WebGLBackend', `Created WebGLContext: ${typeof this.glContext} with matmulMaxBatchSize: ${ this.matmulMaxBatchSize }; textureCacheMode: ${this.textureCacheMode}; pack: ${this.pack}; async: ${ this.async }.` ), !0 ); } catch (t) { return ce.warning('WebGLBackend', `Unable to initialize WebGLBackend. ${t}`), !1; } } createSessionHandler(t) { return new xo(this, t); } dispose() { this.glContext.dispose(); } }); }); async function Yi(t) { if (t) { let e = typeof t == 'string' ? [t] : t; for (let o of e) { let i = dp.get(o); if (i) return i; let u = await Xb(o); if (u) return u; } } else return Yi(['webgl']); throw new Error('no available backend to use'); } async function Xb(t) { let e = Yb; if (typeof e[t] < 'u' && Kb(e[t])) { let o = e[t], i = o.initialize(); if ((typeof i == 'object' && 'then' in i && (i = await i), i)) return dp.set(t, o), o; } } function Kb(t) { let e = t; return ( 'initialize' in e && typeof e.initialize == 'function' && 'createSessionHandler' in e && typeof e.createSessionHandler == 'function' && 'dispose' in e && typeof e.dispose == 'function' ); } var dp, Yb, hp = L(() => { pp(), (dp = new Map()), (Yb = { webgl: new vo() }); }), Xi, wo, mp = L(() => { ut(), (Xi = class { constructor(t, e) { (this.op = t), (this.node = e); } }), (wo = class { constructor(t, e, o) { (this.graph = t), (this.profiler = o), this.initialize(e); } initialize(t) { this.profiler.event('session', 'ExecutionPlan.initialize', () => { let e = this.graph.getNodes(); if (e.length !== t.length) throw new Error('The size of nodes and OPs do not match.'); (this._ops = t.map((o, i) => new Xi(o, e[i]))), this.reset(), (this._starter = []), this._ops.forEach((o, i) => { let u = !0; for (let n of o.node.inputs) if (!this._values[n] && this.graph.getInputIndices().indexOf(n) === -1) { u = !1; break; } u && this._starter.push(i); }); }); } reset() { this._values = this.graph.getValues().map((t) => t.tensor); } async execute(t, e) { return this.profiler.event('session', 'ExecutionPlan.execute', async () => { this.reset(); let o = t.createInferenceHandler(), i = this.graph.getInputIndices(); if (e.length !== i.length) throw new Error( `number of input tensors don't match the number of inputs to the model: actual: ${e.length} expected: ${i.length}` ); e.forEach((r, a) => { let l = i[a]; this._values[l] = r; }); let u = this._starter.slice(0), n = this.graph.getValues(), s = this.graph.getNodes(), d = 0; for (; d < u.length; ) { let r = u[d++], a = this._ops[r], l = a.node.inputs.map((T) => this._values[T]); if (l.indexOf(void 0) !== -1) throw new Error(`unresolved input detected: op: ${a.node}`); let p = l; ce.verbose( 'ExecPlan', `Runing op:${a.node.name} (${p .map((T, v) => `'${a.node.inputs[v]}': ${T.type}[${T.dims.join(',')}]`) .join(', ')})` ); let m = await this.profiler.event('node', a.node.name, async () => a.op.impl(o, p, a.op.context) ); if (m.length !== a.node.outputs.length) throw new Error('the size of output does not match model definition.'); m.forEach((T, v) => { let S = a.node.outputs[v]; if (this._values[S]) throw new Error(`output [${S}] already has value: op:${a.node.name}`); this._values[S] = T; }); let y = new Set(); m.forEach((T, v) => { let S = a.node.outputs[v]; for (let E of n[S].to) { let A = s[E], F = !0; for (let B of A.inputs) if (!this._values[B]) { F = !1; break; } F && y.add(E); } }), u.push(...y); } let f = []; for (let r = 0; r < this.graph.getOutputIndices().length; r++) { let a = this.graph.getOutputIndices()[r], l = this._values[a]; if (l === void 0) throw new Error(`required output [${a}] does not have value`); a === 0 ? await l.getData() : l.data, f.push(l); } return ce.verbose('ExecPlan', 'disposing of inferenceHandler'), o.dispose(), f; }); } }); }), oe, mt, mn, bp = L(() => { tn(), (oe = Er($r())), mr(), fe(), (mt = W.experimental.fbs), (mn = class vr { constructor(e) { if (((this._attributes = new Map()), e != null)) { for (let o of e) o instanceof oe.onnx.AttributeProto ? this._attributes.set(o.name, [vr.getValue(o), vr.getType(o)]) : o instanceof mt.Attribute && this._attributes.set(o.name(), [vr.getValue(o), vr.getType(o)]); if (this._attributes.size < e.length) throw new Error('duplicated attribute names'); } } set(e, o, i) { this._attributes.set(e, [i, o]); } delete(e) { this._attributes.delete(e); } getFloat(e, o) { return this.get(e, 'float', o); } getInt(e, o) { return this.get(e, 'int', o); } getString(e, o) { return this.get(e, 'string', o); } getTensor(e, o) { return this.get(e, 'tensor', o); } getFloats(e, o) { return this.get(e, 'floats', o); } getInts(e, o) { return this.get(e, 'ints', o); } getStrings(e, o) { return this.get(e, 'strings', o); } getTensors(e, o) { return this.get(e, 'tensors', o); } get(e, o, i) { let u = this._attributes.get(e); if (u === void 0) { if (i !== void 0) return i; throw new Error(`required attribute not found: ${e}`); } if (u[1] !== o) throw new Error(`type mismatch: expected ${o} but got ${u[1]}`); return u[0]; } static getType(e) { let o = e instanceof oe.onnx.AttributeProto ? e.type : e.type(); switch (o) { case oe.onnx.AttributeProto.AttributeType.FLOAT: return 'float'; case oe.onnx.AttributeProto.AttributeType.INT: return 'int'; case oe.onnx.AttributeProto.AttributeType.STRING: return 'string'; case oe.onnx.AttributeProto.AttributeType.TENSOR: return 'tensor'; case oe.onnx.AttributeProto.AttributeType.FLOATS: return 'floats'; case oe.onnx.AttributeProto.AttributeType.INTS: return 'ints'; case oe.onnx.AttributeProto.AttributeType.STRINGS: return 'strings'; case oe.onnx.AttributeProto.AttributeType.TENSORS: return 'tensors'; default: throw new Error( `attribute type is not supported yet: ${oe.onnx.AttributeProto.AttributeType[o]}` ); } } static getValue(e) { let o = e instanceof oe.onnx.AttributeProto ? e.type : e.type(); if ( o === oe.onnx.AttributeProto.AttributeType.GRAPH || o === oe.onnx.AttributeProto.AttributeType.GRAPHS ) throw new Error('graph attribute is not supported yet'); let i = this.getValueNoCheck(e); if (o === oe.onnx.AttributeProto.AttributeType.INT && nt.isLong(i)) return nt.longToNumber(i); if (o === oe.onnx.AttributeProto.AttributeType.INTS) { let u = i, n = new Array(u.length); for (let s = 0; s < u.length; s++) { let d = u[s]; n[s] = nt.longToNumber(d); } return n; } if (o === oe.onnx.AttributeProto.AttributeType.TENSOR) return e instanceof oe.onnx.AttributeProto ? Fe.fromProto(i) : Fe.fromOrtTensor(i); if (o === oe.onnx.AttributeProto.AttributeType.TENSORS) { if (e instanceof oe.onnx.AttributeProto) return i.map((u) => Fe.fromProto(u)); if (e instanceof mt.Attribute) return i.map((u) => Fe.fromOrtTensor(u)); } return o === oe.onnx.AttributeProto.AttributeType.STRING && e instanceof oe.onnx.AttributeProto ? sn(i) : o === oe.onnx.AttributeProto.AttributeType.STRINGS && e instanceof oe.onnx.AttributeProto ? i.map(sn) : i; } static getValueNoCheck(e) { return e instanceof oe.onnx.AttributeProto ? this.getValueNoCheckFromOnnxFormat(e) : this.getValueNoCheckFromOrtFormat(e); } static getValueNoCheckFromOnnxFormat(e) { switch (e.type) { case oe.onnx.AttributeProto.AttributeType.FLOAT: return e.f; case oe.onnx.AttributeProto.AttributeType.INT: return e.i; case oe.onnx.AttributeProto.AttributeType.STRING: return e.s; case oe.onnx.AttributeProto.AttributeType.TENSOR: return e.t; case oe.onnx.AttributeProto.AttributeType.GRAPH: return e.g; case oe.onnx.AttributeProto.AttributeType.FLOATS: return e.floats; case oe.onnx.AttributeProto.AttributeType.INTS: return e.ints; case oe.onnx.AttributeProto.AttributeType.STRINGS: return e.strings; case oe.onnx.AttributeProto.AttributeType.TENSORS: return e.tensors; case oe.onnx.AttributeProto.AttributeType.GRAPHS: return e.graphs; default: throw new Error( `unsupported attribute type: ${oe.onnx.AttributeProto.AttributeType[e.type]}` ); } } static getValueNoCheckFromOrtFormat(e) { switch (e.type()) { case mt.AttributeType.FLOAT: return e.f(); case mt.AttributeType.INT: return e.i(); case mt.AttributeType.STRING: return e.s(); case mt.AttributeType.TENSOR: return e.t(); case mt.AttributeType.GRAPH: return e.g(); case mt.AttributeType.FLOATS: return e.floatsArray(); case mt.AttributeType.INTS: { let o = []; for (let i = 0; i < e.intsLength(); i++) o.push(e.ints(i)); return o; } case mt.AttributeType.STRINGS: { let o = []; for (let i = 0; i < e.stringsLength(); i++) o.push(e.strings(i)); return o; } case mt.AttributeType.TENSORS: { let o = []; for (let i = 0; i < e.tensorsLength(); i++) o.push(e.tensors(i)); return o; } default: throw new Error(`unsupported attribute type: ${mt.AttributeType[e.type()]}`); } } }); }), Ji, _o, Zi, kt, Oo, Ki, gp = L(() => { bp(), tn(), (Ji = Er($r())), mr(), fe(), (_o = W.experimental.fbs), (Zi = { from: (t, e) => new Ki(t, e) }), (kt = class { constructor(t) { (this._from = void 0), (this._to = []), (this.tensor = void 0), (this.type = void 0), t && (this.type = Ve.tensorValueTypeFromProto(t.type.tensorType)); } get from() { return this._from; } get to() { return this._to; } }), (Oo = class { constructor(t, e) { t instanceof Ji.onnx.NodeProto ? ((this.name = t.name), (this.opType = t.opType), (this.attributes = new mn(t.attribute))) : t instanceof _o.Node && ((this.name = e ?? t.name()), (this.opType = t.opType()), (this.attributes = new mn(Ve.tensorAttributesFromORTFormat(t)))), (this.inputs = []), (this.outputs = []), (this.executeNode = !0); } }), (Ki = class { constructor(t, e) { if (!t) throw new TypeError('graph is empty'); this.buildGraph(t), this.transformGraph(e), this.checkIsAcyclic(); } getInputIndices() { return this._allInputIndices; } getInputNames() { return this._allInputNames; } getOutputIndices() { return this._allOutputIndices; } getOutputNames() { return this._allOutputNames; } getValues() { return this._allData; } getNodes() { return this._nodes; } buildGraph(t) { if (t instanceof Ji.onnx.GraphProto) this.buildGraphFromOnnxFormat(t); else if (t instanceof _o.Graph) this.buildGraphFromOrtFormat(t); else throw new TypeError('Graph type is not supported.'); } buildGraphFromOnnxFormat(t) { let e = new Map(); (this._allData = []), (this._allInputIndices = []), (this._allInputNames = []), (this._allOutputIndices = []), (this._allOutputNames = []), (this._nodes = []); let o = new Map(); if (!t.input) throw new Error('missing information in graph: input'); let i = []; for (let u of t.input) { if (e.has(u.name)) throw new Error(`duplicated input name: ${u.name}`); let n = this._allData.push(new kt(u)) - 1; e.set(u.name, n), i.push(u.name); } if (!t.initializer) throw new Error('missing information in graph: initializer'); for (let u of t.initializer) { let n = e.get(u.name); if (n === void 0) { let s = new kt(); (s.type = { shape: { dims: Ve.tensorDimsFromProto(u.dims) }, tensorType: Ve.tensorDataTypeFromProto(u.dataType), }), (n = this._allData.push(s) - 1), e.set(u.name, n); } (this._allData[n]._from = -1), (this._allData[n].tensor = Fe.fromProto(u)); } for (let u = 0; u < this._allData.length; u++) this._allData[u].tensor || (this._allInputIndices.push(u), this._allInputNames.push(i[u])); if (!t.output) throw new Error('missing information in graph: output'); for (let u of t.output) { if (e.has(u.name)) throw new Error(`duplicated output name: ${u.name}`); let n = this._allData.push(new kt(u)) - 1; e.set(u.name, n), this._allOutputIndices.push(n), this._allOutputNames.push(u.name); } if (!t.node) throw new Error('missing information in graph: node'); for (let u of t.node) { if (!u.name) for (let s = 0; ; s++) { let d = `unnamed_${u.opType}_${s}`; if (!o.has(d)) { u.name = d; break; } } if (o.has(u.name)) throw new Error(`duplicated node name: ${u.name}`); let n = this._nodes.push(new Oo(u)) - 1; o.set(u.name, n); } for (let u = 0; u < this._nodes.length; u++) { let n = this._nodes[u], s = t.node[u]; if (!s.output) throw new Error(`missing output for node: ${s.name}`); for (let d of s.output) { let f = e.get(d); if ( (typeof f > 'u' && ((f = this._allData.push(new kt()) - 1), e.set(d, f)), n.outputs.push(f), this._allData[f]._from !== void 0) ) throw new Error(`multiple nodes output to one data value: ${f}`); if (((this._allData[f]._from = u), s.opType === 'Constant')) { if (!s.attribute || s.attribute.length !== 1 || !s.attribute[0].t) throw new Error( 'missing attributes or missing tensor value in attributes for this Constant operator' ); if (!s.output || s.output.length !== 1) throw new Error( 'missing output or incorrect number of outputs for this Constant operator' ); n.outputs.pop(), (n.executeNode = !1), (this._allData[f]._from = -1), (this._allData[f].tensor = Fe.fromProto(s.attribute[0].t)); } } } for (let u = 0; u < this._nodes.length; u++) { let n = this._nodes[u], s = t.node[u]; if (!s.input) throw new Error(`missing input for node: ${s.name}`); for (let d of s.input) { let f = e.get(d); if (typeof f > 'u') { if (d === '' && (s.input.length === 3 || s.input.length === 4) && s.opType === 'Resize') continue; throw new Error(`unrecognized input '${d}' for node: ${s.name}`); } n.inputs.push(f), this._allData[f]._to.push(u); } } return !0; } buildGraphFromOrtFormat(t) { let e = new Map(); (this._allData = []), (this._allInputIndices = []), (this._allInputNames = []), (this._allOutputIndices = []), (this._allOutputNames = []), (this._nodes = []); let o = new Map(), i = []; for (let u = 0; u < t.inputsLength(); u++) { let n = t.inputs(u); if (e.has(n)) throw new Error(`duplicated input name: ${n}`); for (let s = 0; s < t.nodeArgsLength(); s++) if (t.nodeArgs(s)?.name() === n) { let d = new kt(); if (t.nodeArgs(s)?.type()?.valueType() !== _o.TypeInfoValue.tensor_type) throw new Error('Unexpected value type for the nodeArg.'); let f = t.nodeArgs(s).type().value(new _o.TensorTypeAndShape()), r = Ve.tensorDataTypeFromProto(f.elemType()), a = f.shape(), l = []; for (let m = 0; m < a.dimLength(); m++) l.push(nt.longToNumber(a.dim(m).value().dimValue())); d.type = { shape: { dims: l }, tensorType: r }; let p = this._allData.push(d) - 1; e.set(n, p), i.push(n); } } for (let u = 0; u < t.initializersLength(); u++) { let n = t.initializers(u), s = e.get(n.name()); if (s === void 0) { let d = new kt(), f = Ve.tensorDimsFromORTFormat(n), r = Ve.tensorDataTypeFromProto(n.dataType()); (d.type = { shape: { dims: f }, tensorType: r }), (s = this._allData.push(d) - 1), e.set(n.name(), s); } (this._allData[s]._from = -1), (this._allData[s].tensor = Fe.fromOrtTensor(n)); } for (let u = 0; u < this._allData.length; u++) this._allData[u].tensor || (this._allInputIndices.push(u), this._allInputNames.push(i[u])); for (let u = 0; u < t.outputsLength(); u++) { let n = t.outputs(u); if (e.has(n)) throw new Error(`duplicated output name: ${n}`); let s = this._allData.push(new kt()) - 1; e.set(n, s), this._allOutputIndices.push(s), this._allOutputNames.push(n); } if (!t.nodes) throw new Error('missing information in graph: node'); for (let u = 0; u < t.nodesLength(); u++) { let n = t.nodes(u), s = n.name(); if (!s) for (let f = 0; (s = `unnamed_${n.opType()}_${f}`), !!o.has(s); f++); if (o.has(s)) throw new Error(`duplicated node name: ${s}`); let d = this._nodes.push(new Oo(n, s)) - 1; o.set(s, d); } for (let u = 0; u < this._nodes.length; u++) { let n = this._nodes[u], s = t.nodes(u); if (s == null) throw new Error(`No node exists at index ${u}`); if (s?.outputsLength() === 0) throw new Error(`missing output for node: ${s.name}`); for (let d = 0; d < s?.outputsLength(); d++) { let f = s?.outputs(d), r = e.get(f); if ( (typeof r > 'u' && ((r = this._allData.push(new kt()) - 1), e.set(f, r)), n.outputs.push(r), this._allData[r]._from !== void 0) ) throw new Error(`multiple nodes output to one data value: ${r}`); if (((this._allData[r]._from = u), s.opType() === 'Constant')) { if (s.attributesLength() !== 1 || !s.attributes(0).t()) throw new Error( 'missing attributes or missing tensor value in attributes for this Constant operator' ); if (s.outputsLength() !== 1) throw new Error( 'missing output or incorrect number of outputs for this Constant operator' ); n.outputs.pop(), (n.executeNode = !1), (this._allData[r]._from = -1), (this._allData[r].tensor = Fe.fromOrtTensor(s.attributes(0).t())); } } } for (let u = 0; u < this._nodes.length; u++) { let n = this._nodes[u], s = t.nodes(u); if (s.inputsLength() === 0) throw new Error(`missing input for node: ${s.name}`); for (let d = 0; d < s.inputsLength(); d++) { let f = s.inputs(d), r = e.get(f); if (typeof r > 'u') throw new Error(`unrecognized input '${f}' for node: ${s.name()}`); n.inputs.push(r), this._allData[r]._to.push(u); } } } checkIsAcyclic() { let t = new Set(); this._allInputIndices.forEach((i) => { this._allData[i]._to.forEach((u) => { t.add(u); }); }); let e = Array.from(t), o = new Array(this._nodes.length).fill('white'); for (; e.length > 0; ) { let i = e.pop(); o[i] === 'gray' ? (o[i] = 'black') : (e.push(i), (o[i] = 'gray'), this._nodes[i].outputs.forEach((u) => { let n = this._allData[u]; if (typeof n.tensor < 'u') throw new Error('node outputs should not be initialized'); if (n._from !== i) throw new Error( "from property of the Value object doesn't match index of Node being processed" ); n._to.forEach((s) => { if (o[s] === 'gray') throw new Error('model graph is cyclic'); o[s] === 'white' && e.push(s); }); })); } } transformGraph(t) { this.removeAllIdentityNodes(), this.removeAllDropoutNodes(), this.fuseConvActivationNodes(), t && t.transformGraph(this), this.finalizeGraph(); } finalizeGraph() { let t = 0, e = new Array(this._nodes.length, 0), o = 0; for (let i = 0; i < this._nodes.length; i++) (e[i] = o), this._nodes[i].executeNode ? (o !== i && (this._nodes[o] = this._nodes[i]), o++) : this._nodes[i].outputs.forEach((u) => { this._allData[u]._from = -2; }); this._nodes.splice(o, this._nodes.length - o); for (let i = 0; i < this._allData.length; i++) { let u = this._allData[i]; u._from !== void 0 && u._from !== -1 && u._from !== -2 && (u._from = e[u._from]); for (let n = 0; n < u._to.length; n++) if (u._to[n] >= 0) u._to[n] = e[u._to[n]]; else throw new Error('Trying to update a removed node'); } t = 0; for (let i = 0; i < this._allData.length; i++) { if (this._allData[i].from === -2 && this._allOutputIndices.indexOf(i + t) === -1) { t++, this._allData.splice(i, 1), i--; continue; } if (t > 0) { let u = -1; this._allData[i].from !== void 0 && this._allData[i].from !== -1 ? ((u = this._nodes[this._allData[i].from].outputs.indexOf(i + t)), u !== -1 && (this._nodes[this._allData[i].from].outputs[u] = i)) : ((u = this._allInputIndices.indexOf(i + t)), u !== -1 && (this._allInputIndices[u] = i)), this._allData[i].to.forEach((n) => { (u = this._nodes[n].inputs.indexOf(i + t)), u !== -1 && (this._nodes[n].inputs[u] = i); }), this._allData[i].to.length === 0 && ((u = this._allOutputIndices.indexOf(i + t)), u !== -1 && (this._allOutputIndices[u] = i)); } } } deleteNode(t) { let e = this._nodes[t]; if (e.outputs.length > 1) { for (let s = 1; s < e.outputs.length; s++) if (this._allData[e.outputs[s]].to.length > 0) throw new Error( 'Node deletion with more than one output connected to other nodes is not supported. ' ); } e.executeNode = !1; let o = e.inputs[0], i = e.outputs[0], u = this._allData[i].to; for (let s = 0; s < e.inputs.length; s++) { let d = this._allData[e.inputs[s]].to.indexOf(t); if (d === -1) throw new Error("The Value object doesn't have the current Node in it's 'to' property "); this._allData[e.inputs[s]].to.splice(d, 1); } this._allData[i]._to = []; let n = this._allOutputIndices.indexOf(i); if ((n !== -1 && (this._allOutputIndices[n] = o), u && u.length > 0)) for (let s of u) { let d = this._nodes[s].inputs.indexOf(i); if (d === -1) throw new Error( "The Node object doesn't have the output Value in it's 'inputs' property " ); (this._nodes[s].inputs[d] = o), this._allData[o].to.push(s); } } removeAllDropoutNodes() { let t = 0; for (let e of this._nodes) { if (e.opType === 'Dropout') { if (e.inputs.length !== 1) throw new Error('Dropout nodes should only contain one input. '); if (e.outputs.length !== 1 && e.outputs.length !== 2) throw new Error('Dropout nodes should contain either 1 or 2 output(s)'); if (e.outputs.length === 2 && this._allData[e.outputs[1]]._to.length !== 0) throw new Error( "Dropout nodes's second output should not be referenced by other nodes" ); this.deleteNode(t); } t++; } } removeAllIdentityNodes() { let t = 0; for (let e of this._nodes) e.opType === 'Identity' && this.deleteNode(t), t++; } isActivation(t) { switch (t.opType) { case 'Relu': case 'Sigmoid': case 'Clip': return !0; default: return !1; } } fuseConvActivationNodes() { for (let t of this._nodes) if (t.opType === 'Conv') { let e = this._allData[t.outputs[0]]._to; if (e.length === 1 && this.isActivation(this._nodes[e[0]])) { let o = this._nodes[e[0]]; if (o.opType === 'Clip') if (o.inputs.length === 1) try { t.attributes.set('activation_params', 'floats', [ o.attributes.getFloat('min'), o.attributes.getFloat('max'), ]); } catch { t.attributes.set('activation_params', 'floats', [dr, hr]); } else if ( o.inputs.length >= 3 && this._allData[o.inputs[1]].tensor !== void 0 && this._allData[o.inputs[2]].tensor !== void 0 ) t.attributes.set('activation_params', 'floats', [ this._allData[o.inputs[1]].tensor.floatData[0], this._allData[o.inputs[2]].tensor.floatData[0], ]); else continue; t.attributes.set('activation', 'string', o.opType), this.deleteNode(e[0]); } } } }); }), yp, Jb, Io, Tp = L(() => { Wn(), gp(), tn(), (yp = Er($r())), fe(), (Jb = W.experimental.fbs), (Io = class { constructor() {} load(t, e, o) { if (!o) try { this.loadFromOnnxFormat(t, e); return; } catch (i) { if (o !== void 0) throw i; } this.loadFromOrtFormat(t, e); } loadFromOnnxFormat(t, e) { let o = yp.onnx.ModelProto.decode(t); if (nt.longToNumber(o.irVersion) < 3) throw new Error('only support ONNX model with IR_VERSION>=3'); (this._opsets = o.opsetImport.map((i) => ({ domain: i.domain, version: nt.longToNumber(i.version), }))), (this._graph = Zi.from(o.graph, e)); } loadFromOrtFormat(t, e) { let o = new _.ByteBuffer(t), i = Jb.InferenceSession.getRootAsInferenceSession(o).model(); if (nt.longToNumber(i.irVersion()) < 3) throw new Error('only support ONNX model with IR_VERSION>=3'); this._opsets = []; for (let u = 0; u < i.opsetImportLength(); u++) { let n = i.opsetImport(u); this._opsets.push({ domain: n?.domain(), version: nt.longToNumber(n.version()) }); } this._graph = Zi.from(i.graph(), e); } get graph() { return this._graph; } get opsets() { return this._opsets; } }); }), So, xp = L(() => { hp(), mp(), ut(), Tp(), (So = class { constructor(t = {}) { (this._initialized = !1), (this.backendHint = t.backendHint), (this.profiler = zn.create(t.profiler)), (this.context = { profiler: this.profiler, graphInputTypes: [], graphInputDims: [] }); } get inputNames() { return this._model.graph.getInputNames(); } get outputNames() { return this._model.graph.getOutputNames(); } startProfiling() { this.profiler.start(); } endProfiling() { this.profiler.stop(); } async loadModel(t, e, o) { await this.profiler.event('session', 'Session.loadModel', async () => { let i = await Yi(this.backendHint); if ( ((this.sessionHandler = i.createSessionHandler(this.context)), (this._model = new Io()), typeof t == 'string') ) { let u = t.endsWith('.ort'); if (typeof process < 'u' && process.versions && process.versions.node) { let n = await (void 0)(t); this.initialize(n, u); } else { let n = await (await fetch(t)).arrayBuffer(); this.initialize(new Uint8Array(n), u); } } else if (ArrayBuffer.isView(t)) this.initialize(t); else { let u = new Uint8Array(t, e || 0, o || t.byteLength); this.initialize(u); } }); } initialize(t, e) { if (this._initialized) throw new Error('already initialized'); this.profiler.event('session', 'Session.initialize', () => { let o = this.sessionHandler.transformGraph ? this.sessionHandler : void 0; this._model.load(t, o, e), this.sessionHandler.onGraphInitialized && this.sessionHandler.onGraphInitialized(this._model.graph), this.initializeOps(this._model.graph), (this._executionPlan = new wo(this._model.graph, this._ops, this.profiler)); }), (this._initialized = !0); } async run(t) { if (!this._initialized) throw new Error('session not initialized yet'); return this.profiler.event('session', 'Session.run', async () => { let e = this.normalizeAndValidateInputs(t), o = await this._executionPlan.execute(this.sessionHandler, e); return this.createOutput(o); }); } normalizeAndValidateInputs(t) { let e = this._model.graph.getInputNames(); if (Array.isArray(t)) { if (t.length !== e.length) throw new Error(`incorrect input array length: expected ${e.length} but got ${t.length}`); } else { if (t.size !== e.length) throw new Error(`incorrect input map size: expected ${e.length} but got ${t.size}`); let o = new Array(t.size), i = 0; for (let u = 0; u < e.length; ++u) { let n = t.get(e[u]); if (!n) throw new Error(`missing input tensor for: '${name}'`); o[i++] = n; } t = o; } if ( !this.context.graphInputTypes || this.context.graphInputTypes.length === 0 || !this.context.graphInputDims || this.context.graphInputDims.length === 0 ) { let o = this._model.graph.getInputIndices(), i = this._model.graph.getValues(), u = new Array(o.length); for (let n = 0; n < o.length; ++n) { let s = i[o[n]]; (u[n] = s.type.shape.dims), this.context.graphInputTypes.push(s.type.tensorType), this.context.graphInputDims.push(t[n].dims); } this.validateInputTensorDims(u, t, !0); } else this.validateInputTensorDims(this.context.graphInputDims, t, !1); return this.validateInputTensorTypes(this.context.graphInputTypes, t), t; } validateInputTensorTypes(t, e) { for (let o = 0; o < e.length; o++) { let i = t[o], u = e[o].type; if (i !== u) throw new Error(`input tensor[${o}] check failed: expected type '${i}' but got ${u}`); } } validateInputTensorDims(t, e, o) { for (let i = 0; i < e.length; i++) { let u = t[i], n = e[i].dims; if (!this.compareTensorDims(u, n, o)) throw new Error( `input tensor[${i}] check failed: expected shape '[${u.join(',')}]' but got [${n.join( ',' )}]` ); } } compareTensorDims(t, e, o) { if (t.length !== e.length) return !1; for (let i = 0; i < t.length; ++i) if (t[i] !== e[i] && (!o || t[i] !== 0)) return !1; return !0; } createOutput(t) { let e = this._model.graph.getOutputNames(); if (t.length !== e.length) throw new Error('expected number of outputs do not match number of generated outputs'); let o = new Map(); for (let i = 0; i < e.length; ++i) o.set(e[i], t[i]); return o; } initializeOps(t) { let e = t.getNodes(); this._ops = new Array(e.length); for (let o = 0; o < e.length; o++) this._ops[o] = this.sessionHandler.resolve(e[o], this._model.opsets, t); } }); }), Ao, vp = L(() => { vt(), mr(), (Ao = class { constructor(t) { (this.session = t), (this.inputNames = this.session.inputNames), (this.outputNames = this.session.outputNames); } async dispose() {} async run(t, e, o) { let i = new Map(); for (let s in t) if (Object.hasOwnProperty.call(t, s)) { let d = t[s]; i.set(s, new Fe(d.dims, d.type, void 0, void 0, d.data)); } let u = await this.session.run(i), n = {}; return ( u.forEach((s, d) => { n[d] = new Re(s.type, s.data, s.dims); }), n ); } startProfiling() { this.session.startProfiling(); } endProfiling() { this.session.endProfiling(); } }); }), wp = {}; Pr(wp, { onnxjsBackend: () => Qb }); var Qi, Qb, _p = L(() => { xp(), vp(), (Qi = class { async init() {} async createInferenceSessionHandler(t, e) { let o = new So(e); return typeof t == 'string' ? await o.loadModel(t) : await o.loadModel(t), new Ao(o); } }), (Qb = new Qi()); }), ea = {}; Pr(ea, { createReadStream: () => Op, readFile: () => eg, readFileSync: () => tg }); var eg, tg, Op, ta = L(() => { (eg = void 0), (tg = void 0), (Op = void 0); }), ra = {}; Pr(ra, { join: () => rg }); var rg, na = L(() => { rg = void 0; }), Ap = me((t, e) => { var o = (() => { var i = typeof document < 'u' && document.currentScript ? document.currentScript.src : void 0; return ( typeof __filename < 'u' && (i = i || __filename), function (u = {}) { var n = u, s, d; n.ready = new Promise((O, M) => { (s = O), (d = M); }); var f = Object.assign({}, n), r = './this.program', a = typeof window == 'object', l = typeof importScripts == 'function', p = typeof process == 'object' && typeof process.versions == 'object' && typeof process.versions.node == 'string', m = '', y, T, v; if (p) { var S = (ta(), rr(ea)), E = (na(), rr(ra)); (m = l ? E.dirname(m) + '/' : __dirname + '/'), (y = (O, M) => ( (O = ve(O) ? new URL(O) : E.normalize(O)), S.readFileSync(O, M ? void 0 : 'utf8') )), (v = (O) => ((O = y(O, !0)), O.buffer || (O = new Uint8Array(O)), O)), (T = (O, M, I, k = !0) => { (O = ve(O) ? new URL(O) : E.normalize(O)), S.readFile(O, k ? void 0 : 'utf8', (G, ne) => { G ? I(G) : M(k ? ne.buffer : ne); }); }), !n.thisProgram && 1 < process.argv.length && (r = process.argv[1].replace(/\\/g, '/')), process.argv.slice(2), (n.inspect = () => '[Emscripten Module object]'); } else (a || l) && (l ? (m = self.location.href) : typeof document < 'u' && document.currentScript && (m = document.currentScript.src), i && (m = i), m.indexOf('blob:') !== 0 ? (m = m.substr(0, m.replace(/[?#].*/, '').lastIndexOf('/') + 1)) : (m = ''), (y = (O) => { var M = new XMLHttpRequest(); return M.open('GET', O, !1), M.send(null), M.responseText; }), l && (v = (O) => { var M = new XMLHttpRequest(); return ( M.open('GET', O, !1), (M.responseType = 'arraybuffer'), M.send(null), new Uint8Array(M.response) ); }), (T = (O, M, I) => { var k = new XMLHttpRequest(); k.open('GET', O, !0), (k.responseType = 'arraybuffer'), (k.onload = () => { k.status == 200 || (k.status == 0 && k.response) ? M(k.response) : I(); }), (k.onerror = I), k.send(null); })); var A = console.log.bind(console), F = console.error.bind(console); Object.assign(n, f), (f = null), typeof WebAssembly != 'object' && pe('no native wasm support detected'); var B, J = !1, Q, re, V, de, ke; function Ne() { var O = B.buffer; (n.HEAP8 = Q = new Int8Array(O)), (n.HEAP16 = new Int16Array(O)), (n.HEAPU8 = re = new Uint8Array(O)), (n.HEAPU16 = new Uint16Array(O)), (n.HEAP32 = V = new Int32Array(O)), (n.HEAPU32 = de = new Uint32Array(O)), (n.HEAPF32 = new Float32Array(O)), (n.HEAPF64 = ke = new Float64Array(O)); } var Me = [], Y = [], _e = [], he = 0, ue = null; function pe(O) { throw ( ((O = 'Aborted(' + O + ')'), F(O), (J = !0), (O = new WebAssembly.RuntimeError(O + '. Build with -sASSERTIONS for more info.')), d(O), O) ); } var X = (O) => O.startsWith('data:application/octet-stream;base64,'), ve = (O) => O.startsWith('file://'), we; if (((we = 'ort-wasm.wasm'), !X(we))) { var rt = we; we = n.locateFile ? n.locateFile(rt, m) : m + rt; } function ot(O) { if (v) return v(O); throw 'both async and sync fetching of the wasm failed'; } function qe(O) { if (a || l) { if (typeof fetch == 'function' && !ve(O)) return fetch(O, { credentials: 'same-origin' }) .then((M) => { if (!M.ok) throw "failed to load wasm binary file at '" + O + "'"; return M.arrayBuffer(); }) .catch(() => ot(O)); if (T) return new Promise((M, I) => { T(O, (k) => M(new Uint8Array(k)), I); }); } return Promise.resolve().then(() => ot(O)); } function He(O, M, I) { return qe(O) .then((k) => WebAssembly.instantiate(k, M)) .then((k) => k) .then(I, (k) => { F(`failed to asynchronously prepare wasm: ${k}`), pe(k); }); } function Qe(O, M) { var I = we; return typeof WebAssembly.instantiateStreaming != 'function' || X(I) || ve(I) || p || typeof fetch != 'function' ? He(I, O, M) : fetch(I, { credentials: 'same-origin' }).then((k) => WebAssembly.instantiateStreaming(k, O).then(M, function (G) { return ( F(`wasm streaming compile failed: ${G}`), F('falling back to ArrayBuffer instantiation'), He(I, O, M) ); }) ); } var Be, Ce = { 919888: (O, M, I, k) => { if (typeof n > 'u' || !n.za) return 1; if ( ((O = Mt(O >>> 0)), O.startsWith('./') && (O = O.substring(2)), (O = n.za.get(O)), !O) ) return 2; if (((M >>>= 0), (I >>>= 0), M + I > O.byteLength)) return 3; try { return re.set(O.subarray(M, M + I), (k >>> 0) >>> 0), 0; } catch { return 4; } }, }; function Se(O) { (this.xa = O - 24), (this.Ha = function (M) { de[((this.xa + 4) >>> 2) >>> 0] = M; }), (this.Ga = function (M) { de[((this.xa + 8) >>> 2) >>> 0] = M; }), (this.Aa = function (M, I) { this.Fa(), this.Ha(M), this.Ga(I); }), (this.Fa = function () { de[((this.xa + 16) >>> 2) >>> 0] = 0; }); } var je = 0, Tt = typeof TextDecoder < 'u' ? new TextDecoder('utf8') : void 0, xt = (O, M, I) => { M >>>= 0; var k = M + I; for (I = M; O[I] && !(I >= k); ) ++I; if (16 < I - M && O.buffer && Tt) return Tt.decode(O.subarray(M, I)); for (k = ''; M < I; ) { var G = O[M++]; if (G & 128) { var ne = O[M++] & 63; if ((G & 224) == 192) k += String.fromCharCode(((G & 31) << 6) | ne); else { var ge = O[M++] & 63; (G = (G & 240) == 224 ? ((G & 15) << 12) | (ne << 6) | ge : ((G & 7) << 18) | (ne << 12) | (ge << 6) | (O[M++] & 63)), 65536 > G ? (k += String.fromCharCode(G)) : ((G -= 65536), (k += String.fromCharCode(55296 | (G >> 10), 56320 | (G & 1023)))); } } else k += String.fromCharCode(G); } return k; }, Mt = (O, M) => ((O >>>= 0) ? xt(re, O, M) : ''), Ot = (O) => { for (var M = 0, I = 0; I < O.length; ++I) { var k = O.charCodeAt(I); 127 >= k ? M++ : 2047 >= k ? (M += 2) : 55296 <= k && 57343 >= k ? ((M += 4), ++I) : (M += 3); } return M; }, gt = (O, M, I, k) => { if (((I >>>= 0), !(0 < k))) return 0; var G = I; k = I + k - 1; for (var ne = 0; ne < O.length; ++ne) { var ge = O.charCodeAt(ne); if (55296 <= ge && 57343 >= ge) { var Ue = O.charCodeAt(++ne); ge = (65536 + ((ge & 1023) << 10)) | (Ue & 1023); } if (127 >= ge) { if (I >= k) break; M[I++ >>> 0] = ge; } else { if (2047 >= ge) { if (I + 1 >= k) break; M[I++ >>> 0] = 192 | (ge >> 6); } else { if (65535 >= ge) { if (I + 2 >= k) break; M[I++ >>> 0] = 224 | (ge >> 12); } else { if (I + 3 >= k) break; (M[I++ >>> 0] = 240 | (ge >> 18)), (M[I++ >>> 0] = 128 | ((ge >> 12) & 63)); } M[I++ >>> 0] = 128 | ((ge >> 6) & 63); } M[I++ >>> 0] = 128 | (ge & 63); } } return (M[I >>> 0] = 0), I - G; }, yt = (O) => O % 4 === 0 && (O % 100 !== 0 || O % 400 === 0), Or = [0, 31, 60, 91, 121, 152, 182, 213, 244, 274, 305, 335], Ht = [0, 31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334], Sr = (O) => { var M = Ot(O) + 1, I = Gt(M); return I && gt(O, re, I, M), I; }, st = [], Bt = {}, At = () => { if (!It) { var O = { USER: 'web_user', LOGNAME: 'web_user', PATH: '/', PWD: '/', HOME: '/home/web_user', LANG: ( (typeof navigator == 'object' && navigator.languages && navigator.languages[0]) || 'C' ).replace('-', '_') + '.UTF-8', _: r || './this.program', }, M; for (M in Bt) Bt[M] === void 0 ? delete O[M] : (O[M] = Bt[M]); var I = []; for (M in O) I.push(`${M}=${O[M]}`); It = I; } return It; }, It, Ar = [null, [], []], Et = [31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31], Yt = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]; function Ir(O) { var M = Array(Ot(O) + 1); return gt(O, M, 0, M.length), M; } function Dt(O, M, I, k) { function G(C, Te, Ie) { for (C = typeof C == 'number' ? C.toString() : C || ''; C.length < Te; ) C = Ie[0] + C; return C; } function ne(C, Te) { return G(C, Te, '0'); } function ge(C, Te) { function Ie(lr) { return 0 > lr ? -1 : 0 < lr ? 1 : 0; } var at; return ( (at = Ie(C.getFullYear() - Te.getFullYear())) === 0 && (at = Ie(C.getMonth() - Te.getMonth())) === 0 && (at = Ie(C.getDate() - Te.getDate())), at ); } function Ue(C) { switch (C.getDay()) { case 0: return new Date(C.getFullYear() - 1, 11, 29); case 1: return C; case 2: return new Date(C.getFullYear(), 0, 3); case 3: return new Date(C.getFullYear(), 0, 2); case 4: return new Date(C.getFullYear(), 0, 1); case 5: return new Date(C.getFullYear() - 1, 11, 31); case 6: return new Date(C.getFullYear() - 1, 11, 30); } } function et(C) { var Te = C.ta; for (C = new Date(new Date(C.ua + 1900, 0, 1).getTime()); 0 < Te; ) { var Ie = C.getMonth(), at = (yt(C.getFullYear()) ? Et : Yt)[Ie]; if (Te > at - C.getDate()) (Te -= at - C.getDate() + 1), C.setDate(1), 11 > Ie ? C.setMonth(Ie + 1) : (C.setMonth(0), C.setFullYear(C.getFullYear() + 1)); else { C.setDate(C.getDate() + Te); break; } } return ( (Ie = new Date(C.getFullYear() + 1, 0, 4)), (Te = Ue(new Date(C.getFullYear(), 0, 4))), (Ie = Ue(Ie)), 0 >= ge(Te, C) ? 0 >= ge(Ie, C) ? C.getFullYear() + 1 : C.getFullYear() : C.getFullYear() - 1 ); } (O >>>= 0), (M >>>= 0), (I >>>= 0), (k >>>= 0); var Ze = de[((k + 40) >>> 2) >>> 0]; (k = { Da: V[(k >>> 2) >>> 0], Ca: V[((k + 4) >>> 2) >>> 0], va: V[((k + 8) >>> 2) >>> 0], ya: V[((k + 12) >>> 2) >>> 0], wa: V[((k + 16) >>> 2) >>> 0], ua: V[((k + 20) >>> 2) >>> 0], oa: V[((k + 24) >>> 2) >>> 0], ta: V[((k + 28) >>> 2) >>> 0], Ia: V[((k + 32) >>> 2) >>> 0], Ba: V[((k + 36) >>> 2) >>> 0], Ea: Ze ? Mt(Ze) : '', }), (I = Mt(I)), (Ze = { '%c': '%a %b %d %H:%M:%S %Y', '%D': '%m/%d/%y', '%F': '%Y-%m-%d', '%h': '%b', '%r': '%I:%M:%S %p', '%R': '%H:%M', '%T': '%H:%M:%S', '%x': '%m/%d/%y', '%X': '%H:%M:%S', '%Ec': '%c', '%EC': '%C', '%Ex': '%m/%d/%y', '%EX': '%H:%M:%S', '%Ey': '%y', '%EY': '%Y', '%Od': '%d', '%Oe': '%e', '%OH': '%H', '%OI': '%I', '%Om': '%m', '%OM': '%M', '%OS': '%S', '%Ou': '%u', '%OU': '%U', '%OV': '%V', '%Ow': '%w', '%OW': '%W', '%Oy': '%y', }); for (var Je in Ze) I = I.replace(new RegExp(Je, 'g'), Ze[Je]); var er = 'Sunday Monday Tuesday Wednesday Thursday Friday Saturday'.split(' '), tr = 'January February March April May June July August September October November December'.split( ' ' ); (Ze = { '%a': (C) => er[C.oa].substring(0, 3), '%A': (C) => er[C.oa], '%b': (C) => tr[C.wa].substring(0, 3), '%B': (C) => tr[C.wa], '%C': (C) => ne(((C.ua + 1900) / 100) | 0, 2), '%d': (C) => ne(C.ya, 2), '%e': (C) => G(C.ya, 2, ' '), '%g': (C) => et(C).toString().substring(2), '%G': (C) => et(C), '%H': (C) => ne(C.va, 2), '%I': (C) => ((C = C.va), C == 0 ? (C = 12) : 12 < C && (C -= 12), ne(C, 2)), '%j': (C) => { for (var Te = 0, Ie = 0; Ie <= C.wa - 1; Te += (yt(C.ua + 1900) ? Et : Yt)[Ie++]); return ne(C.ya + Te, 3); }, '%m': (C) => ne(C.wa + 1, 2), '%M': (C) => ne(C.Ca, 2), '%n': () => ` `, '%p': (C) => (0 <= C.va && 12 > C.va ? 'AM' : 'PM'), '%S': (C) => ne(C.Da, 2), '%t': () => ' ', '%u': (C) => C.oa || 7, '%U': (C) => ne(Math.floor((C.ta + 7 - C.oa) / 7), 2), '%V': (C) => { var Te = Math.floor((C.ta + 7 - ((C.oa + 6) % 7)) / 7); if ((2 >= (C.oa + 371 - C.ta - 2) % 7 && Te++, Te)) Te == 53 && ((Ie = (C.oa + 371 - C.ta) % 7), Ie == 4 || (Ie == 3 && yt(C.ua)) || (Te = 1)); else { Te = 52; var Ie = (C.oa + 7 - C.ta - 1) % 7; (Ie == 4 || (Ie == 5 && yt((C.ua % 400) - 1))) && Te++; } return ne(Te, 2); }, '%w': (C) => C.oa, '%W': (C) => ne(Math.floor((C.ta + 7 - ((C.oa + 6) % 7)) / 7), 2), '%y': (C) => (C.ua + 1900).toString().substring(2), '%Y': (C) => C.ua + 1900, '%z': (C) => { C = C.Ba; var Te = 0 <= C; return ( (C = Math.abs(C) / 60), (Te ? '+' : '-') + ('0000' + ((C / 60) * 100 + (C % 60))).slice(-4) ); }, '%Z': (C) => C.Ea, '%%': () => '%', }), (I = I.replace(/%%/g, '\0\0')); for (Je in Ze) I.includes(Je) && (I = I.replace(new RegExp(Je, 'g'), Ze[Je](k))); return ( (I = I.replace(/\0\0/g, '%')), (Je = Ir(I)), Je.length > M ? 0 : (Q.set(Je, O >>> 0), Je.length - 1) ); } var Zr = { a: function (O, M, I) { throw ((O >>>= 0), new Se(O).Aa(M >>> 0, I >>> 0), (je = O), je); }, e: function () { return 0; }, H: function () {}, x: function () {}, z: function () {}, J: function () { return 0; }, F: function () {}, A: function () {}, E: function () {}, g: function () {}, y: function () {}, v: function () {}, G: function () {}, w: function () {}, k: () => 1, n: function (O, M, I) { (O = (M + 2097152) >>> 0 < 4194305 - !!O ? (O >>> 0) + 4294967296 * M : NaN), (I >>>= 0), (O = new Date(1e3 * O)), (V[(I >>> 2) >>> 0] = O.getUTCSeconds()), (V[((I + 4) >>> 2) >>> 0] = O.getUTCMinutes()), (V[((I + 8) >>> 2) >>> 0] = O.getUTCHours()), (V[((I + 12) >>> 2) >>> 0] = O.getUTCDate()), (V[((I + 16) >>> 2) >>> 0] = O.getUTCMonth()), (V[((I + 20) >>> 2) >>> 0] = O.getUTCFullYear() - 1900), (V[((I + 24) >>> 2) >>> 0] = O.getUTCDay()), (V[((I + 28) >>> 2) >>> 0] = ((O.getTime() - Date.UTC(O.getUTCFullYear(), 0, 1, 0, 0, 0, 0)) / 864e5) | 0); }, o: function (O, M, I) { (O = (M + 2097152) >>> 0 < 4194305 - !!O ? (O >>> 0) + 4294967296 * M : NaN), (I >>>= 0), (O = new Date(1e3 * O)), (V[(I >>> 2) >>> 0] = O.getSeconds()), (V[((I + 4) >>> 2) >>> 0] = O.getMinutes()), (V[((I + 8) >>> 2) >>> 0] = O.getHours()), (V[((I + 12) >>> 2) >>> 0] = O.getDate()), (V[((I + 16) >>> 2) >>> 0] = O.getMonth()), (V[((I + 20) >>> 2) >>> 0] = O.getFullYear() - 1900), (V[((I + 24) >>> 2) >>> 0] = O.getDay()), (V[((I + 28) >>> 2) >>> 0] = ((yt(O.getFullYear()) ? Or : Ht)[O.getMonth()] + O.getDate() - 1) | 0), (V[((I + 36) >>> 2) >>> 0] = -(60 * O.getTimezoneOffset())), (M = new Date(O.getFullYear(), 6, 1).getTimezoneOffset()); var k = new Date(O.getFullYear(), 0, 1).getTimezoneOffset(); V[((I + 32) >>> 2) >>> 0] = (M != k && O.getTimezoneOffset() == Math.min(k, M)) | 0; }, p: function (O) { O >>>= 0; var M = new Date( V[((O + 20) >>> 2) >>> 0] + 1900, V[((O + 16) >>> 2) >>> 0], V[((O + 12) >>> 2) >>> 0], V[((O + 8) >>> 2) >>> 0], V[((O + 4) >>> 2) >>> 0], V[(O >>> 2) >>> 0], 0 ), I = V[((O + 32) >>> 2) >>> 0], k = M.getTimezoneOffset(), G = new Date(M.getFullYear(), 6, 1).getTimezoneOffset(), ne = new Date(M.getFullYear(), 0, 1).getTimezoneOffset(), ge = Math.min(ne, G); return ( 0 > I ? (V[((O + 32) >>> 2) >>> 0] = +(G != ne && ge == k)) : 0 < I != (ge == k) && ((G = Math.max(ne, G)), M.setTime(M.getTime() + 6e4 * ((0 < I ? ge : G) - k))), (V[((O + 24) >>> 2) >>> 0] = M.getDay()), (V[((O + 28) >>> 2) >>> 0] = ((yt(M.getFullYear()) ? Or : Ht)[M.getMonth()] + M.getDate() - 1) | 0), (V[(O >>> 2) >>> 0] = M.getSeconds()), (V[((O + 4) >>> 2) >>> 0] = M.getMinutes()), (V[((O + 8) >>> 2) >>> 0] = M.getHours()), (V[((O + 12) >>> 2) >>> 0] = M.getDate()), (V[((O + 16) >>> 2) >>> 0] = M.getMonth()), (V[((O + 20) >>> 2) >>> 0] = M.getYear()), (O = M.getTime()), isNaN(O) ? ((V[(Kt() >>> 2) >>> 0] = 61), (O = -1)) : (O /= 1e3), Fr( ((Be = O), 1 <= +Math.abs(Be) ? 0 < Be ? +Math.floor(Be / 4294967296) >>> 0 : ~~+Math.ceil((Be - +(~~Be >>> 0)) / 4294967296) >>> 0 : 0) ), O >>> 0 ); }, l: function () { return -52; }, m: function () {}, t: function (O, M, I) { function k(et) { return (et = et.toTimeString().match(/\(([A-Za-z ]+)\)$/)) ? et[1] : 'GMT'; } I >>>= 0; var G = new Date().getFullYear(), ne = new Date(G, 0, 1), ge = new Date(G, 6, 1); G = ne.getTimezoneOffset(); var Ue = ge.getTimezoneOffset(); (de[((O >>> 0) >>> 2) >>> 0] = 60 * Math.max(G, Ue)), (V[((M >>> 0) >>> 2) >>> 0] = +(G != Ue)), (O = k(ne)), (M = k(ge)), (O = Sr(O)), (M = Sr(M)), Ue < G ? ((de[(I >>> 2) >>> 0] = O), (de[((I + 4) >>> 2) >>> 0] = M)) : ((de[(I >>> 2) >>> 0] = M), (de[((I + 4) >>> 2) >>> 0] = O)); }, d: () => { pe(''); }, B: function (O, M, I) { (O >>>= 0), (M >>>= 0), (I >>>= 0), (st.length = 0); for (var k; (k = re[M++ >>> 0]); ) { var G = k != 105; (G &= k != 112), (I += G && I % 8 ? 4 : 0), st.push( k == 112 ? de[(I >>> 2) >>> 0] : k == 105 ? V[(I >>> 2) >>> 0] : ke[(I >>> 3) >>> 0] ), (I += G ? 8 : 4); } return Ce[O].apply(null, st); }, h: () => Date.now(), u: function () { return 4294901760; }, b: () => performance.now(), I: function (O, M, I) { return (M >>>= 0), re.copyWithin((O >>> 0) >>> 0, M >>> 0, (M + (I >>> 0)) >>> 0); }, s: function (O) { O >>>= 0; var M = re.length; if (4294901760 < O) return !1; for (var I = 1; 4 >= I; I *= 2) { var k = M * (1 + 0.2 / I); k = Math.min(k, O + 100663296); var G = Math; k = Math.max(O, k); e: { G = (G.min.call(G, 4294901760, k + ((65536 - (k % 65536)) % 65536)) - B.buffer.byteLength + 65535) / 65536; try { B.grow(G), Ne(); var ne = 1; break e; } catch {} ne = void 0; } if (ne) return !0; } return !1; }, C: function (O, M) { (O >>>= 0), (M >>>= 0); var I = 0; return ( At().forEach((k, G) => { var ne = M + I; for (G = de[((O + 4 * G) >>> 2) >>> 0] = ne, ne = 0; ne < k.length; ++ne) Q[(G++ >>> 0) >>> 0] = k.charCodeAt(ne); (Q[(G >>> 0) >>> 0] = 0), (I += k.length + 1); }), 0 ); }, D: function (O, M) { (O >>>= 0), (M >>>= 0); var I = At(); de[(O >>> 2) >>> 0] = I.length; var k = 0; return I.forEach((G) => (k += G.length + 1)), (de[(M >>> 2) >>> 0] = k), 0; }, f: () => 52, j: function () { return 52; }, q: function () { return 70; }, i: function (O, M, I, k) { (M >>>= 0), (I >>>= 0), (k >>>= 0); for (var G = 0, ne = 0; ne < I; ne++) { var ge = de[(M >>> 2) >>> 0], Ue = de[((M + 4) >>> 2) >>> 0]; M += 8; for (var et = 0; et < Ue; et++) { var Ze = re[(ge + et) >>> 0], Je = Ar[O]; Ze === 0 || Ze === 10 ? ((O === 1 ? A : F)(xt(Je, 0)), (Je.length = 0)) : Je.push(Ze); } G += Ue; } return (de[(k >>> 2) >>> 0] = G), 0; }, r: Dt, c: function (O, M, I, k) { return Dt(O >>> 0, M >>> 0, I >>> 0, k >>> 0); }, }, H = (function () { function O(I) { return ( (H = I.exports), (H = Wt()), (B = H.K), Ne(), Y.unshift(H.L), he--, he == 0 && ue && ((I = ue), (ue = null), I()), H ); } var M = { a: Zr }; if ((he++, n.instantiateWasm)) try { return n.instantiateWasm(M, O); } catch (I) { F(`Module.instantiateWasm callback failed with error: ${I}`), d(I); } return ( Qe(M, function (I) { O(I.instance); }).catch(d), {} ); })(); (n._OrtInit = (O, M) => (n._OrtInit = H.M)(O, M)), (n._OrtGetLastError = (O, M) => (n._OrtGetLastError = H.N)(O, M)), (n._OrtCreateSessionOptions = (O, M, I, k, G, ne, ge, Ue, et, Ze) => (n._OrtCreateSessionOptions = H.O)(O, M, I, k, G, ne, ge, Ue, et, Ze)), (n._OrtAppendExecutionProvider = (O, M) => (n._OrtAppendExecutionProvider = H.P)(O, M)), (n._OrtAddFreeDimensionOverride = (O, M, I) => (n._OrtAddFreeDimensionOverride = H.Q)(O, M, I)), (n._OrtAddSessionConfigEntry = (O, M, I) => (n._OrtAddSessionConfigEntry = H.R)(O, M, I)), (n._OrtReleaseSessionOptions = (O) => (n._OrtReleaseSessionOptions = H.S)(O)), (n._OrtCreateSession = (O, M, I) => (n._OrtCreateSession = H.T)(O, M, I)), (n._OrtReleaseSession = (O) => (n._OrtReleaseSession = H.U)(O)), (n._OrtGetInputOutputCount = (O, M, I) => (n._OrtGetInputOutputCount = H.V)(O, M, I)), (n._OrtGetInputName = (O, M) => (n._OrtGetInputName = H.W)(O, M)), (n._OrtGetOutputName = (O, M) => (n._OrtGetOutputName = H.X)(O, M)), (n._OrtFree = (O) => (n._OrtFree = H.Y)(O)), (n._OrtCreateTensor = (O, M, I, k, G, ne) => (n._OrtCreateTensor = H.Z)(O, M, I, k, G, ne)), (n._OrtGetTensorData = (O, M, I, k, G) => (n._OrtGetTensorData = H._)(O, M, I, k, G)), (n._OrtReleaseTensor = (O) => (n._OrtReleaseTensor = H.$)(O)), (n._OrtCreateRunOptions = (O, M, I, k) => (n._OrtCreateRunOptions = H.aa)(O, M, I, k)), (n._OrtAddRunConfigEntry = (O, M, I) => (n._OrtAddRunConfigEntry = H.ba)(O, M, I)), (n._OrtReleaseRunOptions = (O) => (n._OrtReleaseRunOptions = H.ca)(O)), (n._OrtCreateBinding = (O) => (n._OrtCreateBinding = H.da)(O)), (n._OrtBindInput = (O, M, I) => (n._OrtBindInput = H.ea)(O, M, I)), (n._OrtBindOutput = (O, M, I, k) => (n._OrtBindOutput = H.fa)(O, M, I, k)), (n._OrtClearBoundOutputs = (O) => (n._OrtClearBoundOutputs = H.ga)(O)), (n._OrtReleaseBinding = (O) => (n._OrtReleaseBinding = H.ha)(O)), (n._OrtRunWithBinding = (O, M, I, k, G) => (n._OrtRunWithBinding = H.ia)(O, M, I, k, G)), (n._OrtRun = (O, M, I, k, G, ne, ge, Ue) => (n._OrtRun = H.ja)(O, M, I, k, G, ne, ge, Ue)), (n._OrtEndProfiling = (O) => (n._OrtEndProfiling = H.ka)(O)); var Kt = () => (Kt = H.la)(), Gt = (n._malloc = (O) => (Gt = n._malloc = H.ma)(O)); n._free = (O) => (n._free = H.na)(O); var Fr = (O) => (Fr = H.pa)(O), Qt = () => (Qt = H.qa)(), jr = (O) => (jr = H.ra)(O), se = (O) => (se = H.sa)(O); function Wt() { var O = H; O = Object.assign({}, O); var M = (k) => () => k() >>> 0, I = (k) => (G) => k(G) >>> 0; return (O.la = M(O.la)), (O.ma = I(O.ma)), (O.qa = M(O.qa)), (O.sa = I(O.sa)), O; } (n.stackAlloc = se), (n.stackSave = Qt), (n.stackRestore = jr), (n.UTF8ToString = Mt), (n.stringToUTF8 = (O, M, I) => gt(O, re, M, I)), (n.lengthBytesUTF8 = Ot); var Nt; ue = function O() { Nt || Lt(), Nt || (ue = O); }; function Lt() { if (!(0 < he)) { if (n.preRun) for (typeof n.preRun == 'function' && (n.preRun = [n.preRun]); n.preRun.length; ) { var O = n.preRun.shift(); Me.unshift(O); } for (; 0 < Me.length; ) Me.shift()(n); if (!(0 < he || Nt || ((Nt = !0), (n.calledRun = !0), J))) { for (; 0 < Y.length; ) Y.shift()(n); for (s(n); 0 < _e.length; ) _e.shift()(n); } } } return Lt(), u.ready; } ); })(); typeof t == 'object' && typeof e == 'object' ? (e.exports = o) : typeof define == 'function' && define.amd && define([], () => o); }), Pp = me(() => {}), Ep = me(() => {}), Dp = {}; Pr(Dp, { cpus: () => ng }); var ng, Lp = L(() => { ng = void 0; }), Cp = me((t, e) => { var o = (() => { var i = typeof document < 'u' && document.currentScript ? document.currentScript.src : void 0; return ( typeof __filename < 'u' && (i = i || __filename), function (u = {}) { function n() { return _e.buffer != X.buffer && qe(), X; } function s() { return _e.buffer != X.buffer && qe(), ve; } function d() { return _e.buffer != X.buffer && qe(), we; } function f() { return _e.buffer != X.buffer && qe(), rt; } function r() { return _e.buffer != X.buffer && qe(), ot; } var a = u, l, p; a.ready = new Promise((g, x) => { (l = g), (p = x); }); var m = Object.assign({}, a), y = './this.program', T = (g, x) => { throw x; }, v = typeof window == 'object', S = typeof importScripts == 'function', E = typeof process == 'object' && typeof process.versions == 'object' && typeof process.versions.node == 'string', A = a.ENVIRONMENT_IS_PTHREAD || !1, F = ''; function B(g) { return a.locateFile ? a.locateFile(g, F) : F + g; } var J, Q, re; if (E) { var V = (ta(), rr(ea)), de = (na(), rr(ra)); (F = S ? de.dirname(F) + '/' : __dirname + '/'), (J = (x, P) => ( (x = Ot(x) ? new URL(x) : de.normalize(x)), V.readFileSync(x, P ? void 0 : 'utf8') )), (re = (x) => ((x = J(x, !0)), x.buffer || (x = new Uint8Array(x)), x)), (Q = (x, P, D, j = !0) => { (x = Ot(x) ? new URL(x) : de.normalize(x)), V.readFile(x, j ? void 0 : 'utf8', (z, K) => { z ? D(z) : P(j ? K.buffer : K); }); }), !a.thisProgram && 1 < process.argv.length && (y = process.argv[1].replace(/\\/g, '/')), process.argv.slice(2), (T = (x, P) => { throw ((process.exitCode = x), P); }), (a.inspect = () => '[Emscripten Module object]'); let g; try { g = Pp(); } catch (x) { throw ( (console.error( 'The "worker_threads" module is not supported in this node.js build - perhaps a newer version is needed?' ), x) ); } global.Worker = g.Worker; } else (v || S) && (S ? (F = self.location.href) : typeof document < 'u' && document.currentScript && (F = document.currentScript.src), typeof i < 'u' && i && (F = i), F.indexOf('blob:') !== 0 ? (F = F.substr(0, F.replace(/[?#].*/, '').lastIndexOf('/') + 1)) : (F = ''), E || ((J = (g) => { var x = new XMLHttpRequest(); return x.open('GET', g, !1), x.send(null), x.responseText; }), S && (re = (g) => { var x = new XMLHttpRequest(); return ( x.open('GET', g, !1), (x.responseType = 'arraybuffer'), x.send(null), new Uint8Array(x.response) ); }), (Q = (g, x, P) => { var D = new XMLHttpRequest(); D.open('GET', g, !0), (D.responseType = 'arraybuffer'), (D.onload = () => { D.status == 200 || (D.status == 0 && D.response) ? x(D.response) : P(); }), (D.onerror = P), D.send(null); }))); E && typeof performance > 'u' && (global.performance = Ep().performance); var ke = console.log.bind(console), Ne = console.error.bind(console); E && ((ke = (...g) => V.writeSync( 1, g.join(' ') + ` ` )), (Ne = (...g) => V.writeSync( 2, g.join(' ') + ` ` ))); var Me = ke, Y = Ne; Object.assign(a, m), (m = null), typeof WebAssembly != 'object' && xt('no native wasm support detected'); var _e, he, ue = !1, pe, X, ve, we, rt, ot; function qe() { var g = _e.buffer; (a.HEAP8 = X = new Int8Array(g)), (a.HEAP16 = new Int16Array(g)), (a.HEAPU8 = ve = new Uint8Array(g)), (a.HEAPU16 = new Uint16Array(g)), (a.HEAP32 = we = new Int32Array(g)), (a.HEAPU32 = rt = new Uint32Array(g)), (a.HEAPF32 = new Float32Array(g)), (a.HEAPF64 = ot = new Float64Array(g)); } var He = 16777216; if (A) _e = a.wasmMemory; else if (a.wasmMemory) _e = a.wasmMemory; else if ( ((_e = new WebAssembly.Memory({ initial: He / 65536, maximum: 65536, shared: !0 })), !(_e.buffer instanceof SharedArrayBuffer)) ) throw ( (Y( 'requested a shared WebAssembly.Memory but the returned buffer is not a SharedArrayBuffer, indicating that while the browser has SharedArrayBuffer it does not have WebAssembly threads support - you may need to set a flag' ), E && Y( '(on node you may need: --experimental-wasm-threads --experimental-wasm-bulk-memory and/or recent version)' ), Error('bad memory')) ); qe(), (He = _e.buffer.byteLength); var Qe = [], Be = [], Ce = [], Se = 0, je = null; function Tt() { if ((Se--, Se == 0 && je)) { var g = je; (je = null), g(); } } function xt(g) { throw ( ((g = 'Aborted(' + g + ')'), Y(g), (ue = !0), (pe = 1), (g = new WebAssembly.RuntimeError(g + '. Build with -sASSERTIONS for more info.')), p(g), g) ); } var Mt = (g) => g.startsWith('data:application/octet-stream;base64,'), Ot = (g) => g.startsWith('file://'), gt; (gt = 'ort-wasm-threaded.wasm'), Mt(gt) || (gt = B(gt)); function yt(g) { if (re) return re(g); throw 'both async and sync fetching of the wasm failed'; } function Or(g) { if (v || S) { if (typeof fetch == 'function' && !Ot(g)) return fetch(g, { credentials: 'same-origin' }) .then((x) => { if (!x.ok) throw "failed to load wasm binary file at '" + g + "'"; return x.arrayBuffer(); }) .catch(() => yt(g)); if (Q) return new Promise((x, P) => { Q(g, (D) => x(new Uint8Array(D)), P); }); } return Promise.resolve().then(() => yt(g)); } function Ht(g, x, P) { return Or(g) .then((D) => WebAssembly.instantiate(D, x)) .then((D) => D) .then(P, (D) => { Y(`failed to asynchronously prepare wasm: ${D}`), xt(D); }); } function Sr(g, x) { var P = gt; return typeof WebAssembly.instantiateStreaming != 'function' || Mt(P) || Ot(P) || E || typeof fetch != 'function' ? Ht(P, g, x) : fetch(P, { credentials: 'same-origin' }).then((D) => WebAssembly.instantiateStreaming(D, g).then(x, function (j) { return ( Y(`wasm streaming compile failed: ${j}`), Y('falling back to ArrayBuffer instantiation'), Ht(P, g, x) ); }) ); } var st, Bt = { 921276: (g, x, P, D) => { if (typeof a > 'u' || !a.cb) return 1; if ( ((g = Dt(g >>> 0)), g.startsWith('./') && (g = g.substring(2)), (g = a.cb.get(g)), !g) ) return 2; if (((x >>>= 0), (P >>>= 0), (D >>>= 0), x + P > g.byteLength)) return 3; try { return s().set(g.subarray(x, x + P), D >>> 0), 0; } catch { return 4; } }, }; function At(g) { (this.name = 'ExitStatus'), (this.message = `Program terminated with exit(${g})`), (this.status = g); } var It = (g) => { g.terminate(), (g.onmessage = () => {}); }, Ar = (g) => { se.Pa.length == 0 && (Qt(), se.Ya(se.Pa[0])); var x = se.Pa.pop(); if (!x) return 6; se.Qa.push(x), (se.Ma[g.Oa] = x), (x.Oa = g.Oa); var P = { cmd: 'run', start_routine: g.kb, arg: g.hb, pthread_ptr: g.Oa }; return E && x.unref(), x.postMessage(P, g.qb), 0; }, Et = 0, Yt = typeof TextDecoder < 'u' ? new TextDecoder('utf8') : void 0, Ir = (g, x, P) => { x >>>= 0; var D = x + P; for (P = x; g[P] && !(P >= D); ) ++P; if (16 < P - x && g.buffer && Yt) return Yt.decode( g.buffer instanceof SharedArrayBuffer ? g.slice(x, P) : g.subarray(x, P) ); for (D = ''; x < P; ) { var j = g[x++]; if (j & 128) { var z = g[x++] & 63; if ((j & 224) == 192) D += String.fromCharCode(((j & 31) << 6) | z); else { var K = g[x++] & 63; (j = (j & 240) == 224 ? ((j & 15) << 12) | (z << 6) | K : ((j & 7) << 18) | (z << 12) | (K << 6) | (g[x++] & 63)), 65536 > j ? (D += String.fromCharCode(j)) : ((j -= 65536), (D += String.fromCharCode(55296 | (j >> 10), 56320 | (j & 1023)))); } } else D += String.fromCharCode(j); } return D; }, Dt = (g, x) => ((g >>>= 0) ? Ir(s(), g, x) : ''), Zr = (g) => { var x = xn(); return (g = g()), Yr(x), g; }; function H(g, x) { var P = arguments.length - 2, D = arguments; return Zr(() => { for (var j = On(8 * P), z = j >>> 3, K = 0; K < P; K++) { var $e = D[2 + K]; r()[(z + K) >>> 0] = $e; } return si(g, P, j, x); }); } function Kt(g) { if (A) return H(0, 1, g); (pe = g), 0 < Et || (se.lb(), a.onExit?.(g), (ue = !0)), T(g, new At(g)); } var Gt = (g) => { if (((pe = g), A)) throw (Nt(g), 'unwind'); Kt(g); }; function Fr() { for (var g = a.numThreads; g--; ) Qt(); Qe.unshift(() => { Se++, jr(() => Tt()); }); } function Qt() { var g = B('ort-wasm-threaded.worker.js'); (g = new Worker(g)), se.Pa.push(g); } function jr(g) { A ? g() : Promise.all(se.Pa.map(se.Ya)).then(g); } var se = { Pa: [], Qa: [], bb: [], Ma: {}, Wa() { A ? ((se.receiveObjectTransfer = se.jb), (se.threadInitTLS = se.ab), (se.setExitStatus = se.$a)) : Fr(); }, $a: (g) => (pe = g), tb: ['$terminateWorker'], lb: () => { for (var g of se.Qa) It(g); for (g of se.Pa) It(g); (se.Pa = []), (se.Qa = []), (se.Ma = []); }, Za: (g) => { var x = g.Oa; delete se.Ma[x], se.Pa.push(g), se.Qa.splice(se.Qa.indexOf(g), 1), (g.Oa = 0), wn(x); }, jb() {}, ab() { se.bb.forEach((g) => g()); }, Ya: (g) => new Promise((x) => { (g.onmessage = (z) => { z = z.data; var K = z.cmd; if (z.targetThread && z.targetThread != Hr()) { var $e = se.Ma[z.targetThread]; $e ? $e.postMessage(z, z.transferList) : Y( `Internal error! Worker sent a message "${K}" to target pthread ${z.targetThread}, but that thread no longer exists!` ); } else K === 'checkMailbox' ? qr() : K === 'spawnThread' ? Ar(z) : K === 'cleanupThread' ? se.Za(se.Ma[z.thread]) : K === 'killThread' ? ((z = z.thread), (K = se.Ma[z]), delete se.Ma[z], It(K), wn(z), se.Qa.splice(se.Qa.indexOf(K), 1), (K.Oa = 0)) : K === 'cancelThread' ? se.Ma[z.thread].postMessage({ cmd: 'cancel' }) : K === 'loaded' ? ((g.loaded = !0), E && !g.Oa && g.unref(), x(g)) : K === 'alert' ? alert(`Thread ${z.threadId}: ${z.text}`) : z.target === 'setimmediate' ? g.postMessage(z) : K === 'callHandler' ? a[z.handler](...z.args) : K && Y(`worker sent an unknown command ${K}`); }), (g.onerror = (z) => { throw (Y(`worker sent an error! ${z.filename}:${z.lineno}: ${z.message}`), z); }), E && (g.on('message', (z) => g.onmessage({ data: z })), g.on('error', (z) => g.onerror(z))); var P = [], D = ['onExit'], j; for (j of D) a.hasOwnProperty(j) && P.push(j); g.postMessage({ cmd: 'load', handlers: P, urlOrBlob: a.mainScriptUrlOrBlob || i, wasmMemory: _e, wasmModule: he, }); }), }; a.PThread = se; var Wt = (g) => { for (; 0 < g.length; ) g.shift()(a); }; a.establishStackSpace = () => { var g = Hr(), x = f()[((g + 52) >>> 2) >>> 0]; (g = f()[((g + 56) >>> 2) >>> 0]), ci(x, x - g), Yr(x); }; function Nt(g) { if (A) return H(1, 0, g); Gt(g); } var Lt = [], O; a.invokeEntryPoint = (g, x) => { var P = Lt[g]; P || (g >= Lt.length && (Lt.length = g + 1), (Lt[g] = P = O.get(g))), (g = P(x)), 0 < Et ? se.$a(g) : vn(g); }; function M(g) { (this.Va = g - 24), (this.gb = function (x) { f()[((this.Va + 4) >>> 2) >>> 0] = x; }), (this.fb = function (x) { f()[((this.Va + 8) >>> 2) >>> 0] = x; }), (this.Wa = function (x, P) { this.eb(), this.gb(x), this.fb(P); }), (this.eb = function () { f()[((this.Va + 16) >>> 2) >>> 0] = 0; }); } var I = 0; function k(g, x, P, D) { return A ? H(2, 1, g, x, P, D) : G(g, x, P, D); } function G(g, x, P, D) { if (((g >>>= 0), (x >>>= 0), (P >>>= 0), (D >>>= 0), typeof SharedArrayBuffer > 'u')) return ( Y( 'Current environment does not support SharedArrayBuffer, pthreads are not available!' ), 6 ); var j = []; return A && j.length === 0 ? k(g, x, P, D) : ((g = { kb: P, Oa: g, hb: D, qb: j }), A ? ((g.sb = 'spawnThread'), postMessage(g, j), 0) : Ar(g)); } function ne(g, x, P) { return A ? H(3, 1, g, x, P) : 0; } function ge(g, x) { if (A) return H(4, 1, g, x); } var Ue = (g) => { for (var x = 0, P = 0; P < g.length; ++P) { var D = g.charCodeAt(P); 127 >= D ? x++ : 2047 >= D ? (x += 2) : 55296 <= D && 57343 >= D ? ((x += 4), ++P) : (x += 3); } return x; }, et = (g, x, P, D) => { if (((P >>>= 0), !(0 < D))) return 0; var j = P; D = P + D - 1; for (var z = 0; z < g.length; ++z) { var K = g.charCodeAt(z); if (55296 <= K && 57343 >= K) { var $e = g.charCodeAt(++z); K = (65536 + ((K & 1023) << 10)) | ($e & 1023); } if (127 >= K) { if (P >= D) break; x[P++ >>> 0] = K; } else { if (2047 >= K) { if (P + 1 >= D) break; x[P++ >>> 0] = 192 | (K >> 6); } else { if (65535 >= K) { if (P + 2 >= D) break; x[P++ >>> 0] = 224 | (K >> 12); } else { if (P + 3 >= D) break; (x[P++ >>> 0] = 240 | (K >> 18)), (x[P++ >>> 0] = 128 | ((K >> 12) & 63)); } x[P++ >>> 0] = 128 | ((K >> 6) & 63); } x[P++ >>> 0] = 128 | (K & 63); } } return (x[P >>> 0] = 0), P - j; }, Ze = (g, x, P) => et(g, s(), x, P); function Je(g, x) { if (A) return H(5, 1, g, x); } function er(g, x, P) { if (A) return H(6, 1, g, x, P); } function tr(g, x, P) { return A ? H(7, 1, g, x, P) : 0; } function C(g, x) { if (A) return H(8, 1, g, x); } function Te(g, x, P) { if (A) return H(9, 1, g, x, P); } function Ie(g, x, P, D) { if (A) return H(10, 1, g, x, P, D); } function at(g, x, P, D) { if (A) return H(11, 1, g, x, P, D); } function lr(g, x, P, D) { if (A) return H(12, 1, g, x, P, D); } function An(g) { if (A) return H(13, 1, g); } function In(g, x) { if (A) return H(14, 1, g, x); } function jn(g, x, P) { if (A) return H(15, 1, g, x, P); } function Jr(g) { (g >>>= 0), typeof Atomics.rb == 'function' && (Atomics.rb(d(), g >>> 2, g).value.then(qr), (g += 128), Atomics.store(d(), g >>> 2, 1)); } a.__emscripten_thread_mailbox_await = Jr; var qr = () => { var g = Hr(); if (g && (Jr(g), (g = ai), !ue)) try { if ((g(), !(0 < Et))) try { A ? vn(pe) : Gt(pe); } catch (x) { x instanceof At || x == 'unwind' || T(1, x); } } catch (x) { x instanceof At || x == 'unwind' || T(1, x); } }; a.checkMailbox = qr; var rn = [], qt = (g) => g % 4 === 0 && (g % 100 !== 0 || g % 400 === 0), qn = [0, 31, 60, 91, 121, 152, 182, 213, 244, 274, 305, 335], Hn = [0, 31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334]; function Yn(g, x, P, D, j, z, K, $e) { return A ? H(16, 1, g, x, P, D, j, z, K, $e) : -52; } function Mo(g, x, P, D, j, z, K) { if (A) return H(17, 1, g, x, P, D, j, z, K); } var No = (g) => { var x = Ue(g) + 1, P = oi(x); return P && Ze(g, P, x), P; }, nn = [], on = {}, Ro = () => { if (!_n) { var g = { USER: 'web_user', LOGNAME: 'web_user', PATH: '/', PWD: '/', HOME: '/home/web_user', LANG: ( (typeof navigator == 'object' && navigator.languages && navigator.languages[0]) || 'C' ).replace('-', '_') + '.UTF-8', _: y || './this.program', }, x; for (x in on) on[x] === void 0 ? delete g[x] : (g[x] = on[x]); var P = []; for (x in g) P.push(`${x}=${g[x]}`); _n = P; } return _n; }, _n; function Bo(g, x) { if (A) return H(18, 1, g, x); (g >>>= 0), (x >>>= 0); var P = 0; return ( Ro().forEach((D, j) => { var z = x + P; for (j = f()[((g + 4 * j) >>> 2) >>> 0] = z, z = 0; z < D.length; ++z) n()[(j++ >>> 0) >>> 0] = D.charCodeAt(z); (n()[(j >>> 0) >>> 0] = 0), (P += D.length + 1); }), 0 ); } function Uo(g, x) { if (A) return H(19, 1, g, x); (g >>>= 0), (x >>>= 0); var P = Ro(); f()[(g >>> 2) >>> 0] = P.length; var D = 0; return P.forEach((j) => (D += j.length + 1)), (f()[(x >>> 2) >>> 0] = D), 0; } function zo(g) { return A ? H(20, 1, g) : 52; } function Vo(g, x, P, D) { return A ? H(21, 1, g, x, P, D) : 52; } function Go(g, x, P, D, j) { return A ? H(22, 1, g, x, P, D, j) : 70; } var zs = [null, [], []]; function Wo(g, x, P, D) { if (A) return H(23, 1, g, x, P, D); (x >>>= 0), (P >>>= 0), (D >>>= 0); for (var j = 0, z = 0; z < P; z++) { var K = f()[(x >>> 2) >>> 0], $e = f()[((x + 4) >>> 2) >>> 0]; x += 8; for (var ct = 0; ct < $e; ct++) { var ze = s()[(K + ct) >>> 0], it = zs[g]; ze === 0 || ze === 10 ? ((g === 1 ? Me : Y)(Ir(it, 0)), (it.length = 0)) : it.push(ze); } j += $e; } return (f()[(D >>> 2) >>> 0] = j), 0; } var Jo = [31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31], ti = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]; function Vs(g) { var x = Array(Ue(g) + 1); return et(g, x, 0, x.length), x; } var Gs = (g, x) => { n().set(g, x >>> 0); }; function ri(g, x, P, D) { function j(N, Ae, Le) { for (N = typeof N == 'number' ? N.toString() : N || ''; N.length < Ae; ) N = Le[0] + N; return N; } function z(N, Ae) { return j(N, Ae, '0'); } function K(N, Ae) { function Le(Ns) { return 0 > Ns ? -1 : 0 < Ns ? 1 : 0; } var Rt; return ( (Rt = Le(N.getFullYear() - Ae.getFullYear())) === 0 && (Rt = Le(N.getMonth() - Ae.getMonth())) === 0 && (Rt = Le(N.getDate() - Ae.getDate())), Rt ); } function $e(N) { switch (N.getDay()) { case 0: return new Date(N.getFullYear() - 1, 11, 29); case 1: return N; case 2: return new Date(N.getFullYear(), 0, 3); case 3: return new Date(N.getFullYear(), 0, 2); case 4: return new Date(N.getFullYear(), 0, 1); case 5: return new Date(N.getFullYear() - 1, 11, 31); case 6: return new Date(N.getFullYear() - 1, 11, 30); } } function ct(N) { var Ae = N.Ra; for (N = new Date(new Date(N.Sa + 1900, 0, 1).getTime()); 0 < Ae; ) { var Le = N.getMonth(), Rt = (qt(N.getFullYear()) ? Jo : ti)[Le]; if (Ae > Rt - N.getDate()) (Ae -= Rt - N.getDate() + 1), N.setDate(1), 11 > Le ? N.setMonth(Le + 1) : (N.setMonth(0), N.setFullYear(N.getFullYear() + 1)); else { N.setDate(N.getDate() + Ae); break; } } return ( (Le = new Date(N.getFullYear() + 1, 0, 4)), (Ae = $e(new Date(N.getFullYear(), 0, 4))), (Le = $e(Le)), 0 >= K(Ae, N) ? 0 >= K(Le, N) ? N.getFullYear() + 1 : N.getFullYear() : N.getFullYear() - 1 ); } (g >>>= 0), (x >>>= 0), (P >>>= 0), (D >>>= 0); var ze = f()[((D + 40) >>> 2) >>> 0]; (D = { ob: d()[(D >>> 2) >>> 0], nb: d()[((D + 4) >>> 2) >>> 0], Ta: d()[((D + 8) >>> 2) >>> 0], Xa: d()[((D + 12) >>> 2) >>> 0], Ua: d()[((D + 16) >>> 2) >>> 0], Sa: d()[((D + 20) >>> 2) >>> 0], Na: d()[((D + 24) >>> 2) >>> 0], Ra: d()[((D + 28) >>> 2) >>> 0], ub: d()[((D + 32) >>> 2) >>> 0], mb: d()[((D + 36) >>> 2) >>> 0], pb: ze ? Dt(ze) : '', }), (P = Dt(P)), (ze = { '%c': '%a %b %d %H:%M:%S %Y', '%D': '%m/%d/%y', '%F': '%Y-%m-%d', '%h': '%b', '%r': '%I:%M:%S %p', '%R': '%H:%M', '%T': '%H:%M:%S', '%x': '%m/%d/%y', '%X': '%H:%M:%S', '%Ec': '%c', '%EC': '%C', '%Ex': '%m/%d/%y', '%EX': '%H:%M:%S', '%Ey': '%y', '%EY': '%Y', '%Od': '%d', '%Oe': '%e', '%OH': '%H', '%OI': '%I', '%Om': '%m', '%OM': '%M', '%OS': '%S', '%Ou': '%u', '%OU': '%U', '%OV': '%V', '%Ow': '%w', '%OW': '%W', '%Oy': '%y', }); for (var it in ze) P = P.replace(new RegExp(it, 'g'), ze[it]); var fi = 'Sunday Monday Tuesday Wednesday Thursday Friday Saturday'.split(' '), Cs = 'January February March April May June July August September October November December'.split( ' ' ); (ze = { '%a': (N) => fi[N.Na].substring(0, 3), '%A': (N) => fi[N.Na], '%b': (N) => Cs[N.Ua].substring(0, 3), '%B': (N) => Cs[N.Ua], '%C': (N) => z(((N.Sa + 1900) / 100) | 0, 2), '%d': (N) => z(N.Xa, 2), '%e': (N) => j(N.Xa, 2, ' '), '%g': (N) => ct(N).toString().substring(2), '%G': (N) => ct(N), '%H': (N) => z(N.Ta, 2), '%I': (N) => ((N = N.Ta), N == 0 ? (N = 12) : 12 < N && (N -= 12), z(N, 2)), '%j': (N) => { for (var Ae = 0, Le = 0; Le <= N.Ua - 1; Ae += (qt(N.Sa + 1900) ? Jo : ti)[Le++]); return z(N.Xa + Ae, 3); }, '%m': (N) => z(N.Ua + 1, 2), '%M': (N) => z(N.nb, 2), '%n': () => ` `, '%p': (N) => (0 <= N.Ta && 12 > N.Ta ? 'AM' : 'PM'), '%S': (N) => z(N.ob, 2), '%t': () => ' ', '%u': (N) => N.Na || 7, '%U': (N) => z(Math.floor((N.Ra + 7 - N.Na) / 7), 2), '%V': (N) => { var Ae = Math.floor((N.Ra + 7 - ((N.Na + 6) % 7)) / 7); if ((2 >= (N.Na + 371 - N.Ra - 2) % 7 && Ae++, Ae)) Ae == 53 && ((Le = (N.Na + 371 - N.Ra) % 7), Le == 4 || (Le == 3 && qt(N.Sa)) || (Ae = 1)); else { Ae = 52; var Le = (N.Na + 7 - N.Ra - 1) % 7; (Le == 4 || (Le == 5 && qt((N.Sa % 400) - 1))) && Ae++; } return z(Ae, 2); }, '%w': (N) => N.Na, '%W': (N) => z(Math.floor((N.Ra + 7 - ((N.Na + 6) % 7)) / 7), 2), '%y': (N) => (N.Sa + 1900).toString().substring(2), '%Y': (N) => N.Sa + 1900, '%z': (N) => { N = N.mb; var Ae = 0 <= N; return ( (N = Math.abs(N) / 60), (Ae ? '+' : '-') + ('0000' + ((N / 60) * 100 + (N % 60))).slice(-4) ); }, '%Z': (N) => N.pb, '%%': () => '%', }), (P = P.replace(/%%/g, '\0\0')); for (it in ze) P.includes(it) && (P = P.replace(new RegExp(it, 'g'), ze[it](D))); return ( (P = P.replace(/\0\0/g, '%')), (it = Vs(P)), it.length > x ? 0 : (Gs(it, g), it.length - 1) ); } se.Wa(); var Ws = [ Kt, Nt, k, ne, ge, Je, er, tr, C, Te, Ie, at, lr, An, In, jn, Yn, Mo, Bo, Uo, zo, Vo, Go, Wo, ], qs = { b: function (g, x, P) { throw ((g >>>= 0), new M(g).Wa(x >>> 0, P >>> 0), (I = g), I); }, L: function (g) { ii(g >>> 0, !S, 1, !v, 131072, !1), se.ab(); }, j: function (g) { (g >>>= 0), A ? postMessage({ cmd: 'cleanupThread', thread: g }) : se.Za(se.Ma[g]); }, H: G, h: ne, S: ge, D: Je, F: er, T: tr, Q: C, J: Te, P: Ie, n: at, E: lr, B: An, R: In, C: jn, p: () => 1, z: function (g, x) { (g >>>= 0), g == x >>> 0 ? setTimeout(() => qr()) : A ? postMessage({ targetThread: g, cmd: 'checkMailbox' }) : (g = se.Ma[g]) && g.postMessage({ cmd: 'checkMailbox' }); }, I: function (g, x, P, D) { (x >>>= 0), (rn.length = P), (D = (D >>> 0) >>> 3); for (var j = 0; j < P; j++) rn[j] = r()[(D + j) >>> 0]; return ( (g = 0 > g ? Bt[-g - 1] : Ws[g]), (se.ib = x), (x = g.apply(null, rn)), (se.ib = 0), x ); }, K: Jr, o: function (g) { E && se.Ma[g >>> 0].ref(); }, s: function (g, x, P) { (g = (x + 2097152) >>> 0 < 4194305 - !!g ? (g >>> 0) + 4294967296 * x : NaN), (P >>>= 0), (g = new Date(1e3 * g)), (d()[(P >>> 2) >>> 0] = g.getUTCSeconds()), (d()[((P + 4) >>> 2) >>> 0] = g.getUTCMinutes()), (d()[((P + 8) >>> 2) >>> 0] = g.getUTCHours()), (d()[((P + 12) >>> 2) >>> 0] = g.getUTCDate()), (d()[((P + 16) >>> 2) >>> 0] = g.getUTCMonth()), (d()[((P + 20) >>> 2) >>> 0] = g.getUTCFullYear() - 1900), (d()[((P + 24) >>> 2) >>> 0] = g.getUTCDay()), (g = ((g.getTime() - Date.UTC(g.getUTCFullYear(), 0, 1, 0, 0, 0, 0)) / 864e5) | 0), (d()[((P + 28) >>> 2) >>> 0] = g); }, t: function (g, x, P) { (g = (x + 2097152) >>> 0 < 4194305 - !!g ? (g >>> 0) + 4294967296 * x : NaN), (P >>>= 0), (g = new Date(1e3 * g)), (d()[(P >>> 2) >>> 0] = g.getSeconds()), (d()[((P + 4) >>> 2) >>> 0] = g.getMinutes()), (d()[((P + 8) >>> 2) >>> 0] = g.getHours()), (d()[((P + 12) >>> 2) >>> 0] = g.getDate()), (d()[((P + 16) >>> 2) >>> 0] = g.getMonth()), (d()[((P + 20) >>> 2) >>> 0] = g.getFullYear() - 1900), (d()[((P + 24) >>> 2) >>> 0] = g.getDay()), (x = ((qt(g.getFullYear()) ? qn : Hn)[g.getMonth()] + g.getDate() - 1) | 0), (d()[((P + 28) >>> 2) >>> 0] = x), (d()[((P + 36) >>> 2) >>> 0] = -(60 * g.getTimezoneOffset())), (x = new Date(g.getFullYear(), 6, 1).getTimezoneOffset()); var D = new Date(g.getFullYear(), 0, 1).getTimezoneOffset(); (g = (x != D && g.getTimezoneOffset() == Math.min(D, x)) | 0), (d()[((P + 32) >>> 2) >>> 0] = g); }, u: function (g) { g >>>= 0; var x = new Date( d()[((g + 20) >>> 2) >>> 0] + 1900, d()[((g + 16) >>> 2) >>> 0], d()[((g + 12) >>> 2) >>> 0], d()[((g + 8) >>> 2) >>> 0], d()[((g + 4) >>> 2) >>> 0], d()[(g >>> 2) >>> 0], 0 ), P = d()[((g + 32) >>> 2) >>> 0], D = x.getTimezoneOffset(), j = new Date(x.getFullYear(), 6, 1).getTimezoneOffset(), z = new Date(x.getFullYear(), 0, 1).getTimezoneOffset(), K = Math.min(z, j); return ( 0 > P ? (d()[((g + 32) >>> 2) >>> 0] = +(j != z && K == D)) : 0 < P != (K == D) && ((j = Math.max(z, j)), x.setTime(x.getTime() + 6e4 * ((0 < P ? K : j) - D))), (d()[((g + 24) >>> 2) >>> 0] = x.getDay()), (P = ((qt(x.getFullYear()) ? qn : Hn)[x.getMonth()] + x.getDate() - 1) | 0), (d()[((g + 28) >>> 2) >>> 0] = P), (d()[(g >>> 2) >>> 0] = x.getSeconds()), (d()[((g + 4) >>> 2) >>> 0] = x.getMinutes()), (d()[((g + 8) >>> 2) >>> 0] = x.getHours()), (d()[((g + 12) >>> 2) >>> 0] = x.getDate()), (d()[((g + 16) >>> 2) >>> 0] = x.getMonth()), (d()[((g + 20) >>> 2) >>> 0] = x.getYear()), (g = x.getTime()), isNaN(g) ? ((d()[(ni() >>> 2) >>> 0] = 61), (g = -1)) : (g /= 1e3), ui( ((st = g), 1 <= +Math.abs(st) ? 0 < st ? +Math.floor(st / 4294967296) >>> 0 : ~~+Math.ceil((st - +(~~st >>> 0)) / 4294967296) >>> 0 : 0) ), g >>> 0 ); }, q: Yn, r: Mo, y: function (g, x, P) { function D(ze) { return (ze = ze.toTimeString().match(/\(([A-Za-z ]+)\)$/)) ? ze[1] : 'GMT'; } (g >>>= 0), (x >>>= 0), (P >>>= 0); var j = new Date().getFullYear(), z = new Date(j, 0, 1), K = new Date(j, 6, 1); j = z.getTimezoneOffset(); var $e = K.getTimezoneOffset(), ct = Math.max(j, $e); (f()[(g >>> 2) >>> 0] = 60 * ct), (d()[(x >>> 2) >>> 0] = +(j != $e)), (g = D(z)), (x = D(K)), (g = No(g)), (x = No(x)), $e < j ? ((f()[(P >>> 2) >>> 0] = g), (f()[((P + 4) >>> 2) >>> 0] = x)) : ((f()[(P >>> 2) >>> 0] = x), (f()[((P + 4) >>> 2) >>> 0] = g)); }, c: () => { xt(''); }, O: function (g, x, P) { (g >>>= 0), (x >>>= 0), (P >>>= 0), (nn.length = 0); for (var D; (D = s()[x++ >>> 0]); ) { var j = D != 105; (j &= D != 112), (P += j && P % 8 ? 4 : 0), nn.push( D == 112 ? f()[(P >>> 2) >>> 0] : D == 105 ? d()[(P >>> 2) >>> 0] : r()[(P >>> 3) >>> 0] ), (P += j ? 8 : 4); } return Bt[g].apply(null, nn); }, k: () => {}, i: () => Date.now(), U: () => { throw ((Et += 1), 'unwind'); }, A: function () { return 4294901760; }, e: () => performance.timeOrigin + performance.now(), f: () => (E ? (Lp(), rr(Dp)).cpus().length : navigator.hardwareConcurrency), x: function (g) { g >>>= 0; var x = s().length; if (g <= x || 4294901760 < g) return !1; for (var P = 1; 4 >= P; P *= 2) { var D = x * (1 + 0.2 / P); D = Math.min(D, g + 100663296); var j = Math; D = Math.max(g, D); e: { j = (j.min.call(j, 4294901760, D + ((65536 - (D % 65536)) % 65536)) - _e.buffer.byteLength + 65535) / 65536; try { _e.grow(j), qe(); var z = 1; break e; } catch {} z = void 0; } if (z) return !0; } return !1; }, M: Bo, N: Uo, G: Gt, g: zo, m: Vo, v: Go, l: Wo, a: _e || a.wasmMemory, w: ri, d: function (g, x, P, D) { return ri(g >>> 0, x >>> 0, P >>> 0, D >>> 0); }, }, ie = (function () { function g(P, D) { return ( (ie = P.exports), (ie = Hs()), se.bb.push(ie.za), (O = ie.Aa), Be.unshift(ie.V), (he = D), Tt(), ie ); } var x = { a: qs }; if ((Se++, a.instantiateWasm)) try { return a.instantiateWasm(x, g); } catch (P) { Y(`Module.instantiateWasm callback failed with error: ${P}`), p(P); } return ( Sr(x, function (P) { g(P.instance, P.module); }).catch(p), {} ); })(); (a._OrtInit = (g, x) => (a._OrtInit = ie.W)(g, x)), (a._OrtGetLastError = (g, x) => (a._OrtGetLastError = ie.X)(g, x)), (a._OrtCreateSessionOptions = (g, x, P, D, j, z, K, $e, ct, ze) => (a._OrtCreateSessionOptions = ie.Y)(g, x, P, D, j, z, K, $e, ct, ze)), (a._OrtAppendExecutionProvider = (g, x) => (a._OrtAppendExecutionProvider = ie.Z)(g, x)), (a._OrtAddFreeDimensionOverride = (g, x, P) => (a._OrtAddFreeDimensionOverride = ie._)(g, x, P)), (a._OrtAddSessionConfigEntry = (g, x, P) => (a._OrtAddSessionConfigEntry = ie.$)(g, x, P)), (a._OrtReleaseSessionOptions = (g) => (a._OrtReleaseSessionOptions = ie.aa)(g)), (a._OrtCreateSession = (g, x, P) => (a._OrtCreateSession = ie.ba)(g, x, P)), (a._OrtReleaseSession = (g) => (a._OrtReleaseSession = ie.ca)(g)), (a._OrtGetInputOutputCount = (g, x, P) => (a._OrtGetInputOutputCount = ie.da)(g, x, P)), (a._OrtGetInputName = (g, x) => (a._OrtGetInputName = ie.ea)(g, x)), (a._OrtGetOutputName = (g, x) => (a._OrtGetOutputName = ie.fa)(g, x)), (a._OrtFree = (g) => (a._OrtFree = ie.ga)(g)), (a._OrtCreateTensor = (g, x, P, D, j, z) => (a._OrtCreateTensor = ie.ha)(g, x, P, D, j, z)), (a._OrtGetTensorData = (g, x, P, D, j) => (a._OrtGetTensorData = ie.ia)(g, x, P, D, j)), (a._OrtReleaseTensor = (g) => (a._OrtReleaseTensor = ie.ja)(g)), (a._OrtCreateRunOptions = (g, x, P, D) => (a._OrtCreateRunOptions = ie.ka)(g, x, P, D)), (a._OrtAddRunConfigEntry = (g, x, P) => (a._OrtAddRunConfigEntry = ie.la)(g, x, P)), (a._OrtReleaseRunOptions = (g) => (a._OrtReleaseRunOptions = ie.ma)(g)), (a._OrtCreateBinding = (g) => (a._OrtCreateBinding = ie.na)(g)), (a._OrtBindInput = (g, x, P) => (a._OrtBindInput = ie.oa)(g, x, P)), (a._OrtBindOutput = (g, x, P, D) => (a._OrtBindOutput = ie.pa)(g, x, P, D)), (a._OrtClearBoundOutputs = (g) => (a._OrtClearBoundOutputs = ie.qa)(g)), (a._OrtReleaseBinding = (g) => (a._OrtReleaseBinding = ie.ra)(g)), (a._OrtRunWithBinding = (g, x, P, D, j) => (a._OrtRunWithBinding = ie.sa)(g, x, P, D, j)), (a._OrtRun = (g, x, P, D, j, z, K, $e) => (a._OrtRun = ie.ta)(g, x, P, D, j, z, K, $e)), (a._OrtEndProfiling = (g) => (a._OrtEndProfiling = ie.ua)(g)); var ni = () => (ni = ie.va)(), Hr = (a._pthread_self = () => (Hr = a._pthread_self = ie.wa)()), oi = (a._malloc = (g) => (oi = a._malloc = ie.xa)(g)); (a._free = (g) => (a._free = ie.ya)(g)), (a.__emscripten_tls_init = () => (a.__emscripten_tls_init = ie.za)()); var ii = (a.__emscripten_thread_init = (g, x, P, D, j, z) => (ii = a.__emscripten_thread_init = ie.Ba)(g, x, P, D, j, z)); a.__emscripten_thread_crashed = () => (a.__emscripten_thread_crashed = ie.Ca)(); var si = (g, x, P, D) => (si = ie.Da)(g, x, P, D), wn = (g) => (wn = ie.Ea)(g), vn = (a.__emscripten_thread_exit = (g) => (vn = a.__emscripten_thread_exit = ie.Fa)(g)), ai = () => (ai = ie.Ga)(), ui = (g) => (ui = ie.Ha)(g), ci = (g, x) => (ci = ie.Ia)(g, x), xn = () => (xn = ie.Ja)(), Yr = (g) => (Yr = ie.Ka)(g), On = (g) => (On = ie.La)(g); function Hs() { var g = ie; g = Object.assign({}, g); var x = (D) => () => D() >>> 0, P = (D) => (j) => D(j) >>> 0; return ( (g.va = x(g.va)), (g.wa = x(g.wa)), (g.xa = P(g.xa)), (g.emscripten_main_runtime_thread_id = x(g.emscripten_main_runtime_thread_id)), (g.Ja = x(g.Ja)), (g.La = P(g.La)), g ); } (a.wasmMemory = _e), (a.stackAlloc = On), (a.stackSave = xn), (a.stackRestore = Yr), (a.keepRuntimeAlive = () => 0 < Et), (a.UTF8ToString = Dt), (a.stringToUTF8 = Ze), (a.lengthBytesUTF8 = Ue), (a.ExitStatus = At), (a.PThread = se); var Xr; je = function g() { Xr || di(), Xr || (je = g); }; function di() { if (!(0 < Se)) if (A) l(a), A || Wt(Be), startWorker(a); else { if (a.preRun) for (typeof a.preRun == 'function' && (a.preRun = [a.preRun]); a.preRun.length; ) Qe.unshift(a.preRun.shift()); Wt(Qe), 0 < Se || Xr || ((Xr = !0), (a.calledRun = !0), ue || (A || Wt(Be), l(a), A || Wt(Ce))); } } return di(), u.ready; } ); })(); typeof t == 'object' && typeof e == 'object' ? (e.exports = o) : typeof define == 'function' && define.amd && define([], () => o); }), kp = me((t, e) => { e.exports = '"use strict";var Module={},ENVIRONMENT_IS_NODE=typeof process=="object"&&typeof process.versions=="object"&&typeof process.versions.node=="string";if(ENVIRONMENT_IS_NODE){var nodeWorkerThreads=require("worker_threads"),parentPort=nodeWorkerThreads.parentPort;parentPort.on("message",e=>onmessage({data:e}));var fs=require("fs"),vm=require("vm");Object.assign(global,{self:global,require,Module,location:{href:__filename},Worker:nodeWorkerThreads.Worker,importScripts:e=>vm.runInThisContext(fs.readFileSync(e,"utf8"),{filename:e}),postMessage:e=>parentPort.postMessage(e),performance:global.performance||{now:Date.now}})}var initializedJS=!1;function threadPrintErr(){var e=Array.prototype.slice.call(arguments).join(" ");if(ENVIRONMENT_IS_NODE){fs.writeSync(2,e+`\n`);return}console.error(e)}function threadAlert(){var e=Array.prototype.slice.call(arguments).join(" ");postMessage({cmd:"alert",text:e,threadId:Module._pthread_self()})}var err=threadPrintErr;self.alert=threadAlert,Module.instantiateWasm=(e,t)=>{var a=Module.wasmModule;Module.wasmModule=null;var r=new WebAssembly.Instance(a,e);return t(r)},self.onunhandledrejection=e=>{throw e.reason||e};function handleMessage(e){try{if(e.data.cmd==="load"){let a=[];self.onmessage=r=>a.push(r),self.startWorker=r=>{Module=r,postMessage({cmd:"loaded"});for(let s of a)handleMessage(s);self.onmessage=handleMessage},Module.wasmModule=e.data.wasmModule;for(const r of e.data.handlers)Module[r]=(...s)=>{postMessage({cmd:"callHandler",handler:r,args:s})};if(Module.wasmMemory=e.data.wasmMemory,Module.buffer=Module.wasmMemory.buffer,Module.ENVIRONMENT_IS_PTHREAD=!0,typeof e.data.urlOrBlob=="string")importScripts(e.data.urlOrBlob);else{var t=URL.createObjectURL(e.data.urlOrBlob);importScripts(t),URL.revokeObjectURL(t)}ortWasmThreaded(Module)}else if(e.data.cmd==="run"){Module.__emscripten_thread_init(e.data.pthread_ptr,0,0,1),Module.__emscripten_thread_mailbox_await(e.data.pthread_ptr),Module.establishStackSpace(),Module.PThread.receiveObjectTransfer(e.data),Module.PThread.threadInitTLS(),initializedJS||(initializedJS=!0);try{Module.invokeEntryPoint(e.data.start_routine,e.data.arg)}catch(a){if(a!="unwind")throw a}}else e.data.cmd==="cancel"?Module._pthread_self()&&Module.__emscripten_thread_exit(-1):e.data.target==="setimmediate"||(e.data.cmd==="checkMailbox"?initializedJS&&Module.checkMailbox():e.data.cmd&&(err(`worker.js received unknown command ${e.data.cmd}`),err(e.data)))}catch(a){throw Module.__emscripten_thread_crashed?.(),a}}self.onmessage=handleMessage;\n'; }), Np, ig, aa, sa, Po, Bp, ag, sg, ug, Rp, Ee, zr = L(() => { (Np = Ap()), (ig = Cp()), (sa = !1), (Po = !1), (Bp = !1), (ag = (t) => { if (t === 1) return !1; if (typeof SharedArrayBuffer > 'u') return ( typeof self < 'u' && !self.crossOriginIsolated && console.warn( 'env.wasm.numThreads is set to ' + t + ', but this will not work unless you enable crossOriginIsolated mode. See https://web.dev/cross-origin-isolation-guide/ for more info.' ), !1 ); typeof process < 'u' && process.versions && process.versions.node && console.warn( 'env.wasm.numThreads is set to ' + t + ', however, currently onnxruntime-web does not support multi-threads in Node.js. Please consider using onnxruntime-node for performance critical scenarios.' ); try { return ( typeof MessageChannel < 'u' && new MessageChannel().port1.postMessage(new SharedArrayBuffer(1)), WebAssembly.validate( new Uint8Array([ 0, 97, 115, 109, 1, 0, 0, 0, 1, 4, 1, 96, 0, 0, 3, 2, 1, 0, 5, 4, 1, 3, 1, 1, 10, 11, 1, 9, 0, 65, 0, 254, 16, 2, 0, 26, 11, ]) ) ); } catch { return !1; } }), (sg = () => { try { return WebAssembly.validate( new Uint8Array([ 0, 97, 115, 109, 1, 0, 0, 0, 1, 4, 1, 96, 0, 0, 3, 2, 1, 0, 10, 30, 1, 28, 0, 65, 0, 253, 15, 253, 12, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 253, 186, 1, 26, 11, ]) ); } catch { return !1; } }), (ug = (t, e) => t ? e ? 'ort-wasm-simd-threaded.wasm' : 'ort-wasm-simd.wasm' : e ? 'ort-wasm-threaded.wasm' : 'ort-wasm.wasm'), (Rp = async (t) => { if (sa) return Promise.resolve(); if (Po) throw new Error("multiple calls to 'initializeWebAssembly()' detected."); if (Bp) throw new Error("previous call to 'initializeWebAssembly()' failed."); Po = !0; let e = t.initTimeout, o = t.numThreads, i = t.simd, u = ag(o), n = i && sg(), s = t.wasmPaths, d = typeof s == 'string' ? s : void 0, f = ug(n, u), r = typeof s == 'object' ? s[f] : void 0, a = !1, l = []; if ( (e > 0 && l.push( new Promise((p) => { setTimeout(() => { (a = !0), p(); }, e); }) ), l.push( new Promise((p, m) => { let y = u ? ig : Np, T = { locateFile: (v, S) => u && v.endsWith('.worker.js') && typeof Blob < 'u' ? URL.createObjectURL(new Blob([kp()], { type: 'text/javascript' })) : v.endsWith('.wasm') ? r || (d ?? S) + f : S + v, }; if (u) if (((T.numThreads = o), typeof Blob > 'u')) T.mainScriptUrlOrBlob = (void 0)(__dirname, 'ort-wasm-threaded.js'); else { let v = `var ortWasmThreaded=${y.toString()};`; T.mainScriptUrlOrBlob = new Blob([v], { type: 'text/javascript' }); } y(T).then( (v) => { (Po = !1), (sa = !0), (aa = v), p(); }, (v) => { (Po = !1), (Bp = !0), m(v); } ); }) ), await Promise.race(l), a) ) throw new Error(`WebAssembly backend initializing failed due to timeout: ${e}ms`); }), (Ee = () => { if (sa && aa) return aa; throw new Error('WebAssembly is not initialized yet.'); }); }), De, bn, Oe, Eo = L(() => { zr(), (De = (t, e) => { let o = Ee(), i = o.lengthBytesUTF8(t) + 1, u = o._malloc(i); return o.stringToUTF8(t, u, i), e.push(u), u; }), (bn = (t, e, o, i) => { if (typeof t == 'object' && t !== null) { if (o.has(t)) throw new Error('Circular reference in options'); o.add(t); } Object.entries(t).forEach(([u, n]) => { let s = e ? e + u : u; if (typeof n == 'object') bn(n, s + '.', o, i); else if (typeof n == 'string' || typeof n == 'number') i(s, n.toString()); else if (typeof n == 'boolean') i(s, n ? '1' : '0'); else throw new Error(`Can't handle extra config type: ${typeof n}`); }); }), (Oe = (t) => { let e = Ee(), o = e.stackSave(); try { let i = e.stackAlloc(8); e._OrtGetLastError(i, i + 4); let u = e.HEAP32[i / 4], n = e.HEAPU32[i / 4 + 1], s = n ? e.UTF8ToString(n) : ''; throw new Error(`${t} ERROR_CODE: ${u}, ERROR_MESSAGE: ${s}`); } finally { e.stackRestore(o); } }); }), Mp, Gp = L(() => { zr(), Eo(), (Mp = (t) => { let e = Ee(), o = 0, i = [], u = t || {}; try { if (t?.logSeverityLevel === void 0) u.logSeverityLevel = 2; else if ( typeof t.logSeverityLevel != 'number' || !Number.isInteger(t.logSeverityLevel) || t.logSeverityLevel < 0 || t.logSeverityLevel > 4 ) throw new Error(`log serverity level is not valid: ${t.logSeverityLevel}`); if (t?.logVerbosityLevel === void 0) u.logVerbosityLevel = 0; else if (typeof t.logVerbosityLevel != 'number' || !Number.isInteger(t.logVerbosityLevel)) throw new Error(`log verbosity level is not valid: ${t.logVerbosityLevel}`); t?.terminate === void 0 && (u.terminate = !1); let n = 0; return ( t?.tag !== void 0 && (n = De(t.tag, i)), (o = e._OrtCreateRunOptions(u.logSeverityLevel, u.logVerbosityLevel, !!u.terminate, n)), o === 0 && Oe("Can't create run options."), t?.extra !== void 0 && bn(t.extra, '', new WeakSet(), (s, d) => { let f = De(s, i), r = De(d, i); e._OrtAddRunConfigEntry(o, f, r) !== 0 && Oe(`Can't set a run config entry: ${s} - ${d}.`); }), [o, i] ); } catch (n) { throw (o !== 0 && e._OrtReleaseRunOptions(o), i.forEach((s) => e._free(s)), n); } }); }), lg, fg, cg, pg, Up, zp = L(() => { zr(), Eo(), (lg = (t) => { switch (t) { case 'disabled': return 0; case 'basic': return 1; case 'extended': return 2; case 'all': return 99; default: throw new Error(`unsupported graph optimization level: ${t}`); } }), (fg = (t) => { switch (t) { case 'sequential': return 0; case 'parallel': return 1; default: throw new Error(`unsupported execution mode: ${t}`); } }), (cg = (t) => { t.extra || (t.extra = {}), t.extra.session || (t.extra.session = {}); let e = t.extra.session; e.use_ort_model_bytes_directly || (e.use_ort_model_bytes_directly = '1'), t.executionProviders && t.executionProviders.some((o) => (typeof o == 'string' ? o : o.name) === 'webgpu') && (t.enableMemPattern = !1); }), (pg = (t, e, o) => { for (let i of e) { let u = typeof i == 'string' ? i : i.name; switch (u) { case 'webnn': if (((u = 'WEBNN'), typeof i != 'string')) { let s = i; if (s?.deviceType) { let d = De('deviceType', o), f = De(s.deviceType, o); Ee()._OrtAddSessionConfigEntry(t, d, f) !== 0 && Oe(`Can't set a session config entry: 'deviceType' - ${s.deviceType}.`); } if (s?.numThreads) { let d = s.numThreads; (typeof d != 'number' || !Number.isInteger(d) || d < 0) && (d = 0); let f = De('numThreads', o), r = De(d.toString(), o); Ee()._OrtAddSessionConfigEntry(t, f, r) !== 0 && Oe(`Can't set a session config entry: 'numThreads' - ${s.numThreads}.`); } if (s?.powerPreference) { let d = De('powerPreference', o), f = De(s.powerPreference, o); Ee()._OrtAddSessionConfigEntry(t, d, f) !== 0 && Oe( `Can't set a session config entry: 'powerPreference' - ${s.powerPreference}.` ); } } break; case 'webgpu': if (((u = 'JS'), typeof i != 'string')) { let s = i; if (s?.preferredLayout) { if (s.preferredLayout !== 'NCHW' && s.preferredLayout !== 'NHWC') throw new Error( `preferredLayout must be either 'NCHW' or 'NHWC': ${s.preferredLayout}` ); let d = De('preferredLayout', o), f = De(s.preferredLayout, o); Ee()._OrtAddSessionConfigEntry(t, d, f) !== 0 && Oe( `Can't set a session config entry: 'preferredLayout' - ${s.preferredLayout}.` ); } } break; case 'wasm': case 'cpu': continue; default: throw new Error(`not supported execution provider: ${u}`); } let n = De(u, o); Ee()._OrtAppendExecutionProvider(t, n) !== 0 && Oe(`Can't append execution provider: ${u}.`); } }), (Up = (t) => { let e = Ee(), o = 0, i = [], u = t || {}; cg(u); try { let n = lg(u.graphOptimizationLevel ?? 'all'), s = fg(u.executionMode ?? 'sequential'), d = typeof u.logId == 'string' ? De(u.logId, i) : 0, f = u.logSeverityLevel ?? 2; if (!Number.isInteger(f) || f < 0 || f > 4) throw new Error(`log serverity level is not valid: ${f}`); let r = u.logVerbosityLevel ?? 0; if (!Number.isInteger(r) || r < 0 || r > 4) throw new Error(`log verbosity level is not valid: ${r}`); let a = typeof u.optimizedModelFilePath == 'string' ? De(u.optimizedModelFilePath, i) : 0; if ( ((o = e._OrtCreateSessionOptions( n, !!u.enableCpuMemArena, !!u.enableMemPattern, s, !!u.enableProfiling, 0, d, f, r, a )), o === 0 && Oe("Can't create session options."), u.executionProviders && pg(o, u.executionProviders, i), u.freeDimensionOverrides) ) for (let [l, p] of Object.entries(u.freeDimensionOverrides)) { if (typeof l != 'string') throw new Error(`free dimension override name must be a string: ${l}`); if (typeof p != 'number' || !Number.isInteger(p) || p < 0) throw new Error(`free dimension override value must be a non-negative integer: ${p}`); let m = De(l, i); e._OrtAddFreeDimensionOverride(o, m, p) !== 0 && Oe(`Can't set a free dimension override: ${l} - ${p}.`); } return ( u.extra !== void 0 && bn(u.extra, '', new WeakSet(), (l, p) => { let m = De(l, i), y = De(p, i); e._OrtAddSessionConfigEntry(o, m, y) !== 0 && Oe(`Can't set a session config entry: ${l} - ${p}.`); }), [o, i] ); } catch (n) { throw (o !== 0 && e._OrtReleaseSessionOptions(o), i.forEach((s) => e._free(s)), n); } }); }), ua, Vp, la, Wp, Hp, Do, qp, fa = L(() => { (ua = (t) => { switch (t) { case 'int8': return 3; case 'uint8': return 2; case 'bool': return 9; case 'int16': return 5; case 'uint16': return 4; case 'int32': return 6; case 'uint32': return 12; case 'float16': return 10; case 'float32': return 1; case 'float64': return 11; case 'string': return 8; case 'int64': return 7; case 'uint64': return 13; default: throw new Error(`unsupported data type: ${t}`); } }), (Vp = (t) => { switch (t) { case 3: return 'int8'; case 2: return 'uint8'; case 9: return 'bool'; case 5: return 'int16'; case 4: return 'uint16'; case 6: return 'int32'; case 12: return 'uint32'; case 10: return 'float16'; case 1: return 'float32'; case 11: return 'float64'; case 8: return 'string'; case 7: return 'int64'; case 13: return 'uint64'; default: throw new Error(`unsupported data type: ${t}`); } }), (la = (t) => [void 0, 4, 1, 1, 2, 2, 4, 8, void 0, 1, 2, 8, 4, 8, void 0, void 0, void 0][t]), (Wp = (t) => { switch (t) { case 'float16': return Uint16Array; case 'float32': return Float32Array; case 'uint8': return Uint8Array; case 'int8': return Int8Array; case 'uint16': return Uint16Array; case 'int16': return Int16Array; case 'int32': return Int32Array; case 'bool': return Uint8Array; case 'float64': return Float64Array; case 'uint32': return Uint32Array; case 'int64': return BigInt64Array; case 'uint64': return BigUint64Array; default: throw new Error(`unsupported type: ${t}`); } }), (Hp = (t) => { switch (t) { case 'verbose': return 0; case 'info': return 1; case 'warning': return 2; case 'error': return 3; case 'fatal': return 4; default: throw new Error(`unsupported logging level: ${t}`); } }), (Do = (t) => t === 'float32' || t === 'int32' || t === 'int64' || t === 'bool' || t === 'float16' || t === 'uint32'), (qp = (t) => { switch (t) { case 'none': return 0; case 'cpu': return 1; case 'cpu-pinned': return 2; case 'texture': return 3; case 'gpu-buffer': return 4; default: throw new Error(`unsupported data location: ${t}`); } }); }), gn, ca = L(() => { gn = async (t) => { if (typeof t == 'string') if (typeof process < 'u' && process.versions && process.versions.node) try { return new Uint8Array(await (void 0)(t)); } catch (e) { if (e.code === 'ERR_FS_FILE_TOO_LARGE') { let o = (void 0)(t), i = []; for await (let u of o) i.push(u); return new Uint8Array(Buffer.concat(i)); } throw e; } else { let e = await fetch(t); if (!e.ok) throw new Error(`failed to load external data file: ${t}`); let o = e.headers.get('Content-Length'), i = o ? parseInt(o, 10) : 0; if (i < 1073741824) return new Uint8Array(await e.arrayBuffer()); { if (!e.body) throw new Error(`failed to load external data file: ${t}, no response body.`); let u = e.body.getReader(), n; try { n = new ArrayBuffer(i); } catch (d) { if (d instanceof RangeError) { let f = Math.ceil(i / 65536); n = new WebAssembly.Memory({ initial: f, maximum: f }).buffer; } else throw d; } let s = 0; for (;;) { let { done: d, value: f } = await u.read(); if (d) break; let r = f.byteLength; new Uint8Array(n, s, r).set(f), (s += r); } return new Uint8Array(n, 0, i); } } else return t instanceof Blob ? new Uint8Array(await t.arrayBuffer()) : t instanceof Uint8Array ? t : new Uint8Array(t); }; }), dg, Yp, Xp, yn, hg, pa, Kp, Jp, jp, Zp, Qp, ed, td = L(() => { Gp(), zp(), fa(), zr(), Eo(), ca(), (dg = (t, e) => { Ee()._OrtInit(t, e) !== 0 && Oe("Can't initialize onnxruntime."); }), (Yp = async (t) => { dg(t.wasm.numThreads, Hp(t.logLevel)); }), (Xp = async (t, e) => {}), (yn = new Map()), (hg = (t) => { let e = Ee(), o = e.stackSave(); try { let i = e.stackAlloc(8); return ( e._OrtGetInputOutputCount(t, i, i + 4) !== 0 && Oe("Can't get session input/output count."), [e.HEAP32[i / 4], e.HEAP32[i / 4 + 1]] ); } finally { e.stackRestore(o); } }), (pa = (t) => { let e = Ee(), o = e._malloc(t.byteLength); if (o === 0) throw new Error(`Can't create a session. failed to allocate a buffer of size ${t.byteLength}.`); return e.HEAPU8.set(t, o), [o, t.byteLength]; }), (Kp = async (t, e) => { let o, i, u = Ee(); Array.isArray(t) ? ([o, i] = t) : t.buffer === u.HEAPU8.buffer ? ([o, i] = [t.byteOffset, t.byteLength]) : ([o, i] = pa(t)); let n = 0, s = 0, d = [], f = [], r = []; try { if ((([s, d] = Up(e)), e?.externalData && u.mountExternalData)) { let v = []; for (let S of e.externalData) { let E = typeof S == 'string' ? S : S.path; v.push( gn(typeof S == 'string' ? S : S.data).then((A) => { u.mountExternalData(E, A); }) ); } await Promise.all(v); } (n = u._OrtCreateSession(o, i, s)), n === 0 && Oe("Can't create a session."); let [a, l] = hg(n), p = [], m = [], y = []; for (let v = 0; v < a; v++) { let S = u._OrtGetInputName(n, v); S === 0 && Oe("Can't get an input name."), f.push(S), p.push(u.UTF8ToString(S)); } for (let v = 0; v < l; v++) { let S = u._OrtGetOutputName(n, v); S === 0 && Oe("Can't get an output name."), r.push(S); let E = u.UTF8ToString(S); m.push(E); } return yn.set(n, [n, f, r, null]), [n, p, m]; } catch (a) { throw ( (f.forEach((l) => u._OrtFree(l)), r.forEach((l) => u._OrtFree(l)), n !== 0 && u._OrtReleaseSession(n), a) ); } finally { u._free(o), s !== 0 && u._OrtReleaseSessionOptions(s), d.forEach((a) => u._free(a)), u.unmountExternalData?.(); } }), (Jp = (t) => { let e = Ee(), o = yn.get(t); if (!o) throw new Error(`cannot release session. invalid session id: ${t}`); let [i, u, n, s] = o; s && e._OrtReleaseBinding(s.handle), e.jsepUnregisterBuffers?.(t), u.forEach((d) => e._OrtFree(d)), n.forEach((d) => e._OrtFree(d)), e._OrtReleaseSession(i), yn.delete(t); }), (jp = (t, e, o, i, u) => { if (!t) { e.push(0); return; } let n = Ee(), s = t[0], d = t[1], f = t[3], r, a; if (s === 'string' && f === 'gpu-buffer') throw new Error('String tensor is not supported on GPU.'); if (f === 'gpu-buffer') { let m = t[2].gpuBuffer, y = la(ua(s)); (a = d.reduce((T, v) => T * v, 1) * y), (r = n.jsepRegisterBuffer(i, u, m, a)); } else { let m = t[2]; if (Array.isArray(m)) { (a = 4 * m.length), (r = n._malloc(a)), o.push(r); let y = r / 4; for (let T = 0; T < m.length; T++) { if (typeof m[T] != 'string') throw new TypeError(`tensor data at index ${T} is not a string`); n.HEAPU32[y++] = De(m[T], o); } } else (a = m.byteLength), (r = n._malloc(a)), o.push(r), n.HEAPU8.set(new Uint8Array(m.buffer, m.byteOffset, a), r); } let l = n.stackSave(), p = n.stackAlloc(4 * d.length); try { let m = p / 4; d.forEach((T) => (n.HEAP32[m++] = T)); let y = n._OrtCreateTensor(ua(s), r, a, p, d.length, qp(f)); y === 0 && Oe(`Can't create tensor for input/output. session=${i}, index=${u}.`), e.push(y); } finally { n.stackRestore(l); } }), (Zp = async (t, e, o, i, u, n) => { let s = Ee(), d = yn.get(t); if (!d) throw new Error(`cannot run inference. invalid session id: ${t}`); let [f, r, a, l] = d, p = e.length, m = i.length, y = 0, T = [], v = [], S = [], E = [], A = s.stackSave(), F = s.stackAlloc(p * 4), B = s.stackAlloc(p * 4), J = s.stackAlloc(m * 4), Q = s.stackAlloc(m * 4); try { [y, T] = Mp(n); for (let Y = 0; Y < p; Y++) jp(o[Y], v, E, t, e[Y]); for (let Y = 0; Y < m; Y++) jp(u[Y], S, E, t, p + i[Y]); let re = F / 4, V = B / 4, de = J / 4, ke = Q / 4; for (let Y = 0; Y < p; Y++) (s.HEAPU32[re++] = v[Y]), (s.HEAPU32[V++] = r[e[Y]]); for (let Y = 0; Y < m; Y++) (s.HEAPU32[de++] = S[Y]), (s.HEAPU32[ke++] = a[i[Y]]); let Ne; (Ne = await s._OrtRun(f, B, F, p, Q, m, J, y)), Ne !== 0 && Oe('failed to call OrtRun().'); let Me = []; for (let Y = 0; Y < m; Y++) { let _e = s.HEAPU32[J / 4 + Y]; if (_e === S[Y]) { Me.push(u[Y]); continue; } let he = s.stackSave(), ue = s.stackAlloc(4 * 4), pe = !1, X, ve = 0; try { s._OrtGetTensorData(_e, ue, ue + 4, ue + 8, ue + 12) !== 0 && Oe(`Can't access output tensor data on index ${Y}.`); let we = ue / 4, rt = s.HEAPU32[we++]; ve = s.HEAPU32[we++]; let ot = s.HEAPU32[we++], qe = s.HEAPU32[we++], He = []; for (let Ce = 0; Ce < qe; Ce++) He.push(s.HEAPU32[ot / 4 + Ce]); s._OrtFree(ot); let Qe = He.reduce((Ce, Se) => Ce * Se, 1); X = Vp(rt); let Be = l?.outputPreferredLocations[i[Y]]; if (X === 'string') { if (Be === 'gpu-buffer') throw new Error('String tensor is not supported on GPU.'); let Ce = [], Se = ve / 4; for (let je = 0; je < Qe; je++) { let Tt = s.HEAPU32[Se++], xt = je === Qe - 1 ? void 0 : s.HEAPU32[Se] - Tt; Ce.push(s.UTF8ToString(Tt, xt)); } Me.push([X, He, Ce, 'cpu']); } else if (Be === 'gpu-buffer' && Qe > 0) { let Ce = s.jsepGetBuffer(ve), Se = la(rt); if (Se === void 0 || !Do(X)) throw new Error(`Unsupported data type: ${X}`); (pe = !0), Me.push([ X, He, { gpuBuffer: Ce, download: s.jsepCreateDownloader(Ce, Qe * Se, X), dispose: () => { s._OrtReleaseTensor(_e); }, }, 'gpu-buffer', ]); } else { let Ce = Wp(X), Se = new Ce(Qe); new Uint8Array(Se.buffer, Se.byteOffset, Se.byteLength).set( s.HEAPU8.subarray(ve, ve + Se.byteLength) ), Me.push([X, He, Se, 'cpu']); } } finally { s.stackRestore(he), X === 'string' && ve && s._free(ve), pe || s._OrtReleaseTensor(_e); } } return l && s._OrtClearBoundOutputs(l.handle), Me; } finally { s.stackRestore(A), v.forEach((re) => s._OrtReleaseTensor(re)), S.forEach((re) => s._OrtReleaseTensor(re)), E.forEach((re) => s._free(re)), y !== 0 && s._OrtReleaseRunOptions(y), T.forEach((re) => s._free(re)); } }), (Qp = (t) => { let e = Ee(), o = yn.get(t); if (!o) throw new Error('invalid session id'); let i = o[0], u = e._OrtEndProfiling(i); u === 0 && Oe("Can't get an profile file name."), e._OrtFree(u); }), (ed = (t) => { let e = []; for (let o of t) { let i = o[2]; !Array.isArray(i) && 'buffer' in i && e.push(i.buffer); } return e; }); }), rd = me((t, e) => { e.exports = '/*!\n * ONNX Runtime Web v1.17.1\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n"use strict";(()=>{var Et=Object.defineProperty;var Jr=Object.getOwnPropertyDescriptor;var Xr=Object.getOwnPropertyNames;var Qr=Object.prototype.hasOwnProperty;var St=(u,d)=>()=>(u&&(d=u(u=0)),d);var et=(u,d)=>()=>(d||u((d={exports:{}}).exports,d),d.exports),Tt=(u,d)=>{for(var a in d)Et(u,a,{get:d[a],enumerable:!0})},Zr=(u,d,a,h)=>{if(d&&typeof d=="object"||typeof d=="function")for(let l of Xr(d))!Qr.call(u,l)&&l!==a&&Et(u,l,{get:()=>d[l],enumerable:!(h=Jr(d,l))||h.enumerable});return u};var tt=u=>Zr(Et({},"__esModule",{value:!0}),u);var At={};Tt(At,{createReadStream:()=>dr,readFile:()=>Kr,readFileSync:()=>en});var Kr,en,dr,Mt=St(()=>{Kr=void 0,en=void 0,dr=void 0});var Ct={};Tt(Ct,{join:()=>tn});var tn,Dt=St(()=>{tn=void 0});var gr=et((mr,xt)=>{"use strict";var pr=(()=>{var u=typeof document<"u"&&document.currentScript?document.currentScript.src:void 0;return typeof __filename<"u"&&(u=u||__filename),function(d={}){var a=d,h,l;a.ready=new Promise((r,o)=>{h=r,l=o});var w=Object.assign({},a),g="./this.program",i=typeof window=="object",A=typeof importScripts=="function",D=typeof process=="object"&&typeof process.versions=="object"&&typeof process.versions.node=="string",I="",B,F,U;if(D){var k=(Mt(),tt(At)),L=(Dt(),tt(Ct));I=A?L.dirname(I)+"/":__dirname+"/",B=(r,o)=>(r=ye(r)?new URL(r):L.normalize(r),k.readFileSync(r,o?void 0:"utf8")),U=r=>(r=B(r,!0),r.buffer||(r=new Uint8Array(r)),r),F=(r,o,s,m=!0)=>{r=ye(r)?new URL(r):L.normalize(r),k.readFile(r,m?void 0:"utf8",(O,S)=>{O?s(O):o(m?S.buffer:S)})},!a.thisProgram&&1"[Emscripten Module object]"}else(i||A)&&(A?I=self.location.href:typeof document<"u"&&document.currentScript&&(I=document.currentScript.src),u&&(I=u),I.indexOf("blob:")!==0?I=I.substr(0,I.replace(/[?#].*/,"").lastIndexOf("/")+1):I="",B=r=>{var o=new XMLHttpRequest;return o.open("GET",r,!1),o.send(null),o.responseText},A&&(U=r=>{var o=new XMLHttpRequest;return o.open("GET",r,!1),o.responseType="arraybuffer",o.send(null),new Uint8Array(o.response)}),F=(r,o,s)=>{var m=new XMLHttpRequest;m.open("GET",r,!0),m.responseType="arraybuffer",m.onload=()=>{m.status==200||m.status==0&&m.response?o(m.response):s()},m.onerror=s,m.send(null)});var _=console.log.bind(console),x=console.error.bind(console);Object.assign(a,w),w=null,typeof WebAssembly!="object"&&de("no native wasm support detected");var N,he=!1,ie,ae,E,Y,ue;function Re(){var r=N.buffer;a.HEAP8=ie=new Int8Array(r),a.HEAP16=new Int16Array(r),a.HEAPU8=ae=new Uint8Array(r),a.HEAPU16=new Uint16Array(r),a.HEAP32=E=new Int32Array(r),a.HEAPU32=Y=new Uint32Array(r),a.HEAPF32=new Float32Array(r),a.HEAPF64=ue=new Float64Array(r)}var Ie=[],ee=[],j=[],ce=0,P=null,te=null;function de(r){throw r="Aborted("+r+")",x(r),he=!0,r=new WebAssembly.RuntimeError(r+". Build with -sASSERTIONS for more info."),l(r),r}var ge=r=>r.startsWith("data:application/octet-stream;base64,"),ye=r=>r.startsWith("file://"),J;if(J="ort-wasm.wasm",!ge(J)){var fe=J;J=a.locateFile?a.locateFile(fe,I):I+fe}function we(r){if(U)return U(r);throw"both async and sync fetching of the wasm failed"}function Ae(r){if(i||A){if(typeof fetch=="function"&&!ye(r))return fetch(r,{credentials:"same-origin"}).then(o=>{if(!o.ok)throw"failed to load wasm binary file at \'"+r+"\'";return o.arrayBuffer()}).catch(()=>we(r));if(F)return new Promise((o,s)=>{F(r,m=>o(new Uint8Array(m)),s)})}return Promise.resolve().then(()=>we(r))}function Me(r,o,s){return Ae(r).then(m=>WebAssembly.instantiate(m,o)).then(m=>m).then(s,m=>{x(`failed to asynchronously prepare wasm: ${m}`),de(m)})}function Fe(r,o){var s=J;return typeof WebAssembly.instantiateStreaming!="function"||ge(s)||ye(s)||D||typeof fetch!="function"?Me(s,r,o):fetch(s,{credentials:"same-origin"}).then(m=>WebAssembly.instantiateStreaming(m,r).then(o,function(O){return x(`wasm streaming compile failed: ${O}`),x("falling back to ArrayBuffer instantiation"),Me(s,r,o)}))}var Ee,pe={919888:(r,o,s,m)=>{if(typeof a>"u"||!a.za)return 1;if(r=be(r>>>0),r.startsWith("./")&&(r=r.substring(2)),r=a.za.get(r),!r)return 2;if(o>>>=0,s>>>=0,o+s>r.byteLength)return 3;try{return ae.set(r.subarray(o,o+s),m>>>0>>>0),0}catch{return 4}}};function Oe(r){this.xa=r-24,this.Ha=function(o){Y[this.xa+4>>>2>>>0]=o},this.Ga=function(o){Y[this.xa+8>>>2>>>0]=o},this.Aa=function(o,s){this.Fa(),this.Ha(o),this.Ga(s)},this.Fa=function(){Y[this.xa+16>>>2>>>0]=0}}var ve=0,re=0,Z=typeof TextDecoder<"u"?new TextDecoder("utf8"):void 0,Ce=(r,o,s)=>{o>>>=0;var m=o+s;for(s=o;r[s]&&!(s>=m);)++s;if(16O?m+=String.fromCharCode(O):(O-=65536,m+=String.fromCharCode(55296|O>>10,56320|O&1023))}}else m+=String.fromCharCode(O)}return m},be=(r,o)=>(r>>>=0)?Ce(ae,r,o):"",_e=r=>{for(var o=0,s=0;s=m?o++:2047>=m?o+=2:55296<=m&&57343>=m?(o+=4,++s):o+=3}return o},ke=(r,o,s,m)=>{if(s>>>=0,!(0=R){var K=r.charCodeAt(++S);R=65536+((R&1023)<<10)|K&1023}if(127>=R){if(s>=m)break;o[s++>>>0]=R}else{if(2047>=R){if(s+1>=m)break;o[s++>>>0]=192|R>>6}else{if(65535>=R){if(s+2>=m)break;o[s++>>>0]=224|R>>12}else{if(s+3>=m)break;o[s++>>>0]=240|R>>18,o[s++>>>0]=128|R>>12&63}o[s++>>>0]=128|R>>6&63}o[s++>>>0]=128|R&63}}return o[s>>>0]=0,s-O},Ue=r=>r%4===0&&(r%100!==0||r%400===0),ze=[0,31,60,91,121,152,182,213,244,274,305,335],at=[0,31,59,90,120,151,181,212,243,273,304,334],De=r=>{var o=_e(r)+1,s=st(o);return s&&ke(r,ae,s,o),s},Ne=[],Pe={},He=()=>{if(!$e){var r={USER:"web_user",LOGNAME:"web_user",PATH:"/",PWD:"/",HOME:"/home/web_user",LANG:(typeof navigator=="object"&&navigator.languages&&navigator.languages[0]||"C").replace("-","_")+".UTF-8",_:g||"./this.program"},o;for(o in Pe)Pe[o]===void 0?delete r[o]:r[o]=Pe[o];var s=[];for(o in r)s.push(`${o}=${r[o]}`);$e=s}return $e},$e,Le=[null,[],[]],qe=[31,29,31,30,31,30,31,31,30,31,30,31],Ve=[31,28,31,30,31,30,31,31,30,31,30,31];function Ge(r){var o=Array(_e(r)+1);return ke(r,o,0,o.length),o}function ot(r,o,s,m){function O(c,W,G){for(c=typeof c=="number"?c.toString():c||"";c.lengthKe?-1:0Se-c.getDate())W-=Se-c.getDate()+1,c.setDate(1),11>G?c.setMonth(G+1):(c.setMonth(0),c.setFullYear(c.getFullYear()+1));else{c.setDate(c.getDate()+W);break}}return G=new Date(c.getFullYear()+1,0,4),W=K(new Date(c.getFullYear(),0,4)),G=K(G),0>=R(W,c)?0>=R(G,c)?c.getFullYear()+1:c.getFullYear():c.getFullYear()-1}r>>>=0,o>>>=0,s>>>=0,m>>>=0;var oe=Y[m+40>>>2>>>0];m={Da:E[m>>>2>>>0],Ca:E[m+4>>>2>>>0],va:E[m+8>>>2>>>0],ya:E[m+12>>>2>>>0],wa:E[m+16>>>2>>>0],ua:E[m+20>>>2>>>0],oa:E[m+24>>>2>>>0],ta:E[m+28>>>2>>>0],Ia:E[m+32>>>2>>>0],Ba:E[m+36>>>2>>>0],Ea:oe?be(oe):""},s=be(s),oe={"%c":"%a %b %d %H:%M:%S %Y","%D":"%m/%d/%y","%F":"%Y-%m-%d","%h":"%b","%r":"%I:%M:%S %p","%R":"%H:%M","%T":"%H:%M:%S","%x":"%m/%d/%y","%X":"%H:%M:%S","%Ec":"%c","%EC":"%C","%Ex":"%m/%d/%y","%EX":"%H:%M:%S","%Ey":"%y","%EY":"%Y","%Od":"%d","%Oe":"%e","%OH":"%H","%OI":"%I","%Om":"%m","%OM":"%M","%OS":"%S","%Ou":"%u","%OU":"%U","%OV":"%V","%Ow":"%w","%OW":"%W","%Oy":"%y"};for(var se in oe)s=s.replace(new RegExp(se,"g"),oe[se]);var Qe="Sunday Monday Tuesday Wednesday Thursday Friday Saturday".split(" "),Ze="January February March April May June July August September October November December".split(" ");oe={"%a":c=>Qe[c.oa].substring(0,3),"%A":c=>Qe[c.oa],"%b":c=>Ze[c.wa].substring(0,3),"%B":c=>Ze[c.wa],"%C":c=>S((c.ua+1900)/100|0,2),"%d":c=>S(c.ya,2),"%e":c=>O(c.ya,2," "),"%g":c=>le(c).toString().substring(2),"%G":c=>le(c),"%H":c=>S(c.va,2),"%I":c=>(c=c.va,c==0?c=12:12{for(var W=0,G=0;G<=c.wa-1;W+=(Ue(c.ua+1900)?qe:Ve)[G++]);return S(c.ya+W,3)},"%m":c=>S(c.wa+1,2),"%M":c=>S(c.Ca,2),"%n":()=>`\n`,"%p":c=>0<=c.va&&12>c.va?"AM":"PM","%S":c=>S(c.Da,2),"%t":()=>" ","%u":c=>c.oa||7,"%U":c=>S(Math.floor((c.ta+7-c.oa)/7),2),"%V":c=>{var W=Math.floor((c.ta+7-(c.oa+6)%7)/7);if(2>=(c.oa+371-c.ta-2)%7&&W++,W)W==53&&(G=(c.oa+371-c.ta)%7,G==4||G==3&&Ue(c.ua)||(W=1));else{W=52;var G=(c.oa+7-c.ta-1)%7;(G==4||G==5&&Ue(c.ua%400-1))&&W++}return S(W,2)},"%w":c=>c.oa,"%W":c=>S(Math.floor((c.ta+7-(c.oa+6)%7)/7),2),"%y":c=>(c.ua+1900).toString().substring(2),"%Y":c=>c.ua+1900,"%z":c=>{c=c.Ba;var W=0<=c;return c=Math.abs(c)/60,(W?"+":"-")+("0000"+(c/60*100+c%60)).slice(-4)},"%Z":c=>c.Ea,"%%":()=>"%"},s=s.replace(/%%/g,"\\0\\0");for(se in oe)s.includes(se)&&(s=s.replace(new RegExp(se,"g"),oe[se](m)));return s=s.replace(/\\0\\0/g,"%"),se=Ge(s),se.length>o?0:(ie.set(se,r>>>0),se.length-1)}var $={a:function(r,o,s){throw r>>>=0,new Oe(r).Aa(o>>>0,s>>>0),ve=r,re++,ve},e:function(){return 0},H:function(){},x:function(){},z:function(){},J:function(){return 0},F:function(){},A:function(){},E:function(){},g:function(){},y:function(){},v:function(){},G:function(){},w:function(){},k:()=>1,n:function(r,o,s){r=o+2097152>>>0<4194305-!!r?(r>>>0)+4294967296*o:NaN,s>>>=0,r=new Date(1e3*r),E[s>>>2>>>0]=r.getUTCSeconds(),E[s+4>>>2>>>0]=r.getUTCMinutes(),E[s+8>>>2>>>0]=r.getUTCHours(),E[s+12>>>2>>>0]=r.getUTCDate(),E[s+16>>>2>>>0]=r.getUTCMonth(),E[s+20>>>2>>>0]=r.getUTCFullYear()-1900,E[s+24>>>2>>>0]=r.getUTCDay(),E[s+28>>>2>>>0]=(r.getTime()-Date.UTC(r.getUTCFullYear(),0,1,0,0,0,0))/864e5|0},o:function(r,o,s){r=o+2097152>>>0<4194305-!!r?(r>>>0)+4294967296*o:NaN,s>>>=0,r=new Date(1e3*r),E[s>>>2>>>0]=r.getSeconds(),E[s+4>>>2>>>0]=r.getMinutes(),E[s+8>>>2>>>0]=r.getHours(),E[s+12>>>2>>>0]=r.getDate(),E[s+16>>>2>>>0]=r.getMonth(),E[s+20>>>2>>>0]=r.getFullYear()-1900,E[s+24>>>2>>>0]=r.getDay(),E[s+28>>>2>>>0]=(Ue(r.getFullYear())?ze:at)[r.getMonth()]+r.getDate()-1|0,E[s+36>>>2>>>0]=-(60*r.getTimezoneOffset()),o=new Date(r.getFullYear(),6,1).getTimezoneOffset();var m=new Date(r.getFullYear(),0,1).getTimezoneOffset();E[s+32>>>2>>>0]=(o!=m&&r.getTimezoneOffset()==Math.min(m,o))|0},p:function(r){r>>>=0;var o=new Date(E[r+20>>>2>>>0]+1900,E[r+16>>>2>>>0],E[r+12>>>2>>>0],E[r+8>>>2>>>0],E[r+4>>>2>>>0],E[r>>>2>>>0],0),s=E[r+32>>>2>>>0],m=o.getTimezoneOffset(),O=new Date(o.getFullYear(),6,1).getTimezoneOffset(),S=new Date(o.getFullYear(),0,1).getTimezoneOffset(),R=Math.min(S,O);return 0>s?E[r+32>>>2>>>0]=+(O!=S&&R==m):0>>2>>>0]=o.getDay(),E[r+28>>>2>>>0]=(Ue(o.getFullYear())?ze:at)[o.getMonth()]+o.getDate()-1|0,E[r>>>2>>>0]=o.getSeconds(),E[r+4>>>2>>>0]=o.getMinutes(),E[r+8>>>2>>>0]=o.getHours(),E[r+12>>>2>>>0]=o.getDate(),E[r+16>>>2>>>0]=o.getMonth(),E[r+20>>>2>>>0]=o.getYear(),r=o.getTime(),isNaN(r)?(E[Ye()>>>2>>>0]=61,r=-1):r/=1e3,Je((Ee=r,1<=+Math.abs(Ee)?0>>0:~~+Math.ceil((Ee-+(~~Ee>>>0))/4294967296)>>>0:0)),r>>>0},l:function(){return-52},m:function(){},t:function(r,o,s){function m(le){return(le=le.toTimeString().match(/\\(([A-Za-z ]+)\\)$/))?le[1]:"GMT"}s>>>=0;var O=new Date().getFullYear(),S=new Date(O,0,1),R=new Date(O,6,1);O=S.getTimezoneOffset();var K=R.getTimezoneOffset();Y[r>>>0>>>2>>>0]=60*Math.max(O,K),E[o>>>0>>>2>>>0]=+(O!=K),r=m(S),o=m(R),r=De(r),o=De(o),K>>2>>>0]=r,Y[s+4>>>2>>>0]=o):(Y[s>>>2>>>0]=o,Y[s+4>>>2>>>0]=r)},d:()=>{de("")},B:function(r,o,s){r>>>=0,o>>>=0,s>>>=0,Ne.length=0;for(var m;m=ae[o++>>>0];){var O=m!=105;O&=m!=112,s+=O&&s%8?4:0,Ne.push(m==112?Y[s>>>2>>>0]:m==105?E[s>>>2>>>0]:ue[s>>>3>>>0]),s+=O?8:4}return pe[r].apply(null,Ne)},h:()=>Date.now(),u:function(){return 4294901760},b:()=>performance.now(),I:function(r,o,s){return o>>>=0,ae.copyWithin(r>>>0>>>0,o>>>0,o+(s>>>0)>>>0)},s:function(r){r>>>=0;var o=ae.length;if(4294901760=s;s*=2){var m=o*(1+.2/s);m=Math.min(m,r+100663296);var O=Math;m=Math.max(r,m);e:{O=(O.min.call(O,4294901760,m+(65536-m%65536)%65536)-N.buffer.byteLength+65535)/65536;try{N.grow(O),Re();var S=1;break e}catch{}S=void 0}if(S)return!0}return!1},C:function(r,o){r>>>=0,o>>>=0;var s=0;return He().forEach((m,O)=>{var S=o+s;for(O=Y[r+4*O>>>2>>>0]=S,S=0;S>>0>>>0]=m.charCodeAt(S);ie[O>>>0>>>0]=0,s+=m.length+1}),0},D:function(r,o){r>>>=0,o>>>=0;var s=He();Y[r>>>2>>>0]=s.length;var m=0;return s.forEach(O=>m+=O.length+1),Y[o>>>2>>>0]=m,0},f:()=>52,j:function(){return 52},q:function(){return 70},i:function(r,o,s,m){o>>>=0,s>>>=0,m>>>=0;for(var O=0,S=0;S>>2>>>0],K=Y[o+4>>>2>>>0];o+=8;for(var le=0;le>>0],se=Le[r];oe===0||oe===10?((r===1?_:x)(Ce(se,0)),se.length=0):se.push(oe)}O+=K}return Y[m>>>2>>>0]=O,0},r:ot,c:function(r,o,s,m){return ot(r>>>0,o>>>0,s>>>0,m>>>0)}},C=function(){function r(s){return C=s.exports,C=ut(),N=C.K,Re(),ee.unshift(C.L),ce--,ce==0&&(P!==null&&(clearInterval(P),P=null),te&&(s=te,te=null,s())),C}var o={a:$};if(ce++,a.instantiateWasm)try{return a.instantiateWasm(o,r)}catch(s){x(`Module.instantiateWasm callback failed with error: ${s}`),l(s)}return Fe(o,function(s){r(s.instance)}).catch(l),{}}();a._OrtInit=(r,o)=>(a._OrtInit=C.M)(r,o),a._OrtGetLastError=(r,o)=>(a._OrtGetLastError=C.N)(r,o),a._OrtCreateSessionOptions=(r,o,s,m,O,S,R,K,le,oe)=>(a._OrtCreateSessionOptions=C.O)(r,o,s,m,O,S,R,K,le,oe),a._OrtAppendExecutionProvider=(r,o)=>(a._OrtAppendExecutionProvider=C.P)(r,o),a._OrtAddFreeDimensionOverride=(r,o,s)=>(a._OrtAddFreeDimensionOverride=C.Q)(r,o,s),a._OrtAddSessionConfigEntry=(r,o,s)=>(a._OrtAddSessionConfigEntry=C.R)(r,o,s),a._OrtReleaseSessionOptions=r=>(a._OrtReleaseSessionOptions=C.S)(r),a._OrtCreateSession=(r,o,s)=>(a._OrtCreateSession=C.T)(r,o,s),a._OrtReleaseSession=r=>(a._OrtReleaseSession=C.U)(r),a._OrtGetInputOutputCount=(r,o,s)=>(a._OrtGetInputOutputCount=C.V)(r,o,s),a._OrtGetInputName=(r,o)=>(a._OrtGetInputName=C.W)(r,o),a._OrtGetOutputName=(r,o)=>(a._OrtGetOutputName=C.X)(r,o),a._OrtFree=r=>(a._OrtFree=C.Y)(r),a._OrtCreateTensor=(r,o,s,m,O,S)=>(a._OrtCreateTensor=C.Z)(r,o,s,m,O,S),a._OrtGetTensorData=(r,o,s,m,O)=>(a._OrtGetTensorData=C._)(r,o,s,m,O),a._OrtReleaseTensor=r=>(a._OrtReleaseTensor=C.$)(r),a._OrtCreateRunOptions=(r,o,s,m)=>(a._OrtCreateRunOptions=C.aa)(r,o,s,m),a._OrtAddRunConfigEntry=(r,o,s)=>(a._OrtAddRunConfigEntry=C.ba)(r,o,s),a._OrtReleaseRunOptions=r=>(a._OrtReleaseRunOptions=C.ca)(r),a._OrtCreateBinding=r=>(a._OrtCreateBinding=C.da)(r),a._OrtBindInput=(r,o,s)=>(a._OrtBindInput=C.ea)(r,o,s),a._OrtBindOutput=(r,o,s,m)=>(a._OrtBindOutput=C.fa)(r,o,s,m),a._OrtClearBoundOutputs=r=>(a._OrtClearBoundOutputs=C.ga)(r),a._OrtReleaseBinding=r=>(a._OrtReleaseBinding=C.ha)(r),a._OrtRunWithBinding=(r,o,s,m,O)=>(a._OrtRunWithBinding=C.ia)(r,o,s,m,O),a._OrtRun=(r,o,s,m,O,S,R,K)=>(a._OrtRun=C.ja)(r,o,s,m,O,S,R,K),a._OrtEndProfiling=r=>(a._OrtEndProfiling=C.ka)(r);var Ye=()=>(Ye=C.la)(),st=a._malloc=r=>(st=a._malloc=C.ma)(r);a._free=r=>(a._free=C.na)(r);var Je=r=>(Je=C.pa)(r),it=()=>(it=C.qa)(),M=r=>(M=C.ra)(r),Be=r=>(Be=C.sa)(r);function ut(){var r=C;r=Object.assign({},r);var o=m=>()=>m()>>>0,s=m=>O=>m(O)>>>0;return r.la=o(r.la),r.ma=s(r.ma),r.qa=o(r.qa),r.sa=s(r.sa),r}a.stackAlloc=Be,a.stackSave=it,a.stackRestore=M,a.UTF8ToString=be,a.stringToUTF8=(r,o,s)=>ke(r,ae,o,s),a.lengthBytesUTF8=_e;var xe;te=function r(){xe||Xe(),xe||(te=r)};function Xe(){if(!(0pr)});var hr=et(()=>{});var yr=et(()=>{});var br={};Tt(br,{cpus:()=>rn});var rn,wr=St(()=>{rn=void 0});var _r=et((vr,Ft)=>{"use strict";var Or=(()=>{var u=typeof document<"u"&&document.currentScript?document.currentScript.src:void 0;return typeof __filename<"u"&&(u=u||__filename),function(d={}){function a(){return j.buffer!=de.buffer&&we(),de}function h(){return j.buffer!=de.buffer&&we(),ge}function l(){return j.buffer!=de.buffer&&we(),ye}function w(){return j.buffer!=de.buffer&&we(),J}function g(){return j.buffer!=de.buffer&&we(),fe}var i=d,A,D;i.ready=new Promise((e,t)=>{A=e,D=t});var I=Object.assign({},i),B="./this.program",F=(e,t)=>{throw t},U=typeof window=="object",k=typeof importScripts=="function",L=typeof process=="object"&&typeof process.versions=="object"&&typeof process.versions.node=="string",_=i.ENVIRONMENT_IS_PTHREAD||!1,x="";function N(e){return i.locateFile?i.locateFile(e,x):x+e}var he,ie,ae;if(L){var E=(Mt(),tt(At)),Y=(Dt(),tt(Ct));x=k?Y.dirname(x)+"/":__dirname+"/",he=(t,n)=>(t=be(t)?new URL(t):Y.normalize(t),E.readFileSync(t,n?void 0:"utf8")),ae=t=>(t=he(t,!0),t.buffer||(t=new Uint8Array(t)),t),ie=(t,n,f,y=!0)=>{t=be(t)?new URL(t):Y.normalize(t),E.readFile(t,y?void 0:"utf8",(b,v)=>{b?f(b):n(y?v.buffer:v)})},!i.thisProgram&&1{throw process.exitCode=t,n},i.inspect=()=>"[Emscripten Module object]";let e;try{e=hr()}catch(t){throw console.error(\'The "worker_threads" module is not supported in this node.js build - perhaps a newer version is needed?\'),t}global.Worker=e.Worker}else(U||k)&&(k?x=self.location.href:typeof document<"u"&&document.currentScript&&(x=document.currentScript.src),typeof u<"u"&&u&&(x=u),x.indexOf("blob:")!==0?x=x.substr(0,x.replace(/[?#].*/,"").lastIndexOf("/")+1):x="",L||(he=e=>{var t=new XMLHttpRequest;return t.open("GET",e,!1),t.send(null),t.responseText},k&&(ae=e=>{var t=new XMLHttpRequest;return t.open("GET",e,!1),t.responseType="arraybuffer",t.send(null),new Uint8Array(t.response)}),ie=(e,t,n)=>{var f=new XMLHttpRequest;f.open("GET",e,!0),f.responseType="arraybuffer",f.onload=()=>{f.status==200||f.status==0&&f.response?t(f.response):n()},f.onerror=n,f.send(null)}));L&&typeof performance>"u"&&(global.performance=yr().performance);var ue=console.log.bind(console),Re=console.error.bind(console);L&&(ue=(...e)=>E.writeSync(1,e.join(" ")+`\n`),Re=(...e)=>E.writeSync(2,e.join(" ")+`\n`));var Ie=ue,ee=Re;Object.assign(i,I),I=null,typeof WebAssembly!="object"&&Z("no native wasm support detected");var j,ce,P=!1,te,de,ge,ye,J,fe;function we(){var e=j.buffer;i.HEAP8=de=new Int8Array(e),i.HEAP16=new Int16Array(e),i.HEAPU8=ge=new Uint8Array(e),i.HEAPU16=new Uint16Array(e),i.HEAP32=ye=new Int32Array(e),i.HEAPU32=J=new Uint32Array(e),i.HEAPF32=new Float32Array(e),i.HEAPF64=fe=new Float64Array(e)}var Ae=16777216;if(_)j=i.wasmMemory;else if(i.wasmMemory)j=i.wasmMemory;else if(j=new WebAssembly.Memory({initial:Ae/65536,maximum:65536,shared:!0}),!(j.buffer instanceof SharedArrayBuffer))throw ee("requested a shared WebAssembly.Memory but the returned buffer is not a SharedArrayBuffer, indicating that while the browser has SharedArrayBuffer it does not have WebAssembly threads support - you may need to set a flag"),L&&ee("(on node you may need: --experimental-wasm-threads --experimental-wasm-bulk-memory and/or recent version)"),Error("bad memory");we(),Ae=j.buffer.byteLength;var Me=[],Fe=[],Ee=[],pe=0,Oe=null,ve=null;function re(){if(pe--,pe==0&&(Oe!==null&&(clearInterval(Oe),Oe=null),ve)){var e=ve;ve=null,e()}}function Z(e){throw e="Aborted("+e+")",ee(e),P=!0,te=1,e=new WebAssembly.RuntimeError(e+". Build with -sASSERTIONS for more info."),D(e),e}var Ce=e=>e.startsWith("data:application/octet-stream;base64,"),be=e=>e.startsWith("file://"),_e;_e="ort-wasm-threaded.wasm",Ce(_e)||(_e=N(_e));function ke(e){if(ae)return ae(e);throw"both async and sync fetching of the wasm failed"}function Ue(e){if(U||k){if(typeof fetch=="function"&&!be(e))return fetch(e,{credentials:"same-origin"}).then(t=>{if(!t.ok)throw"failed to load wasm binary file at \'"+e+"\'";return t.arrayBuffer()}).catch(()=>ke(e));if(ie)return new Promise((t,n)=>{ie(e,f=>t(new Uint8Array(f)),n)})}return Promise.resolve().then(()=>ke(e))}function ze(e,t,n){return Ue(e).then(f=>WebAssembly.instantiate(f,t)).then(f=>f).then(n,f=>{ee(`failed to asynchronously prepare wasm: ${f}`),Z(f)})}function at(e,t){var n=_e;return typeof WebAssembly.instantiateStreaming!="function"||Ce(n)||be(n)||L||typeof fetch!="function"?ze(n,e,t):fetch(n,{credentials:"same-origin"}).then(f=>WebAssembly.instantiateStreaming(f,e).then(t,function(y){return ee(`wasm streaming compile failed: ${y}`),ee("falling back to ArrayBuffer instantiation"),ze(n,e,t)}))}var De,Ne={921276:(e,t,n,f)=>{if(typeof i>"u"||!i.cb)return 1;if(e=Ge(e>>>0),e.startsWith("./")&&(e=e.substring(2)),e=i.cb.get(e),!e)return 2;if(t>>>=0,n>>>=0,f>>>=0,t+n>e.byteLength)return 3;try{return h().set(e.subarray(t,t+n),f>>>0),0}catch{return 4}}};function Pe(e){this.name="ExitStatus",this.message=`Program terminated with exit(${e})`,this.status=e}var He=e=>{e.terminate(),e.onmessage=()=>{}},$e=e=>{M.Pa.length==0&&(Je(),M.Ya(M.Pa[0]));var t=M.Pa.pop();if(!t)return 6;M.Qa.push(t),M.Ma[e.Oa]=t,t.Oa=e.Oa;var n={cmd:"run",start_routine:e.kb,arg:e.hb,pthread_ptr:e.Oa};return L&&t.unref(),t.postMessage(n,e.qb),0},Le=0,qe=typeof TextDecoder<"u"?new TextDecoder("utf8"):void 0,Ve=(e,t,n)=>{t>>>=0;var f=t+n;for(n=t;e[n]&&!(n>=f);)++n;if(16y?f+=String.fromCharCode(y):(y-=65536,f+=String.fromCharCode(55296|y>>10,56320|y&1023))}}else f+=String.fromCharCode(y)}return f},Ge=(e,t)=>(e>>>=0)?Ve(h(),e,t):"",ot=e=>{var t=vt();return e=e(),ct(t),e};function $(e,t){var n=arguments.length-2,f=arguments;return ot(()=>{for(var y=_t(8*n),b=y>>>3,v=0;v>>0]=z}return ar(e,n,y,t)})}function C(e){if(_)return $(0,1,e);te=e,0{if(te=e,_)throw ut(e),"unwind";C(e)};function st(){for(var e=i.numThreads;e--;)Je();Me.unshift(()=>{pe++,it(()=>re())})}function Je(){var e=N("ort-wasm-threaded.worker.js");e=new Worker(e),M.Pa.push(e)}function it(e){_?e():Promise.all(M.Pa.map(M.Ya)).then(e)}var M={Pa:[],Qa:[],bb:[],Ma:{},Wa(){_?(M.receiveObjectTransfer=M.jb,M.threadInitTLS=M.ab,M.setExitStatus=M.$a):st()},$a:e=>te=e,tb:["$terminateWorker"],lb:()=>{for(var e of M.Qa)He(e);for(e of M.Pa)He(e);M.Pa=[],M.Qa=[],M.Ma=[]},Za:e=>{var t=e.Oa;delete M.Ma[t],M.Pa.push(e),M.Qa.splice(M.Qa.indexOf(e),1),e.Oa=0,wt(t)},jb(){},ab(){M.bb.forEach(e=>e())},Ya:e=>new Promise(t=>{e.onmessage=b=>{b=b.data;var v=b.cmd;if(b.targetThread&&b.targetThread!=lt()){var z=M.Ma[b.targetThread];z?z.postMessage(b,b.transferList):ee(`Internal error! Worker sent a message "${v}" to target pthread ${b.targetThread}, but that thread no longer exists!`)}else v==="checkMailbox"?ft():v==="spawnThread"?$e(b):v==="cleanupThread"?M.Za(M.Ma[b.thread]):v==="killThread"?(b=b.thread,v=M.Ma[b],delete M.Ma[b],He(v),wt(b),M.Qa.splice(M.Qa.indexOf(v),1),v.Oa=0):v==="cancelThread"?M.Ma[b.thread].postMessage({cmd:"cancel"}):v==="loaded"?(e.loaded=!0,L&&!e.Oa&&e.unref(),t(e)):v==="alert"?alert(`Thread ${b.threadId}: ${b.text}`):b.target==="setimmediate"?e.postMessage(b):v==="callHandler"?i[b.handler](...b.args):v&&ee(`worker sent an unknown command ${v}`)},e.onerror=b=>{throw ee(`worker sent an error! ${b.filename}:${b.lineno}: ${b.message}`),b},L&&(e.on("message",b=>e.onmessage({data:b})),e.on("error",b=>e.onerror(b)));var n=[],f=["onExit"],y;for(y of f)i.hasOwnProperty(y)&&n.push(y);e.postMessage({cmd:"load",handlers:n,urlOrBlob:i.mainScriptUrlOrBlob||u,wasmMemory:j,wasmModule:ce})})};i.PThread=M;var Be=e=>{for(;0{var e=lt(),t=w()[e+52>>>2>>>0];e=w()[e+56>>>2>>>0],ir(t,t-e),ct(t)};function ut(e){if(_)return $(1,0,e);Ye(e)}var xe=[],Xe;i.invokeEntryPoint=(e,t)=>{var n=xe[e];n||(e>=xe.length&&(xe.length=e+1),xe[e]=n=Xe.get(e)),e=n(t),0>>2>>>0]=t},this.fb=function(t){w()[this.Va+8>>>2>>>0]=t},this.Wa=function(t,n){this.eb(),this.gb(t),this.fb(n)},this.eb=function(){w()[this.Va+16>>>2>>>0]=0}}var o=0,s=0;function m(e,t,n,f){return _?$(2,1,e,t,n,f):O(e,t,n,f)}function O(e,t,n,f){if(e>>>=0,t>>>=0,n>>>=0,f>>>=0,typeof SharedArrayBuffer>"u")return ee("Current environment does not support SharedArrayBuffer, pthreads are not available!"),6;var y=[];return _&&y.length===0?m(e,t,n,f):(e={kb:n,Oa:e,hb:f,qb:y},_?(e.sb="spawnThread",postMessage(e,y),0):$e(e))}function S(e,t,n){return _?$(3,1,e,t,n):0}function R(e,t){if(_)return $(4,1,e,t)}var K=e=>{for(var t=0,n=0;n=f?t++:2047>=f?t+=2:55296<=f&&57343>=f?(t+=4,++n):t+=3}return t},le=(e,t,n,f)=>{if(n>>>=0,!(0=v){var z=e.charCodeAt(++b);v=65536+((v&1023)<<10)|z&1023}if(127>=v){if(n>=f)break;t[n++>>>0]=v}else{if(2047>=v){if(n+1>=f)break;t[n++>>>0]=192|v>>6}else{if(65535>=v){if(n+2>=f)break;t[n++>>>0]=224|v>>12}else{if(n+3>=f)break;t[n++>>>0]=240|v>>18,t[n++>>>0]=128|v>>12&63}t[n++>>>0]=128|v>>6&63}t[n++>>>0]=128|v&63}}return t[n>>>0]=0,n-y},oe=(e,t,n)=>le(e,h(),t,n);function se(e,t){if(_)return $(5,1,e,t)}function Qe(e,t,n){if(_)return $(6,1,e,t,n)}function Ze(e,t,n){return _?$(7,1,e,t,n):0}function c(e,t){if(_)return $(8,1,e,t)}function W(e,t,n){if(_)return $(9,1,e,t,n)}function G(e,t,n,f){if(_)return $(10,1,e,t,n,f)}function Se(e,t,n,f){if(_)return $(11,1,e,t,n,f)}function Ke(e,t,n,f){if(_)return $(12,1,e,t,n,f)}function Bt(e){if(_)return $(13,1,e)}function Wt(e,t){if(_)return $(14,1,e,t)}function kt(e,t,n){if(_)return $(15,1,e,t,n)}function mt(e){e>>>=0,typeof Atomics.rb=="function"&&(Atomics.rb(l(),e>>>2,e).value.then(ft),e+=128,Atomics.store(l(),e>>>2,1))}i.__emscripten_thread_mailbox_await=mt;var ft=()=>{var e=lt();if(e&&(mt(e),e=or,!P))try{if(e(),!(0e%4===0&&(e%100!==0||e%400===0),Nt=[0,31,60,91,121,152,182,213,244,274,305,335],Ht=[0,31,59,90,120,151,181,212,243,273,304,334];function $t(e,t,n,f,y,b,v,z){return _?$(16,1,e,t,n,f,y,b,v,z):-52}function Gt(e,t,n,f,y,b,v){if(_)return $(17,1,e,t,n,f,y,b,v)}var Yt=e=>{var t=K(e)+1,n=rr(t);return n&&oe(e,n,t),n},ht=[],yt={},jt=()=>{if(!bt){var e={USER:"web_user",LOGNAME:"web_user",PATH:"/",PWD:"/",HOME:"/home/web_user",LANG:(typeof navigator=="object"&&navigator.languages&&navigator.languages[0]||"C").replace("-","_")+".UTF-8",_:B||"./this.program"},t;for(t in yt)yt[t]===void 0?delete e[t]:e[t]=yt[t];var n=[];for(t in e)n.push(`${t}=${e[t]}`);bt=n}return bt},bt;function zt(e,t){if(_)return $(18,1,e,t);e>>>=0,t>>>=0;var n=0;return jt().forEach((f,y)=>{var b=t+n;for(y=w()[e+4*y>>>2>>>0]=b,b=0;b>>0>>>0]=f.charCodeAt(b);a()[y>>>0>>>0]=0,n+=f.length+1}),0}function qt(e,t){if(_)return $(19,1,e,t);e>>>=0,t>>>=0;var n=jt();w()[e>>>2>>>0]=n.length;var f=0;return n.forEach(y=>f+=y.length+1),w()[t>>>2>>>0]=f,0}function Vt(e){return _?$(20,1,e):52}function Jt(e,t,n,f){return _?$(21,1,e,t,n,f):52}function Xt(e,t,n,f,y){return _?$(22,1,e,t,n,f,y):70}var Gr=[null,[],[]];function Qt(e,t,n,f){if(_)return $(23,1,e,t,n,f);t>>>=0,n>>>=0,f>>>=0;for(var y=0,b=0;b>>2>>>0],z=w()[t+4>>>2>>>0];t+=8;for(var Te=0;Te>>0],me=Gr[e];ne===0||ne===10?((e===1?Ie:ee)(Ve(me,0)),me.length=0):me.push(ne)}y+=z}return w()[f>>>2>>>0]=y,0}var Zt=[31,29,31,30,31,30,31,31,30,31,30,31],Kt=[31,28,31,30,31,30,31,31,30,31,30,31];function Yr(e){var t=Array(K(e)+1);return le(e,t,0,t.length),t}var jr=(e,t)=>{a().set(e,t>>>0)};function er(e,t,n,f){function y(p,H,q){for(p=typeof p=="number"?p.toString():p||"";p.lengthcr?-1:0We-p.getDate())H-=We-p.getDate()+1,p.setDate(1),11>q?p.setMonth(q+1):(p.setMonth(0),p.setFullYear(p.getFullYear()+1));else{p.setDate(p.getDate()+H);break}}return q=new Date(p.getFullYear()+1,0,4),H=z(new Date(p.getFullYear(),0,4)),q=z(q),0>=v(H,p)?0>=v(q,p)?p.getFullYear()+1:p.getFullYear():p.getFullYear()-1}e>>>=0,t>>>=0,n>>>=0,f>>>=0;var ne=w()[f+40>>>2>>>0];f={ob:l()[f>>>2>>>0],nb:l()[f+4>>>2>>>0],Ta:l()[f+8>>>2>>>0],Xa:l()[f+12>>>2>>>0],Ua:l()[f+16>>>2>>>0],Sa:l()[f+20>>>2>>>0],Na:l()[f+24>>>2>>>0],Ra:l()[f+28>>>2>>>0],ub:l()[f+32>>>2>>>0],mb:l()[f+36>>>2>>>0],pb:ne?Ge(ne):""},n=Ge(n),ne={"%c":"%a %b %d %H:%M:%S %Y","%D":"%m/%d/%y","%F":"%Y-%m-%d","%h":"%b","%r":"%I:%M:%S %p","%R":"%H:%M","%T":"%H:%M:%S","%x":"%m/%d/%y","%X":"%H:%M:%S","%Ec":"%c","%EC":"%C","%Ex":"%m/%d/%y","%EX":"%H:%M:%S","%Ey":"%y","%EY":"%Y","%Od":"%d","%Oe":"%e","%OH":"%H","%OI":"%I","%Om":"%m","%OM":"%M","%OS":"%S","%Ou":"%u","%OU":"%U","%OV":"%V","%Ow":"%w","%OW":"%W","%Oy":"%y"};for(var me in ne)n=n.replace(new RegExp(me,"g"),ne[me]);var fr="Sunday Monday Tuesday Wednesday Thursday Friday Saturday".split(" "),lr="January February March April May June July August September October November December".split(" ");ne={"%a":p=>fr[p.Na].substring(0,3),"%A":p=>fr[p.Na],"%b":p=>lr[p.Ua].substring(0,3),"%B":p=>lr[p.Ua],"%C":p=>b((p.Sa+1900)/100|0,2),"%d":p=>b(p.Xa,2),"%e":p=>y(p.Xa,2," "),"%g":p=>Te(p).toString().substring(2),"%G":p=>Te(p),"%H":p=>b(p.Ta,2),"%I":p=>(p=p.Ta,p==0?p=12:12{for(var H=0,q=0;q<=p.Ua-1;H+=(je(p.Sa+1900)?Zt:Kt)[q++]);return b(p.Xa+H,3)},"%m":p=>b(p.Ua+1,2),"%M":p=>b(p.nb,2),"%n":()=>`\n`,"%p":p=>0<=p.Ta&&12>p.Ta?"AM":"PM","%S":p=>b(p.ob,2),"%t":()=>" ","%u":p=>p.Na||7,"%U":p=>b(Math.floor((p.Ra+7-p.Na)/7),2),"%V":p=>{var H=Math.floor((p.Ra+7-(p.Na+6)%7)/7);if(2>=(p.Na+371-p.Ra-2)%7&&H++,H)H==53&&(q=(p.Na+371-p.Ra)%7,q==4||q==3&&je(p.Sa)||(H=1));else{H=52;var q=(p.Na+7-p.Ra-1)%7;(q==4||q==5&&je(p.Sa%400-1))&&H++}return b(H,2)},"%w":p=>p.Na,"%W":p=>b(Math.floor((p.Ra+7-(p.Na+6)%7)/7),2),"%y":p=>(p.Sa+1900).toString().substring(2),"%Y":p=>p.Sa+1900,"%z":p=>{p=p.mb;var H=0<=p;return p=Math.abs(p)/60,(H?"+":"-")+("0000"+(p/60*100+p%60)).slice(-4)},"%Z":p=>p.pb,"%%":()=>"%"},n=n.replace(/%%/g,"\\0\\0");for(me in ne)n.includes(me)&&(n=n.replace(new RegExp(me,"g"),ne[me](f)));return n=n.replace(/\\0\\0/g,"%"),me=Yr(n),me.length>t?0:(jr(me,e),me.length-1)}M.Wa();var zr=[C,ut,m,S,R,se,Qe,Ze,c,W,G,Se,Ke,Bt,Wt,kt,$t,Gt,zt,qt,Vt,Jt,Xt,Qt],qr={b:function(e,t,n){throw e>>>=0,new r(e).Wa(t>>>0,n>>>0),o=e,s++,o},L:function(e){nr(e>>>0,!k,1,!U,131072,!1),M.ab()},j:function(e){e>>>=0,_?postMessage({cmd:"cleanupThread",thread:e}):M.Za(M.Ma[e])},H:O,h:S,S:R,D:se,F:Qe,T:Ze,Q:c,J:W,P:G,n:Se,E:Ke,B:Bt,R:Wt,C:kt,p:()=>1,z:function(e,t){e>>>=0,e==t>>>0?setTimeout(()=>ft()):_?postMessage({targetThread:e,cmd:"checkMailbox"}):(e=M.Ma[e])&&e.postMessage({cmd:"checkMailbox"})},I:function(e,t,n,f){t>>>=0,gt.length=n,f=f>>>0>>>3;for(var y=0;y>>0];return e=0>e?Ne[-e-1]:zr[e],M.ib=t,t=e.apply(null,gt),M.ib=0,t},K:mt,o:function(e){L&&M.Ma[e>>>0].ref()},s:function(e,t,n){e=t+2097152>>>0<4194305-!!e?(e>>>0)+4294967296*t:NaN,n>>>=0,e=new Date(1e3*e),l()[n>>>2>>>0]=e.getUTCSeconds(),l()[n+4>>>2>>>0]=e.getUTCMinutes(),l()[n+8>>>2>>>0]=e.getUTCHours(),l()[n+12>>>2>>>0]=e.getUTCDate(),l()[n+16>>>2>>>0]=e.getUTCMonth(),l()[n+20>>>2>>>0]=e.getUTCFullYear()-1900,l()[n+24>>>2>>>0]=e.getUTCDay(),e=(e.getTime()-Date.UTC(e.getUTCFullYear(),0,1,0,0,0,0))/864e5|0,l()[n+28>>>2>>>0]=e},t:function(e,t,n){e=t+2097152>>>0<4194305-!!e?(e>>>0)+4294967296*t:NaN,n>>>=0,e=new Date(1e3*e),l()[n>>>2>>>0]=e.getSeconds(),l()[n+4>>>2>>>0]=e.getMinutes(),l()[n+8>>>2>>>0]=e.getHours(),l()[n+12>>>2>>>0]=e.getDate(),l()[n+16>>>2>>>0]=e.getMonth(),l()[n+20>>>2>>>0]=e.getFullYear()-1900,l()[n+24>>>2>>>0]=e.getDay(),t=(je(e.getFullYear())?Nt:Ht)[e.getMonth()]+e.getDate()-1|0,l()[n+28>>>2>>>0]=t,l()[n+36>>>2>>>0]=-(60*e.getTimezoneOffset()),t=new Date(e.getFullYear(),6,1).getTimezoneOffset();var f=new Date(e.getFullYear(),0,1).getTimezoneOffset();e=(t!=f&&e.getTimezoneOffset()==Math.min(f,t))|0,l()[n+32>>>2>>>0]=e},u:function(e){e>>>=0;var t=new Date(l()[e+20>>>2>>>0]+1900,l()[e+16>>>2>>>0],l()[e+12>>>2>>>0],l()[e+8>>>2>>>0],l()[e+4>>>2>>>0],l()[e>>>2>>>0],0),n=l()[e+32>>>2>>>0],f=t.getTimezoneOffset(),y=new Date(t.getFullYear(),6,1).getTimezoneOffset(),b=new Date(t.getFullYear(),0,1).getTimezoneOffset(),v=Math.min(b,y);return 0>n?l()[e+32>>>2>>>0]=+(y!=b&&v==f):0>>2>>>0]=t.getDay(),n=(je(t.getFullYear())?Nt:Ht)[t.getMonth()]+t.getDate()-1|0,l()[e+28>>>2>>>0]=n,l()[e>>>2>>>0]=t.getSeconds(),l()[e+4>>>2>>>0]=t.getMinutes(),l()[e+8>>>2>>>0]=t.getHours(),l()[e+12>>>2>>>0]=t.getDate(),l()[e+16>>>2>>>0]=t.getMonth(),l()[e+20>>>2>>>0]=t.getYear(),e=t.getTime(),isNaN(e)?(l()[tr()>>>2>>>0]=61,e=-1):e/=1e3,sr((De=e,1<=+Math.abs(De)?0>>0:~~+Math.ceil((De-+(~~De>>>0))/4294967296)>>>0:0)),e>>>0},q:$t,r:Gt,y:function(e,t,n){function f(ne){return(ne=ne.toTimeString().match(/\\(([A-Za-z ]+)\\)$/))?ne[1]:"GMT"}e>>>=0,t>>>=0,n>>>=0;var y=new Date().getFullYear(),b=new Date(y,0,1),v=new Date(y,6,1);y=b.getTimezoneOffset();var z=v.getTimezoneOffset(),Te=Math.max(y,z);w()[e>>>2>>>0]=60*Te,l()[t>>>2>>>0]=+(y!=z),e=f(b),t=f(v),e=Yt(e),t=Yt(t),z>>2>>>0]=e,w()[n+4>>>2>>>0]=t):(w()[n>>>2>>>0]=t,w()[n+4>>>2>>>0]=e)},c:()=>{Z("")},O:function(e,t,n){e>>>=0,t>>>=0,n>>>=0,ht.length=0;for(var f;f=h()[t++>>>0];){var y=f!=105;y&=f!=112,n+=y&&n%8?4:0,ht.push(f==112?w()[n>>>2>>>0]:f==105?l()[n>>>2>>>0]:g()[n>>>3>>>0]),n+=y?8:4}return Ne[e].apply(null,ht)},k:()=>{},i:()=>Date.now(),U:()=>{throw Le+=1,"unwind"},A:function(){return 4294901760},e:()=>performance.timeOrigin+performance.now(),f:()=>L?(wr(),tt(br)).cpus().length:navigator.hardwareConcurrency,x:function(e){e>>>=0;var t=h().length;if(e<=t||4294901760=n;n*=2){var f=t*(1+.2/n);f=Math.min(f,e+100663296);var y=Math;f=Math.max(e,f);e:{y=(y.min.call(y,4294901760,f+(65536-f%65536)%65536)-j.buffer.byteLength+65535)/65536;try{j.grow(y),we();var b=1;break e}catch{}b=void 0}if(b)return!0}return!1},M:zt,N:qt,G:Ye,g:Vt,m:Jt,v:Xt,l:Qt,a:j||i.wasmMemory,w:er,d:function(e,t,n,f){return er(e>>>0,t>>>0,n>>>0,f>>>0)}},T=function(){function e(n,f){return T=n.exports,T=Vr(),M.bb.push(T.za),Xe=T.Aa,Fe.unshift(T.V),ce=f,re(),T}var t={a:qr};if(pe++,i.instantiateWasm)try{return i.instantiateWasm(t,e)}catch(n){ee(`Module.instantiateWasm callback failed with error: ${n}`),D(n)}return at(t,function(n){e(n.instance,n.module)}).catch(D),{}}();i._OrtInit=(e,t)=>(i._OrtInit=T.W)(e,t),i._OrtGetLastError=(e,t)=>(i._OrtGetLastError=T.X)(e,t),i._OrtCreateSessionOptions=(e,t,n,f,y,b,v,z,Te,ne)=>(i._OrtCreateSessionOptions=T.Y)(e,t,n,f,y,b,v,z,Te,ne),i._OrtAppendExecutionProvider=(e,t)=>(i._OrtAppendExecutionProvider=T.Z)(e,t),i._OrtAddFreeDimensionOverride=(e,t,n)=>(i._OrtAddFreeDimensionOverride=T._)(e,t,n),i._OrtAddSessionConfigEntry=(e,t,n)=>(i._OrtAddSessionConfigEntry=T.$)(e,t,n),i._OrtReleaseSessionOptions=e=>(i._OrtReleaseSessionOptions=T.aa)(e),i._OrtCreateSession=(e,t,n)=>(i._OrtCreateSession=T.ba)(e,t,n),i._OrtReleaseSession=e=>(i._OrtReleaseSession=T.ca)(e),i._OrtGetInputOutputCount=(e,t,n)=>(i._OrtGetInputOutputCount=T.da)(e,t,n),i._OrtGetInputName=(e,t)=>(i._OrtGetInputName=T.ea)(e,t),i._OrtGetOutputName=(e,t)=>(i._OrtGetOutputName=T.fa)(e,t),i._OrtFree=e=>(i._OrtFree=T.ga)(e),i._OrtCreateTensor=(e,t,n,f,y,b)=>(i._OrtCreateTensor=T.ha)(e,t,n,f,y,b),i._OrtGetTensorData=(e,t,n,f,y)=>(i._OrtGetTensorData=T.ia)(e,t,n,f,y),i._OrtReleaseTensor=e=>(i._OrtReleaseTensor=T.ja)(e),i._OrtCreateRunOptions=(e,t,n,f)=>(i._OrtCreateRunOptions=T.ka)(e,t,n,f),i._OrtAddRunConfigEntry=(e,t,n)=>(i._OrtAddRunConfigEntry=T.la)(e,t,n),i._OrtReleaseRunOptions=e=>(i._OrtReleaseRunOptions=T.ma)(e),i._OrtCreateBinding=e=>(i._OrtCreateBinding=T.na)(e),i._OrtBindInput=(e,t,n)=>(i._OrtBindInput=T.oa)(e,t,n),i._OrtBindOutput=(e,t,n,f)=>(i._OrtBindOutput=T.pa)(e,t,n,f),i._OrtClearBoundOutputs=e=>(i._OrtClearBoundOutputs=T.qa)(e),i._OrtReleaseBinding=e=>(i._OrtReleaseBinding=T.ra)(e),i._OrtRunWithBinding=(e,t,n,f,y)=>(i._OrtRunWithBinding=T.sa)(e,t,n,f,y),i._OrtRun=(e,t,n,f,y,b,v,z)=>(i._OrtRun=T.ta)(e,t,n,f,y,b,v,z),i._OrtEndProfiling=e=>(i._OrtEndProfiling=T.ua)(e);var tr=()=>(tr=T.va)(),lt=i._pthread_self=()=>(lt=i._pthread_self=T.wa)(),rr=i._malloc=e=>(rr=i._malloc=T.xa)(e);i._free=e=>(i._free=T.ya)(e),i.__emscripten_tls_init=()=>(i.__emscripten_tls_init=T.za)();var nr=i.__emscripten_thread_init=(e,t,n,f,y,b)=>(nr=i.__emscripten_thread_init=T.Ba)(e,t,n,f,y,b);i.__emscripten_thread_crashed=()=>(i.__emscripten_thread_crashed=T.Ca)();var ar=(e,t,n,f)=>(ar=T.Da)(e,t,n,f),wt=e=>(wt=T.Ea)(e),Ot=i.__emscripten_thread_exit=e=>(Ot=i.__emscripten_thread_exit=T.Fa)(e),or=()=>(or=T.Ga)(),sr=e=>(sr=T.Ha)(e),ir=(e,t)=>(ir=T.Ia)(e,t),vt=()=>(vt=T.Ja)(),ct=e=>(ct=T.Ka)(e),_t=e=>(_t=T.La)(e);function Vr(){var e=T;e=Object.assign({},e);var t=f=>()=>f()>>>0,n=f=>y=>f(y)>>>0;return e.va=t(e.va),e.wa=t(e.wa),e.xa=n(e.xa),e.emscripten_main_runtime_thread_id=t(e.emscripten_main_runtime_thread_id),e.Ja=t(e.Ja),e.La=n(e.La),e}i.wasmMemory=j,i.stackAlloc=_t,i.stackSave=vt,i.stackRestore=ct,i.keepRuntimeAlive=()=>0Or)});var Er=et((On,nn)=>{nn.exports=\'"use strict";var Module={},ENVIRONMENT_IS_NODE=typeof process=="object"&&typeof process.versions=="object"&&typeof process.versions.node=="string";if(ENVIRONMENT_IS_NODE){var nodeWorkerThreads=require("worker_threads"),parentPort=nodeWorkerThreads.parentPort;parentPort.on("message",e=>onmessage({data:e}));var fs=require("fs"),vm=require("vm");Object.assign(global,{self:global,require,Module,location:{href:__filename},Worker:nodeWorkerThreads.Worker,importScripts:e=>vm.runInThisContext(fs.readFileSync(e,"utf8"),{filename:e}),postMessage:e=>parentPort.postMessage(e),performance:global.performance||{now:Date.now}})}var initializedJS=!1;function threadPrintErr(){var e=Array.prototype.slice.call(arguments).join(" ");if(ENVIRONMENT_IS_NODE){fs.writeSync(2,e+`\\n`);return}console.error(e)}function threadAlert(){var e=Array.prototype.slice.call(arguments).join(" ");postMessage({cmd:"alert",text:e,threadId:Module._pthread_self()})}var err=threadPrintErr;self.alert=threadAlert,Module.instantiateWasm=(e,t)=>{var a=Module.wasmModule;Module.wasmModule=null;var r=new WebAssembly.Instance(a,e);return t(r)},self.onunhandledrejection=e=>{throw e.reason||e};function handleMessage(e){try{if(e.data.cmd==="load"){let a=[];self.onmessage=r=>a.push(r),self.startWorker=r=>{Module=r,postMessage({cmd:"loaded"});for(let s of a)handleMessage(s);self.onmessage=handleMessage},Module.wasmModule=e.data.wasmModule;for(const r of e.data.handlers)Module[r]=(...s)=>{postMessage({cmd:"callHandler",handler:r,args:s})};if(Module.wasmMemory=e.data.wasmMemory,Module.buffer=Module.wasmMemory.buffer,Module.ENVIRONMENT_IS_PTHREAD=!0,typeof e.data.urlOrBlob=="string")importScripts(e.data.urlOrBlob);else{var t=URL.createObjectURL(e.data.urlOrBlob);importScripts(t),URL.revokeObjectURL(t)}ortWasmThreaded(Module)}else if(e.data.cmd==="run"){Module.__emscripten_thread_init(e.data.pthread_ptr,0,0,1),Module.__emscripten_thread_mailbox_await(e.data.pthread_ptr),Module.establishStackSpace(),Module.PThread.receiveObjectTransfer(e.data),Module.PThread.threadInitTLS(),initializedJS||(initializedJS=!0);try{Module.invokeEntryPoint(e.data.start_routine,e.data.arg)}catch(a){if(a!="unwind")throw a}}else e.data.cmd==="cancel"?Module._pthread_self()&&Module.__emscripten_thread_exit(-1):e.data.target==="setimmediate"||(e.data.cmd==="checkMailbox"?initializedJS&&Module.checkMailbox():e.data.cmd&&(err(`worker.js received unknown command ${e.data.cmd}`),err(e.data)))}catch(a){throw Module.__emscripten_thread_crashed?.(),a}}self.onmessage=handleMessage;\\n\'});var Tr;Tr=gr();var an=_r(),Ut,Pt=!1,pt=!1,Sr=!1,on=u=>{if(u===1)return!1;if(typeof SharedArrayBuffer>"u")return typeof self<"u"&&!self.crossOriginIsolated&&console.warn("env.wasm.numThreads is set to "+u+", but this will not work unless you enable crossOriginIsolated mode. See https://web.dev/cross-origin-isolation-guide/ for more info."),!1;typeof process<"u"&&process.versions&&process.versions.node&&console.warn("env.wasm.numThreads is set to "+u+", however, currently onnxruntime-web does not support multi-threads in Node.js. Please consider using onnxruntime-node for performance critical scenarios.");try{return typeof MessageChannel<"u"&&new MessageChannel().port1.postMessage(new SharedArrayBuffer(1)),WebAssembly.validate(new Uint8Array([0,97,115,109,1,0,0,0,1,4,1,96,0,0,3,2,1,0,5,4,1,3,1,1,10,11,1,9,0,65,0,254,16,2,0,26,11]))}catch{return!1}},sn=()=>{try{return WebAssembly.validate(new Uint8Array([0,97,115,109,1,0,0,0,1,4,1,96,0,0,3,2,1,0,10,30,1,28,0,65,0,253,15,253,12,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,253,186,1,26,11]))}catch{return!1}},un=(u,d)=>u?d?"ort-wasm-simd-threaded.wasm":"ort-wasm-simd.wasm":d?"ort-wasm-threaded.wasm":"ort-wasm.wasm",Ar=async u=>{if(Pt)return Promise.resolve();if(pt)throw new Error("multiple calls to \'initializeWebAssembly()\' detected.");if(Sr)throw new Error("previous call to \'initializeWebAssembly()\' failed.");pt=!0;let d=u.initTimeout,a=u.numThreads,h=u.simd,l=on(a),w=h&&sn(),g=u.wasmPaths,i=typeof g=="string"?g:void 0,A=un(w,l),D=typeof g=="object"?g[A]:void 0,I=!1,B=[];if(d>0&&B.push(new Promise(F=>{setTimeout(()=>{I=!0,F()},d)})),B.push(new Promise((F,U)=>{let k=l?an:Tr,L={locateFile:(_,x)=>l&&_.endsWith(".worker.js")&&typeof Blob<"u"?URL.createObjectURL(new Blob([Er()],{type:"text/javascript"})):_.endsWith(".wasm")?D||(i??x)+A:x+_};if(l)if(L.numThreads=a,typeof Blob>"u")L.mainScriptUrlOrBlob=(void 0)(__dirname,"ort-wasm-threaded.js");else{let _=`var ortWasmThreaded=${k.toString()};`;L.mainScriptUrlOrBlob=new Blob([_],{type:"text/javascript"})}k(L).then(_=>{pt=!1,Pt=!0,Ut=_,F()},_=>{pt=!1,Sr=!0,U(_)})})),await Promise.race(B),I)throw new Error(`WebAssembly backend initializing failed due to timeout: ${d}ms`)},X=()=>{if(Pt&&Ut)return Ut;throw new Error("WebAssembly is not initialized yet.")};var Q=(u,d)=>{let a=X(),h=a.lengthBytesUTF8(u)+1,l=a._malloc(h);return a.stringToUTF8(u,l,h),d.push(l),l},rt=(u,d,a,h)=>{if(typeof u=="object"&&u!==null){if(a.has(u))throw new Error("Circular reference in options");a.add(u)}Object.entries(u).forEach(([l,w])=>{let g=d?d+l:l;if(typeof w=="object")rt(w,g+".",a,h);else if(typeof w=="string"||typeof w=="number")h(g,w.toString());else if(typeof w=="boolean")h(g,w?"1":"0");else throw new Error(`Can\'t handle extra config type: ${typeof w}`)})},V=u=>{let d=X(),a=d.stackSave();try{let h=d.stackAlloc(8);d._OrtGetLastError(h,h+4);let l=d.HEAP32[h/4],w=d.HEAPU32[h/4+1],g=w?d.UTF8ToString(w):"";throw new Error(`${u} ERROR_CODE: ${l}, ERROR_MESSAGE: ${g}`)}finally{d.stackRestore(a)}};var Mr=u=>{let d=X(),a=0,h=[],l=u||{};try{if(u?.logSeverityLevel===void 0)l.logSeverityLevel=2;else if(typeof u.logSeverityLevel!="number"||!Number.isInteger(u.logSeverityLevel)||u.logSeverityLevel<0||u.logSeverityLevel>4)throw new Error(`log serverity level is not valid: ${u.logSeverityLevel}`);if(u?.logVerbosityLevel===void 0)l.logVerbosityLevel=0;else if(typeof u.logVerbosityLevel!="number"||!Number.isInteger(u.logVerbosityLevel))throw new Error(`log verbosity level is not valid: ${u.logVerbosityLevel}`);u?.terminate===void 0&&(l.terminate=!1);let w=0;return u?.tag!==void 0&&(w=Q(u.tag,h)),a=d._OrtCreateRunOptions(l.logSeverityLevel,l.logVerbosityLevel,!!l.terminate,w),a===0&&V("Can\'t create run options."),u?.extra!==void 0&&rt(u.extra,"",new WeakSet,(g,i)=>{let A=Q(g,h),D=Q(i,h);d._OrtAddRunConfigEntry(a,A,D)!==0&&V(`Can\'t set a run config entry: ${g} - ${i}.`)}),[a,h]}catch(w){throw a!==0&&d._OrtReleaseRunOptions(a),h.forEach(g=>d._free(g)),w}};var fn=u=>{switch(u){case"disabled":return 0;case"basic":return 1;case"extended":return 2;case"all":return 99;default:throw new Error(`unsupported graph optimization level: ${u}`)}},ln=u=>{switch(u){case"sequential":return 0;case"parallel":return 1;default:throw new Error(`unsupported execution mode: ${u}`)}},cn=u=>{u.extra||(u.extra={}),u.extra.session||(u.extra.session={});let d=u.extra.session;d.use_ort_model_bytes_directly||(d.use_ort_model_bytes_directly="1"),u.executionProviders&&u.executionProviders.some(a=>(typeof a=="string"?a:a.name)==="webgpu")&&(u.enableMemPattern=!1)},dn=(u,d,a)=>{for(let h of d){let l=typeof h=="string"?h:h.name;switch(l){case"webnn":if(l="WEBNN",typeof h!="string"){let g=h;if(g?.deviceType){let i=Q("deviceType",a),A=Q(g.deviceType,a);X()._OrtAddSessionConfigEntry(u,i,A)!==0&&V(`Can\'t set a session config entry: \'deviceType\' - ${g.deviceType}.`)}if(g?.numThreads){let i=g.numThreads;(typeof i!="number"||!Number.isInteger(i)||i<0)&&(i=0);let A=Q("numThreads",a),D=Q(i.toString(),a);X()._OrtAddSessionConfigEntry(u,A,D)!==0&&V(`Can\'t set a session config entry: \'numThreads\' - ${g.numThreads}.`)}if(g?.powerPreference){let i=Q("powerPreference",a),A=Q(g.powerPreference,a);X()._OrtAddSessionConfigEntry(u,i,A)!==0&&V(`Can\'t set a session config entry: \'powerPreference\' - ${g.powerPreference}.`)}}break;case"webgpu":if(l="JS",typeof h!="string"){let g=h;if(g?.preferredLayout){if(g.preferredLayout!=="NCHW"&&g.preferredLayout!=="NHWC")throw new Error(`preferredLayout must be either \'NCHW\' or \'NHWC\': ${g.preferredLayout}`);let i=Q("preferredLayout",a),A=Q(g.preferredLayout,a);X()._OrtAddSessionConfigEntry(u,i,A)!==0&&V(`Can\'t set a session config entry: \'preferredLayout\' - ${g.preferredLayout}.`)}}break;case"wasm":case"cpu":continue;default:throw new Error(`not supported execution provider: ${l}`)}let w=Q(l,a);X()._OrtAppendExecutionProvider(u,w)!==0&&V(`Can\'t append execution provider: ${l}.`)}},Cr=u=>{let d=X(),a=0,h=[],l=u||{};cn(l);try{let w=fn(l.graphOptimizationLevel??"all"),g=ln(l.executionMode??"sequential"),i=typeof l.logId=="string"?Q(l.logId,h):0,A=l.logSeverityLevel??2;if(!Number.isInteger(A)||A<0||A>4)throw new Error(`log serverity level is not valid: ${A}`);let D=l.logVerbosityLevel??0;if(!Number.isInteger(D)||D<0||D>4)throw new Error(`log verbosity level is not valid: ${D}`);let I=typeof l.optimizedModelFilePath=="string"?Q(l.optimizedModelFilePath,h):0;if(a=d._OrtCreateSessionOptions(w,!!l.enableCpuMemArena,!!l.enableMemPattern,g,!!l.enableProfiling,0,i,A,D,I),a===0&&V("Can\'t create session options."),l.executionProviders&&dn(a,l.executionProviders,h),l.freeDimensionOverrides)for(let[B,F]of Object.entries(l.freeDimensionOverrides)){if(typeof B!="string")throw new Error(`free dimension override name must be a string: ${B}`);if(typeof F!="number"||!Number.isInteger(F)||F<0)throw new Error(`free dimension override value must be a non-negative integer: ${F}`);let U=Q(B,h);d._OrtAddFreeDimensionOverride(a,U,F)!==0&&V(`Can\'t set a free dimension override: ${B} - ${F}.`)}return l.extra!==void 0&&rt(l.extra,"",new WeakSet,(B,F)=>{let U=Q(B,h),k=Q(F,h);d._OrtAddSessionConfigEntry(a,U,k)!==0&&V(`Can\'t set a session config entry: ${B} - ${F}.`)}),[a,h]}catch(w){throw a!==0&&d._OrtReleaseSessionOptions(a),h.forEach(g=>d._free(g)),w}};var Rt=u=>{switch(u){case"int8":return 3;case"uint8":return 2;case"bool":return 9;case"int16":return 5;case"uint16":return 4;case"int32":return 6;case"uint32":return 12;case"float16":return 10;case"float32":return 1;case"float64":return 11;case"string":return 8;case"int64":return 7;case"uint64":return 13;default:throw new Error(`unsupported data type: ${u}`)}},Dr=u=>{switch(u){case 3:return"int8";case 2:return"uint8";case 9:return"bool";case 5:return"int16";case 4:return"uint16";case 6:return"int32";case 12:return"uint32";case 10:return"float16";case 1:return"float32";case 11:return"float64";case 8:return"string";case 7:return"int64";case 13:return"uint64";default:throw new Error(`unsupported data type: ${u}`)}},It=u=>[void 0,4,1,1,2,2,4,8,void 0,1,2,8,4,8,void 0,void 0,void 0][u],xr=u=>{switch(u){case"float16":return Uint16Array;case"float32":return Float32Array;case"uint8":return Uint8Array;case"int8":return Int8Array;case"uint16":return Uint16Array;case"int16":return Int16Array;case"int32":return Int32Array;case"bool":return Uint8Array;case"float64":return Float64Array;case"uint32":return Uint32Array;case"int64":return BigInt64Array;case"uint64":return BigUint64Array;default:throw new Error(`unsupported type: ${u}`)}},Fr=u=>{switch(u){case"verbose":return 0;case"info":return 1;case"warning":return 2;case"error":return 3;case"fatal":return 4;default:throw new Error(`unsupported logging level: ${u}`)}},Ur=u=>u==="float32"||u==="int32"||u==="int64"||u==="bool"||u==="float16"||u==="uint32",Pr=u=>{switch(u){case"none":return 0;case"cpu":return 1;case"cpu-pinned":return 2;case"texture":return 3;case"gpu-buffer":return 4;default:throw new Error(`unsupported data location: ${u}`)}};var Rr=async u=>{if(typeof u=="string")if(typeof process<"u"&&process.versions&&process.versions.node)try{return new Uint8Array(await(void 0)(u))}catch(d){if(d.code==="ERR_FS_FILE_TOO_LARGE"){let a=(void 0)(u),h=[];for await(let l of a)h.push(l);return new Uint8Array(Buffer.concat(h))}throw d}else{let d=await fetch(u);if(!d.ok)throw new Error(`failed to load external data file: ${u}`);let a=d.headers.get("Content-Length"),h=a?parseInt(a,10):0;if(h<1073741824)return new Uint8Array(await d.arrayBuffer());{if(!d.body)throw new Error(`failed to load external data file: ${u}, no response body.`);let l=d.body.getReader(),w;try{w=new ArrayBuffer(h)}catch(i){if(i instanceof RangeError){let A=Math.ceil(h/65536);w=new WebAssembly.Memory({initial:A,maximum:A}).buffer}else throw i}let g=0;for(;;){let{done:i,value:A}=await l.read();if(i)break;let D=A.byteLength;new Uint8Array(w,g,D).set(A),g+=D}return new Uint8Array(w,0,h)}}else return u instanceof Blob?new Uint8Array(await u.arrayBuffer()):u instanceof Uint8Array?u:new Uint8Array(u)};var pn=(u,d)=>{X()._OrtInit(u,d)!==0&&V("Can\'t initialize onnxruntime.")},Lr=async u=>{pn(u.wasm.numThreads,Fr(u.logLevel))},Br=async(u,d)=>{},nt=new Map,mn=u=>{let d=X(),a=d.stackSave();try{let h=d.stackAlloc(8);return d._OrtGetInputOutputCount(u,h,h+4)!==0&&V("Can\'t get session input/output count."),[d.HEAP32[h/4],d.HEAP32[h/4+1]]}finally{d.stackRestore(a)}},Lt=u=>{let d=X(),a=d._malloc(u.byteLength);if(a===0)throw new Error(`Can\'t create a session. failed to allocate a buffer of size ${u.byteLength}.`);return d.HEAPU8.set(u,a),[a,u.byteLength]},Wr=async(u,d)=>{let a,h,l=X();Array.isArray(u)?[a,h]=u:u.buffer===l.HEAPU8.buffer?[a,h]=[u.byteOffset,u.byteLength]:[a,h]=Lt(u);let w=0,g=0,i=0,A=[],D=[],I=[];try{if([g,A]=Cr(d),d?.externalData&&l.mountExternalData){let x=[];for(let N of d.externalData){let he=typeof N=="string"?N:N.path;x.push(Rr(typeof N=="string"?N:N.data).then(ie=>{l.mountExternalData(he,ie)}))}await Promise.all(x)}w=l._OrtCreateSession(a,h,g),w===0&&V("Can\'t create a session.");let[B,F]=mn(w),U=[],k=[],L=[];for(let x=0;xl._OrtFree(F)),I.forEach(F=>l._OrtFree(F)),i!==0&&l._OrtReleaseBinding(i),w!==0&&l._OrtReleaseSession(w),B}finally{l._free(a),g!==0&&l._OrtReleaseSessionOptions(g),A.forEach(B=>l._free(B)),l.unmountExternalData?.()}},kr=u=>{let d=X(),a=nt.get(u);if(!a)throw new Error(`cannot release session. invalid session id: ${u}`);let[h,l,w,g]=a;g&&d._OrtReleaseBinding(g.handle),d.jsepUnregisterBuffers?.(u),l.forEach(i=>d._OrtFree(i)),w.forEach(i=>d._OrtFree(i)),d._OrtReleaseSession(h),nt.delete(u)},Ir=(u,d,a,h,l)=>{if(!u){d.push(0);return}let w=X(),g=u[0],i=u[1],A=u[3],D,I;if(g==="string"&&A==="gpu-buffer")throw new Error("String tensor is not supported on GPU.");if(A==="gpu-buffer"){let U=u[2].gpuBuffer,k=It(Rt(g));I=i.reduce((L,_)=>L*_,1)*k,D=w.jsepRegisterBuffer(h,l,U,I)}else{let U=u[2];if(Array.isArray(U)){I=4*U.length,D=w._malloc(I),a.push(D);let k=D/4;for(let L=0;Lw.HEAP32[U++]=L);let k=w._OrtCreateTensor(Rt(g),D,I,F,i.length,Pr(A));k===0&&V(`Can\'t create tensor for input/output. session=${h}, index=${l}.`),d.push(k)}finally{w.stackRestore(B)}},Nr=async(u,d,a,h,l,w)=>{let g=X(),i=nt.get(u);if(!i)throw new Error(`cannot run inference. invalid session id: ${u}`);let[A,D,I,B]=i,F=d.length,U=h.length,k=0,L=[],_=[],x=[],N=[],he=g.stackSave(),ie=g.stackAlloc(F*4),ae=g.stackAlloc(F*4),E=g.stackAlloc(U*4),Y=g.stackAlloc(U*4);try{[k,L]=Mr(w);for(let P=0;Pre*Z,1);J=Dr(Me);let ve=B?.outputPreferredLocations[h[P]];if(J==="string"){if(ve==="gpu-buffer")throw new Error("String tensor is not supported on GPU.");let re=[],Z=fe/4;for(let Ce=0;Ce0){let re=g.jsepGetBuffer(fe),Z=It(Me);if(Z===void 0||!Ur(J))throw new Error(`Unsupported data type: ${J}`);ye=!0,ce.push([J,pe,{gpuBuffer:re,download:g.jsepCreateDownloader(re,Oe*Z,J),dispose:()=>{g._OrtReleaseTensor(te)}},"gpu-buffer"])}else{let re=xr(J),Z=new re(Oe);new Uint8Array(Z.buffer,Z.byteOffset,Z.byteLength).set(g.HEAPU8.subarray(fe,fe+Z.byteLength)),ce.push([J,pe,Z,"cpu"])}}finally{g.stackRestore(de),J==="string"&&fe&&g._free(fe),ye||g._OrtReleaseTensor(te)}}return B&&g._OrtClearBoundOutputs(B.handle),ce}finally{g.stackRestore(he),_.forEach(ue=>g._OrtReleaseTensor(ue)),x.forEach(ue=>g._OrtReleaseTensor(ue)),N.forEach(ue=>g._free(ue)),k!==0&&g._OrtReleaseRunOptions(k),L.forEach(ue=>g._free(ue))}},Hr=u=>{let d=X(),a=nt.get(u);if(!a)throw new Error("invalid session id");let h=a[0],l=d._OrtEndProfiling(h);l===0&&V("Can\'t get an profile file name."),d._OrtFree(l)},$r=u=>{let d=[];for(let a of u){let h=a[2];!Array.isArray(h)&&"buffer"in h&&d.push(h.buffer)}return d};self.onmessage=u=>{let{type:d,in:a}=u.data;try{switch(d){case"init-wasm":Ar(a.wasm).then(()=>{Lr(a).then(()=>{postMessage({type:d})},h=>{postMessage({type:d,err:h})})},h=>{postMessage({type:d,err:h})});break;case"init-ep":{let{epName:h,env:l}=a;Br(l,h).then(()=>{postMessage({type:d})},w=>{postMessage({type:d,err:w})});break}case"copy-from":{let{buffer:h}=a,l=Lt(h);postMessage({type:d,out:l});break}case"create":{let{model:h,options:l}=a;Wr(h,l).then(w=>{postMessage({type:d,out:w})},w=>{postMessage({type:d,err:w})});break}case"release":kr(a),postMessage({type:d});break;case"run":{let{sessionId:h,inputIndices:l,inputs:w,outputIndices:g,options:i}=a;Nr(h,l,w,g,new Array(g.length).fill(null),i).then(A=>{A.some(D=>D[3]!=="cpu")?postMessage({type:d,err:"Proxy does not support non-cpu tensor location."}):postMessage({type:d,out:A},$r(A))},A=>{postMessage({type:d,err:A})});break}case"end-profiling":Hr(a),postMessage({type:d});break;default:}}catch(h){postMessage({type:d,err:h})}};})();\n'; }), xr, bt, Tn, Fo, $o, da, ha, Vr, Wr, gg, Lo, nd, od, id, ad, sd, ud, ld, ma = L(() => { vt(), td(), zr(), (xr = () => !!Z.wasm.proxy && typeof document < 'u'), (Tn = !1), (Fo = !1), ($o = !1), (ha = new Map()), (Vr = (t, e) => { let o = ha.get(t); o ? o.push(e) : ha.set(t, [e]); }), (Wr = () => { if (Tn || !Fo || $o || !bt) throw new Error('worker not ready'); }), (gg = (t) => { switch (t.data.type) { case 'init-wasm': (Tn = !1), t.data.err ? (($o = !0), da[1](t.data.err)) : ((Fo = !0), da[0]()); break; case 'init-ep': case 'copy-from': case 'create': case 'release': case 'run': case 'end-profiling': { let e = ha.get(t.data.type); t.data.err ? e.shift()[1](t.data.err) : e.shift()[0](t.data.out); break; } } }), (Lo = typeof document < 'u' ? document?.currentScript?.src : void 0), (nd = async () => { if (!Fo) { if (Tn) throw new Error("multiple calls to 'initWasm()' detected."); if ($o) throw new Error("previous call to 'initWasm()' failed."); if (((Tn = !0), xr())) return ( Z.wasm.wasmPaths === void 0 && Lo && Lo.indexOf('blob:') !== 0 && (Z.wasm.wasmPaths = Lo.substr(0, +Lo.lastIndexOf('/') + 1)), new Promise((t, e) => { bt?.terminate(); let o = URL.createObjectURL(new Blob([rd()], { type: 'text/javascript' })); (bt = new Worker(o, { name: 'ort-wasm-proxy-worker' })), (bt.onerror = (u) => e(u)), (bt.onmessage = gg), URL.revokeObjectURL(o), (da = [t, e]); let i = { type: 'init-wasm', in: Z }; bt.postMessage(i); }) ); try { await Rp(Z.wasm), await Yp(Z), (Fo = !0); } catch (t) { throw (($o = !0), t); } finally { Tn = !1; } } }), (od = async (t) => { if (xr()) return ( Wr(), new Promise((e, o) => { Vr('init-ep', [e, o]); let i = { type: 'init-ep', in: { epName: t, env: Z } }; bt.postMessage(i); }) ); await Xp(Z, t); }), (id = async (t) => xr() ? (Wr(), new Promise((e, o) => { Vr('copy-from', [e, o]); let i = { type: 'copy-from', in: { buffer: t } }; bt.postMessage(i, [t.buffer]); })) : pa(t)), (ad = async (t, e) => { if (xr()) { if (e?.preferredOutputLocation) throw new Error('session option "preferredOutputLocation" is not supported for proxy.'); return ( Wr(), new Promise((o, i) => { Vr('create', [o, i]); let u = { type: 'create', in: { model: t, options: e } }, n = []; t instanceof Uint8Array && n.push(t.buffer), bt.postMessage(u, n); }) ); } else return Kp(t, e); }), (sd = async (t) => { if (xr()) return ( Wr(), new Promise((e, o) => { Vr('release', [e, o]); let i = { type: 'release', in: t }; bt.postMessage(i); }) ); Jp(t); }), (ud = async (t, e, o, i, u, n) => { if (xr()) { if (o.some((s) => s[3] !== 'cpu')) throw new Error('input tensor on GPU is not supported for proxy.'); if (u.some((s) => s)) throw new Error('pre-allocated output tensor is not supported for proxy.'); return ( Wr(), new Promise((s, d) => { Vr('run', [s, d]); let f = o, r = { type: 'run', in: { sessionId: t, inputIndices: e, inputs: f, outputIndices: i, options: n }, }; bt.postMessage(r, ed(f)); }) ); } else return Zp(t, e, o, i, u, n); }), (ld = async (t) => { if (xr()) return ( Wr(), new Promise((e, o) => { Vr('end-profiling', [e, o]); let i = { type: 'end-profiling', in: t }; bt.postMessage(i); }) ); Qp(t); }); }), fd, yg, Co, cd = L(() => { vt(), ma(), fa(), ca(), (fd = (t, e) => { switch (t.location) { case 'cpu': return [t.type, t.dims, t.data, 'cpu']; case 'gpu-buffer': return [t.type, t.dims, { gpuBuffer: t.gpuBuffer }, 'gpu-buffer']; default: throw new Error(`invalid data location: ${t.location} for ${e()}`); } }), (yg = (t) => { switch (t[3]) { case 'cpu': return new Re(t[0], t[2], t[1]); case 'gpu-buffer': { let e = t[0]; if (!Do(e)) throw new Error(`not supported data type: ${e} for deserializing GPU tensor`); let { gpuBuffer: o, download: i, dispose: u } = t[2]; return Re.fromGpuBuffer(o, { dataType: e, dims: t[1], download: i, dispose: u }); } default: throw new Error(`invalid data location: ${t[3]}`); } }), (Co = class { async fetchModelAndCopyToWasmMemory(t) { return id(await gn(t)); } async loadModel(t, e) { ar(); let o; typeof t == 'string' ? typeof process < 'u' && process.versions && process.versions.node ? (o = await gn(t)) : (o = await this.fetchModelAndCopyToWasmMemory(t)) : (o = t), ([this.sessionId, this.inputNames, this.outputNames] = await ad(o, e)), sr(); } async dispose() { return sd(this.sessionId); } async run(t, e, o) { ar(); let i = [], u = []; Object.entries(t).forEach((l) => { let p = l[0], m = l[1], y = this.inputNames.indexOf(p); if (y === -1) throw new Error(`invalid input '${p}'`); i.push(m), u.push(y); }); let n = [], s = []; Object.entries(e).forEach((l) => { let p = l[0], m = l[1], y = this.outputNames.indexOf(p); if (y === -1) throw new Error(`invalid output '${p}'`); n.push(m), s.push(y); }); let d = i.map((l, p) => fd(l, () => `input "${this.inputNames[u[p]]}"`)), f = n.map((l, p) => (l ? fd(l, () => `output "${this.outputNames[s[p]]}"`) : null)), r = await ud(this.sessionId, u, d, s, f, o), a = {}; for (let l = 0; l < r.length; l++) a[this.outputNames[s[l]]] = n[l] ?? yg(r[l]); return sr(), a; } startProfiling() {} endProfiling() { ld(this.sessionId); } }); }), Tg, ko, pd = L(() => { vt(), ma(), cd(), (Tg = () => { if ( ((typeof Z.wasm.initTimeout != 'number' || Z.wasm.initTimeout < 0) && (Z.wasm.initTimeout = 0), typeof Z.wasm.simd != 'boolean' && (Z.wasm.simd = !0), typeof Z.wasm.proxy != 'boolean' && (Z.wasm.proxy = !1), typeof Z.wasm.trace != 'boolean' && (Z.wasm.trace = !1), typeof Z.wasm.numThreads != 'number' || !Number.isInteger(Z.wasm.numThreads) || Z.wasm.numThreads <= 0) ) { ((typeof self < 'u' && !self.crossOriginIsolated) || (typeof process < 'u' && process.versions && process.versions.node)) && (Z.wasm.numThreads = 1); let t = typeof navigator > 'u' ? (void 0)().length : navigator.hardwareConcurrency; Z.wasm.numThreads = Math.min(4, Math.ceil((t || 1) / 2)); } }), (ko = class { async init(t) { Tg(), await nd(), await od(t); } async createInferenceSessionHandler(t, e) { let o = new Co(); return await o.loadModel(t, e), Promise.resolve(o); } }); }), dd = {}; Pr(dd, { wasmBackend: () => xg }); var xg, hd = L(() => { pd(), (xg = new ko()); }); vt(); vt(); vt(); var ys = '1.17.1', zO = Yo; { let t = (_p(), rr(wp)).onnxjsBackend; or('webgl', t, -10); } { let t = (hd(), rr(dd)).wasmBackend; or('cpu', t, 10), or('wasm', t, 10), or('webnn', t, 9); } Object.defineProperty(Z.versions, 'web', { value: ys, enumerable: !0 }); /*! Bundled license information: long/index.js: (** * @license * Copyright 2009 The Closure Library Authors * Copyright 2020 Daniel Wirtz / The long.js Authors. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * SPDX-License-Identifier: Apache-2.0 *) */ const ONNX_WEB = Object.freeze( Object.defineProperty( { __proto__: null, get InferenceSession() { return Sd; }, get TRACE() { return cs; }, get TRACE_FUNC_BEGIN() { return ar; }, get TRACE_FUNC_END() { return sr; }, get Tensor() { return Re; }, get TrainingSession() { return Pd; }, default: zO, get env() { return Z; }, get registerBackend() { return or; }, }, Symbol.toStringTag, { value: 'Module' } ) ), tensorToDataURL = (t, e) => { const o = typeof document < 'u' ? document.createElement('canvas') : new OffscreenCanvas(1, 1); (o.width = t.dims[3]), (o.height = t.dims[2]); const i = o.getContext('2d'); if (i != null) { let u, n; e?.tensorLayout !== void 0 && e.tensorLayout === 'NHWC' ? ((u = t.dims[2]), (n = t.dims[3])) : ((u = t.dims[3]), (n = t.dims[2])); const s = e?.format !== void 0 ? e.format : 'RGB', d = e?.norm; let f, r; d === void 0 || d.mean === void 0 ? (f = [255, 255, 255, 255]) : typeof d.mean == 'number' ? (f = [d.mean, d.mean, d.mean, d.mean]) : ((f = [d.mean[0], d.mean[1], d.mean[2], 0]), d.mean[3] !== void 0 && (f[3] = d.mean[3])), d === void 0 || d.bias === void 0 ? (r = [0, 0, 0, 0]) : typeof d.bias == 'number' ? (r = [d.bias, d.bias, d.bias, d.bias]) : ((r = [d.bias[0], d.bias[1], d.bias[2], 0]), d.bias[3] !== void 0 && (r[3] = d.bias[3])); const a = n * u; let l = 0, p = a, m = a * 2, y = -1; s === 'RGBA' ? ((l = 0), (p = a), (m = a * 2), (y = a * 3)) : s === 'RGB' ? ((l = 0), (p = a), (m = a * 2)) : s === 'RBG' && ((l = 0), (m = a), (p = a * 2)); for (let T = 0; T < n; T++) for (let v = 0; v < u; v++) { const S = (t.data[l++] - r[0]) * f[0], E = (t.data[p++] - r[1]) * f[1], A = (t.data[m++] - r[2]) * f[2], F = y === -1 ? 255 : (t.data[y++] - r[3]) * f[3]; (i.fillStyle = 'rgba(' + S + ',' + E + ',' + A + ',' + F + ')'), i.fillRect(v, T, 1, 1); } if ('toDataURL' in o) return o.toDataURL(); throw new Error('toDataURL is not supported'); } else throw new Error('Can not access image data'); }, tensorToImageData = (t, e) => { const o = typeof document < 'u' ? document.createElement('canvas').getContext('2d') : new OffscreenCanvas(1, 1).getContext('2d'); let i; if (o != null) { let u, n, s; e?.tensorLayout !== void 0 && e.tensorLayout === 'NHWC' ? ((u = t.dims[2]), (n = t.dims[1]), (s = t.dims[3])) : ((u = t.dims[3]), (n = t.dims[2]), (s = t.dims[1])); const d = e !== void 0 && e.format !== void 0 ? e.format : 'RGB', f = e?.norm; let r, a; f === void 0 || f.mean === void 0 ? (r = [255, 255, 255, 255]) : typeof f.mean == 'number' ? (r = [f.mean, f.mean, f.mean, f.mean]) : ((r = [f.mean[0], f.mean[1], f.mean[2], 255]), f.mean[3] !== void 0 && (r[3] = f.mean[3])), f === void 0 || f.bias === void 0 ? (a = [0, 0, 0, 0]) : typeof f.bias == 'number' ? (a = [f.bias, f.bias, f.bias, f.bias]) : ((a = [f.bias[0], f.bias[1], f.bias[2], 0]), f.bias[3] !== void 0 && (a[3] = f.bias[3])); const l = n * u; if ( e !== void 0 && ((e.format !== void 0 && s === 4 && e.format !== 'RGBA') || (s === 3 && e.format !== 'RGB' && e.format !== 'BGR')) ) throw new Error("Tensor format doesn't match input tensor dims"); const p = 4; let m = 0, y = 1, T = 2, v = 3, S = 0, E = l, A = l * 2, F = -1; d === 'RGBA' ? ((S = 0), (E = l), (A = l * 2), (F = l * 3)) : d === 'RGB' ? ((S = 0), (E = l), (A = l * 2)) : d === 'RBG' && ((S = 0), (A = l), (E = l * 2)), (i = o.createImageData(u, n)); for (let B = 0; B < n * u; m += p, y += p, T += p, v += p, B++) (i.data[m] = (t.data[S++] - a[0]) * r[0]), (i.data[y] = (t.data[E++] - a[1]) * r[1]), (i.data[T] = (t.data[A++] - a[2]) * r[2]), (i.data[v] = F === -1 ? 255 : (t.data[F++] - a[3]) * r[3]); } else throw new Error('Can not access image data'); return i; }, bufferToTensor = (t, e) => { if (t === void 0) throw new Error('Image buffer must be defined'); if (e.height === void 0 || e.width === void 0) throw new Error('Image height and width must be defined'); if (e.tensorLayout === 'NHWC') throw new Error('NHWC Tensor layout is not supported yet'); const { height: o, width: i } = e, u = e.norm ?? { mean: 255, bias: 0 }; let n, s; typeof u.mean == 'number' ? (n = [u.mean, u.mean, u.mean, u.mean]) : (n = [u.mean[0], u.mean[1], u.mean[2], u.mean[3] ?? 255]), typeof u.bias == 'number' ? (s = [u.bias, u.bias, u.bias, u.bias]) : (s = [u.bias[0], u.bias[1], u.bias[2], u.bias[3] ?? 0]); const d = e.format !== void 0 ? e.format : 'RGBA', f = e.tensorFormat !== void 0 && e.tensorFormat !== void 0 ? e.tensorFormat : 'RGB', r = o * i, a = f === 'RGBA' ? new Float32Array(r * 4) : new Float32Array(r * 3); let l = 4, p = 0, m = 1, y = 2, T = 3, v = 0, S = r, E = r * 2, A = -1; d === 'RGB' && ((l = 3), (p = 0), (m = 1), (y = 2), (T = -1)), f === 'RGBA' ? (A = r * 3) : f === 'RBG' ? ((v = 0), (E = r), (S = r * 2)) : f === 'BGR' && ((E = 0), (S = r), (v = r * 2)); for (let B = 0; B < r; B++, p += l, y += l, m += l, T += l) (a[v++] = (t[p] + s[0]) / n[0]), (a[S++] = (t[m] + s[1]) / n[1]), (a[E++] = (t[y] + s[2]) / n[2]), A !== -1 && T !== -1 && (a[A++] = (t[T] + s[3]) / n[3]); return f === 'RGBA' ? new Tensor$2('float32', a, [1, 4, o, i]) : new Tensor$2('float32', a, [1, 3, o, i]); }, tensorFromImage = async (t, e) => { const o = typeof HTMLImageElement < 'u' && t instanceof HTMLImageElement, i = typeof ImageData < 'u' && t instanceof ImageData, u = typeof ImageBitmap < 'u' && t instanceof ImageBitmap, n = typeof t == 'string'; let s, d = e ?? {}; const f = () => { if (typeof document < 'u') return document.createElement('canvas'); if (typeof OffscreenCanvas < 'u') return new OffscreenCanvas(1, 1); throw new Error('Canvas is not supported'); }, r = (a) => (a instanceof HTMLCanvasElement || a instanceof OffscreenCanvas ? a.getContext('2d') : null); if (o) { const a = f(); (a.width = t.width), (a.height = t.height); const l = r(a); if (l != null) { let p = t.height, m = t.width; if ( (e !== void 0 && e.resizedHeight !== void 0 && e.resizedWidth !== void 0 && ((p = e.resizedHeight), (m = e.resizedWidth)), e !== void 0) ) { if (((d = e), e.tensorFormat !== void 0)) throw new Error('Image input config format must be RGBA for HTMLImageElement'); (d.tensorFormat = 'RGBA'), (d.height = p), (d.width = m); } else (d.tensorFormat = 'RGBA'), (d.height = p), (d.width = m); l.drawImage(t, 0, 0), (s = l.getImageData(0, 0, m, p).data); } else throw new Error('Can not access image data'); } else if (i) { let a, l; if ( (e !== void 0 && e.resizedWidth !== void 0 && e.resizedHeight !== void 0 ? ((a = e.resizedHeight), (l = e.resizedWidth)) : ((a = t.height), (l = t.width)), e !== void 0 && (d = e), (d.format = 'RGBA'), (d.height = a), (d.width = l), e !== void 0) ) { const p = f(); (p.width = l), (p.height = a); const m = r(p); if (m != null) m.putImageData(t, 0, 0), (s = m.getImageData(0, 0, l, a).data); else throw new Error('Can not access image data'); } else s = t.data; } else if (u) { if (e === void 0) throw new Error('Please provide image config with format for Imagebitmap'); const a = f(); (a.width = t.width), (a.height = t.height); const l = r(a); if (l != null) { const p = t.height, m = t.width; return ( l.drawImage(t, 0, 0, m, p), (s = l.getImageData(0, 0, m, p).data), (d.height = p), (d.width = m), bufferToTensor(s, d) ); } else throw new Error('Can not access image data'); } else { if (n) return new Promise((a, l) => { const p = f(), m = r(p); if (!t || !m) return l(); const y = new Image(); (y.crossOrigin = 'Anonymous'), (y.src = t), (y.onload = () => { (p.width = y.width), (p.height = y.height), m.drawImage(y, 0, 0, p.width, p.height); const T = m.getImageData(0, 0, p.width, p.height); (d.height = p.height), (d.width = p.width), a(bufferToTensor(T.data, d)); }); }); throw new Error('Input data provided is not supported - aborted tensor creation'); } if (s !== void 0) return bufferToTensor(s, d); throw new Error('Input data provided is not supported - aborted tensor creation'); }, tensorFromTexture = (t, e) => { const { width: o, height: i, download: u, dispose: n } = e, s = [1, i, o, 4]; return new Tensor$2({ location: 'texture', type: 'float32', texture: t, dims: s, download: u, dispose: n }); }, tensorFromGpuBuffer = (t, e) => { const { dataType: o, dims: i, download: u, dispose: n } = e; return new Tensor$2({ location: 'gpu-buffer', type: o ?? 'float32', gpuBuffer: t, dims: i, download: u, dispose: n, }); }, tensorFromPinnedBuffer = (t, e, o) => new Tensor$2({ location: 'cpu-pinned', type: t, data: e, dims: o ?? [e.length] }), NUMERIC_TENSOR_TYPE_TO_TYPEDARRAY_MAP = new Map([ ['float32', Float32Array], ['uint8', Uint8Array], ['int8', Int8Array], ['uint16', Uint16Array], ['float16', Uint16Array], ['int16', Int16Array], ['int32', Int32Array], ['bool', Uint8Array], ['float64', Float64Array], ['uint32', Uint32Array], ]), NUMERIC_TENSOR_TYPEDARRAY_TO_TYPE_MAP = new Map([ [Float32Array, 'float32'], [Uint8Array, 'uint8'], [Int8Array, 'int8'], [Uint16Array, 'uint16'], [Int16Array, 'int16'], [Int32Array, 'int32'], [Float64Array, 'float64'], [Uint32Array, 'uint32'], ]); let isBigIntChecked = !1; const checkBigInt = () => { if (!isBigIntChecked) { isBigIntChecked = !0; const t = typeof BigInt64Array < 'u' && typeof BigInt64Array.from == 'function', e = typeof BigUint64Array < 'u' && typeof BigUint64Array.from == 'function'; t && (NUMERIC_TENSOR_TYPE_TO_TYPEDARRAY_MAP.set('int64', BigInt64Array), NUMERIC_TENSOR_TYPEDARRAY_TO_TYPE_MAP.set(BigInt64Array, 'int64')), e && (NUMERIC_TENSOR_TYPE_TO_TYPEDARRAY_MAP.set('uint64', BigUint64Array), NUMERIC_TENSOR_TYPEDARRAY_TO_TYPE_MAP.set(BigUint64Array, 'uint64')); } }, calculateSize = (t) => { let e = 1; for (let o = 0; o < t.length; o++) { const i = t[o]; if (typeof i != 'number' || !Number.isSafeInteger(i)) throw new TypeError(`dims[${o}] must be an integer, got: ${i}`); if (i < 0) throw new RangeError(`dims[${o}] must be a non-negative integer, got: ${i}`); e *= i; } return e; }, tensorReshape = (t, e) => { switch (t.location) { case 'cpu': return new Tensor$2(t.type, t.data, e); case 'cpu-pinned': return new Tensor$2({ location: 'cpu-pinned', data: t.data, type: t.type, dims: e }); case 'texture': return new Tensor$2({ location: 'texture', texture: t.texture, type: t.type, dims: e }); case 'gpu-buffer': return new Tensor$2({ location: 'gpu-buffer', gpuBuffer: t.gpuBuffer, type: t.type, dims: e }); default: throw new Error(`tensorReshape: tensor location ${t.location} is not supported`); } }; let Tensor$2 = class { constructor(e, o, i) { checkBigInt(); let u, n; if (typeof e == 'object' && 'location' in e) switch (((this.dataLocation = e.location), (u = e.type), (n = e.dims), e.location)) { case 'cpu-pinned': { const d = NUMERIC_TENSOR_TYPE_TO_TYPEDARRAY_MAP.get(u); if (!d) throw new TypeError(`unsupported type "${u}" to create tensor from pinned buffer`); if (!(e.data instanceof d)) throw new TypeError(`buffer should be of type ${d.name}`); this.cpuData = e.data; break; } case 'texture': { if (u !== 'float32') throw new TypeError(`unsupported type "${u}" to create tensor from texture`); (this.gpuTextureData = e.texture), (this.downloader = e.download), (this.disposer = e.dispose); break; } case 'gpu-buffer': { if ( u !== 'float32' && u !== 'float16' && u !== 'int32' && u !== 'int64' && u !== 'uint32' && u !== 'bool' ) throw new TypeError(`unsupported type "${u}" to create tensor from gpu buffer`); (this.gpuBufferData = e.gpuBuffer), (this.downloader = e.download), (this.disposer = e.dispose); break; } default: throw new Error(`Tensor constructor: unsupported location '${this.dataLocation}'`); } else { let d, f; if (typeof e == 'string') if (((u = e), (f = i), e === 'string')) { if (!Array.isArray(o)) throw new TypeError("A string tensor's data must be a string array."); d = o; } else { const r = NUMERIC_TENSOR_TYPE_TO_TYPEDARRAY_MAP.get(e); if (r === void 0) throw new TypeError(`Unsupported tensor type: ${e}.`); if (Array.isArray(o)) { if (e === 'float16') throw new TypeError( 'Creating a float16 tensor from number array is not supported. Please use Uint16Array as data.' ); e === 'uint64' || e === 'int64' ? (d = r.from(o, BigInt)) : (d = r.from(o)); } else if (o instanceof r) d = o; else throw new TypeError(`A ${u} tensor's data must be type of ${r}`); } else if (((f = o), Array.isArray(e))) { if (e.length === 0) throw new TypeError('Tensor type cannot be inferred from an empty array.'); const r = typeof e[0]; if (r === 'string') (u = 'string'), (d = e); else if (r === 'boolean') (u = 'bool'), (d = Uint8Array.from(e)); else throw new TypeError(`Invalid element type of data array: ${r}.`); } else { const r = NUMERIC_TENSOR_TYPEDARRAY_TO_TYPE_MAP.get(e.constructor); if (r === void 0) throw new TypeError(`Unsupported type for tensor data: ${e.constructor}.`); (u = r), (d = e); } if (f === void 0) f = [d.length]; else if (!Array.isArray(f)) throw new TypeError("A tensor's dims must be a number array"); (n = f), (this.cpuData = d), (this.dataLocation = 'cpu'); } const s = calculateSize(n); if (this.cpuData && s !== this.cpuData.length) throw new Error(`Tensor's size(${s}) does not match data length(${this.cpuData.length}).`); (this.type = u), (this.dims = n), (this.size = s); } static async fromImage(e, o) { return tensorFromImage(e, o); } static fromTexture(e, o) { return tensorFromTexture(e, o); } static fromGpuBuffer(e, o) { return tensorFromGpuBuffer(e, o); } static fromPinnedBuffer(e, o, i) { return tensorFromPinnedBuffer(e, o, i); } toDataURL(e) { return tensorToDataURL(this, e); } toImageData(e) { return tensorToImageData(this, e); } get data() { if ((this.ensureValid(), !this.cpuData)) throw new Error( 'The data is not on CPU. Use `getData()` to download GPU data to CPU, or use `texture` or `gpuBuffer` property to access the GPU data directly.' ); return this.cpuData; } get location() { return this.dataLocation; } get texture() { if ((this.ensureValid(), !this.gpuTextureData)) throw new Error('The data is not stored as a WebGL texture.'); return this.gpuTextureData; } get gpuBuffer() { if ((this.ensureValid(), !this.gpuBufferData)) throw new Error('The data is not stored as a WebGPU buffer.'); return this.gpuBufferData; } async getData(e) { switch ((this.ensureValid(), this.dataLocation)) { case 'cpu': case 'cpu-pinned': return this.data; case 'texture': case 'gpu-buffer': { if (!this.downloader) throw new Error('The current tensor is not created with a specified data downloader.'); if (this.isDownloading) throw new Error('The current tensor is being downloaded.'); try { this.isDownloading = !0; const o = await this.downloader(); return ( (this.downloader = void 0), (this.dataLocation = 'cpu'), (this.cpuData = o), e && this.disposer && (this.disposer(), (this.disposer = void 0)), o ); } finally { this.isDownloading = !1; } } default: throw new Error(`cannot get data from location: ${this.dataLocation}`); } } dispose() { if (this.isDownloading) throw new Error('The current tensor is being downloaded.'); this.disposer && (this.disposer(), (this.disposer = void 0)), (this.cpuData = void 0), (this.gpuTextureData = void 0), (this.gpuBufferData = void 0), (this.downloader = void 0), (this.isDownloading = void 0), (this.dataLocation = 'none'); } ensureValid() { if (this.dataLocation === 'none') throw new Error('The tensor is disposed.'); } reshape(e) { if ((this.ensureValid(), this.downloader || this.disposer)) throw new Error('Cannot reshape a tensor that owns GPU resource.'); return tensorReshape(this, e); } }; const Tensor$1 = Tensor$2; let ONNX; const WEBGPU_AVAILABLE = typeof navigator < 'u' && 'gpu' in navigator, USE_ONNXRUNTIME_NODE = typeof process < 'u' && process?.release?.name === 'node', ONNX_MODULES = new Map(); USE_ONNXRUNTIME_NODE ? ((ONNX = sharp ?? ONNX_NODE), ONNX_MODULES.set('node', ONNX)) : ((ONNX = zO ?? ONNX_WEB), ONNX_MODULES.set('web', ONNX)); async function createInferenceSession(t, e) { let o, i; if (USE_ONNXRUNTIME_NODE) { const s = ONNX_MODULES.get('node'); (i = s.InferenceSession), (o = ['cpu']), Object.assign(s.env, env.backends.onnx); } else if (WEBGPU_AVAILABLE && env.experimental.useWebGPU) { let s = ONNX_MODULES.get('webgpu'); s === void 0 && ((s = await __vitePreload(() => import('./ort.webgpu.min-7V0I_OOb.js'), __vite__mapDeps([]))), ONNX_MODULES.set('webgpu', s)), (i = s.InferenceSession), (o = ['webgpu', 'wasm']), Object.assign(s.env, env.backends.onnx); } else { const s = ONNX_MODULES.get('web'); (i = s.InferenceSession), (o = ['wasm']), Object.assign(s.env, env.backends.onnx); } const u = { executionProviders: o, ...e }; return await i.create(t, u); } function isONNXTensor(t) { for (const e of ONNX_MODULES.values()) if (t instanceof e.Tensor) return !0; return !1; } const ONNX_ENV = ONNX?.env; ONNX_ENV && ONNX_ENV.wasm && ((ONNX_ENV.wasm.wasmPaths = RUNNING_LOCALLY ? sharp.join(env.__dirname, '/dist/') : `https://cdn.jsdelivr.net/npm/@xenova/transformers@${env.version}/dist/`), typeof navigator < 'u' && /iP(hone|od|ad).+16_4.+AppleWebKit/.test(navigator.userAgent) && (ONNX_ENV.wasm.simd = !1), (ONNX_ENV.wasm.proxy = !0)); function isONNXProxy() { return ONNX_ENV.wasm.proxy; } env.backends.onnx = ONNX_ENV; const DataTypeMap = Object.freeze({ float32: Float32Array, float16: Uint16Array, float64: Float64Array, string: Array, int8: Int8Array, uint8: Uint8Array, int16: Int16Array, uint16: Uint16Array, int32: Int32Array, uint32: Uint32Array, int64: BigInt64Array, uint64: BigUint64Array, bool: Uint8Array, }); class Tensor { get dims() { return this.ort_tensor.dims; } set dims(e) { this.ort_tensor.dims = e; } get type() { return this.ort_tensor.type; } get data() { return this.ort_tensor.data; } get size() { return this.ort_tensor.size; } ort_tensor; constructor(...e) { return ( isONNXTensor(e[0]) ? (this.ort_tensor = e[0]) : (this.ort_tensor = new Tensor$1(e[0], e[1], e[2])), new Proxy(this, { get: (o, i) => { if (typeof i == 'string') { let u = Number(i); if (Number.isInteger(u)) return o._getitem(u); } return o[i]; }, set: (o, i, u) => (o[i] = u), }) ); } dispose() { this.ort_tensor.dispose(); } *[Symbol.iterator]() { const [e, ...o] = this.dims; if (o.length > 0) { const i = o.reduce((u, n) => u * n); for (let u = 0; u < e; ++u) yield this._subarray(u, i, o); } else yield* this.data; } _getitem(e) { const [o, ...i] = this.dims; if (((e = safeIndex(e, o)), i.length > 0)) { const u = i.reduce((n, s) => n * s); return this._subarray(e, u, i); } else return new Tensor(this.type, [this.data[e]], i); } indexOf(e) { for (let o = 0; o < this.data.length; ++o) if (this.data[o] == e) return o; return -1; } _subarray(e, o, i) { const u = e * o, n = (e + 1) * o, s = 'subarray' in this.data ? this.data.subarray(u, n) : this.data.slice(u, n); return new Tensor(this.type, s, i); } item() { if (this.data.length !== 1) throw new Error(`a Tensor with ${this.data.length} elements cannot be converted to Scalar`); return this.data[0]; } tolist() { return reshape(this.data, this.dims); } sigmoid() { return this.clone().sigmoid_(); } sigmoid_() { for (let e = 0; e < this.data.length; ++e) this.data[e] = 1 / (1 + Math.exp(-this.data[e])); return this; } mul(e) { return this.clone().mul_(e); } mul_(e) { for (let o = 0; o < this.data.length; ++o) this.data[o] *= e; return this; } add(e) { return this.clone().add_(e); } add_(e) { for (let o = 0; o < this.data.length; ++o) this.data[o] += e; return this; } clone() { return new Tensor(this.type, this.data.slice(), this.dims.slice()); } slice(...e) { let o = [], i = []; for (let f = 0; f < this.dims.length; ++f) { let r = e[f]; if (r == null) i.push([0, this.dims[f]]), o.push(this.dims[f]); else if (typeof r == 'number') (r = safeIndex(r, this.dims[f], f)), i.push([r, r + 1]); else if (Array.isArray(r) && r.length === 2) { if (r[0] > r[1]) throw new Error(`Invalid slice: ${r}`); let a = [Math.max(r[0], 0), Math.min(r[1], this.dims[f])]; i.push(a), o.push(a[1] - a[0]); } else throw new Error(`Invalid slice: ${r}`); } let u = i.map(([f, r]) => r - f), n = u.reduce((f, r) => f * r), s = new this.data.constructor(n); const d = this.stride(); for (let f = 0; f < n; ++f) { let r = 0; for (let a = u.length - 1, l = f; a >= 0; --a) { const p = u[a]; (r += ((l % p) + i[a][0]) * d[a]), (l = Math.floor(l / p)); } s[f] = this.data[r]; } return new Tensor(this.type, s, o); } transpose(...e) { return transpose(this, e); } sum(e = null, o = !1) { return this.norm(1, e, o); } norm(e = 'fro', o = null, i = !1) { if (e === 'fro') e = 2; else if (typeof e == 'string') throw Error(`Unsupported norm: ${e}`); if (o === null) { let s = this.data.reduce((d, f) => d + f ** e, 0) ** (1 / e); return new Tensor(this.type, [s], []); } o = safeIndex(o, this.dims.length); const u = this.dims.slice(); u[o] = 1; const n = new this.data.constructor(this.data.length / this.dims[o]); for (let s = 0; s < this.data.length; ++s) { let d = 0; for (let f = this.dims.length - 1, r = s, a = 1; f >= 0; --f) { const l = this.dims[f]; if (f !== o) { const p = r % l; (d += p * a), (a *= u[f]); } r = Math.floor(r / l); } n[d] += this.data[s] ** e; } if (e !== 1) for (let s = 0; s < n.length; ++s) n[s] = n[s] ** (1 / e); return i || u.splice(o, 1), new Tensor(this.type, n, u); } normalize_(e = 2, o = 1) { o = safeIndex(o, this.dims.length); const i = this.norm(e, o, !0); for (let u = 0; u < this.data.length; ++u) { let n = 0; for (let s = this.dims.length - 1, d = u, f = 1; s >= 0; --s) { const r = this.dims[s]; if (s !== o) { const a = d % r; (n += a * f), (f *= this.dims[s]); } d = Math.floor(d / r); } this.data[u] /= i.data[n]; } return this; } normalize(e = 2, o = 1) { return this.clone().normalize_(e, o); } stride() { return dimsToStride(this.dims); } squeeze(e = null) { return new Tensor(this.type, this.data, calc_squeeze_dims(this.dims, e)); } squeeze_(e = null) { return (this.dims = calc_squeeze_dims(this.dims, e)), this; } unsqueeze(e = null) { return new Tensor(this.type, this.data, calc_unsqueeze_dims(this.dims, e)); } unsqueeze_(e = null) { return (this.dims = calc_unsqueeze_dims(this.dims, e)), this; } flatten_(e = 0, o = -1) { o = (o + this.dims.length) % this.dims.length; let i = this.dims.slice(0, e), u = this.dims.slice(e, o + 1), n = this.dims.slice(o + 1); return (this.dims = [...i, u.reduce((s, d) => s * d, 1), ...n]), this; } flatten(e = 0, o = -1) { return this.clone().flatten_(e, o); } view(...e) { let o = -1; for (let i = 0; i < e.length; ++i) if (e[i] === -1) { if (o !== -1) throw new Error('Only one dimension can be inferred'); o = i; } if (o !== -1) { const i = e.reduce((u, n, s) => (s !== o ? u * n : u), 1); e[o] = this.data.length / i; } return new Tensor(this.type, this.data, e); } neg_() { for (let e = 0; e < this.data.length; ++e) this.data[e] = -this.data[e]; return this; } neg() { return this.clone().neg_(); } clamp_(e, o) { for (let i = 0; i < this.data.length; ++i) this.data[i] = Math.min(Math.max(this.data[i], e), o); return this; } clamp(e, o) { return this.clone().clamp_(e, o); } round_() { for (let e = 0; e < this.data.length; ++e) this.data[e] = Math.round(this.data[e]); return this; } round() { return this.clone().round_(); } to(e) { if (this.type === e) return this; if (!DataTypeMap.hasOwnProperty(e)) throw new Error(`Unsupported type: ${e}`); return new Tensor(e, DataTypeMap[e].from(this.data), this.dims); } } function reshape(t, e) { const o = t.length, i = e.reduce((n, s) => n * s); if (o !== i) throw Error(`cannot reshape array of size ${o} into shape (${e})`); let u = t; for (let n = e.length - 1; n >= 0; n--) u = u.reduce( (s, d) => { let f = s[s.length - 1]; return f.length < e[n] ? f.push(d) : s.push([d]), s; }, [[]] ); return u[0]; } function transpose(t, e) { const [o, i] = transpose_data(t.data, t.dims, e); return new Tensor(t.type, o, i); } function interpolate(t, [e, o], i = 'bilinear', u = !1) { const n = t.dims.at(-3) ?? 1, s = t.dims.at(-2), d = t.dims.at(-1); let f = interpolate_data(t.data, [n, s, d], [e, o], i, u); return new Tensor(t.type, f, [n, e, o]); } function calc_squeeze_dims(t, e) { return ( (t = t.slice()), e === null ? (t = t.filter((o) => o !== 1)) : typeof e == 'number' ? t[e] === 1 && t.splice(e, 1) : Array.isArray(e) && (t = t.filter((o, i) => o !== 1 || !e.includes(i))), t ); } function calc_unsqueeze_dims(t, e) { return (e = safeIndex(e, t.length + 1)), (t = t.slice()), t.splice(e, 0, 1), t; } function safeIndex(t, e, o = null) { if (t < -e || t >= e) throw new Error( `IndexError: index ${t} is out of bounds for dimension${o === null ? '' : ' ' + o} with size ${e}` ); return t < 0 && (t = ((t % e) + e) % e), t; } function cat(t, e = 0) { e = safeIndex(e, t[0].dims.length); const o = t[0].dims.slice(); o[e] = t.reduce((s, d) => s + d.dims[e], 0); const i = o.reduce((s, d) => s * d, 1), u = new t[0].data.constructor(i), n = t[0].type; if (e === 0) { let s = 0; for (let d of t) u.set(d.data, s), (s += d.data.length); } else { let s = 0; for (let d = 0; d < t.length; ++d) { let f = t[d]; for (let r = 0; r < f.data.length; ++r) { let a = 0; for (let l = f.dims.length - 1, p = r, m = 1; l >= 0; --l) { const y = f.dims[l]; let T = p % y; l === e && (T += s), (a += T * m), (m *= o[l]), (p = Math.floor(p / y)); } u[a] = f.data[r]; } s += f.dims[e]; } } return new Tensor(n, u, o); } function stack(t, e = 0) { return cat( t.map((o) => o.unsqueeze(e)), e ); } function std_mean(t, e = null, o = 1, i = !1) { if (e === null) { const r = t.data.reduce((m, y) => m + y, 0) / t.data.length, a = Math.sqrt(t.data.reduce((m, y) => m + (y - r) ** 2, 0) / (t.data.length - o)), l = new Tensor(t.type, [r], []); return [new Tensor(t.type, [a], []), l]; } e = safeIndex(e, t.dims.length); const u = mean(t, e, i), n = t.dims.slice(); n[e] = 1; const s = new t.data.constructor(t.data.length / t.dims[e]); for (let f = 0; f < t.data.length; ++f) { let r = 0; for (let a = t.dims.length - 1, l = f, p = 1; a >= 0; --a) { const m = t.dims[a]; if (a !== e) { const y = l % m; (r += y * p), (p *= n[a]); } l = Math.floor(l / m); } s[r] += (t.data[f] - u.data[r]) ** 2; } for (let f = 0; f < s.length; ++f) s[f] = Math.sqrt(s[f] / (t.dims[e] - o)); return i || n.splice(e, 1), [new Tensor(t.type, s, n), u]; } function mean(t, e = null, o = !1) { if (e === null) { let n = t.data.reduce((s, d) => s + d, 0); return new Tensor(t.type, [n / t.data.length], []); } e = safeIndex(e, t.dims.length); const i = t.dims.slice(); i[e] = 1; const u = new t.data.constructor(t.data.length / t.dims[e]); for (let n = 0; n < t.data.length; ++n) { let s = 0; for (let d = t.dims.length - 1, f = n, r = 1; d >= 0; --d) { const a = t.dims[d]; if (d !== e) { const l = f % a; (s += l * r), (r *= i[d]); } f = Math.floor(f / a); } u[s] += t.data[n]; } if (t.dims[e] !== 1) for (let n = 0; n < u.length; ++n) u[n] = u[n] / t.dims[e]; return o || i.splice(e, 1), new Tensor(t.type, u, i); } function dynamicTimeWarping(t) { const [e, o] = t.dims, i = [e + 1, o + 1], u = new Tensor('float32', new Float32Array(i[0] * i[1]).fill(1 / 0), i), n = new Tensor('float32', new Float32Array(i[0] * i[1]).fill(-1), i); u[0].data[0] = 0; for (let a = 1; a < o + 1; ++a) for (let l = 1; l < e + 1; ++l) { const p = u[l - 1][a - 1].item(), m = u[l - 1][a].item(), y = u[l][a - 1].item(); let T, v; p < m && p < y ? ((T = p), (v = 0)) : m < p && m < y ? ((T = m), (v = 1)) : ((T = y), (v = 2)), (u[l].data[a] = t[l - 1][a - 1].item() + T), (n[l].data[a] = v); } let s = e, d = o; n.data.fill(2, 0, i[1]); for (let a = 0; a < i[0]; ++a) n[a].data[0] = 1; let f = [], r = []; for (; s > 0 || d > 0; ) switch ((f.push(s - 1), r.push(d - 1), n[s][d].item())) { case 0: --s, --d; break; case 1: --s; break; case 2: --d; break; default: throw new Error( `Internal error in dynamic time warping. Unexpected trace[${s}, ${d}]. Please file a bug report.` ); } return f.reverse(), r.reverse(), [f, r]; } function dimsToStride(t) { const e = new Array(t.length); for (let o = t.length - 1, i = 1; o >= 0; --o) (e[o] = i), (i *= t[o]); return e; } function ones(t) { const e = t.reduce((o, i) => o * i, 1); return new Tensor('int64', new BigInt64Array(e).fill(1n), t); } function ones_like(t) { return ones(t.dims); } var TOKEN_TYPES = Object.freeze({ Text: 'Text', NumericLiteral: 'NumericLiteral', BooleanLiteral: 'BooleanLiteral', StringLiteral: 'StringLiteral', Identifier: 'Identifier', Equals: 'Equals', OpenParen: 'OpenParen', CloseParen: 'CloseParen', OpenStatement: 'OpenStatement', CloseStatement: 'CloseStatement', OpenExpression: 'OpenExpression', CloseExpression: 'CloseExpression', OpenSquareBracket: 'OpenSquareBracket', CloseSquareBracket: 'CloseSquareBracket', OpenCurlyBracket: 'OpenCurlyBracket', CloseCurlyBracket: 'CloseCurlyBracket', Comma: 'Comma', Dot: 'Dot', Colon: 'Colon', Pipe: 'Pipe', CallOperator: 'CallOperator', AdditiveBinaryOperator: 'AdditiveBinaryOperator', MultiplicativeBinaryOperator: 'MultiplicativeBinaryOperator', ComparisonBinaryOperator: 'ComparisonBinaryOperator', UnaryOperator: 'UnaryOperator', Set: 'Set', If: 'If', For: 'For', In: 'In', Is: 'Is', NotIn: 'NotIn', Else: 'Else', EndIf: 'EndIf', ElseIf: 'ElseIf', EndFor: 'EndFor', And: 'And', Or: 'Or', Not: 'UnaryOperator', }); Object.freeze({ set: TOKEN_TYPES.Set, for: TOKEN_TYPES.For, in: TOKEN_TYPES.In, is: TOKEN_TYPES.Is, if: TOKEN_TYPES.If, else: TOKEN_TYPES.Else, endif: TOKEN_TYPES.EndIf, elif: TOKEN_TYPES.ElseIf, endfor: TOKEN_TYPES.EndFor, and: TOKEN_TYPES.And, or: TOKEN_TYPES.Or, not: TOKEN_TYPES.Not, 'not in': TOKEN_TYPES.NotIn, true: TOKEN_TYPES.BooleanLiteral, false: TOKEN_TYPES.BooleanLiteral, }); TOKEN_TYPES.OpenStatement, TOKEN_TYPES.CloseStatement, TOKEN_TYPES.OpenExpression, TOKEN_TYPES.CloseExpression, TOKEN_TYPES.OpenParen, TOKEN_TYPES.CloseParen, TOKEN_TYPES.OpenCurlyBracket, TOKEN_TYPES.CloseCurlyBracket, TOKEN_TYPES.OpenSquareBracket, TOKEN_TYPES.CloseSquareBracket, TOKEN_TYPES.Comma, TOKEN_TYPES.Dot, TOKEN_TYPES.Colon, TOKEN_TYPES.Pipe, TOKEN_TYPES.ComparisonBinaryOperator, TOKEN_TYPES.ComparisonBinaryOperator, TOKEN_TYPES.ComparisonBinaryOperator, TOKEN_TYPES.ComparisonBinaryOperator, TOKEN_TYPES.ComparisonBinaryOperator, TOKEN_TYPES.ComparisonBinaryOperator, TOKEN_TYPES.AdditiveBinaryOperator, TOKEN_TYPES.AdditiveBinaryOperator, TOKEN_TYPES.MultiplicativeBinaryOperator, TOKEN_TYPES.MultiplicativeBinaryOperator, TOKEN_TYPES.MultiplicativeBinaryOperator, TOKEN_TYPES.Equals; const BYTES_TO_UNICODE = (() => { const t = [ ...Array.from({ length: 94 }, (u, n) => n + 33), ...Array.from({ length: 12 }, (u, n) => n + 161), ...Array.from({ length: 82 }, (u, n) => n + 174), ], e = t.slice(); let o = 0; for (let u = 0; u < 256; ++u) t.includes(u) || (t.push(u), e.push(256 + o), (o += 1)); const i = e.map((u) => String.fromCharCode(u)); return Object.fromEntries(t.map((u, n) => [u, i[n]])); })(); reverseDictionary(BYTES_TO_UNICODE); const WHISPER_LANGUAGES = [ ['en', 'english'], ['zh', 'chinese'], ['de', 'german'], ['es', 'spanish'], ['ru', 'russian'], ['ko', 'korean'], ['fr', 'french'], ['ja', 'japanese'], ['pt', 'portuguese'], ['tr', 'turkish'], ['pl', 'polish'], ['ca', 'catalan'], ['nl', 'dutch'], ['ar', 'arabic'], ['sv', 'swedish'], ['it', 'italian'], ['id', 'indonesian'], ['hi', 'hindi'], ['fi', 'finnish'], ['vi', 'vietnamese'], ['he', 'hebrew'], ['uk', 'ukrainian'], ['el', 'greek'], ['ms', 'malay'], ['cs', 'czech'], ['ro', 'romanian'], ['da', 'danish'], ['hu', 'hungarian'], ['ta', 'tamil'], ['no', 'norwegian'], ['th', 'thai'], ['ur', 'urdu'], ['hr', 'croatian'], ['bg', 'bulgarian'], ['lt', 'lithuanian'], ['la', 'latin'], ['mi', 'maori'], ['ml', 'malayalam'], ['cy', 'welsh'], ['sk', 'slovak'], ['te', 'telugu'], ['fa', 'persian'], ['lv', 'latvian'], ['bn', 'bengali'], ['sr', 'serbian'], ['az', 'azerbaijani'], ['sl', 'slovenian'], ['kn', 'kannada'], ['et', 'estonian'], ['mk', 'macedonian'], ['br', 'breton'], ['eu', 'basque'], ['is', 'icelandic'], ['hy', 'armenian'], ['ne', 'nepali'], ['mn', 'mongolian'], ['bs', 'bosnian'], ['kk', 'kazakh'], ['sq', 'albanian'], ['sw', 'swahili'], ['gl', 'galician'], ['mr', 'marathi'], ['pa', 'punjabi'], ['si', 'sinhala'], ['km', 'khmer'], ['sn', 'shona'], ['yo', 'yoruba'], ['so', 'somali'], ['af', 'afrikaans'], ['oc', 'occitan'], ['ka', 'georgian'], ['be', 'belarusian'], ['tg', 'tajik'], ['sd', 'sindhi'], ['gu', 'gujarati'], ['am', 'amharic'], ['yi', 'yiddish'], ['lo', 'lao'], ['uz', 'uzbek'], ['fo', 'faroese'], ['ht', 'haitian creole'], ['ps', 'pashto'], ['tk', 'turkmen'], ['nn', 'nynorsk'], ['mt', 'maltese'], ['sa', 'sanskrit'], ['lb', 'luxembourgish'], ['my', 'myanmar'], ['bo', 'tibetan'], ['tl', 'tagalog'], ['mg', 'malagasy'], ['as', 'assamese'], ['tt', 'tatar'], ['haw', 'hawaiian'], ['ln', 'lingala'], ['ha', 'hausa'], ['ba', 'bashkir'], ['jw', 'javanese'], ['su', 'sundanese'], ]; new Map(WHISPER_LANGUAGES); async function loadConfig(t, e) { return await getModelJSON(t, 'config.json', !0, e); } class PretrainedConfig { constructor(e) { (this.model_type = null), (this.is_encoder_decoder = !1), Object.assign(this, e); } static async from_pretrained( e, { progress_callback: o = null, config: i = null, cache_dir: u = null, local_files_only: n = !1, revision: s = 'main', } = {} ) { let d = i ?? (await loadConfig(e, { progress_callback: o, config: i, cache_dir: u, local_files_only: n, revision: s })); return new this(d); } } class AutoConfig { static async from_pretrained(...e) { return PretrainedConfig.from_pretrained(...e); } } class LogitsProcessorList extends Callable { constructor() { super(), (this.processors = []); } push(e) { this.processors.push(e); } extend(e) { this.processors.push(...e); } _call(e, o) { for (let i of o) this.processors.forEach((u) => u(e, i)); } [Symbol.iterator]() { return this.processors.values(); } } class LogitsProcessor extends Callable { _call(e, o) { throw Error('`_call` should be implemented in a subclass'); } } class ForceTokensLogitsProcessor extends LogitsProcessor { constructor(e) { super(), (this.force_token_map = Object.fromEntries(e ?? [])); } _call(e, o) { let i = this.force_token_map[e.length]; return exists(i) && (o.data.fill(-1 / 0), (o.data[i] = 0)), o; } } class ForcedBOSTokenLogitsProcessor extends LogitsProcessor { constructor(e) { super(), (this.bos_token_id = e); } _call(e, o) { return e.length === 1 && (o.data.fill(-1 / 0), (o.data[this.bos_token_id] = 0)), o; } } class ForcedEOSTokenLogitsProcessor extends LogitsProcessor { constructor(e, o) { super(), (this.max_length = e), (this.forced_eos_token_id = o); } _call(e, o) {} } class SuppressTokensAtBeginLogitsProcessor extends LogitsProcessor { constructor(e, o) { super(), (this.begin_suppress_tokens = e), (this.begin_index = o); } _call(e, o) { if (e.length === this.begin_index) for (let i of this.begin_suppress_tokens) o.data[i] = -1 / 0; return o; } } class WhisperTimeStampLogitsProcessor extends LogitsProcessor { constructor(e) { super(), (this.eos_token_id = e.eos_token_id), (this.no_timestamps_token_id = e.no_timestamps_token_id), (this.timestamp_begin = this.no_timestamps_token_id + 1), (this.begin_index = (e.forced_decoder_ids || []).length + 2), e.forced_decoder_ids.slice(-1)[0][1] === this.no_timestamps_token_id && (this.begin_index -= 1), (this.max_initial_timestamp_index = e.max_initial_timestamp_index); } _call(e, o) { const i = o.data; if (((i[this.no_timestamps_token_id] = -1 / 0), e.length === this.begin_index - 1)) return i.fill(-1 / 0), (i[this.timestamp_begin] = 0), o; const u = e.slice(this.begin_index), n = u.length >= 1 && u[u.length - 1] >= this.timestamp_begin, s = u.length < 2 || u[u.length - 2] >= this.timestamp_begin; if ( (n && (s ? i.subarray(this.timestamp_begin).fill(-1 / 0) : i.subarray(0, this.eos_token_id).fill(-1 / 0)), e.length === this.begin_index && this.max_initial_timestamp_index !== null) ) { const a = this.timestamp_begin + this.max_initial_timestamp_index; i.subarray(a + 1).fill(-1 / 0); } const d = log_softmax(i), f = Math.log( d .subarray(this.timestamp_begin) .map(Math.exp) .reduce((a, l) => a + l) ), r = max(d.subarray(0, this.timestamp_begin))[0]; return f > r && i.subarray(0, this.timestamp_begin).fill(-1 / 0), o; } } class NoRepeatNGramLogitsProcessor extends LogitsProcessor { constructor(e) { super(), (this.no_repeat_ngram_size = e); } getNgrams(e) { const o = e.length, i = []; for (let n = 0; n < o + 1 - this.no_repeat_ngram_size; ++n) { const s = []; for (let d = 0; d < this.no_repeat_ngram_size; ++d) s.push(e[n + d]); i.push(s); } const u = new Map(); for (const n of i) { const s = n.slice(0, n.length - 1), d = JSON.stringify(s), f = u.get(d) ?? []; f.push(n[n.length - 1]), u.set(d, f); } return u; } getGeneratedNgrams(e, o) { const i = o.slice(o.length + 1 - this.no_repeat_ngram_size, o.length); return e.get(JSON.stringify(i)) ?? []; } calcBannedNgramTokens(e) { const o = []; if (e.length + 1 < this.no_repeat_ngram_size) return o; { const i = this.getNgrams(e); return this.getGeneratedNgrams(i, e); } } _call(e, o) { const i = this.calcBannedNgramTokens(e); for (const u of i) o.data[u] = -1 / 0; return o; } } class RepetitionPenaltyLogitsProcessor extends LogitsProcessor { constructor(e) { super(), (this.penalty = e); } _call(e, o) { for (const i of e) o.data[i] < 0 ? (o.data[i] *= this.penalty) : (o.data[i] /= this.penalty); return o; } } class MinLengthLogitsProcessor extends LogitsProcessor { constructor(e, o) { super(), (this.min_length = e), (this.eos_token_id = Array.isArray(o) ? o : [o]); } _call(e, o) { if (e.length < this.min_length) for (const i of this.eos_token_id) o.data[i] = -1 / 0; return o; } } class MinNewTokensLengthLogitsProcessor extends LogitsProcessor { constructor(e, o, i) { super(), (this.prompt_length_to_skip = e), (this.min_new_tokens = o), (this.eos_token_id = Array.isArray(i) ? i : [i]); } _call(e, o) { if (e.length - this.prompt_length_to_skip < this.min_new_tokens) for (const u of this.eos_token_id) o.data[u] = -1 / 0; return o; } } class NoBadWordsLogitsProcessor extends LogitsProcessor { constructor(e, o) { super(), (this.bad_words_ids = e), (this.eos_token_id = Array.isArray(o) ? o : [o]); } _call(e, o) { for (const i of this.bad_words_ids) { let u = !0; for (let n = 1; n <= i.length - 1 && i.length < e.length; ++n) if (i.at(-n - 1) !== e.at(-n)) { u = !1; break; } u && (o.data[i.at(-1)] = -1 / 0); } return o; } } const GenerationConfig = class { constructor(t = {}) { (this.max_length = t.max_length ?? 20), (this.max_new_tokens = t.max_new_tokens ?? null), (this.min_length = t.min_length ?? 0), (this.min_new_tokens = t.min_new_tokens ?? null), (this.early_stopping = t.early_stopping ?? !1), (this.max_time = t.max_time ?? null), (this.do_sample = t.do_sample ?? !1), (this.num_beams = t.num_beams ?? 1), (this.num_beam_groups = t.num_beam_groups ?? 1), (this.penalty_alpha = t.penalty_alpha ?? null), (this.use_cache = t.use_cache ?? !0), (this.temperature = t.temperature ?? 1), (this.top_k = t.top_k ?? 50), (this.top_p = t.top_p ?? 1), (this.typical_p = t.typical_p ?? 1), (this.epsilon_cutoff = t.epsilon_cutoff ?? 0), (this.eta_cutoff = t.eta_cutoff ?? 0), (this.diversity_penalty = t.diversity_penalty ?? 0), (this.repetition_penalty = t.repetition_penalty ?? 1), (this.encoder_repetition_penalty = t.encoder_repetition_penalty ?? 1), (this.length_penalty = t.length_penalty ?? 1), (this.no_repeat_ngram_size = t.no_repeat_ngram_size ?? 0), (this.bad_words_ids = t.bad_words_ids ?? null), (this.force_words_ids = t.force_words_ids ?? null), (this.renormalize_logits = t.renormalize_logits ?? !1), (this.constraints = t.constraints ?? null), (this.forced_bos_token_id = t.forced_bos_token_id ?? null), (this.forced_eos_token_id = t.forced_eos_token_id ?? null), (this.remove_invalid_values = t.remove_invalid_values ?? !1), (this.exponential_decay_length_penalty = t.exponential_decay_length_penalty ?? null), (this.suppress_tokens = t.suppress_tokens ?? null), (this.begin_suppress_tokens = t.begin_suppress_tokens ?? null), (this.forced_decoder_ids = t.forced_decoder_ids ?? null), (this.num_return_sequences = t.num_return_sequences ?? 1), (this.output_attentions = t.output_attentions ?? !1), (this.output_hidden_states = t.output_hidden_states ?? !1), (this.output_scores = t.output_scores ?? !1), (this.return_dict_in_generate = t.return_dict_in_generate ?? !1), (this.pad_token_id = t.pad_token_id ?? null), (this.bos_token_id = t.bos_token_id ?? null), (this.eos_token_id = t.eos_token_id ?? null), (this.encoder_no_repeat_ngram_size = t.encoder_no_repeat_ngram_size ?? 0), (this.decoder_start_token_id = t.decoder_start_token_id ?? null), (this.generation_kwargs = t.generation_kwargs ?? {}); } }; class Sampler extends Callable { constructor(e) { super(), (this.generation_config = e); } _call(e, o = -1) { return this.sample(e, o); } sample(e, o) { throw Error('sample should be implemented in subclasses.'); } getLogits(e, o) { let i = e.dims.at(-1), u = e.data; if (o === -1) u = u.slice(-i); else { let n = o * i; u = u.slice(n, n + i); } return this.generation_config.temperature > 0 && (u = u.map((n) => n / this.generation_config.temperature)), u; } randomSelect(e) { let o = e.reduce((u, n) => u + n, 0), i = Math.random() * o; for (let u = 0; u < e.length; ++u) if (((i -= e[u]), i <= 0)) return u; return 0; } static getSampler(e) { if (e.do_sample) return new MultinomialSampler(e); if (e.num_beams > 1) return new BeamSearchSampler(e); if (e.num_return_sequences > 1) throw Error(`num_return_sequences has to be 1 when doing greedy search, but is ${e.num_return_sequences}.`); return new GreedySampler(e); } } class GreedySampler extends Sampler { sample(e, o = -1) { let i = this.getLogits(e, o); return [[max(i)[1], 0]]; } } class MultinomialSampler extends Sampler { sample(e, o = -1) { let i = e.dims.at(-1); this.generation_config.top_k > 0 && (i = Math.min(this.generation_config.top_k, i)); const u = this.getLogits(e, o), n = getTopItems(u, i), s = softmax(n.map((d) => d[1])); return Array.from({ length: this.generation_config.num_beams }, () => { const d = this.randomSelect(s); return [n[d][0], Math.log(s[d])]; }); } } class BeamSearchSampler extends Sampler { sample(e, o = -1) { let i = e.dims.at(-1); this.generation_config.top_k > 0 && (i = Math.min(this.generation_config.top_k, i)); const u = this.getLogits(e, o), n = getTopItems(u, i), s = softmax(n.map((d) => d[1])); return Array.from({ length: this.generation_config.num_beams }, (d, f) => [n[f][0], Math.log(s[f])]); } } const MODEL_TYPES = { EncoderOnly: 0, EncoderDecoder: 1, Seq2Seq: 2, Vision2Seq: 3, DecoderOnly: 4, MaskGeneration: 5 }, MODEL_TYPE_MAPPING = new Map(), MODEL_NAME_TO_CLASS_MAPPING = new Map(), MODEL_CLASS_TO_NAME_MAPPING = new Map(); async function constructSession(t, e, o) { const i = `onnx/${e}${o.quantized ? '_quantized' : ''}.onnx`, u = await getModelFile(t, i, !0, o), n = o.session_options ?? {}; if (n.externalData !== void 0) for (let s = 0; s < n.externalData.length; s++) { const d = n.externalData[s]; if (typeof d.data == 'string') { const f = await getModelFile(t, d.data, !0, o); d.data = f; } } return await createInferenceSession(u, n); } function validateInputs(t, e) { const o = Object.create(null), i = []; for (const s of t.inputNames) { const d = e[s]; if (!(d instanceof Tensor)) { i.push(s); continue; } o[s] = isONNXProxy() ? d.clone() : d; } if (i.length > 0) throw new Error(`An error occurred during model execution: "Missing the following inputs: ${i.join(', ')}.`); const u = Object.keys(e).length, n = t.inputNames.length; if (u > n) { let s = Object.keys(e).filter((d) => !t.inputNames.includes(d)); console.warn( `WARNING: Too many inputs were provided (${u} > ${n}). The following inputs will be ignored: "${s.join( ', ' )}".` ); } return o; } async function sessionRun(t, e) { const o = validateInputs(t, e); try { const i = Object.fromEntries(Object.entries(o).map(([n, s]) => [n, s.ort_tensor])); let u = await t.run(i); u = replaceTensors(u); for (const [n, s] of Object.entries(o)) n.startsWith('past_key_values') && s.dispose(); return u; } catch (i) { throw ( (console.error(`An error occurred during model execution: "${i}".`), console.error('Inputs given to model:', o), i) ); } } function replaceTensors(t) { for (let e in t) isONNXTensor(t[e]) ? (t[e] = new Tensor(t[e])) : typeof t[e] == 'object' && replaceTensors(t[e]); return t; } function toI64Tensor(t) { if (t instanceof Tensor) return t; if (t.length === 0) throw Error('items must be non-empty'); if (Array.isArray(t[0])) { if (t.some((e) => e.length !== t[0].length)) throw Error( "Unable to create tensor, you should probably activate truncation and/or padding with 'padding=True' and/or 'truncation=True' to have batched tensors with the same length." ); return new Tensor('int64', BigInt64Array.from(t.flat().map((e) => BigInt(e))), [t.length, t[0].length]); } else return new Tensor('int64', BigInt64Array.from(t.map((e) => BigInt(e))), [1, t.length]); } function prepareAttentionMask(t, e) { let o = t.config.pad_token_id ?? null, i = t.config.eos_token_id ?? null; isIntegralNumber(i) && (i = [i]); let u = e.indexOf(o) !== -1, n = i === null || !i.includes(o); if (u && n) { let s = BigInt64Array.from(e.data.map((d) => d != o)); return new Tensor('int64', s, e.dims); } else return ones_like(e); } function preparePositionIds(t, e, o) { if (!t.inputNames.includes('position_ids')) return; const i = new BigInt64Array(e.attention_mask.data.length); for (let u = 0; u < e.attention_mask.dims[0]; ++u) { let n = u * e.attention_mask.dims[1], s = BigInt(0); for (let d = 0; d < e.attention_mask.dims[1]; ++d) { const f = n + d; e.attention_mask.data[f] === 0n ? (i[f] = BigInt(1)) : ((i[f] = s), (s += e.attention_mask.data[f])); } } (e.position_ids = new Tensor('int64', i, e.attention_mask.dims)), o && (e.position_ids = e.position_ids.slice(null, -1).unsqueeze_(-1)); } function boolTensor(t) { return new Tensor('bool', [t], [1]); } async function seq2seqForward(t, e) { let { encoder_outputs: o, past_key_values: i } = e; o || (o = (await encoderForward(t, e)).last_hidden_state); let u = { input_ids: e.decoder_input_ids, encoder_hidden_states: o }; const n = !!i; t.decoder_merged_session.inputNames.includes('use_cache_branch') && (u.use_cache_branch = boolTensor(n)), t.decoder_merged_session.inputNames.includes('encoder_attention_mask') && (u.encoder_attention_mask = e.attention_mask), preparePositionIds(t.decoder_merged_session, u, n), t.addPastKeyValues(u, i); const s = await sessionRun(t.decoder_merged_session, u); let d = s.logits; i = t.getPastKeyValues(s, i); const f = t.getAttentions(s); return new Seq2SeqLMOutput({ logits: d, past_key_values: i, encoder_outputs: o, ...f }); } function seq2seqStartBeams(t, e, o, i) { let u = [], n = 0; const s = t.requires_attention_mask ?? !0; let d = o.decoder_input_ids ?? o.decoder_start_token_id ?? o.bos_token_id ?? o.eos_token_id; d instanceof Tensor ? (d = d.tolist().flat()) : Array.isArray(d) || (d = [d]); for (let f of e) { f.dims = [1, ...f.dims]; let r = { inputs: f, encoder_outputs: null, prev_model_outputs: null, output_token_ids: d, done: !1, score: 0, id: n++, }; s && (r.attention_mask = prepareAttentionMask(t, f)), u.push(r); } return u; } async function seq2seqRunBeam(t, e) { const o = t.main_input_name; let i = e.output_token_ids; e.prev_model_outputs && (i = i.slice(-1)); let u = { [o]: e.inputs, decoder_input_ids: toI64Tensor(i), encoder_outputs: e.encoder_outputs, past_key_values: e.prev_model_outputs?.past_key_values, }; e.attention_mask && (u.attention_mask = e.attention_mask); let n = await t.forward(u); return (e.prev_model_outputs = n), (e.encoder_outputs = n.encoder_outputs), n; } function seq2seqUpdatebeam(t, e) { t.output_token_ids = [...t.output_token_ids, e]; } async function encoderForward(t, e) { const o = Object.create(null); for (const i of t.session.inputNames) o[i] = e[i]; return ( t.session.inputNames.includes('token_type_ids') && !o.token_type_ids && (o.token_type_ids = new Tensor('int64', new BigInt64Array(o.input_ids.data.length), o.input_ids.dims)), await sessionRun(t.session, o) ); } async function decoderForward(t, e) { let { input_ids: o, past_key_values: i, attention_mask: u } = e, n = { input_ids: o, attention_mask: u ?? prepareAttentionMask(t, o) }; const s = !!i; t.session.inputNames.includes('use_cache_branch') && (n.use_cache_branch = boolTensor(s)), preparePositionIds(t.session, n, s), t.addPastKeyValues(n, i); let d = await sessionRun(t.session, n), f = d.logits; return (i = t.getPastKeyValues(d, i)), { logits: f, past_key_values: i }; } function decoderStartBeams(t, e, o, i, u) { let n = [], s = 0; for (let d of e) { let f = d.tolist().map(Number); d.dims = [1, ...d.dims]; let r; u ? ((r = u[s]), (r.dims = [1, ...r.dims])) : (r = prepareAttentionMask(t, d)); let a = { input: d, model_input_ids: d, attention_mask: r, prev_model_outputs: null, output_token_ids: f, num_output_tokens: i, done: !1, score: 0, id: s++, }; n.push(a); } return n; } async function decoderRunBeam(t, e) { let o = new BigInt64Array(e.output_token_ids.length).fill(1n), i = { input_ids: e.model_input_ids, attention_mask: new Tensor('int64', o, [1, o.length]), past_key_values: e.prev_model_outputs?.past_key_values, }, u = await t.forward(i); return (e.prev_model_outputs = u), u; } function decoderUpdatebeam(t, e) { (t.output_token_ids = [...t.output_token_ids, e]), (t.model_input_ids = new Tensor('int64', [BigInt(e)], [1, 1])); } class PreTrainedModel extends Callable { main_input_name = 'input_ids'; constructor(e, o) { super(), (this.config = e), (this.session = o); const i = MODEL_CLASS_TO_NAME_MAPPING.get(this.constructor), u = MODEL_TYPE_MAPPING.get(i); (this.can_generate = !1), (this._runBeam = null), (this._getStartBeams = null), (this._updateBeam = null), (this._forward = null), u === MODEL_TYPES.DecoderOnly ? ((this.can_generate = !0), (this._runBeam = decoderRunBeam), (this._getStartBeams = decoderStartBeams), (this._updateBeam = decoderUpdatebeam), (this._forward = decoderForward)) : u === MODEL_TYPES.Seq2Seq || u === MODEL_TYPES.Vision2Seq ? ((this.can_generate = !0), (this._runBeam = seq2seqRunBeam), (this._getStartBeams = seq2seqStartBeams), (this._updateBeam = seq2seqUpdatebeam), (this._forward = seq2seqForward)) : u === MODEL_TYPES.EncoderDecoder ? (this._forward = encoderForward) : (this._forward = encoderForward); } async dispose() { const e = []; for (let o of Object.keys(this)) { let i = this[o]; i?.handler?.dispose !== void 0 && e.push(i.handler.dispose()); } return await Promise.all(e); } static async from_pretrained( e, { quantized: o = !0, progress_callback: i = null, config: u = null, cache_dir: n = null, local_files_only: s = !1, revision: d = 'main', model_file_name: f = null, session_options: r = {}, } = {} ) { let a = { quantized: o, progress_callback: i, config: u, cache_dir: n, local_files_only: s, revision: d, model_file_name: f, session_options: r, }; const l = MODEL_CLASS_TO_NAME_MAPPING.get(this), p = MODEL_TYPE_MAPPING.get(l); let m; return ( p === MODEL_TYPES.DecoderOnly ? (m = await Promise.all([ AutoConfig.from_pretrained(e, a), constructSession(e, a.model_file_name ?? 'decoder_model_merged', a), getModelJSON(e, 'generation_config.json', !1, a), ])) : p === MODEL_TYPES.Seq2Seq || p === MODEL_TYPES.Vision2Seq ? (m = await Promise.all([ AutoConfig.from_pretrained(e, a), constructSession(e, 'encoder_model', a), constructSession(e, 'decoder_model_merged', a), getModelJSON(e, 'generation_config.json', !1, a), ])) : p === MODEL_TYPES.MaskGeneration ? (m = await Promise.all([ AutoConfig.from_pretrained(e, a), constructSession(e, 'vision_encoder', a), constructSession(e, 'prompt_encoder_mask_decoder', a), ])) : p === MODEL_TYPES.EncoderDecoder ? (m = await Promise.all([ AutoConfig.from_pretrained(e, a), constructSession(e, 'encoder_model', a), constructSession(e, 'decoder_model_merged', a), ])) : (p !== MODEL_TYPES.EncoderOnly && console.warn( `Model type for '${ l ?? u?.model_type }' not found, assuming encoder-only architecture. Please report this at https://github.com/xenova/transformers.js/issues/new/choose.` ), (m = await Promise.all([ AutoConfig.from_pretrained(e, a), constructSession(e, a.model_file_name ?? 'model', a), ]))), new this(...m) ); } async _call(e) { return await this.forward(e); } async forward(e) { return await this._forward(this, e); } _get_logits_processor(e, o, i = null) { const u = new LogitsProcessorList(); if ( (e.repetition_penalty !== null && e.repetition_penalty !== 1 && u.push(new RepetitionPenaltyLogitsProcessor(e.repetition_penalty)), e.no_repeat_ngram_size !== null && e.no_repeat_ngram_size > 0 && u.push(new NoRepeatNGramLogitsProcessor(e.no_repeat_ngram_size)), e.bad_words_ids !== null && u.push(new NoBadWordsLogitsProcessor(e.bad_words_ids, e.eos_token_id)), e.min_length !== null && e.eos_token_id !== null && e.min_length > 0 && u.push(new MinLengthLogitsProcessor(e.min_length, e.eos_token_id)), e.min_new_tokens !== null && e.eos_token_id !== null && e.min_new_tokens > 0 && u.push(new MinNewTokensLengthLogitsProcessor(o, e.min_new_tokens, e.eos_token_id)), e.forced_bos_token_id !== null && u.push(new ForcedBOSTokenLogitsProcessor(e.forced_bos_token_id)), e.forced_eos_token_id !== null && u.push(new ForcedEOSTokenLogitsProcessor(e.max_length, e.forced_eos_token_id)), e.begin_suppress_tokens !== null) ) { let n = o > 1 || e.forced_bos_token_id === null ? o : o + 1; e.forced_decoder_ids !== null && (n += e.forced_decoder_ids[e.forced_decoder_ids.length - 1][0]), u.push(new SuppressTokensAtBeginLogitsProcessor(e.begin_suppress_tokens, n)); } return ( e.forced_decoder_ids !== null && u.push(new ForceTokensLogitsProcessor(e.forced_decoder_ids)), i !== null && u.extend(i), u ); } _get_generation_config(e) { let o = new GenerationConfig(this.config); return ( 'generation_config' in this && Object.assign(o, this.generation_config), e !== null && Object.assign(o, e), o ); } async generate(e, o = null, i = null, { inputs_attention_mask: u = null } = {}) { if (!this.can_generate) { let v = `The current model class (${MODEL_CLASS_TO_NAME_MAPPING.get( this.constructor )}) is not compatible with \`.generate()\`, as it doesn't have a language model head.`; const S = this.config.model_type, E = MODEL_WITH_LM_HEAD_MAPPING_NAMES.get(S) ?? MODEL_FOR_SEQ_TO_SEQ_CAUSAL_LM_MAPPING_NAMES.get(S) ?? MODEL_FOR_SPEECH_SEQ_2_SEQ_MAPPING_NAMES.get(S) ?? MODEL_FOR_VISION_2_SEQ_MAPPING_NAMES.get(S); throw (E && (v += ` Please use the following class instead: '${E[0]}'`), Error(v)); } if (!(e instanceof Tensor) && !isTypedArray(e) && !Array.isArray(e)) throw Error(`\`inputs\` must be a Tensor, TypedArray, or Array, but is "${e.constructor.name}".`); let n; if (this.config.is_encoder_decoder) n = 0; else if (((n = e instanceof Tensor ? e.dims.at(-1) : e.length), n === 0)) throw Error('Must supply a non-empty array of input token ids.'); (o = this._get_generation_config(o)), (i = i ?? new LogitsProcessorList()), (i = this._get_logits_processor(o, n, i)); let s = o.eos_token_id; s !== null && !Array.isArray(s) && (s = [s]); let d = 1; const f = d + (o.max_new_tokens ?? 1 / 0), r = Number.isInteger(o.max_length) && (o.max_new_tokens ?? null) === null; let a = Sampler.getSampler(o), l = this.getStartBeams(e, o, d, u); for (; l.some((T) => !T.done) && d < f; ) { let T = []; for (let v of l) { if (v.done) { T.push(v); continue; } if (r && v.output_token_ids.length >= o.max_length) { (v.done = !0), T.push(v); continue; } let S = await this.runBeam(v); o.output_attentions && this.addAttentionsToBeam(v, S), o.output_scores; let E = S.logits.slice(null, -1, null); i(v.output_token_ids, E); let A = a(E); for (let [F, B] of A) { let J = { ...v }; this.updateBeam(J, F), (J.score += B), s && s.includes(F) && (J.done = !0), T.push(J); } } ++d, (T = this.groupBeams(T).map((v) => v.sort((S, E) => E.score - S.score).slice(0, o.num_beams))), (l = T.flat()), o.callback_function && o.callback_function(l); } const p = this.groupBeams(l), m = (T) => p .map((v) => o.num_return_sequences > 1 ? v.slice(0, o.num_return_sequences).map((S) => S[T]) : [v[0][T]] ) .flat(), y = m('output_token_ids'); if (o.return_dict_in_generate) { const T = m('decoder_attentions'), v = m('cross_attentions'); return { sequences: y, decoder_attentions: T, cross_attentions: v }; } else return y; } addAttentionsToBeam(e, o) { if (this.config.is_encoder_decoder) { if (!o.cross_attentions || o.cross_attentions.length === 0) throw Error( '`output_attentions` is true, but the model did not produce cross-attentions. This is most likely because the model was not exported with `output_attentions=True`.' ); e.cross_attentions || (e.cross_attentions = []), e.cross_attentions.push(o.cross_attentions); } if (!o.decoder_attentions || o.decoder_attentions.length === 0) throw Error( '`output_attentions` is true, but the model did not produce decoder-attentions. This is most likely because the model was not exported with `output_attentions=True`.' ); e.decoder_attentions || (e.decoder_attentions = []), e.decoder_attentions.push(o.decoder_attentions); } groupBeams(e) { const o = Object.create(null); for (const i of e) o[i.id] === void 0 ? (o[i.id] = [i]) : o[i.id].push(i); return Object.values(o); } getPastKeyValues(e, o) { const i = Object.create(null); for (const u in e) if (u.startsWith('present')) { let n = u.replace('present', 'past_key_values'); o && u.includes('encoder') ? (i[n] = o[n]) : (i[n] = e[u]); } return i; } getAttentions(e) { const o = Object.create(null); for (const i of ['cross_attentions', 'decoder_attentions']) { const u = []; for (const n in e) if (n.startsWith(i)) { const s = n.split('.').pop(); u[s] = e[n]; } o[i] = u; } return o; } addPastKeyValues(e, o) { if (o) Object.assign(e, o); else { const u = this.config.precision || 'float32', n = u === 'float16' ? new Uint16Array() : []; if (this.config.is_encoder_decoder && (this.add_encoder_pkv ?? !0)) { let s = [1, this.num_encoder_heads, 0, this.encoder_dim_kv], d = [1, this.num_decoder_heads, 0, this.decoder_dim_kv]; for (let f = 0; f < this.num_decoder_layers; ++f) (e[`past_key_values.${f}.encoder.key`] = new Tensor(u, n, s)), (e[`past_key_values.${f}.encoder.value`] = new Tensor(u, n, s)), (e[`past_key_values.${f}.decoder.key`] = new Tensor(u, n, d)), (e[`past_key_values.${f}.decoder.value`] = new Tensor(u, n, d)); } else if (this.config.model_type === 'falcon') { let s = [1 * this.num_heads, 0, this.dim_kv]; for (let d = 0; d < this.num_layers; ++d) (e[`past_key_values.${d}.key`] = new Tensor(u, n, s)), (e[`past_key_values.${d}.value`] = new Tensor(u, n, s)); } else if (this.config.multi_query) { let s = [1 * this.num_heads, 0, 2 * this.dim_kv]; for (let d = 0; d < this.num_layers; ++d) e[`past_key_values.${d}.key_value`] = new Tensor(u, n, s); } else if (this.config.model_type === 'bloom') { let s = [1 * this.num_heads, this.dim_kv, 0], d = [1 * this.num_heads, 0, this.dim_kv]; for (let f = 0; f < this.num_layers; ++f) (e[`past_key_values.${f}.key`] = new Tensor(u, n, s)), (e[`past_key_values.${f}.value`] = new Tensor(u, n, d)); } else { let s = [1, this.num_heads, 0, this.dim_kv]; for (let d = 0; d < this.num_layers; ++d) (e[`past_key_values.${d}.key`] = new Tensor(u, n, s)), (e[`past_key_values.${d}.value`] = new Tensor(u, n, s)); } } } getStartBeams(e, o, i, u) { return this._getStartBeams(this, e, o, i, u); } async runBeam(e) { return await this._runBeam(this, e); } updateBeam(e, o) { return this._updateBeam(e, o); } } class ModelOutput {} class BertPreTrainedModel extends PreTrainedModel {} class BertModel extends BertPreTrainedModel {} class BertForMaskedLM extends BertPreTrainedModel { async _call(e) { return new MaskedLMOutput(await super._call(e)); } } class BertForSequenceClassification extends BertPreTrainedModel { async _call(e) { return new SequenceClassifierOutput(await super._call(e)); } } class BertForTokenClassification extends BertPreTrainedModel { async _call(e) { return new TokenClassifierOutput(await super._call(e)); } } class BertForQuestionAnswering extends BertPreTrainedModel { async _call(e) { return new QuestionAnsweringModelOutput(await super._call(e)); } } class NomicBertPreTrainedModel extends PreTrainedModel {} class NomicBertModel extends NomicBertPreTrainedModel {} class RoFormerPreTrainedModel extends PreTrainedModel {} class RoFormerModel extends RoFormerPreTrainedModel {} class RoFormerForMaskedLM extends RoFormerPreTrainedModel { async _call(e) { return new MaskedLMOutput(await super._call(e)); } } class RoFormerForSequenceClassification extends RoFormerPreTrainedModel { async _call(e) { return new SequenceClassifierOutput(await super._call(e)); } } class RoFormerForTokenClassification extends RoFormerPreTrainedModel { async _call(e) { return new TokenClassifierOutput(await super._call(e)); } } class RoFormerForQuestionAnswering extends RoFormerPreTrainedModel { async _call(e) { return new QuestionAnsweringModelOutput(await super._call(e)); } } class ConvBertPreTrainedModel extends PreTrainedModel {} class ConvBertModel extends ConvBertPreTrainedModel {} class ConvBertForMaskedLM extends ConvBertPreTrainedModel { async _call(e) { return new MaskedLMOutput(await super._call(e)); } } class ConvBertForSequenceClassification extends ConvBertPreTrainedModel { async _call(e) { return new SequenceClassifierOutput(await super._call(e)); } } class ConvBertForTokenClassification extends ConvBertPreTrainedModel { async _call(e) { return new TokenClassifierOutput(await super._call(e)); } } class ConvBertForQuestionAnswering extends ConvBertPreTrainedModel { async _call(e) { return new QuestionAnsweringModelOutput(await super._call(e)); } } class ElectraPreTrainedModel extends PreTrainedModel {} class ElectraModel extends ElectraPreTrainedModel {} class ElectraForMaskedLM extends ElectraPreTrainedModel { async _call(e) { return new MaskedLMOutput(await super._call(e)); } } class ElectraForSequenceClassification extends ElectraPreTrainedModel { async _call(e) { return new SequenceClassifierOutput(await super._call(e)); } } class ElectraForTokenClassification extends ElectraPreTrainedModel { async _call(e) { return new TokenClassifierOutput(await super._call(e)); } } class ElectraForQuestionAnswering extends ElectraPreTrainedModel { async _call(e) { return new QuestionAnsweringModelOutput(await super._call(e)); } } class CamembertPreTrainedModel extends PreTrainedModel {} class CamembertModel extends CamembertPreTrainedModel {} class CamembertForMaskedLM extends CamembertPreTrainedModel { async _call(e) { return new MaskedLMOutput(await super._call(e)); } } class CamembertForSequenceClassification extends CamembertPreTrainedModel { async _call(e) { return new SequenceClassifierOutput(await super._call(e)); } } class CamembertForTokenClassification extends CamembertPreTrainedModel { async _call(e) { return new TokenClassifierOutput(await super._call(e)); } } class CamembertForQuestionAnswering extends CamembertPreTrainedModel { async _call(e) { return new QuestionAnsweringModelOutput(await super._call(e)); } } class DebertaPreTrainedModel extends PreTrainedModel {} class DebertaModel extends DebertaPreTrainedModel {} class DebertaForMaskedLM extends DebertaPreTrainedModel { async _call(e) { return new MaskedLMOutput(await super._call(e)); } } class DebertaForSequenceClassification extends DebertaPreTrainedModel { async _call(e) { return new SequenceClassifierOutput(await super._call(e)); } } class DebertaForTokenClassification extends DebertaPreTrainedModel { async _call(e) { return new TokenClassifierOutput(await super._call(e)); } } class DebertaForQuestionAnswering extends DebertaPreTrainedModel { async _call(e) { return new QuestionAnsweringModelOutput(await super._call(e)); } } class DebertaV2PreTrainedModel extends PreTrainedModel {} class DebertaV2Model extends DebertaV2PreTrainedModel {} class DebertaV2ForMaskedLM extends DebertaV2PreTrainedModel { async _call(e) { return new MaskedLMOutput(await super._call(e)); } } class DebertaV2ForSequenceClassification extends DebertaV2PreTrainedModel { async _call(e) { return new SequenceClassifierOutput(await super._call(e)); } } class DebertaV2ForTokenClassification extends DebertaV2PreTrainedModel { async _call(e) { return new TokenClassifierOutput(await super._call(e)); } } class DebertaV2ForQuestionAnswering extends DebertaV2PreTrainedModel { async _call(e) { return new QuestionAnsweringModelOutput(await super._call(e)); } } class DistilBertPreTrainedModel extends PreTrainedModel {} class DistilBertModel extends DistilBertPreTrainedModel {} class DistilBertForSequenceClassification extends DistilBertPreTrainedModel { async _call(e) { return new SequenceClassifierOutput(await super._call(e)); } } class DistilBertForTokenClassification extends DistilBertPreTrainedModel { async _call(e) { return new TokenClassifierOutput(await super._call(e)); } } class DistilBertForQuestionAnswering extends DistilBertPreTrainedModel { async _call(e) { return new QuestionAnsweringModelOutput(await super._call(e)); } } class DistilBertForMaskedLM extends DistilBertPreTrainedModel { async _call(e) { return new MaskedLMOutput(await super._call(e)); } } class EsmPreTrainedModel extends PreTrainedModel {} class EsmModel extends EsmPreTrainedModel {} class EsmForMaskedLM extends EsmPreTrainedModel { async _call(e) { return new MaskedLMOutput(await super._call(e)); } } class EsmForSequenceClassification extends EsmPreTrainedModel { async _call(e) { return new SequenceClassifierOutput(await super._call(e)); } } class EsmForTokenClassification extends EsmPreTrainedModel { async _call(e) { return new TokenClassifierOutput(await super._call(e)); } } class MobileBertPreTrainedModel extends PreTrainedModel {} class MobileBertModel extends MobileBertPreTrainedModel {} class MobileBertForMaskedLM extends MobileBertPreTrainedModel { async _call(e) { return new MaskedLMOutput(await super._call(e)); } } class MobileBertForSequenceClassification extends MobileBertPreTrainedModel { async _call(e) { return new SequenceClassifierOutput(await super._call(e)); } } class MobileBertForQuestionAnswering extends MobileBertPreTrainedModel { async _call(e) { return new QuestionAnsweringModelOutput(await super._call(e)); } } class MPNetPreTrainedModel extends PreTrainedModel {} class MPNetModel extends MPNetPreTrainedModel {} class MPNetForMaskedLM extends MPNetPreTrainedModel { async _call(e) { return new MaskedLMOutput(await super._call(e)); } } class MPNetForSequenceClassification extends MPNetPreTrainedModel { async _call(e) { return new SequenceClassifierOutput(await super._call(e)); } } class MPNetForTokenClassification extends MPNetPreTrainedModel { async _call(e) { return new TokenClassifierOutput(await super._call(e)); } } class MPNetForQuestionAnswering extends MPNetPreTrainedModel { async _call(e) { return new QuestionAnsweringModelOutput(await super._call(e)); } } class SqueezeBertPreTrainedModel extends PreTrainedModel {} class SqueezeBertModel extends SqueezeBertPreTrainedModel {} class SqueezeBertForMaskedLM extends SqueezeBertPreTrainedModel { async _call(e) { return new MaskedLMOutput(await super._call(e)); } } class SqueezeBertForSequenceClassification extends SqueezeBertPreTrainedModel { async _call(e) { return new SequenceClassifierOutput(await super._call(e)); } } class SqueezeBertForQuestionAnswering extends SqueezeBertPreTrainedModel { async _call(e) { return new QuestionAnsweringModelOutput(await super._call(e)); } } class AlbertPreTrainedModel extends PreTrainedModel {} class AlbertModel extends AlbertPreTrainedModel {} class AlbertForSequenceClassification extends AlbertPreTrainedModel { async _call(e) { return new SequenceClassifierOutput(await super._call(e)); } } class AlbertForQuestionAnswering extends AlbertPreTrainedModel { async _call(e) { return new QuestionAnsweringModelOutput(await super._call(e)); } } class AlbertForMaskedLM extends AlbertPreTrainedModel { async _call(e) { return new MaskedLMOutput(await super._call(e)); } } class T5PreTrainedModel extends PreTrainedModel {} class T5Model extends T5PreTrainedModel {} class T5ForConditionalGeneration extends T5PreTrainedModel { constructor(e, o, i, u) { super(e, o), (this.decoder_merged_session = i), (this.generation_config = u), (this.num_decoder_layers = this.config.num_decoder_layers), (this.num_decoder_heads = this.config.num_heads), (this.decoder_dim_kv = this.config.d_kv), (this.num_encoder_layers = this.config.num_layers), (this.num_encoder_heads = this.config.num_heads), (this.encoder_dim_kv = this.config.d_kv); } } class LongT5PreTrainedModel extends PreTrainedModel {} class LongT5Model extends LongT5PreTrainedModel {} class LongT5ForConditionalGeneration extends LongT5PreTrainedModel { constructor(e, o, i, u) { super(e, o), (this.decoder_merged_session = i), (this.generation_config = u), (this.num_decoder_layers = this.config.num_decoder_layers), (this.num_decoder_heads = this.config.num_heads), (this.decoder_dim_kv = this.config.d_kv), (this.num_encoder_layers = this.config.num_layers), (this.num_encoder_heads = this.config.num_heads), (this.encoder_dim_kv = this.config.d_kv); } } class MT5PreTrainedModel extends PreTrainedModel {} class MT5Model extends MT5PreTrainedModel {} class MT5ForConditionalGeneration extends MT5PreTrainedModel { constructor(e, o, i, u) { super(e, o), (this.decoder_merged_session = i), (this.generation_config = u), (this.num_decoder_layers = this.config.num_decoder_layers), (this.num_decoder_heads = this.config.num_heads), (this.decoder_dim_kv = this.config.d_kv), (this.num_encoder_layers = this.config.num_layers), (this.num_encoder_heads = this.config.num_heads), (this.encoder_dim_kv = this.config.d_kv); } } class BartPretrainedModel extends PreTrainedModel {} class BartModel extends BartPretrainedModel {} class BartForConditionalGeneration extends BartPretrainedModel { constructor(e, o, i, u) { super(e, o), (this.decoder_merged_session = i), (this.generation_config = u), (this.num_decoder_layers = this.config.decoder_layers), (this.num_decoder_heads = this.config.decoder_attention_heads), (this.decoder_dim_kv = this.config.d_model / this.num_decoder_heads), (this.num_encoder_layers = this.config.encoder_layers), (this.num_encoder_heads = this.config.encoder_attention_heads), (this.encoder_dim_kv = this.config.d_model / this.num_encoder_heads); } } class BartForSequenceClassification extends BartPretrainedModel { async _call(e) { return new SequenceClassifierOutput(await super._call(e)); } } class MBartPreTrainedModel extends PreTrainedModel {} class MBartModel extends MBartPreTrainedModel {} class MBartForConditionalGeneration extends MBartPreTrainedModel { constructor(e, o, i, u) { super(e, o), (this.decoder_merged_session = i), (this.generation_config = u), (this.num_decoder_layers = this.config.decoder_layers), (this.num_decoder_heads = this.config.decoder_attention_heads), (this.decoder_dim_kv = this.config.d_model / this.num_decoder_heads), (this.num_encoder_layers = this.config.encoder_layers), (this.num_encoder_heads = this.config.encoder_attention_heads), (this.encoder_dim_kv = this.config.d_model / this.num_encoder_heads); } } class MBartForSequenceClassification extends MBartPreTrainedModel { async _call(e) { return new SequenceClassifierOutput(await super._call(e)); } } class MBartForCausalLM extends MBartPreTrainedModel { constructor(e, o, i) { super(e, o), (this.generation_config = i), (this.num_decoder_layers = this.config.decoder_layers), (this.num_decoder_heads = this.config.decoder_attention_heads), (this.decoder_dim_kv = this.config.d_model / this.num_decoder_heads), (this.num_encoder_layers = this.config.encoder_layers), (this.num_encoder_heads = this.config.encoder_attention_heads), (this.encoder_dim_kv = this.config.d_model / this.num_encoder_heads); } } class BlenderbotPreTrainedModel extends PreTrainedModel {} class BlenderbotModel extends BlenderbotPreTrainedModel {} class BlenderbotForConditionalGeneration extends BlenderbotPreTrainedModel { constructor(e, o, i, u) { super(e, o), (this.decoder_merged_session = i), (this.generation_config = u), (this.num_decoder_layers = this.config.decoder_layers), (this.num_decoder_heads = this.config.decoder_attention_heads), (this.decoder_dim_kv = this.config.d_model / this.num_decoder_heads), (this.num_encoder_layers = this.config.encoder_layers), (this.num_encoder_heads = this.config.encoder_attention_heads), (this.encoder_dim_kv = this.config.d_model / this.num_encoder_heads); } } class BlenderbotSmallPreTrainedModel extends PreTrainedModel {} class BlenderbotSmallModel extends BlenderbotSmallPreTrainedModel {} class BlenderbotSmallForConditionalGeneration extends BlenderbotSmallPreTrainedModel { constructor(e, o, i, u) { super(e, o), (this.decoder_merged_session = i), (this.generation_config = u), (this.num_decoder_layers = this.config.decoder_layers), (this.num_decoder_heads = this.config.decoder_attention_heads), (this.decoder_dim_kv = this.config.d_model / this.num_decoder_heads), (this.num_encoder_layers = this.config.encoder_layers), (this.num_encoder_heads = this.config.encoder_attention_heads), (this.encoder_dim_kv = this.config.d_model / this.num_encoder_heads); } } class RobertaPreTrainedModel extends PreTrainedModel {} class RobertaModel extends RobertaPreTrainedModel {} class RobertaForMaskedLM extends RobertaPreTrainedModel { async _call(e) { return new MaskedLMOutput(await super._call(e)); } } class RobertaForSequenceClassification extends RobertaPreTrainedModel { async _call(e) { return new SequenceClassifierOutput(await super._call(e)); } } class RobertaForTokenClassification extends RobertaPreTrainedModel { async _call(e) { return new TokenClassifierOutput(await super._call(e)); } } class RobertaForQuestionAnswering extends RobertaPreTrainedModel { async _call(e) { return new QuestionAnsweringModelOutput(await super._call(e)); } } class XLMPreTrainedModel extends PreTrainedModel {} class XLMModel extends XLMPreTrainedModel {} class XLMWithLMHeadModel extends XLMPreTrainedModel { async _call(e) { return new MaskedLMOutput(await super._call(e)); } } class XLMForSequenceClassification extends XLMPreTrainedModel { async _call(e) { return new SequenceClassifierOutput(await super._call(e)); } } class XLMForTokenClassification extends XLMPreTrainedModel { async _call(e) { return new TokenClassifierOutput(await super._call(e)); } } class XLMForQuestionAnswering extends XLMPreTrainedModel { async _call(e) { return new QuestionAnsweringModelOutput(await super._call(e)); } } class XLMRobertaPreTrainedModel extends PreTrainedModel {} class XLMRobertaModel extends XLMRobertaPreTrainedModel {} class XLMRobertaForMaskedLM extends XLMRobertaPreTrainedModel { async _call(e) { return new MaskedLMOutput(await super._call(e)); } } class XLMRobertaForSequenceClassification extends XLMRobertaPreTrainedModel { async _call(e) { return new SequenceClassifierOutput(await super._call(e)); } } class XLMRobertaForTokenClassification extends XLMRobertaPreTrainedModel { async _call(e) { return new TokenClassifierOutput(await super._call(e)); } } class XLMRobertaForQuestionAnswering extends XLMRobertaPreTrainedModel { async _call(e) { return new QuestionAnsweringModelOutput(await super._call(e)); } } class ASTPreTrainedModel extends PreTrainedModel {} class ASTModel extends ASTPreTrainedModel {} class ASTForAudioClassification extends ASTPreTrainedModel {} class WhisperPreTrainedModel extends PreTrainedModel {} class WhisperModel extends WhisperPreTrainedModel {} class WhisperForConditionalGeneration extends WhisperPreTrainedModel { requires_attention_mask = !1; main_input_name = 'input_features'; constructor(e, o, i, u) { super(e, o), (this.decoder_merged_session = i), (this.generation_config = u), (this.num_decoder_layers = this.config.decoder_layers), (this.num_decoder_heads = this.config.decoder_attention_heads), (this.decoder_dim_kv = this.config.d_model / this.num_decoder_heads), (this.num_encoder_layers = this.config.encoder_layers), (this.num_encoder_heads = this.config.encoder_attention_heads), (this.encoder_dim_kv = this.config.d_model / this.num_encoder_heads); } async generate(e, o = null, i = null) { if ( ((o = this._get_generation_config(o)), (o.return_timestamps ??= !1), o.return_timestamps && (i = [new WhisperTimeStampLogitsProcessor(o)]), o.return_token_timestamps && ((o.output_attentions = !0), (o.return_dict_in_generate = !0), o.task === 'translate' && console.warn("Token-level timestamps may not be reliable for task 'translate'."), !o.alignment_heads)) ) throw new Error( 'Model generation config has no `alignment_heads`, token-level timestamps not available. See https://gist.github.com/hollance/42e32852f24243b748ae6bc1f985b13a on how to add this property to the generation config.' ); const u = await super.generate(e, o, i); return ( o.return_token_timestamps && o.alignment_heads && (u.token_timestamps = this._extract_token_timestamps(u, o.alignment_heads, o.num_frames)), u ); } _extract_token_timestamps(e, o, i = null, u = 0.02) { if (!e.cross_attentions) throw new Error( 'Model outputs must contain cross attentions to extract timestamps. This is most likely because the model was not exported with `output_attentions=True`.' ); let n = this.config.median_filter_width; n === void 0 && (console.warn('Model config has no `median_filter_width`, using default value of 7.'), (n = 7)); const s = e.cross_attentions.map((r) => { let a = Array.from({ length: this.config.decoder_layers }, (v, S) => cat( r.map((E) => E[S]), 2 ) ), l = stack(o.map(([v, S]) => (i ? a[v].slice(null, S, null, [0, i]) : a[v].slice(null, S)))); l = l.transpose(1, 0, 2, 3); let [p, m] = std_mean(l, -2, 0, !0), y = l.clone(); for (let v = 0; v < y.dims[0]; ++v) { let S = y[v]; for (let E = 0; E < S.dims[0]; ++E) { let A = S[E]; const F = p[v][E][0], B = m[v][E][0]; for (let J = 0; J < A.dims[0]; ++J) { let Q = A[J]; for (let re = 0; re < Q.data.length; ++re) Q.data[re] = (Q.data[re] - B.data[re]) / F.data[re]; Q.data.set(medianFilter(Q.data, n)); } } } return mean(y, 1); }), d = [e.sequences.length, e.sequences[0].length], f = new Tensor('float32', new Float32Array(d[0] * d[1]), d); for (let r = 0; r < d[0]; ++r) { const a = s[r].neg().squeeze_(0); let [l, p] = dynamicTimeWarping(a), m = Array.from({ length: l.length - 1 }, (v, S) => l[S + 1] - l[S]), y = mergeArrays([1], m).map((v) => !!v), T = []; for (let v = 0; v < y.length; ++v) y[v] && T.push(p[v] * u); f[r].data.set(T, 1); } return f; } } class VisionEncoderDecoderModel extends PreTrainedModel { main_input_name = 'pixel_values'; constructor(e, o, i, u) { super(e, o), (this.decoder_merged_session = i), (this.generation_config = u); const n = this.config.encoder, s = this.config.decoder, d = n.model_type; (MODEL_MAPPING_NAMES_ENCODER_ONLY.get(d) ?? MODEL_MAPPING_NAMES_ENCODER_DECODER.get(d)) || console.warn( `Model type for encoder '${d}' not found, assuming encoder-only architecture. Please report this at https://github.com/xenova/transformers.js/issues/new/choose.` ); const r = MODEL_WITH_LM_HEAD_MAPPING_NAMES.get(s.model_type); if (!r) throw new Error( `Unable to construct \`VisionEncoderDecoder\` due to unsupported decoder: "${this.config.decoder.model_type}"` ); const a = r[1], l = new a(s, i, u); (this.add_encoder_pkv = 'num_decoder_layers' in l), this.add_encoder_pkv ? ((this.num_decoder_layers = l.num_decoder_layers), (this.num_decoder_heads = l.num_decoder_heads), (this.decoder_dim_kv = l.decoder_dim_kv), (this.num_encoder_layers = l.num_encoder_layers), (this.num_encoder_heads = l.num_encoder_heads), (this.encoder_dim_kv = l.encoder_dim_kv)) : ((this.num_layers = l.num_layers), (this.num_heads = l.num_heads), (this.dim_kv = l.dim_kv)); } } class CLIPPreTrainedModel extends PreTrainedModel {} class CLIPModel extends CLIPPreTrainedModel {} class CLIPTextModelWithProjection extends CLIPPreTrainedModel { static async from_pretrained(e, o = {}) { return (o.model_file_name ??= 'text_model'), super.from_pretrained(e, o); } } class CLIPVisionModelWithProjection extends CLIPPreTrainedModel { static async from_pretrained(e, o = {}) { return (o.model_file_name ??= 'vision_model'), super.from_pretrained(e, o); } } class SiglipPreTrainedModel extends PreTrainedModel {} class SiglipModel extends SiglipPreTrainedModel {} class SiglipTextModel extends SiglipPreTrainedModel { static async from_pretrained(e, o = {}) { return (o.model_file_name ??= 'text_model'), super.from_pretrained(e, o); } } class SiglipVisionModel extends CLIPPreTrainedModel { static async from_pretrained(e, o = {}) { return (o.model_file_name ??= 'vision_model'), super.from_pretrained(e, o); } } class ChineseCLIPPreTrainedModel extends PreTrainedModel {} class ChineseCLIPModel extends ChineseCLIPPreTrainedModel {} class CLIPSegPreTrainedModel extends PreTrainedModel {} class CLIPSegModel extends CLIPSegPreTrainedModel {} class CLIPSegForImageSegmentation extends CLIPSegPreTrainedModel {} class GPT2PreTrainedModel extends PreTrainedModel { constructor(e, o, i) { super(e, o), (this.generation_config = i), (this.config.pad_token_id = this.config.eos_token_id), (this.num_heads = this.config.n_head), (this.num_layers = this.config.n_layer), (this.dim_kv = this.config.n_embd / this.num_heads); } } class GPT2Model extends GPT2PreTrainedModel {} class GPT2LMHeadModel extends GPT2PreTrainedModel {} class GPTNeoPreTrainedModel extends PreTrainedModel { constructor(e, o, i) { super(e, o), (this.generation_config = i), (this.config.pad_token_id = this.config.eos_token_id), (this.num_heads = this.config.num_heads), (this.num_layers = this.config.num_layers), (this.dim_kv = this.config.hidden_size / this.num_heads); } } class GPTNeoModel extends GPTNeoPreTrainedModel {} class GPTNeoForCausalLM extends GPTNeoPreTrainedModel {} class GPTNeoXPreTrainedModel extends PreTrainedModel { constructor(e, o, i) { super(e, o), (this.generation_config = i), (this.config.pad_token_id = this.config.eos_token_id), (this.num_heads = this.config.num_attention_heads), (this.num_layers = this.config.num_hidden_layers), (this.dim_kv = this.config.hidden_size / this.num_heads); } } class GPTNeoXModel extends GPTNeoXPreTrainedModel {} class GPTNeoXForCausalLM extends GPTNeoXPreTrainedModel {} class GPTJPreTrainedModel extends PreTrainedModel { constructor(e, o, i) { super(e, o), (this.generation_config = i), (this.config.pad_token_id = this.config.eos_token_id), (this.num_heads = this.config.n_head), (this.num_layers = this.config.n_layer), (this.dim_kv = this.config.n_embd / this.num_heads); } } class GPTJModel extends GPTJPreTrainedModel {} class GPTJForCausalLM extends GPTJPreTrainedModel {} class GPTBigCodePreTrainedModel extends PreTrainedModel { constructor(e, o, i) { super(e, o), (this.generation_config = i), (this.config.pad_token_id = this.config.eos_token_id), (this.num_heads = this.config.n_head), (this.num_layers = this.config.n_layer), (this.dim_kv = this.config.n_embd / this.num_heads); } } class GPTBigCodeModel extends GPTBigCodePreTrainedModel {} class GPTBigCodeForCausalLM extends GPTBigCodePreTrainedModel {} class CodeGenPreTrainedModel extends PreTrainedModel { constructor(e, o, i) { super(e, o), (this.generation_config = i), (this.config.pad_token_id = this.config.eos_token_id), (this.num_heads = this.config.n_head), (this.num_layers = this.config.n_layer), (this.dim_kv = this.config.n_embd / this.num_heads); } } class CodeGenModel extends CodeGenPreTrainedModel {} class CodeGenForCausalLM extends CodeGenPreTrainedModel {} class LlamaPreTrainedModel extends PreTrainedModel { constructor(e, o, i) { super(e, o), (this.generation_config = i), (this.config.pad_token_id = this.config.eos_token_id), (this.num_heads = this.config.num_key_value_heads ?? this.config.num_attention_heads), (this.num_layers = this.config.num_hidden_layers), (this.dim_kv = this.config.hidden_size / this.config.num_attention_heads); } } class LlamaModel extends LlamaPreTrainedModel {} class LlamaForCausalLM extends LlamaPreTrainedModel {} class Qwen2PreTrainedModel extends PreTrainedModel { constructor(e, o, i) { super(e, o), (this.generation_config = i), (this.config.pad_token_id = this.config.eos_token_id), (this.num_heads = this.config.num_key_value_heads ?? this.config.num_attention_heads), (this.num_layers = this.config.num_hidden_layers), (this.dim_kv = this.config.hidden_size / this.config.num_attention_heads); } } class Qwen2Model extends Qwen2PreTrainedModel {} class Qwen2ForCausalLM extends Qwen2PreTrainedModel {} class PhiPreTrainedModel extends PreTrainedModel { constructor(e, o, i) { super(e, o), (this.generation_config = i), (this.config.pad_token_id = this.config.eos_token_id), (this.num_heads = this.config.num_attention_heads), (this.num_layers = this.config.num_hidden_layers), (this.dim_kv = this.config.hidden_size / this.num_heads); } } class PhiModel extends PhiPreTrainedModel {} class PhiForCausalLM extends PhiPreTrainedModel {} class BloomPreTrainedModel extends PreTrainedModel { constructor(e, o, i) { super(e, o), (this.generation_config = i), (this.config.pad_token_id = this.config.eos_token_id), (this.num_heads = this.config.n_head), (this.num_layers = this.config.n_layer), (this.dim_kv = this.config.hidden_size / this.num_heads); } } class BloomModel extends BloomPreTrainedModel {} class BloomForCausalLM extends BloomPreTrainedModel {} class MptPreTrainedModel extends PreTrainedModel { constructor(e, o, i) { super(e, o), (this.generation_config = i), (this.config.pad_token_id = this.config.eos_token_id), (this.num_heads = this.config.n_heads), (this.num_layers = this.config.n_layers), (this.dim_kv = this.config.d_model / this.num_heads); } } class MptModel extends MptPreTrainedModel {} class MptForCausalLM extends MptPreTrainedModel {} class OPTPreTrainedModel extends PreTrainedModel { constructor(e, o, i) { super(e, o), (this.generation_config = i), (this.config.pad_token_id = this.config.eos_token_id), (this.num_heads = this.config.num_attention_heads), (this.num_layers = this.config.num_hidden_layers), (this.dim_kv = this.config.hidden_size / this.num_heads); } } class OPTModel extends OPTPreTrainedModel {} class OPTForCausalLM extends OPTPreTrainedModel {} class ViTPreTrainedModel extends PreTrainedModel {} class ViTModel extends ViTPreTrainedModel {} class ViTForImageClassification extends ViTPreTrainedModel { async _call(e) { return new SequenceClassifierOutput(await super._call(e)); } } class VitMattePreTrainedModel extends PreTrainedModel {} class VitMatteForImageMatting extends VitMattePreTrainedModel { async _call(e) { return new ImageMattingOutput(await super._call(e)); } } class MobileViTPreTrainedModel extends PreTrainedModel {} class MobileViTModel extends MobileViTPreTrainedModel {} class MobileViTForImageClassification extends MobileViTPreTrainedModel { async _call(e) { return new SequenceClassifierOutput(await super._call(e)); } } class OwlViTPreTrainedModel extends PreTrainedModel {} class OwlViTModel extends OwlViTPreTrainedModel {} class OwlViTForObjectDetection extends OwlViTPreTrainedModel {} class Owlv2PreTrainedModel extends PreTrainedModel {} class Owlv2Model extends Owlv2PreTrainedModel {} class Owlv2ForObjectDetection extends Owlv2PreTrainedModel {} class BeitPreTrainedModel extends PreTrainedModel {} class BeitModel extends BeitPreTrainedModel {} class BeitForImageClassification extends BeitPreTrainedModel { async _call(e) { return new SequenceClassifierOutput(await super._call(e)); } } class DetrPreTrainedModel extends PreTrainedModel {} class DetrModel extends DetrPreTrainedModel {} class DetrForObjectDetection extends DetrPreTrainedModel { async _call(e) { return new DetrObjectDetectionOutput(await super._call(e)); } } class DetrForSegmentation extends DetrPreTrainedModel { async _call(e) { return new DetrSegmentationOutput(await super._call(e)); } } class DetrObjectDetectionOutput extends ModelOutput { constructor({ logits: e, pred_boxes: o }) { super(), (this.logits = e), (this.pred_boxes = o); } } class DetrSegmentationOutput extends ModelOutput { constructor({ logits: e, pred_boxes: o, pred_masks: i }) { super(), (this.logits = e), (this.pred_boxes = o), (this.pred_masks = i); } } class TableTransformerPreTrainedModel extends PreTrainedModel {} class TableTransformerModel extends TableTransformerPreTrainedModel {} class TableTransformerForObjectDetection extends TableTransformerPreTrainedModel { async _call(e) { return new TableTransformerObjectDetectionOutput(await super._call(e)); } } class TableTransformerObjectDetectionOutput extends DetrObjectDetectionOutput {} class DeiTPreTrainedModel extends PreTrainedModel {} class DeiTModel extends DeiTPreTrainedModel {} class DeiTForImageClassification extends DeiTPreTrainedModel { async _call(e) { return new SequenceClassifierOutput(await super._call(e)); } } class ResNetPreTrainedModel extends PreTrainedModel {} class ResNetModel extends ResNetPreTrainedModel {} class ResNetForImageClassification extends ResNetPreTrainedModel { async _call(e) { return new SequenceClassifierOutput(await super._call(e)); } } class SwinPreTrainedModel extends PreTrainedModel {} class SwinModel extends SwinPreTrainedModel {} class SwinForImageClassification extends SwinPreTrainedModel { async _call(e) { return new SequenceClassifierOutput(await super._call(e)); } } class Swin2SRPreTrainedModel extends PreTrainedModel {} class Swin2SRModel extends Swin2SRPreTrainedModel {} class Swin2SRForImageSuperResolution extends Swin2SRPreTrainedModel {} class DPTPreTrainedModel extends PreTrainedModel {} class DPTModel extends DPTPreTrainedModel {} class DPTForDepthEstimation extends DPTPreTrainedModel {} class DepthAnythingPreTrainedModel extends PreTrainedModel {} class DepthAnythingForDepthEstimation extends DepthAnythingPreTrainedModel {} class GLPNPreTrainedModel extends PreTrainedModel {} class GLPNModel extends GLPNPreTrainedModel {} class GLPNForDepthEstimation extends GLPNPreTrainedModel {} class DonutSwinPreTrainedModel extends PreTrainedModel {} class DonutSwinModel extends DonutSwinPreTrainedModel {} class ConvNextPreTrainedModel extends PreTrainedModel {} class ConvNextModel extends ConvNextPreTrainedModel {} class ConvNextForImageClassification extends ConvNextPreTrainedModel { async _call(e) { return new SequenceClassifierOutput(await super._call(e)); } } class ConvNextV2PreTrainedModel extends PreTrainedModel {} class ConvNextV2Model extends ConvNextV2PreTrainedModel {} class ConvNextV2ForImageClassification extends ConvNextV2PreTrainedModel { async _call(e) { return new SequenceClassifierOutput(await super._call(e)); } } class Dinov2PreTrainedModel extends PreTrainedModel {} class Dinov2Model extends Dinov2PreTrainedModel {} class Dinov2ForImageClassification extends Dinov2PreTrainedModel { async _call(e) { return new SequenceClassifierOutput(await super._call(e)); } } class YolosPreTrainedModel extends PreTrainedModel {} class YolosModel extends YolosPreTrainedModel {} class YolosForObjectDetection extends YolosPreTrainedModel { async _call(e) { return new YolosObjectDetectionOutput(await super._call(e)); } } class YolosObjectDetectionOutput extends ModelOutput { constructor({ logits: e, pred_boxes: o }) { super(), (this.logits = e), (this.pred_boxes = o); } } class SamPreTrainedModel extends PreTrainedModel {} class SamModel extends SamPreTrainedModel { constructor(e, o, i) { super(e, o), (this.prompt_encoder_mask_decoder = i); } async get_image_embeddings({ pixel_values: e }) { return await encoderForward(this, { pixel_values: e }); } async forward(e) { if ( ((!e.image_embeddings || !e.image_positional_embeddings) && (e = { ...e, ...(await this.get_image_embeddings(e)) }), !e.input_labels) ) { const o = e.input_points.dims.slice(0, -1), i = o.reduce((u, n) => u * n, 1); e.input_labels = new Tensor('int64', new BigInt64Array(i).fill(1n), o); } return await sessionRun(this.prompt_encoder_mask_decoder, { input_points: e.input_points, input_labels: e.input_labels, image_embeddings: e.image_embeddings, image_positional_embeddings: e.image_positional_embeddings, }); } async _call(e) { return new SamImageSegmentationOutput(await super._call(e)); } } class SamImageSegmentationOutput extends ModelOutput { constructor({ iou_scores: e, pred_masks: o }) { super(), (this.iou_scores = e), (this.pred_masks = o); } } class MarianPreTrainedModel extends PreTrainedModel {} class MarianModel extends MarianPreTrainedModel {} class MarianMTModel extends MarianPreTrainedModel { constructor(e, o, i, u) { super(e, o), (this.decoder_merged_session = i), (this.generation_config = u), (this.num_decoder_layers = this.config.decoder_layers), (this.num_decoder_heads = this.config.decoder_attention_heads), (this.decoder_dim_kv = this.config.d_model / this.num_decoder_heads), (this.num_encoder_layers = this.config.encoder_layers), (this.num_encoder_heads = this.config.encoder_attention_heads), (this.encoder_dim_kv = this.config.d_model / this.num_encoder_heads); } } class M2M100PreTrainedModel extends PreTrainedModel {} class M2M100Model extends M2M100PreTrainedModel {} class M2M100ForConditionalGeneration extends M2M100PreTrainedModel { constructor(e, o, i, u) { super(e, o), (this.decoder_merged_session = i), (this.generation_config = u), (this.num_decoder_layers = this.config.decoder_layers), (this.num_decoder_heads = this.config.decoder_attention_heads), (this.decoder_dim_kv = this.config.d_model / this.num_decoder_heads), (this.num_encoder_layers = this.config.encoder_layers), (this.num_encoder_heads = this.config.encoder_attention_heads), (this.encoder_dim_kv = this.config.d_model / this.num_encoder_heads); } } class Wav2Vec2PreTrainedModel extends PreTrainedModel {} class Wav2Vec2Model extends Wav2Vec2PreTrainedModel {} class Wav2Vec2ForCTC extends Wav2Vec2PreTrainedModel { async _call(e) { return new CausalLMOutput(await super._call(e)); } } class Wav2Vec2ForSequenceClassification extends Wav2Vec2PreTrainedModel { async _call(e) { return new SequenceClassifierOutput(await super._call(e)); } } class Wav2Vec2ForAudioFrameClassification extends Wav2Vec2PreTrainedModel { async _call(e) { return new TokenClassifierOutput(await super._call(e)); } } class UniSpeechPreTrainedModel extends PreTrainedModel {} class UniSpeechModel extends UniSpeechPreTrainedModel {} class UniSpeechForCTC extends UniSpeechPreTrainedModel { async _call(e) { return new CausalLMOutput(await super._call(e)); } } class UniSpeechForSequenceClassification extends UniSpeechPreTrainedModel { async _call(e) { return new SequenceClassifierOutput(await super._call(e)); } } class UniSpeechSatPreTrainedModel extends PreTrainedModel {} class UniSpeechSatModel extends UniSpeechSatPreTrainedModel {} class UniSpeechSatForCTC extends UniSpeechSatPreTrainedModel { async _call(e) { return new CausalLMOutput(await super._call(e)); } } class UniSpeechSatForSequenceClassification extends UniSpeechSatPreTrainedModel { async _call(e) { return new SequenceClassifierOutput(await super._call(e)); } } class UniSpeechSatForAudioFrameClassification extends UniSpeechSatPreTrainedModel { async _call(e) { return new TokenClassifierOutput(await super._call(e)); } } class Wav2Vec2BertPreTrainedModel extends PreTrainedModel {} class Wav2Vec2BertModel extends Wav2Vec2BertPreTrainedModel {} class Wav2Vec2BertForCTC extends Wav2Vec2BertPreTrainedModel { async _call(e) { return new CausalLMOutput(await super._call(e)); } } class Wav2Vec2BertForSequenceClassification extends Wav2Vec2BertPreTrainedModel { async _call(e) { return new SequenceClassifierOutput(await super._call(e)); } } class HubertModel extends Wav2Vec2PreTrainedModel {} class HubertForCTC extends Wav2Vec2PreTrainedModel { async _call(e) { return new CausalLMOutput(await super._call(e)); } } class HubertForSequenceClassification extends Wav2Vec2PreTrainedModel { async _call(e) { return new SequenceClassifierOutput(await super._call(e)); } } class WavLMPreTrainedModel extends PreTrainedModel {} class WavLMModel extends WavLMPreTrainedModel {} class WavLMForCTC extends WavLMPreTrainedModel { async _call(e) { return new CausalLMOutput(await super._call(e)); } } class WavLMForSequenceClassification extends WavLMPreTrainedModel { async _call(e) { return new SequenceClassifierOutput(await super._call(e)); } } class WavLMForXVector extends WavLMPreTrainedModel { async _call(e) { return new XVectorOutput(await super._call(e)); } } class WavLMForAudioFrameClassification extends WavLMPreTrainedModel { async _call(e) { return new TokenClassifierOutput(await super._call(e)); } } class SpeechT5PreTrainedModel extends PreTrainedModel {} class SpeechT5ForSpeechToText extends SpeechT5PreTrainedModel {} class SpeechT5ForTextToSpeech extends SpeechT5PreTrainedModel { constructor(e, o, i, u) { super(e, o), (this.decoder_merged_session = i), (this.generation_config = u), (this.num_decoder_layers = this.config.decoder_layers), (this.num_decoder_heads = this.config.decoder_attention_heads), (this.decoder_dim_kv = this.config.hidden_size / this.num_decoder_heads), (this.num_encoder_layers = this.config.encoder_layers), (this.num_encoder_heads = this.config.encoder_attention_heads), (this.encoder_dim_kv = this.config.hidden_size / this.num_encoder_heads); } async generate_speech( e, o, { threshold: i = 0.5, minlenratio: u = 0, maxlenratio: n = 20, vocoder: s = null } = {} ) { const d = { input_ids: e }, { encoder_outputs: f, encoder_attention_mask: r } = await encoderForward(this, d), a = f.dims[1] / this.config.reduction_factor, l = Math.floor(a * n), p = Math.floor(a * u), m = this.config.num_mel_bins; let y = [], T = null, v = null, S = 0; for (;;) { ++S; const F = boolTensor(!!v); let B; v ? (B = v.output_sequence_out) : (B = new Tensor('float32', new Float32Array(m), [1, 1, m])); let J = { use_cache_branch: F, output_sequence: B, encoder_attention_mask: r, speaker_embeddings: o, encoder_hidden_states: f, }; this.addPastKeyValues(J, T), (v = await sessionRun(this.decoder_merged_session, J)), (T = this.getPastKeyValues(v, T)); const { prob: Q, spectrum: re } = v; if ((y.push(re), S >= p && (Array.from(Q.data).filter((V) => V >= i).length > 0 || S >= l))) break; } const E = cat(y), { waveform: A } = await sessionRun(s.session, { spectrogram: E }); return { spectrogram: E, waveform: A }; } } class SpeechT5HifiGan extends PreTrainedModel { main_input_name = 'spectrogram'; } class TrOCRPreTrainedModel extends PreTrainedModel { constructor(e, o, i) { super(e, o), (this.generation_config = i), (this.config.pad_token_id = this.config.eos_token_id), (this.num_encoder_layers = this.num_decoder_layers = this.config.decoder_layers), (this.num_encoder_heads = this.num_decoder_heads = this.config.decoder_attention_heads), (this.encoder_dim_kv = this.decoder_dim_kv = this.config.d_model / this.num_decoder_heads); } } class TrOCRForCausalLM extends TrOCRPreTrainedModel {} class MistralPreTrainedModel extends PreTrainedModel { constructor(e, o, i) { super(e, o), (this.generation_config = i), (this.config.pad_token_id = this.config.eos_token_id), (this.num_heads = this.config.num_key_value_heads), (this.num_layers = this.config.num_hidden_layers), (this.dim_kv = this.config.hidden_size / this.config.num_attention_heads); } } class MistralModel extends MistralPreTrainedModel {} class MistralForCausalLM extends MistralPreTrainedModel {} class Starcoder2PreTrainedModel extends PreTrainedModel { constructor(e, o, i) { super(e, o), (this.generation_config = i), (this.config.pad_token_id = this.config.eos_token_id), (this.num_heads = this.config.num_key_value_heads), (this.num_layers = this.config.num_hidden_layers), (this.dim_kv = this.config.hidden_size / this.config.num_attention_heads); } } class Starcoder2Model extends Starcoder2PreTrainedModel {} class Starcoder2ForCausalLM extends Starcoder2PreTrainedModel {} class FalconPreTrainedModel extends PreTrainedModel { constructor(e, o, i) { super(e, o), (this.generation_config = i), (this.config.pad_token_id = this.config.eos_token_id), (this.num_heads = this.config.num_attention_heads), (this.num_layers = this.config.num_hidden_layers), (this.dim_kv = this.config.hidden_size / this.config.num_attention_heads); } } class FalconModel extends FalconPreTrainedModel {} class FalconForCausalLM extends FalconPreTrainedModel {} class ClapPreTrainedModel extends PreTrainedModel {} class ClapModel extends ClapPreTrainedModel {} class ClapTextModelWithProjection extends ClapPreTrainedModel { static async from_pretrained(e, o = {}) { return (o.model_file_name ??= 'text_model'), super.from_pretrained(e, o); } } class ClapAudioModelWithProjection extends ClapPreTrainedModel { static async from_pretrained(e, o = {}) { return (o.model_file_name ??= 'audio_model'), super.from_pretrained(e, o); } } class VitsPreTrainedModel extends PreTrainedModel {} class VitsModel extends VitsPreTrainedModel { async _call(e) { return new VitsModelOutput(await super._call(e)); } } class SegformerPreTrainedModel extends PreTrainedModel {} class SegformerForImageClassification extends SegformerPreTrainedModel {} class SegformerForSemanticSegmentation extends SegformerPreTrainedModel {} class StableLmPreTrainedModel extends PreTrainedModel { constructor(e, o, i) { super(e, o), (this.generation_config = i), (this.config.pad_token_id = this.config.eos_token_id), (this.num_heads = this.config.num_attention_heads), (this.num_layers = this.config.num_hidden_layers), (this.dim_kv = this.config.hidden_size / this.num_heads); } } class StableLmForCausalLM extends StableLmPreTrainedModel {} class PretrainedMixin { static MODEL_CLASS_MAPPINGS = null; static BASE_IF_FAIL = !1; static async from_pretrained( e, { quantized: o = !0, progress_callback: i = null, config: u = null, cache_dir: n = null, local_files_only: s = !1, revision: d = 'main', model_file_name: f = null, session_options: r = {}, } = {} ) { let a = { quantized: o, progress_callback: i, config: u, cache_dir: n, local_files_only: s, revision: d, model_file_name: f, session_options: r, }; if (((u = await AutoConfig.from_pretrained(e, a)), a.config || (a.config = u), !this.MODEL_CLASS_MAPPINGS)) throw new Error('`MODEL_CLASS_MAPPINGS` not implemented for this type of `AutoClass`: ' + this.name); for (let l of this.MODEL_CLASS_MAPPINGS) { const p = l.get(u.model_type); if (p) return await p[1].from_pretrained(e, a); } if (this.BASE_IF_FAIL) return ( console.warn(`Unknown model class "${u.model_type}", attempting to construct from base class.`), await PreTrainedModel.from_pretrained(e, a) ); throw Error(`Unsupported model type: ${u.model_type}`); } } const MODEL_MAPPING_NAMES_ENCODER_ONLY = new Map([ ['bert', ['BertModel', BertModel]], ['nomic_bert', ['NomicBertModel', NomicBertModel]], ['roformer', ['RoFormerModel', RoFormerModel]], ['electra', ['ElectraModel', ElectraModel]], ['esm', ['EsmModel', EsmModel]], ['convbert', ['ConvBertModel', ConvBertModel]], ['camembert', ['CamembertModel', CamembertModel]], ['deberta', ['DebertaModel', DebertaModel]], ['deberta-v2', ['DebertaV2Model', DebertaV2Model]], ['mpnet', ['MPNetModel', MPNetModel]], ['albert', ['AlbertModel', AlbertModel]], ['distilbert', ['DistilBertModel', DistilBertModel]], ['roberta', ['RobertaModel', RobertaModel]], ['xlm', ['XLMModel', XLMModel]], ['xlm-roberta', ['XLMRobertaModel', XLMRobertaModel]], ['clap', ['ClapModel', ClapModel]], ['clip', ['CLIPModel', CLIPModel]], ['clipseg', ['CLIPSegModel', CLIPSegModel]], ['chinese_clip', ['ChineseCLIPModel', ChineseCLIPModel]], ['siglip', ['SiglipModel', SiglipModel]], ['mobilebert', ['MobileBertModel', MobileBertModel]], ['squeezebert', ['SqueezeBertModel', SqueezeBertModel]], ['wav2vec2', ['Wav2Vec2Model', Wav2Vec2Model]], ['wav2vec2-bert', ['Wav2Vec2BertModel', Wav2Vec2BertModel]], ['unispeech', ['UniSpeechModel', UniSpeechModel]], ['unispeech-sat', ['UniSpeechSatModel', UniSpeechSatModel]], ['hubert', ['HubertModel', HubertModel]], ['wavlm', ['WavLMModel', WavLMModel]], ['audio-spectrogram-transformer', ['ASTModel', ASTModel]], ['vits', ['VitsModel', VitsModel]], ['detr', ['DetrModel', DetrModel]], ['table-transformer', ['TableTransformerModel', TableTransformerModel]], ['vit', ['ViTModel', ViTModel]], ['mobilevit', ['MobileViTModel', MobileViTModel]], ['owlvit', ['OwlViTModel', OwlViTModel]], ['owlv2', ['Owlv2Model', Owlv2Model]], ['beit', ['BeitModel', BeitModel]], ['deit', ['DeiTModel', DeiTModel]], ['convnext', ['ConvNextModel', ConvNextModel]], ['convnextv2', ['ConvNextV2Model', ConvNextV2Model]], ['dinov2', ['Dinov2Model', Dinov2Model]], ['resnet', ['ResNetModel', ResNetModel]], ['swin', ['SwinModel', SwinModel]], ['swin2sr', ['Swin2SRModel', Swin2SRModel]], ['donut-swin', ['DonutSwinModel', DonutSwinModel]], ['yolos', ['YolosModel', YolosModel]], ['dpt', ['DPTModel', DPTModel]], ['glpn', ['GLPNModel', GLPNModel]], ['hifigan', ['SpeechT5HifiGan', SpeechT5HifiGan]], ]), MODEL_MAPPING_NAMES_ENCODER_DECODER = new Map([ ['t5', ['T5Model', T5Model]], ['longt5', ['LongT5Model', LongT5Model]], ['mt5', ['MT5Model', MT5Model]], ['bart', ['BartModel', BartModel]], ['mbart', ['MBartModel', MBartModel]], ['marian', ['MarianModel', MarianModel]], ['whisper', ['WhisperModel', WhisperModel]], ['m2m_100', ['M2M100Model', M2M100Model]], ['blenderbot', ['BlenderbotModel', BlenderbotModel]], ['blenderbot-small', ['BlenderbotSmallModel', BlenderbotSmallModel]], ]), MODEL_MAPPING_NAMES_DECODER_ONLY = new Map([ ['bloom', ['BloomModel', BloomModel]], ['gpt2', ['GPT2Model', GPT2Model]], ['gptj', ['GPTJModel', GPTJModel]], ['gpt_bigcode', ['GPTBigCodeModel', GPTBigCodeModel]], ['gpt_neo', ['GPTNeoModel', GPTNeoModel]], ['gpt_neox', ['GPTNeoXModel', GPTNeoXModel]], ['codegen', ['CodeGenModel', CodeGenModel]], ['llama', ['LlamaModel', LlamaModel]], ['qwen2', ['Qwen2Model', Qwen2Model]], ['phi', ['PhiModel', PhiModel]], ['mpt', ['MptModel', MptModel]], ['opt', ['OPTModel', OPTModel]], ['mistral', ['MistralModel', MistralModel]], ['starcoder2', ['Starcoder2Model', Starcoder2Model]], ['falcon', ['FalconModel', FalconModel]], ]), MODEL_FOR_SPEECH_SEQ_2_SEQ_MAPPING_NAMES = new Map([ ['speecht5', ['SpeechT5ForSpeechToText', SpeechT5ForSpeechToText]], ['whisper', ['WhisperForConditionalGeneration', WhisperForConditionalGeneration]], ]), MODEL_FOR_TEXT_TO_SPECTROGRAM_MAPPING_NAMES = new Map([ ['speecht5', ['SpeechT5ForTextToSpeech', SpeechT5ForTextToSpeech]], ]), MODEL_FOR_TEXT_TO_WAVEFORM_MAPPING_NAMES = new Map([['vits', ['VitsModel', VitsModel]]]), MODEL_FOR_SEQUENCE_CLASSIFICATION_MAPPING_NAMES = new Map([ ['bert', ['BertForSequenceClassification', BertForSequenceClassification]], ['roformer', ['RoFormerForSequenceClassification', RoFormerForSequenceClassification]], ['electra', ['ElectraForSequenceClassification', ElectraForSequenceClassification]], ['esm', ['EsmForSequenceClassification', EsmForSequenceClassification]], ['convbert', ['ConvBertForSequenceClassification', ConvBertForSequenceClassification]], ['camembert', ['CamembertForSequenceClassification', CamembertForSequenceClassification]], ['deberta', ['DebertaForSequenceClassification', DebertaForSequenceClassification]], ['deberta-v2', ['DebertaV2ForSequenceClassification', DebertaV2ForSequenceClassification]], ['mpnet', ['MPNetForSequenceClassification', MPNetForSequenceClassification]], ['albert', ['AlbertForSequenceClassification', AlbertForSequenceClassification]], ['distilbert', ['DistilBertForSequenceClassification', DistilBertForSequenceClassification]], ['roberta', ['RobertaForSequenceClassification', RobertaForSequenceClassification]], ['xlm', ['XLMForSequenceClassification', XLMForSequenceClassification]], ['xlm-roberta', ['XLMRobertaForSequenceClassification', XLMRobertaForSequenceClassification]], ['bart', ['BartForSequenceClassification', BartForSequenceClassification]], ['mbart', ['MBartForSequenceClassification', MBartForSequenceClassification]], ['mobilebert', ['MobileBertForSequenceClassification', MobileBertForSequenceClassification]], ['squeezebert', ['SqueezeBertForSequenceClassification', SqueezeBertForSequenceClassification]], ]), MODEL_FOR_TOKEN_CLASSIFICATION_MAPPING_NAMES = new Map([ ['bert', ['BertForTokenClassification', BertForTokenClassification]], ['roformer', ['RoFormerForTokenClassification', RoFormerForTokenClassification]], ['electra', ['ElectraForTokenClassification', ElectraForTokenClassification]], ['esm', ['EsmForTokenClassification', EsmForTokenClassification]], ['convbert', ['ConvBertForTokenClassification', ConvBertForTokenClassification]], ['camembert', ['CamembertForTokenClassification', CamembertForTokenClassification]], ['deberta', ['DebertaForTokenClassification', DebertaForTokenClassification]], ['deberta-v2', ['DebertaV2ForTokenClassification', DebertaV2ForTokenClassification]], ['mpnet', ['MPNetForTokenClassification', MPNetForTokenClassification]], ['distilbert', ['DistilBertForTokenClassification', DistilBertForTokenClassification]], ['roberta', ['RobertaForTokenClassification', RobertaForTokenClassification]], ['xlm', ['XLMForTokenClassification', XLMForTokenClassification]], ['xlm-roberta', ['XLMRobertaForTokenClassification', XLMRobertaForTokenClassification]], ]), MODEL_FOR_SEQ_TO_SEQ_CAUSAL_LM_MAPPING_NAMES = new Map([ ['t5', ['T5ForConditionalGeneration', T5ForConditionalGeneration]], ['longt5', ['LongT5ForConditionalGeneration', LongT5ForConditionalGeneration]], ['mt5', ['MT5ForConditionalGeneration', MT5ForConditionalGeneration]], ['bart', ['BartForConditionalGeneration', BartForConditionalGeneration]], ['mbart', ['MBartForConditionalGeneration', MBartForConditionalGeneration]], ['marian', ['MarianMTModel', MarianMTModel]], ['m2m_100', ['M2M100ForConditionalGeneration', M2M100ForConditionalGeneration]], ['blenderbot', ['BlenderbotForConditionalGeneration', BlenderbotForConditionalGeneration]], ['blenderbot-small', ['BlenderbotSmallForConditionalGeneration', BlenderbotSmallForConditionalGeneration]], ]), MODEL_WITH_LM_HEAD_MAPPING_NAMES = new Map([ ['bloom', ['BloomForCausalLM', BloomForCausalLM]], ['gpt2', ['GPT2LMHeadModel', GPT2LMHeadModel]], ['gptj', ['GPTJForCausalLM', GPTJForCausalLM]], ['gpt_bigcode', ['GPTBigCodeForCausalLM', GPTBigCodeForCausalLM]], ['gpt_neo', ['GPTNeoForCausalLM', GPTNeoForCausalLM]], ['gpt_neox', ['GPTNeoXForCausalLM', GPTNeoXForCausalLM]], ['codegen', ['CodeGenForCausalLM', CodeGenForCausalLM]], ['llama', ['LlamaForCausalLM', LlamaForCausalLM]], ['qwen2', ['Qwen2ForCausalLM', Qwen2ForCausalLM]], ['phi', ['PhiForCausalLM', PhiForCausalLM]], ['mpt', ['MptForCausalLM', MptForCausalLM]], ['opt', ['OPTForCausalLM', OPTForCausalLM]], ['mbart', ['MBartForCausalLM', MBartForCausalLM]], ['mistral', ['MistralForCausalLM', MistralForCausalLM]], ['starcoder2', ['Starcoder2ForCausalLM', Starcoder2ForCausalLM]], ['falcon', ['FalconForCausalLM', FalconForCausalLM]], ['trocr', ['TrOCRForCausalLM', TrOCRForCausalLM]], ['stablelm', ['StableLmForCausalLM', StableLmForCausalLM]], ]), MODEL_FOR_MASKED_LM_MAPPING_NAMES = new Map([ ['bert', ['BertForMaskedLM', BertForMaskedLM]], ['roformer', ['RoFormerForMaskedLM', RoFormerForMaskedLM]], ['electra', ['ElectraForMaskedLM', ElectraForMaskedLM]], ['esm', ['EsmForMaskedLM', EsmForMaskedLM]], ['convbert', ['ConvBertForMaskedLM', ConvBertForMaskedLM]], ['camembert', ['CamembertForMaskedLM', CamembertForMaskedLM]], ['deberta', ['DebertaForMaskedLM', DebertaForMaskedLM]], ['deberta-v2', ['DebertaV2ForMaskedLM', DebertaV2ForMaskedLM]], ['mpnet', ['MPNetForMaskedLM', MPNetForMaskedLM]], ['albert', ['AlbertForMaskedLM', AlbertForMaskedLM]], ['distilbert', ['DistilBertForMaskedLM', DistilBertForMaskedLM]], ['roberta', ['RobertaForMaskedLM', RobertaForMaskedLM]], ['xlm', ['XLMWithLMHeadModel', XLMWithLMHeadModel]], ['xlm-roberta', ['XLMRobertaForMaskedLM', XLMRobertaForMaskedLM]], ['mobilebert', ['MobileBertForMaskedLM', MobileBertForMaskedLM]], ['squeezebert', ['SqueezeBertForMaskedLM', SqueezeBertForMaskedLM]], ]), MODEL_FOR_QUESTION_ANSWERING_MAPPING_NAMES = new Map([ ['bert', ['BertForQuestionAnswering', BertForQuestionAnswering]], ['roformer', ['RoFormerForQuestionAnswering', RoFormerForQuestionAnswering]], ['electra', ['ElectraForQuestionAnswering', ElectraForQuestionAnswering]], ['convbert', ['ConvBertForQuestionAnswering', ConvBertForQuestionAnswering]], ['camembert', ['CamembertForQuestionAnswering', CamembertForQuestionAnswering]], ['deberta', ['DebertaForQuestionAnswering', DebertaForQuestionAnswering]], ['deberta-v2', ['DebertaV2ForQuestionAnswering', DebertaV2ForQuestionAnswering]], ['mpnet', ['MPNetForQuestionAnswering', MPNetForQuestionAnswering]], ['albert', ['AlbertForQuestionAnswering', AlbertForQuestionAnswering]], ['distilbert', ['DistilBertForQuestionAnswering', DistilBertForQuestionAnswering]], ['roberta', ['RobertaForQuestionAnswering', RobertaForQuestionAnswering]], ['xlm', ['XLMForQuestionAnswering', XLMForQuestionAnswering]], ['xlm-roberta', ['XLMRobertaForQuestionAnswering', XLMRobertaForQuestionAnswering]], ['mobilebert', ['MobileBertForQuestionAnswering', MobileBertForQuestionAnswering]], ['squeezebert', ['SqueezeBertForQuestionAnswering', SqueezeBertForQuestionAnswering]], ]), MODEL_FOR_VISION_2_SEQ_MAPPING_NAMES = new Map([ ['vision-encoder-decoder', ['VisionEncoderDecoderModel', VisionEncoderDecoderModel]], ]), MODEL_FOR_IMAGE_CLASSIFICATION_MAPPING_NAMES = new Map([ ['vit', ['ViTForImageClassification', ViTForImageClassification]], ['mobilevit', ['MobileViTForImageClassification', MobileViTForImageClassification]], ['beit', ['BeitForImageClassification', BeitForImageClassification]], ['deit', ['DeiTForImageClassification', DeiTForImageClassification]], ['convnext', ['ConvNextForImageClassification', ConvNextForImageClassification]], ['convnextv2', ['ConvNextV2ForImageClassification', ConvNextV2ForImageClassification]], ['dinov2', ['Dinov2ForImageClassification', Dinov2ForImageClassification]], ['resnet', ['ResNetForImageClassification', ResNetForImageClassification]], ['swin', ['SwinForImageClassification', SwinForImageClassification]], ['segformer', ['SegformerForImageClassification', SegformerForImageClassification]], ]), MODEL_FOR_OBJECT_DETECTION_MAPPING_NAMES = new Map([ ['detr', ['DetrForObjectDetection', DetrForObjectDetection]], ['table-transformer', ['TableTransformerForObjectDetection', TableTransformerForObjectDetection]], ['yolos', ['YolosForObjectDetection', YolosForObjectDetection]], ]), MODEL_FOR_ZERO_SHOT_OBJECT_DETECTION_MAPPING_NAMES = new Map([ ['owlvit', ['OwlViTForObjectDetection', OwlViTForObjectDetection]], ['owlv2', ['Owlv2ForObjectDetection', Owlv2ForObjectDetection]], ]), MODEL_FOR_IMAGE_SEGMENTATION_MAPPING_NAMES = new Map([ ['detr', ['DetrForSegmentation', DetrForSegmentation]], ['clipseg', ['CLIPSegForImageSegmentation', CLIPSegForImageSegmentation]], ]), MODEL_FOR_SEMANTIC_SEGMENTATION_MAPPING_NAMES = new Map([ ['segformer', ['SegformerForSemanticSegmentation', SegformerForSemanticSegmentation]], ]), MODEL_FOR_MASK_GENERATION_MAPPING_NAMES = new Map([['sam', ['SamModel', SamModel]]]), MODEL_FOR_CTC_MAPPING_NAMES = new Map([ ['wav2vec2', ['Wav2Vec2ForCTC', Wav2Vec2ForCTC]], ['wav2vec2-bert', ['Wav2Vec2BertForCTC', Wav2Vec2BertForCTC]], ['unispeech', ['UniSpeechForCTC', UniSpeechForCTC]], ['unispeech-sat', ['UniSpeechSatForCTC', UniSpeechSatForCTC]], ['wavlm', ['WavLMForCTC', WavLMForCTC]], ['hubert', ['HubertForCTC', HubertForCTC]], ]), MODEL_FOR_AUDIO_CLASSIFICATION_MAPPING_NAMES = new Map([ ['wav2vec2', ['Wav2Vec2ForSequenceClassification', Wav2Vec2ForSequenceClassification]], ['wav2vec2-bert', ['Wav2Vec2BertForSequenceClassification', Wav2Vec2BertForSequenceClassification]], ['unispeech', ['UniSpeechForSequenceClassification', UniSpeechForSequenceClassification]], ['unispeech-sat', ['UniSpeechSatForSequenceClassification', UniSpeechSatForSequenceClassification]], ['wavlm', ['WavLMForSequenceClassification', WavLMForSequenceClassification]], ['hubert', ['HubertForSequenceClassification', HubertForSequenceClassification]], ['audio-spectrogram-transformer', ['ASTForAudioClassification', ASTForAudioClassification]], ]), MODEL_FOR_AUDIO_XVECTOR_MAPPING_NAMES = new Map([['wavlm', ['WavLMForXVector', WavLMForXVector]]]), MODEL_FOR_AUDIO_FRAME_CLASSIFICATION_MAPPING_NAMES = new Map([ ['unispeech-sat', ['UniSpeechSatForAudioFrameClassification', UniSpeechSatForAudioFrameClassification]], ['wavlm', ['WavLMForAudioFrameClassification', WavLMForAudioFrameClassification]], ['wav2vec2', ['Wav2Vec2ForAudioFrameClassification', Wav2Vec2ForAudioFrameClassification]], ]), MODEL_FOR_IMAGE_MATTING_MAPPING_NAMES = new Map([ ['vitmatte', ['VitMatteForImageMatting', VitMatteForImageMatting]], ]), MODEL_FOR_IMAGE_TO_IMAGE_MAPPING_NAMES = new Map([ ['swin2sr', ['Swin2SRForImageSuperResolution', Swin2SRForImageSuperResolution]], ]), MODEL_FOR_DEPTH_ESTIMATION_MAPPING_NAMES = new Map([ ['dpt', ['DPTForDepthEstimation', DPTForDepthEstimation]], ['depth_anything', ['DepthAnythingForDepthEstimation', DepthAnythingForDepthEstimation]], ['glpn', ['GLPNForDepthEstimation', GLPNForDepthEstimation]], ]), MODEL_CLASS_TYPE_MAPPING = [ [MODEL_MAPPING_NAMES_ENCODER_ONLY, MODEL_TYPES.EncoderOnly], [MODEL_MAPPING_NAMES_ENCODER_DECODER, MODEL_TYPES.EncoderDecoder], [MODEL_MAPPING_NAMES_DECODER_ONLY, MODEL_TYPES.DecoderOnly], [MODEL_FOR_SEQUENCE_CLASSIFICATION_MAPPING_NAMES, MODEL_TYPES.EncoderOnly], [MODEL_FOR_TOKEN_CLASSIFICATION_MAPPING_NAMES, MODEL_TYPES.EncoderOnly], [MODEL_FOR_SEQ_TO_SEQ_CAUSAL_LM_MAPPING_NAMES, MODEL_TYPES.Seq2Seq], [MODEL_FOR_SPEECH_SEQ_2_SEQ_MAPPING_NAMES, MODEL_TYPES.Seq2Seq], [MODEL_WITH_LM_HEAD_MAPPING_NAMES, MODEL_TYPES.DecoderOnly], [MODEL_FOR_MASKED_LM_MAPPING_NAMES, MODEL_TYPES.EncoderOnly], [MODEL_FOR_QUESTION_ANSWERING_MAPPING_NAMES, MODEL_TYPES.EncoderOnly], [MODEL_FOR_VISION_2_SEQ_MAPPING_NAMES, MODEL_TYPES.Vision2Seq], [MODEL_FOR_IMAGE_CLASSIFICATION_MAPPING_NAMES, MODEL_TYPES.EncoderOnly], [MODEL_FOR_IMAGE_SEGMENTATION_MAPPING_NAMES, MODEL_TYPES.EncoderOnly], [MODEL_FOR_SEMANTIC_SEGMENTATION_MAPPING_NAMES, MODEL_TYPES.EncoderOnly], [MODEL_FOR_IMAGE_MATTING_MAPPING_NAMES, MODEL_TYPES.EncoderOnly], [MODEL_FOR_IMAGE_TO_IMAGE_MAPPING_NAMES, MODEL_TYPES.EncoderOnly], [MODEL_FOR_DEPTH_ESTIMATION_MAPPING_NAMES, MODEL_TYPES.EncoderOnly], [MODEL_FOR_OBJECT_DETECTION_MAPPING_NAMES, MODEL_TYPES.EncoderOnly], [MODEL_FOR_ZERO_SHOT_OBJECT_DETECTION_MAPPING_NAMES, MODEL_TYPES.EncoderOnly], [MODEL_FOR_MASK_GENERATION_MAPPING_NAMES, MODEL_TYPES.MaskGeneration], [MODEL_FOR_CTC_MAPPING_NAMES, MODEL_TYPES.EncoderOnly], [MODEL_FOR_AUDIO_CLASSIFICATION_MAPPING_NAMES, MODEL_TYPES.EncoderOnly], [MODEL_FOR_TEXT_TO_SPECTROGRAM_MAPPING_NAMES, MODEL_TYPES.Seq2Seq], [MODEL_FOR_TEXT_TO_WAVEFORM_MAPPING_NAMES, MODEL_TYPES.EncoderOnly], [MODEL_FOR_AUDIO_XVECTOR_MAPPING_NAMES, MODEL_TYPES.EncoderOnly], [MODEL_FOR_AUDIO_FRAME_CLASSIFICATION_MAPPING_NAMES, MODEL_TYPES.EncoderOnly], ]; for (const [t, e] of MODEL_CLASS_TYPE_MAPPING) for (const [o, i] of t.values()) MODEL_TYPE_MAPPING.set(o, e), MODEL_CLASS_TO_NAME_MAPPING.set(i, o), MODEL_NAME_TO_CLASS_MAPPING.set(o, i); const CUSTOM_MAPPING = [ ['CLIPTextModelWithProjection', CLIPTextModelWithProjection, MODEL_TYPES.EncoderOnly], ['CLIPVisionModelWithProjection', CLIPVisionModelWithProjection, MODEL_TYPES.EncoderOnly], ['SiglipTextModel', SiglipTextModel, MODEL_TYPES.EncoderOnly], ['SiglipVisionModel', SiglipVisionModel, MODEL_TYPES.EncoderOnly], ['ClapTextModelWithProjection', ClapTextModelWithProjection, MODEL_TYPES.EncoderOnly], ['ClapAudioModelWithProjection', ClapAudioModelWithProjection, MODEL_TYPES.EncoderOnly], ]; for (const [t, e, o] of CUSTOM_MAPPING) MODEL_TYPE_MAPPING.set(t, o), MODEL_CLASS_TO_NAME_MAPPING.set(e, t), MODEL_NAME_TO_CLASS_MAPPING.set(t, e); class AutoModel extends PretrainedMixin { static MODEL_CLASS_MAPPINGS = MODEL_CLASS_TYPE_MAPPING.map((e) => e[0]); static BASE_IF_FAIL = !0; } class Seq2SeqLMOutput extends ModelOutput { constructor({ logits: e, past_key_values: o, encoder_outputs: i, decoder_attentions: u = null, cross_attentions: n = null, }) { super(), (this.logits = e), (this.past_key_values = o), (this.encoder_outputs = i), (this.decoder_attentions = u), (this.cross_attentions = n); } } class SequenceClassifierOutput extends ModelOutput { constructor({ logits: e }) { super(), (this.logits = e); } } class XVectorOutput extends ModelOutput { constructor({ logits: e, embeddings: o }) { super(), (this.logits = e), (this.embeddings = o); } } class TokenClassifierOutput extends ModelOutput { constructor({ logits: e }) { super(), (this.logits = e); } } class MaskedLMOutput extends ModelOutput { constructor({ logits: e }) { super(), (this.logits = e); } } class QuestionAnsweringModelOutput extends ModelOutput { constructor({ start_logits: e, end_logits: o }) { super(), (this.start_logits = e), (this.end_logits = o); } } class CausalLMOutput extends ModelOutput { constructor({ logits: e }) { super(), (this.logits = e); } } class ImageMattingOutput extends ModelOutput { constructor({ alphas: e }) { super(), (this.alphas = e); } } class VitsModelOutput extends ModelOutput { constructor({ waveform: e, spectrogram: o }) { super(), (this.waveform = e), (this.spectrogram = o); } } const BROWSER_ENV = typeof self < 'u', WEBWORKER_ENV = BROWSER_ENV && self.constructor.name === 'DedicatedWorkerGlobalScope'; let createCanvasFunction, ImageDataClass, loadImageFunction; if (BROWSER_ENV) (createCanvasFunction = (t, e) => { if (!self.OffscreenCanvas) throw new Error('OffscreenCanvas not supported by this browser.'); return new self.OffscreenCanvas(t, e); }), (loadImageFunction = self.createImageBitmap), (ImageDataClass = self.ImageData); else if (sharp) loadImageFunction = async (t) => { const o = (await t.metadata()).channels, { data: i, info: u } = await t.raw().toBuffer({ resolveWithObject: !0 }), n = new RawImage(new Uint8ClampedArray(i), u.width, u.height, u.channels); return o !== void 0 && o !== u.channels && n.convert(o), n; }; else throw new Error('Unable to load image processing library.'); const RESAMPLING_MAPPING = { 0: 'nearest', 1: 'lanczos', 2: 'bilinear', 3: 'bicubic', 4: 'box', 5: 'hamming' }, CONTENT_TYPE_MAP = new Map([ ['png', 'image/png'], ['jpg', 'image/jpeg'], ['jpeg', 'image/jpeg'], ['gif', 'image/gif'], ]); class RawImage { constructor(e, o, i, u) { (this.data = e), (this.width = o), (this.height = i), (this.channels = u); } get size() { return [this.width, this.height]; } static async read(e) { if (e instanceof RawImage) return e; if (typeof e == 'string' || e instanceof URL) return await this.fromURL(e); throw new Error(`Unsupported input type: ${typeof e}`); } static async fromURL(e) { const o = await getFile(e); if (o.status !== 200) throw new Error(`Unable to read image from "${e}" (${o.status} ${o.statusText})`); const i = await o.blob(); return this.fromBlob(i); } static async fromBlob(e) { if (BROWSER_ENV) { const o = await loadImageFunction(e), i = createCanvasFunction(o.width, o.height).getContext('2d'); return i.drawImage(o, 0, 0), new this(i.getImageData(0, 0, o.width, o.height).data, o.width, o.height, 4); } else { const o = sharp(await e.arrayBuffer()); return await loadImageFunction(o); } } static fromTensor(e, o = 'CHW') { if (e.dims.length !== 3) throw new Error(`Tensor should have 3 dimensions, but has ${e.dims.length} dimensions.`); if (o === 'CHW') e = e.transpose(1, 2, 0); else if (o !== 'HWC') throw new Error(`Unsupported channel format: ${o}`); if (!(e.data instanceof Uint8ClampedArray || e.data instanceof Uint8Array)) throw new Error(`Unsupported tensor type: ${e.type}`); switch (e.dims[2]) { case 1: case 2: case 3: case 4: return new RawImage(e.data, e.dims[1], e.dims[0], e.dims[2]); default: throw new Error(`Unsupported number of channels: ${e.dims[2]}`); } } grayscale() { if (this.channels === 1) return this; const e = new Uint8ClampedArray(this.width * this.height * 1); switch (this.channels) { case 3: case 4: for (let o = 0, i = 0; o < this.data.length; o += this.channels) { const u = this.data[o], n = this.data[o + 1], s = this.data[o + 2]; e[i++] = Math.round(0.2989 * u + 0.587 * n + 0.114 * s); } break; default: throw new Error(`Conversion failed due to unsupported number of channels: ${this.channels}`); } return this._update(e, this.width, this.height, 1); } rgb() { if (this.channels === 3) return this; const e = new Uint8ClampedArray(this.width * this.height * 3); switch (this.channels) { case 1: for (let o = 0, i = 0; o < this.data.length; ++o) (e[i++] = this.data[o]), (e[i++] = this.data[o]), (e[i++] = this.data[o]); break; case 4: for (let o = 0, i = 0; o < this.data.length; o += 4) (e[i++] = this.data[o]), (e[i++] = this.data[o + 1]), (e[i++] = this.data[o + 2]); break; default: throw new Error(`Conversion failed due to unsupported number of channels: ${this.channels}`); } return this._update(e, this.width, this.height, 3); } rgba() { if (this.channels === 4) return this; const e = new Uint8ClampedArray(this.width * this.height * 4); switch (this.channels) { case 1: for (let o = 0, i = 0; o < this.data.length; ++o) (e[i++] = this.data[o]), (e[i++] = this.data[o]), (e[i++] = this.data[o]), (e[i++] = 255); break; case 3: for (let o = 0, i = 0; o < this.data.length; o += 3) (e[i++] = this.data[o]), (e[i++] = this.data[o + 1]), (e[i++] = this.data[o + 2]), (e[i++] = 255); break; default: throw new Error(`Conversion failed due to unsupported number of channels: ${this.channels}`); } return this._update(e, this.width, this.height, 4); } async resize(e, o, { resample: i = 2 } = {}) { let u = RESAMPLING_MAPPING[i] ?? i; if (BROWSER_ENV) { const n = this.channels, s = this.toCanvas(), d = createCanvasFunction(e, o).getContext('2d'); return d.drawImage(s, 0, 0, e, o), new RawImage(d.getImageData(0, 0, e, o).data, e, o, 4).convert(n); } else { let n = this.toSharp(); switch (u) { case 'box': case 'hamming': (u === 'box' || u === 'hamming') && (console.warn(`Resampling method ${u} is not yet supported. Using bilinear instead.`), (u = 'bilinear')); case 'nearest': case 'bilinear': case 'bicubic': n = n.affine([e / this.width, 0, 0, o / this.height], { interpolator: u }); break; case 'lanczos': n = n.resize({ width: e, height: o, fit: 'fill', kernel: 'lanczos3' }); break; default: throw new Error(`Resampling method ${u} is not supported.`); } return await loadImageFunction(n); } } async pad([e, o, i, u]) { if ( ((e = Math.max(e, 0)), (o = Math.max(o, 0)), (i = Math.max(i, 0)), (u = Math.max(u, 0)), e === 0 && o === 0 && i === 0 && u === 0) ) return this; if (BROWSER_ENV) { const n = this.channels, s = this.toCanvas(), d = this.width + e + o, f = this.height + i + u, r = createCanvasFunction(d, f).getContext('2d'); return ( r.drawImage(s, 0, 0, this.width, this.height, e, i, d, f), new RawImage(r.getImageData(0, 0, d, f).data, d, f, 4).convert(n) ); } else { const n = this.toSharp().extend({ left: e, right: o, top: i, bottom: u }); return await loadImageFunction(n); } } async crop([e, o, i, u]) { if ( ((e = Math.max(e, 0)), (o = Math.max(o, 0)), (i = Math.min(i, this.width - 1)), (u = Math.min(u, this.height - 1)), e === 0 && o === 0 && i === this.width - 1 && u === this.height - 1) ) return this; const n = i - e + 1, s = u - o + 1; if (BROWSER_ENV) { const d = this.channels, f = this.toCanvas(), r = createCanvasFunction(n, s).getContext('2d'); return ( r.drawImage(f, e, o, n, s, 0, 0, n, s), new RawImage(r.getImageData(0, 0, n, s).data, n, s, 4).convert(d) ); } else { const d = this.toSharp().extract({ left: e, top: o, width: n, height: s }); return await loadImageFunction(d); } } async center_crop(e, o) { if (this.width === e && this.height === o) return this; const i = (this.width - e) / 2, u = (this.height - o) / 2; if (BROWSER_ENV) { const n = this.channels, s = this.toCanvas(), d = createCanvasFunction(e, o).getContext('2d'); let f = 0, r = 0, a = 0, l = 0; return ( i >= 0 ? (f = i) : (a = -i), u >= 0 ? (r = u) : (l = -u), d.drawImage(s, f, r, e, o, a, l, e, o), new RawImage(d.getImageData(0, 0, e, o).data, e, o, 4).convert(n) ); } else { let n = this.toSharp(); if (i >= 0 && u >= 0) n = n.extract({ left: Math.floor(i), top: Math.floor(u), width: e, height: o }); else if (i <= 0 && u <= 0) { const s = Math.floor(-u), d = Math.floor(-i); n = n.extend({ top: s, left: d, right: e - this.width - d, bottom: o - this.height - s }); } else { let s = [0, 0], d = 0; u < 0 ? ((s[0] = Math.floor(-u)), (s[1] = o - this.height - s[0])) : (d = Math.floor(u)); let f = [0, 0], r = 0; i < 0 ? ((f[0] = Math.floor(-i)), (f[1] = e - this.width - f[0])) : (r = Math.floor(i)), (n = n .extend({ top: s[0], bottom: s[1], left: f[0], right: f[1] }) .extract({ left: r, top: d, width: e, height: o })); } return await loadImageFunction(n); } } async toBlob(e = 'image/png', o = 1) { if (!BROWSER_ENV) throw new Error('toBlob() is only supported in browser environments.'); return await this.toCanvas().convertToBlob({ type: e, quality: o }); } toCanvas() { if (!BROWSER_ENV) throw new Error('toCanvas() is only supported in browser environments.'); const e = this.clone().rgba(), o = createCanvasFunction(e.width, e.height), i = new ImageDataClass(e.data, e.width, e.height); return o.getContext('2d').putImageData(i, 0, 0), o; } _update(e, o, i, u = null) { return (this.data = e), (this.width = o), (this.height = i), u !== null && (this.channels = u), this; } clone() { return new RawImage(this.data.slice(), this.width, this.height, this.channels); } convert(e) { if (this.channels === e) return this; switch (e) { case 1: this.grayscale(); break; case 3: this.rgb(); break; case 4: this.rgba(); break; default: throw new Error(`Conversion failed due to unsupported number of channels: ${this.channels}`); } return this; } async save(e) { if (BROWSER_ENV) { if (WEBWORKER_ENV) throw new Error('Unable to save an image from a Web Worker.'); const o = e.split('.').pop().toLowerCase(), i = CONTENT_TYPE_MAP.get(o) ?? 'image/png', u = await this.toBlob(i), n = URL.createObjectURL(u), s = document.createElement('a'); (s.href = n), (s.download = e), s.click(), s.remove(); } else { if (env.useFS) return await this.toSharp().toFile(e); throw new Error('Unable to save the image because filesystem is disabled in this environment.'); } } toSharp() { if (BROWSER_ENV) throw new Error('toSharp() is only supported in server-side environments.'); return sharp(this.data, { raw: { width: this.width, height: this.height, channels: this.channels } }); } } function hanning(t) { if (t < 1) return new Float64Array(); if (t === 1) return new Float64Array([1]); const e = t - 1, o = Math.PI / e, i = new Float64Array(t); for (let u = 0; u < t; ++u) { const n = 2 * u - e; i[u] = 0.5 + 0.5 * Math.cos(o * n); } return i; } const HERTZ_TO_MEL_MAPPING = { htk: (t) => 2595 * Math.log10(1 + t / 700), kaldi: (t) => 1127 * Math.log(1 + t / 700), slaney: (t, e = 1e3, o = 15, i = 27 / Math.log(6.4)) => (t >= e ? o + Math.log(t / e) * i : (3 * t) / 200), }; function hertz_to_mel(t, e = 'htk') { const o = HERTZ_TO_MEL_MAPPING[e]; if (!o) throw new Error('mel_scale should be one of "htk", "slaney" or "kaldi".'); return typeof t == 'number' ? o(t) : t.map((i) => o(i)); } const MEL_TO_HERTZ_MAPPING = { htk: (t) => 700 * (10 ** (t / 2595) - 1), kaldi: (t) => 700 * (Math.exp(t / 1127) - 1), slaney: (t, e = 1e3, o = 15, i = Math.log(6.4) / 27) => (t >= o ? e * Math.exp(i * (t - o)) : (200 * t) / 3), }; function mel_to_hertz(t, e = 'htk') { const o = MEL_TO_HERTZ_MAPPING[e]; if (!o) throw new Error('mel_scale should be one of "htk", "slaney" or "kaldi".'); return typeof t == 'number' ? o(t) : t.map((i) => o(i)); } function _create_triangular_filter_bank(t, e) { const o = Float64Array.from({ length: e.length - 1 }, (s, d) => e[d + 1] - e[d]), i = Array.from({ length: t.length }, () => new Array(e.length)); for (let s = 0; s < t.length; ++s) { const d = i[s]; for (let f = 0; f < e.length; ++f) d[f] = e[f] - t[s]; } const u = e.length - 2, n = Array.from({ length: u }, () => new Array(t.length)); for (let s = 0; s < t.length; ++s) { const d = i[s]; for (let f = 0; f < u; ++f) { const r = -d[f] / o[f], a = d[f + 2] / o[f + 1]; n[f][s] = Math.max(0, Math.min(r, a)); } } return n; } function linspace(t, e, o) { const i = (e - t) / (o - 1); return Float64Array.from({ length: o }, (u, n) => t + i * n); } function mel_filter_bank(t, e, o, i, u, n = null, s = 'htk', d = !1) { if (n !== null && n !== 'slaney') throw new Error('norm must be one of null or "slaney"'); const f = hertz_to_mel(o, s), r = hertz_to_mel(i, s), a = linspace(f, r, e + 2); let l = mel_to_hertz(a, s), p; if (d) { const y = u / (t * 2); (p = hertz_to_mel( Float64Array.from({ length: t }, (T, v) => v * y), s )), (l = a); } else p = linspace(0, Math.floor(u / 2), t); const m = _create_triangular_filter_bank(p, l); if (n !== null && n === 'slaney') for (let y = 0; y < e; ++y) { const T = m[y], v = 2 / (l[y + 2] - l[y]); for (let S = 0; S < t; ++S) T[S] *= v; } return m; } function padReflect(t, e, o) { const i = new t.constructor(t.length + e + o), u = t.length - 1; for (let n = 0; n < t.length; ++n) i[e + n] = t[n]; for (let n = 1; n <= e; ++n) i[e - n] = t[calculateReflectOffset(n, u)]; for (let n = 1; n <= o; ++n) i[u + e + n] = t[calculateReflectOffset(u - n, u)]; return i; } function _db_conversion_helper(t, e, o, i, u) { if (o <= 0) throw new Error('reference must be greater than zero'); if (i <= 0) throw new Error('min_value must be greater than zero'); o = Math.max(i, o); const n = Math.log10(o); for (let s = 0; s < t.length; ++s) t[s] = e * Math.log10(Math.max(i, t[s]) - n); if (u !== null) { if (u <= 0) throw new Error('db_range must be greater than zero'); const s = max(t)[0] - u; for (let d = 0; d < t.length; ++d) t[d] = Math.max(t[d], s); } return t; } function amplitude_to_db(t, e = 1, o = 1e-5, i = null) { return _db_conversion_helper(t, 20, e, o, i); } function power_to_db(t, e = 1, o = 1e-10, i = null) { return _db_conversion_helper(t, 10, e, o, i); } function spectrogram( t, e, o, i, { fft_length: u = null, power: n = 1, center: s = !0, pad_mode: d = 'reflect', onesided: f = !0, preemphasis: r = null, mel_filters: a = null, mel_floor: l = 1e-10, log_mel: p = null, reference: m = 1, min_value: y = 1e-10, db_range: T = null, remove_dc_offset: v = null, max_num_frames: S = null, do_pad: E = !0, transpose: A = !1, } = {} ) { const F = e.length; if ((u === null && (u = o), o > u)) throw Error(`frame_length (${o}) may not be larger than fft_length (${u})`); if (F !== o) throw new Error(`Length of the window (${F}) must equal frame_length (${o})`); if (i <= 0) throw new Error('hop_length must be greater than zero'); if (s) { if (d !== 'reflect') throw new Error(`pad_mode="${d}" not implemented yet.`); const he = Math.floor((u - 1) / 2) + 1; t = padReflect(t, he, he); } const B = Math.floor(1 + Math.floor((t.length - o) / i)), J = f ? Math.floor(u / 2) + 1 : u; let Q = B, re = B; S !== null && (S > B ? E && (re = S) : (re = Q = S)); const V = new FFT(u), de = new Float64Array(u), ke = new Float64Array(V.outputBufferSize), Ne = new Array(Q); for (let he = 0; he < Q; ++he) { const ue = he * i; for (let X = 0; X < o; ++X) de[X] = t[ue + X]; if (v) { let X = 0; for (let we = 0; we < o; ++we) X += de[we]; const ve = X / o; for (let we = 0; we < o; ++we) de[we] -= ve; } if (r !== null) { for (let X = o - 1; X >= 1; --X) de[X] -= r * de[X - 1]; de[0] *= 1 - r; } for (let X = 0; X < e.length; ++X) de[X] *= e[X]; V.realTransform(ke, de); const pe = new Array(J); for (let X = 0; X < pe.length; ++X) { const ve = X << 1; pe[X] = ke[ve] ** 2 + ke[ve + 1] ** 2; } Ne[he] = pe; } if (n !== null && n !== 2) { const he = 2 / n; for (let ue = 0; ue < Ne.length; ++ue) { const pe = Ne[ue]; for (let X = 0; X < pe.length; ++X) pe[X] **= he; } } const Me = a.length, Y = new Float32Array(Me * re), _e = A ? [re, Me] : [Me, re]; for (let he = 0; he < Me; ++he) { const ue = a[he]; for (let pe = 0; pe < Q; ++pe) { const X = Ne[pe]; let ve = 0; for (let we = 0; we < J; ++we) ve += ue[we] * X[we]; Y[A ? pe * Me + he : he * Q + pe] = Math.max(l, ve); } } if (n !== null && p !== null) { const he = Math.min(Y.length, Q * Me); switch (p) { case 'log': for (let ue = 0; ue < he; ++ue) Y[ue] = Math.log(Y[ue]); break; case 'log10': for (let ue = 0; ue < he; ++ue) Y[ue] = Math.log10(Y[ue]); break; case 'dB': if (n === 1) amplitude_to_db(Y, m, y, T); else if (n === 2) power_to_db(Y, m, y, T); else throw new Error(`Cannot use log_mel option '${p}' with power ${n}`); break; default: throw new Error(`log_mel must be one of null, 'log', 'log10' or 'dB'. Got '${p}'`); } } return { data: Y, dims: _e }; } function window_function(t, e, { periodic: o = !0, frame_length: i = null, center: u = !0 } = {}) { const n = o ? t + 1 : t; let s; switch (e) { case 'boxcar': s = new Float64Array(n).fill(1); break; case 'hann': case 'hann_window': s = hanning(n); break; case 'povey': s = hanning(n).map((d) => Math.pow(d, 0.85)); break; default: throw new Error(`Unknown window type ${e}.`); } if ((o && (s = s.subarray(0, t)), i === null)) return s; if (t > i) throw new Error(`Length of the window (${t}) may not be larger than frame_length (${i})`); return s; } function center_to_corners_format([t, e, o, i]) { return [t - o / 2, e - i / 2, t + o / 2, e + i / 2]; } function post_process_object_detection(t, e = 0.5, o = null, i = !1) { const u = t.logits, n = t.pred_boxes, [s, d, f] = u.dims; if (o !== null && o.length !== s) throw Error('Make sure that you pass in as many target sizes as the batch dimension of the logits'); let r = []; for (let a = 0; a < s; ++a) { let l = o !== null ? o[a] : null, p = { boxes: [], classes: [], scores: [] }, m = u[a], y = n[a]; for (let T = 0; T < d; ++T) { let v = m[T], S = [], E; if (i) { E = v.sigmoid().data; for (let A = 0; A < E.length; ++A) E[A] > e && S.push(A); } else { let A = max(v.data)[1]; if (A === f - 1) continue; S.push(A), (E = softmax(v.data)); } for (const A of S) { let F = y[T].data; (F = center_to_corners_format(F)), l !== null && (F = F.map((B, J) => B * l[(J + 1) % 2])), p.boxes.push(F), p.classes.push(A), p.scores.push(E[A]); } } r.push(p); } return r; } function validate_audio_inputs(t, e) { if (!(t instanceof Float32Array || t instanceof Float64Array)) throw new Error( `${e} expects input to be a Float32Array or a Float64Array, but got ${ t?.constructor?.name ?? typeof t } instead. If using the feature extractor directly, remember to use \`read_audio(url, sampling_rate)\` to obtain the raw audio data of the file/url.` ); } function constraint_to_multiple_of(t, e, o = 0, i = null) { let u = Math.round(t / e) * e; return i !== null && u > i && (u = Math.floor(t / e) * e), u < o && (u = Math.ceil(t / e) * e), u; } function enforce_size_divisibility([t, e], o) { return [Math.floor(t / o) * o, Math.floor(e / o) * o]; } class FeatureExtractor extends Callable { constructor(e) { super(), (this.config = e); } } class ImageFeatureExtractor extends FeatureExtractor { constructor(e) { super(e), (this.image_mean = this.config.image_mean ?? this.config.mean), (this.image_std = this.config.image_std ?? this.config.std), (this.resample = this.config.resample ?? 2), (this.do_rescale = this.config.do_rescale ?? !0), (this.rescale_factor = this.config.rescale_factor ?? 1 / 255), (this.do_normalize = this.config.do_normalize), (this.do_resize = this.config.do_resize), (this.do_thumbnail = this.config.do_thumbnail), (this.size = this.config.size), (this.size_divisibility = this.config.size_divisibility ?? this.config.size_divisor), (this.do_center_crop = this.config.do_center_crop), (this.crop_size = this.config.crop_size), (this.do_convert_rgb = this.config.do_convert_rgb ?? !0), (this.do_crop_margin = this.config.do_crop_margin), (this.pad_size = this.config.pad_size), (this.do_pad = this.config.do_pad), this.do_pad && !this.pad_size && this.size && this.size.width !== void 0 && this.size.height !== void 0 && (this.pad_size = this.size); } async thumbnail(e, o, i = 2) { const u = e.height, n = e.width, s = o.height, d = o.width; let f = Math.min(u, s), r = Math.min(n, d); return f === u && r === n ? e : (u > n ? (r = Math.floor((n * f) / u)) : n > u && (f = Math.floor((u * r) / n)), await e.resize(r, f, { resample: i })); } async crop_margin(e, o = 200) { const i = e.clone().grayscale(), u = min(i.data)[0], s = max(i.data)[0] - u; if (s === 0) return e; const d = o / 255; let f = i.width, r = i.height, a = 0, l = 0; for (let p = 0; p < i.height; ++p) { const m = p * i.width; for (let y = 0; y < i.width; ++y) (i.data[m + y] - u) / s < d && ((f = Math.min(f, y)), (r = Math.min(r, p)), (a = Math.max(a, y)), (l = Math.max(l, p))); } return (e = await e.crop([f, r, a, l])), e; } pad_image(e, o, i, { mode: u = 'constant', center: n = !1, constant_values: s = 0 } = {}) { const [d, f, r] = o; let a, l; if ((typeof i == 'number' ? ((a = i), (l = i)) : ((a = i.width), (l = i.height)), a !== d || l !== f)) { const p = new Float32Array(a * l * r); if (Array.isArray(s)) for (let T = 0; T < p.length; ++T) p[T] = s[T % r]; else s !== 0 && p.fill(s); const [m, y] = n ? [Math.floor((a - d) / 2), Math.floor((l - f) / 2)] : [0, 0]; for (let T = 0; T < f; ++T) { const v = (T + y) * a, S = T * d; for (let E = 0; E < d; ++E) { const A = (v + E + m) * r, F = (S + E) * r; for (let B = 0; B < r; ++B) p[A + B] = e[F + B]; } } if (u === 'symmetric') { if (n) throw new Error('`center` padding is not supported when `mode` is set to `symmetric`.'); const T = f - 1, v = d - 1; for (let S = 0; S < l; ++S) { const E = S * a, A = calculateReflectOffset(S, T) * d; for (let F = 0; F < a; ++F) { if (S < f && F < d) continue; const B = (E + F) * r, J = (A + calculateReflectOffset(F, v)) * r; for (let Q = 0; Q < r; ++Q) p[B + Q] = e[J + Q]; } } } (e = p), (o = [l, a, r]); } return [e, o]; } rescale(e) { for (let o = 0; o < e.length; ++o) e[o] = this.rescale_factor * e[o]; } get_resize_output_image_size(e, o) { const [i, u] = e.size; let n, s; if (this.do_thumbnail) { const { height: d, width: f } = o; n = Math.min(d, f); } else Number.isInteger(o) ? ((n = o), (s = this.config.max_size ?? n)) : o !== void 0 && ((n = o.shortest_edge), (s = o.longest_edge)); if (n !== void 0 || s !== void 0) { const d = n === void 0 ? 1 : Math.max(n / i, n / u), f = i * d, r = u * d, a = s === void 0 ? 1 : Math.min(s / f, s / r); let l = Math.floor(Number((f * a).toFixed(2))), p = Math.floor(Number((r * a).toFixed(2))); return ( this.size_divisibility !== void 0 && ([l, p] = enforce_size_divisibility([l, p], this.size_divisibility)), [l, p] ); } else if (o !== void 0 && o.width !== void 0 && o.height !== void 0) { let d = o.width, f = o.height; if (this.config.keep_aspect_ratio && this.config.ensure_multiple_of) { let r = o.height / u, a = o.width / i; Math.abs(1 - a) < Math.abs(1 - r) ? (r = a) : (a = r), (f = constraint_to_multiple_of(r * u, this.config.ensure_multiple_of)), (d = constraint_to_multiple_of(a * i, this.config.ensure_multiple_of)); } return [d, f]; } else { if (this.size_divisibility !== void 0) return enforce_size_divisibility([i, u], this.size_divisibility); throw new Error( `Could not resize image due to unsupported \`this.size\` option in config: ${JSON.stringify(o)}` ); } } async resize(e) { const [o, i] = this.get_resize_output_image_size(e, this.size); return await e.resize(o, i, { resample: this.resample }); } async preprocess( e, { do_normalize: o = null, do_pad: i = null, do_convert_rgb: u = null, do_convert_grayscale: n = null } = {} ) { this.do_crop_margin && (e = await this.crop_margin(e)); const [s, d] = e.size; if ( (u ?? this.do_convert_rgb ? (e = e.rgb()) : n && (e = e.grayscale()), this.do_resize && (e = await this.resize(e)), this.do_thumbnail && (e = await this.thumbnail(e, this.size, this.resample)), this.do_center_crop) ) { let m, y; Number.isInteger(this.crop_size) ? ((m = this.crop_size), (y = this.crop_size)) : ((m = this.crop_size.width), (y = this.crop_size.height)), (e = await e.center_crop(m, y)); } const f = [e.height, e.width]; let r = Float32Array.from(e.data), a = [e.height, e.width, e.channels]; if ((this.do_rescale && this.rescale(r), o ?? this.do_normalize)) { let m = this.image_mean; Array.isArray(this.image_mean) || (m = new Array(e.channels).fill(m)); let y = this.image_std; if ( (Array.isArray(this.image_std) || (y = new Array(e.channels).fill(m)), m.length !== e.channels || y.length !== e.channels) ) throw new Error( `When set to arrays, the length of \`image_mean\` (${m.length}) and \`image_std\` (${y.length}) must match the number of channels in the image (${e.channels}).` ); for (let T = 0; T < r.length; T += e.channels) for (let v = 0; v < e.channels; ++v) r[T + v] = (r[T + v] - this.image_mean[v]) / this.image_std[v]; } if (this.do_pad && this.pad_size) { const m = new Float32Array(this.pad_size.width * this.pad_size.height * e.channels); for (let y = 0; y < e.height; ++y) { const T = y * this.pad_size.width, v = y * e.width; for (let S = 0; S < e.width; ++S) { const E = (T + S) * e.channels, A = (v + S) * e.channels; for (let F = 0; F < e.channels; ++F) m[E + F] = r[A + F]; } } (r = m), (a = [this.pad_size.height, this.pad_size.width, e.channels]); } const l = new Tensor('float32', r, a), p = transpose(l, [2, 0, 1]); return { original_size: [d, s], reshaped_input_size: f, pixel_values: p }; } async _call(e, ...o) { Array.isArray(e) || (e = [e]); const i = await Promise.all(e.map((n) => this.preprocess(n))); return { pixel_values: stack( i.map((n) => n.pixel_values), 0 ), original_sizes: i.map((n) => n.original_size), reshaped_input_sizes: i.map((n) => n.reshaped_input_size), }; } } class SegformerFeatureExtractor extends ImageFeatureExtractor { post_process_semantic_segmentation(e, o = null) { const i = e.logits, u = i.dims[0]; if (o !== null && o.length !== u) throw Error('Make sure that you pass in as many target sizes as the batch dimension of the logits'); const n = []; for (let s = 0; s < u; ++s) { const d = o !== null ? o[s] : null; let f = i[s]; d !== null && (f = interpolate(f, d, 'bilinear', !1)); const [r, a] = d ?? f.dims.slice(-2), l = new Tensor('int32', new Int32Array(r * a), [r, a]), p = f[0].data; for (let v = 1; v < f.dims[0]; ++v) { const S = f[v].data; for (let E = 0; E < S.length; ++E) S[E] > p[E] && ((p[E] = S[E]), (l.data[E] = v)); } const m = new Array(f.dims[0]), y = l.data; for (let v = 0; v < y.length; ++v) { const S = y[v]; m[S] = S; } const T = m.filter((v) => v !== void 0); n.push({ segmentation: l, labels: T }); } return n; } } class DPTImageProcessor extends ImageFeatureExtractor {} class BitImageProcessor extends ImageFeatureExtractor {} class DPTFeatureExtractor extends ImageFeatureExtractor {} class GLPNFeatureExtractor extends ImageFeatureExtractor {} class CLIPFeatureExtractor extends ImageFeatureExtractor {} class ChineseCLIPFeatureExtractor extends ImageFeatureExtractor {} class SiglipImageProcessor extends ImageFeatureExtractor {} class ConvNextFeatureExtractor extends ImageFeatureExtractor { constructor(e) { super(e), (this.crop_pct = this.config.crop_pct ?? 224 / 256); } async resize(e) { const o = this.size?.shortest_edge; if (o === void 0) throw new Error("Size dictionary must contain 'shortest_edge' key."); if (o < 384) { const i = Math.floor(o / this.crop_pct), [u, n] = this.get_resize_output_image_size(e, { shortest_edge: i }); (e = await e.resize(u, n, { resample: this.resample })), (e = await e.center_crop(o, o)); } else e = await e.resize(o, o, { resample: this.resample }); return e; } } class ConvNextImageProcessor extends ConvNextFeatureExtractor {} class ViTFeatureExtractor extends ImageFeatureExtractor {} class ViTImageProcessor extends ImageFeatureExtractor {} class MobileViTFeatureExtractor extends ImageFeatureExtractor {} class OwlViTFeatureExtractor extends ImageFeatureExtractor { post_process_object_detection(...e) { return post_process_object_detection(...e); } } class Owlv2ImageProcessor extends OwlViTFeatureExtractor {} class DeiTFeatureExtractor extends ImageFeatureExtractor {} class BeitFeatureExtractor extends ImageFeatureExtractor {} class DonutFeatureExtractor extends ImageFeatureExtractor { pad_image(e, o, i, u = {}) { const [n, s, d] = o; let f = this.image_mean; Array.isArray(this.image_mean) || (f = new Array(d).fill(f)); let r = this.image_std; Array.isArray(r) || (r = new Array(d).fill(f)); const a = f.map((l, p) => -l / this.image_std[p]); return super.pad_image(e, o, i, { center: !0, constant_values: a, ...u }); } } class NougatImageProcessor extends DonutFeatureExtractor {} class DetrFeatureExtractor extends ImageFeatureExtractor { async _call(e) { const o = await super._call(e), i = [o.pixel_values.dims[0], 64, 64], u = new Tensor('int64', new BigInt64Array(i.reduce((n, s) => n * s)).fill(1n), i); return { ...o, pixel_mask: u }; } post_process_object_detection(...e) { return post_process_object_detection(...e); } remove_low_and_no_objects(e, o, i, u) { let n = [], s = [], d = []; for (let f = 0; f < e.dims[0]; ++f) { let r = e[f], a = o[f], l = max(r.data)[1]; if (l === u) continue; let m = softmax(r.data)[l]; m > i && (n.push(a), s.push(m), d.push(l)); } return [n, s, d]; } check_segment_validity(e, o, i, u = 0.5, n = 0.8) { let s = [], d = 0, f = 0; for (let a = 0; a < e.length; ++a) e[a] === i && (s.push(a), ++d), o[i].data[a] >= u && ++f; let r = d > 0 && f > 0; return r && (r = d / f > n), [r, s]; } compute_segments(e, o, i, u, n, s = null, d = null) { let [f, r] = d ?? e[0].dims, a = new Tensor('int32', new Int32Array(f * r), [f, r]), l = []; if (d !== null) for (let T = 0; T < e.length; ++T) e[T] = interpolate(e[T], d, 'bilinear', !1); let p = new Int32Array(e[0].data.length), m = new Float32Array(e[0].data.length); for (let T = 0; T < e.length; ++T) { let v = o[T]; for (let S = 0; S < e[T].data.length; ++S) (e[T].data[S] *= v), e[T].data[S] > m[S] && ((p[S] = T), (m[S] = e[T].data[S])); } let y = 0; for (let T = 0; T < i.length; ++T) { let v = i[T], [S, E] = this.check_segment_validity(p, e, T, u, n); if (S) { ++y; for (let A of E) a.data[A] = y; l.push({ id: y, label_id: v, score: o[T] }); } } return [a, l]; } post_process_panoptic_segmentation(e, o = 0.5, i = 0.5, u = 0.8, n = null, s = null) { n === null && (console.warn('`label_ids_to_fuse` unset. No instance will be fused.'), (n = new Set())); const d = e.logits, r = e.pred_masks.sigmoid(); let [a, l, p] = d.dims; if (((p -= 1), s !== null && s.length !== a)) throw Error('Make sure that you pass in as many target sizes as the batch dimension of the logits'); let m = []; for (let y = 0; y < a; ++y) { let T = s !== null ? s[y] : null, v = d[y], S = r[y], [E, A, F] = this.remove_low_and_no_objects(v, S, o, p); if (F.length === 0) { let [Q, re] = T ?? S.dims.slice(-2), V = new Tensor('int32', new Int32Array(Q * re).fill(-1), [Q, re]); m.push({ segmentation: V, segments_info: [] }); continue; } let [B, J] = this.compute_segments(E, A, F, i, u, n, T); m.push({ segmentation: B, segments_info: J }); } return m; } post_process_instance_segmentation() { throw Error('Not implemented yet'); } } class YolosFeatureExtractor extends ImageFeatureExtractor { post_process_object_detection(...e) { return post_process_object_detection(...e); } } class SamImageProcessor extends ImageFeatureExtractor { reshape_input_points(e, o, i) { e = structuredClone(e); let u = calculateDimensions(e); if (u.length === 3) (u = [1, ...u]), (e = [e]); else if (u.length !== 4) throw Error( 'The input_points must be a 4D tensor of shape `batch_size`, `point_batch_size`, `nb_points_per_image`, `2`.' ); for (let n = 0; n < e.length; ++n) { let s = o[n], d = i[n], f = [d[0] / s[0], d[1] / s[1]]; for (let r = 0; r < e[n].length; ++r) for (let a = 0; a < e[n][r].length; ++a) for (let l = 0; l < e[n][r][a].length; ++l) e[n][r][a][l] *= f[l]; } return new Tensor('float32', Float32Array.from(e.flat(1 / 0)), u); } add_input_labels(e, o) { let i = calculateDimensions(e); if (i.length === 2) (i = [1, ...i]), (e = [e]); else if (i.length !== 3) throw Error( 'The input_points must be a 4D tensor of shape `batch_size`, `point_batch_size`, `nb_points_per_image`, `2`.' ); if (i.some((u, n) => u !== o.dims[n])) throw Error(`The first ${i.length} dimensions of 'input_points' and 'input_labels' must be the same.`); return new Tensor('int64', e.flat(1 / 0).map(BigInt), i); } async _call(e, o = null, i = null) { const u = await super._call(e); if ((o && (u.input_points = this.reshape_input_points(o, u.original_sizes, u.reshaped_input_sizes)), i)) { if (!u.input_points) throw Error('`input_points` must be provided if `input_labels` are provided.'); u.input_labels = this.add_input_labels(i, u.input_points); } return u; } post_process_masks(e, o, i, { mask_threshold: u = 0, binarize: n = !0, pad_size: s = null } = {}) { const d = []; s = s ?? this.pad_size; const f = [s.height, s.width]; for (let r = 0; r < o.length; ++r) { const a = o[r], l = i[r], p = e[r], m = []; for (let y = 0; y < p.dims[0]; ++y) { const T = p[y]; let v = interpolate(T, f, 'bilinear', !1); if (((v = v.slice(null, [0, l[0]], [0, l[1]])), (v = interpolate(v, a, 'bilinear', !1)), n)) { const S = new Uint8Array(v.data.length); for (let E = 0; E < v.data.length; ++E) v.data[E] > u && (S[E] = 1); v = new Tensor('bool', S, v.dims); } m.push(v); } d.push(stack(m)); } return d; } generate_crop_boxes( e, o, { crop_n_layers: i = 0, overlap_ratio: u = 512 / 1500, points_per_crop: n = 32, crop_n_points_downscale_factor: s = 1, } = {} ) {} } class Swin2SRImageProcessor extends ImageFeatureExtractor { pad_image(e, o, i, u = {}) { const [n, s, d] = o; return super.pad_image( e, o, { width: n + ((i - (n % i)) % i), height: s + ((i - (s % i)) % i) }, { mode: 'symmetric', center: !1, constant_values: -1, ...u } ); } } class VitMatteImageProcessor extends ImageFeatureExtractor { async _call(e, o) { Array.isArray(e) || (e = [e]), Array.isArray(o) || (o = [o]); const i = await Promise.all(e.map((s) => this.preprocess(s))), u = await Promise.all( o.map((s) => this.preprocess(s, { do_normalize: !1, do_convert_rgb: !1, do_convert_grayscale: !0 })) ); return { pixel_values: stack( i.map((s, d) => cat([s.pixel_values, u[d].pixel_values], 0)), 0 ), original_sizes: i.map((s) => s.original_size), reshaped_input_sizes: i.map((s) => s.reshaped_input_size), }; } } class WhisperFeatureExtractor extends FeatureExtractor { constructor(e) { super(e), (this.config.mel_filters ??= mel_filter_bank( Math.floor(1 + this.config.n_fft / 2), this.config.feature_size, 0, 8e3, this.config.sampling_rate, 'slaney', 'slaney' )), (this.window = window_function(this.config.n_fft, 'hann')); } _extract_fbank_features(e) { const { data: o, dims: i } = spectrogram(e, this.window, this.config.n_fft, this.config.hop_length, { power: 2, mel_filters: this.config.mel_filters, log_mel: 'log10', max_num_frames: this.config.nb_max_frames, }), u = max(o)[0]; for (let n = 0; n < o.length; ++n) o[n] = (Math.max(o[n], u - 8) + 4) / 4; return { data: o, dims: i }; } async _call(e) { validate_audio_inputs(e, 'WhisperFeatureExtractor'); let o; e.length > this.config.n_samples ? (console.warn( 'Attempting to extract features for audio longer than 30 seconds. If using a pipeline to extract transcript from a long audio clip, remember to specify `chunk_length_s` and/or `stride_length_s`.' ), (o = e.slice(0, this.config.n_samples))) : ((o = new Float32Array(this.config.n_samples)), o.set(e)); const { data: i, dims: u } = this._extract_fbank_features(o); return { input_features: new Tensor('float32', i, [1, ...u]) }; } } class Wav2Vec2FeatureExtractor extends FeatureExtractor { _zero_mean_unit_var_norm(e) { const i = e.reduce((n, s) => n + s, 0) / e.length, u = e.reduce((n, s) => n + (s - i) ** 2, 0) / e.length; return e.map((n) => (n - i) / Math.sqrt(u + 1e-7)); } async _call(e) { validate_audio_inputs(e, 'Wav2Vec2FeatureExtractor'), e instanceof Float64Array && (e = new Float32Array(e)); let o = e; this.config.do_normalize && (o = this._zero_mean_unit_var_norm(o)); const i = [1, o.length]; return { input_values: new Tensor('float32', o, i), attention_mask: new Tensor('int64', new BigInt64Array(o.length).fill(1n), i), }; } } class SeamlessM4TFeatureExtractor extends FeatureExtractor { constructor(e) { super(e); const o = this.config.sampling_rate, i = mel_filter_bank(256, this.config.num_mel_bins, 20, Math.floor(o / 2), o, null, 'kaldi', !0); for (let u = 0; u < i.length; ++u) i[u].push(0); (this.mel_filters = i), (this.window = window_function(400, 'povey', { periodic: !1 })); } _extract_fbank_features(e, o) { return ( (e = e.map((i) => i * 32768)), spectrogram(e, this.window, 400, 160, { fft_length: 512, power: 2, center: !1, preemphasis: 0.97, mel_filters: this.mel_filters, log_mel: 'log', mel_floor: 1192092955078125e-22, remove_dc_offset: !0, max_num_frames: o, transpose: !0, }) ); } async _call( e, { padding: o = !0, pad_to_multiple_of: i = 2, do_normalize_per_mel_bins: u = !0, return_attention_mask: n = !0, } = {} ) { validate_audio_inputs(e, 'SeamlessM4TFeatureExtractor'); let s = this._extract_fbank_features(e, this.config.max_length); if (u) { const [y, T] = s.dims; for (let v = 0; v < T; ++v) { let S = 0; for (let B = 0; B < y; ++B) S += s.data[B * T + v]; const E = S / y; let A = 0; for (let B = 0; B < y; ++B) A += (s.data[B * T + v] - E) ** 2; A /= y - 1; const F = Math.sqrt(A + 1e-7); for (let B = 0; B < y; ++B) { const J = B * T + v; s.data[J] = (s.data[J] - E) / F; } } } let d; if (o) { const [y, T] = s.dims, v = y % i; if (v > 0) { const S = new Float32Array(T * (y + v)); S.set(s.data), S.fill(this.config.padding_value, s.data.length); const E = y + v; (s = { data: S, dims: [E, T] }), n && ((d = new Tensor('int64', new BigInt64Array(E), [1, E])), d.data.fill(1n, 0, y)); } } const [f, r] = s.dims, a = this.config.stride; if (f % a !== 0) throw new Error(`The number of frames (${f}) must be a multiple of the stride (${a}).`); const p = new Tensor('float32', s.data, s.dims).view(1, Math.floor(f / a), r * a), m = { input_features: p }; if (n) { const y = p.dims[1], T = new Tensor('int64', new BigInt64Array(y), [1, y]); if (d) for (let v = 1, S = 0; v < f; v += a, ++S) T.data[S] = d.data[v]; else T.data.fill(1n); m.attention_mask = T; } return m; } } class ASTFeatureExtractor extends FeatureExtractor { constructor(e) { super(e); const o = this.config.sampling_rate, i = mel_filter_bank(256, this.config.num_mel_bins, 20, Math.floor(o / 2), o, null, 'kaldi', !0); for (let u = 0; u < i.length; ++u) i[u].push(0); (this.mel_filters = i), (this.window = window_function(400, 'hann', { periodic: !1 })), (this.mean = this.config.mean), (this.std = this.config.std); } _extract_fbank_features(e, o) { return spectrogram(e, this.window, 400, 160, { fft_length: 512, power: 2, center: !1, preemphasis: 0.97, mel_filters: this.mel_filters, log_mel: 'log', mel_floor: 1192092955078125e-22, remove_dc_offset: !0, max_num_frames: o, transpose: !0, }); } async _call(e) { validate_audio_inputs(e, 'ASTFeatureExtractor'); const o = this._extract_fbank_features(e, this.config.max_length); if (this.config.do_normalize) { const i = this.std * 2; for (let u = 0; u < o.data.length; ++u) o.data[u] = (o.data[u] - this.mean) / i; } return { input_values: new Tensor('float32', o.data, [1, ...o.dims]) }; } } class ClapFeatureExtractor extends FeatureExtractor { constructor(e) { super(e), (this.mel_filters = mel_filter_bank( this.config.nb_frequency_bins, this.config.feature_size, this.config.frequency_min, this.config.frequency_max, this.config.sampling_rate, null, 'htk' )), (this.mel_filters_slaney = mel_filter_bank( this.config.nb_frequency_bins, this.config.feature_size, this.config.frequency_min, this.config.frequency_max, this.config.sampling_rate, 'slaney', 'slaney' )), (this.window = window_function(this.config.fft_window_size, 'hann')); } _get_input_mel(e, o, i, u) { let n, s = !1; const d = e.length - o; if (d > 0) if (i === 'rand_trunc') { s = !0; const f = Math.floor(Math.random() * (d + 1)); (e = e.subarray(f, f + o)), (n = this._extract_fbank_features(e, this.mel_filters_slaney, this.config.nb_max_samples)), (n.dims = [1, ...n.dims]); } else throw new Error(`Truncation strategy "${i}" not implemented`); else { if (d < 0) { let f = new Float64Array(o); if ((f.set(e), u === 'repeat')) for (let r = e.length; r < o; r += e.length) f.set(e.subarray(0, Math.min(e.length, o - r)), r); else if (u === 'repeatpad') for (let r = e.length; r < -d; r += e.length) f.set(e, r); e = f; } if (i === 'fusion') throw new Error(`Truncation strategy "${i}" not implemented`); (n = this._extract_fbank_features(e, this.mel_filters_slaney, this.config.nb_max_samples)), (n.dims = [1, ...n.dims]); } return { ...n, longer: s }; } _extract_fbank_features(e, o, i = null) { return spectrogram(e, this.window, this.config.fft_window_size, this.config.hop_length, { power: 2, mel_filters: o, log_mel: 'dB', max_num_frames: i, do_pad: !1, transpose: !0, }); } async _call(e, { max_length: o = null } = {}) { validate_audio_inputs(e, 'ClapFeatureExtractor'); const i = this._get_input_mel(e, o ?? this.config.nb_max_samples, this.config.truncation, this.config.padding); return { input_features: new Tensor('float32', i.data, [1, ...i.dims]) }; } } class SpeechT5FeatureExtractor extends FeatureExtractor {} class Processor extends Callable { constructor(e) { super(), (this.feature_extractor = e); } async _call(e, ...o) { return await this.feature_extractor(e, ...o); } } class SamProcessor extends Processor { async _call(...e) { return await this.feature_extractor(...e); } post_process_masks(...e) { return this.feature_extractor.post_process_masks(...e); } reshape_input_points(...e) { return this.feature_extractor.reshape_input_points(...e); } } class WhisperProcessor extends Processor { async _call(e) { return await this.feature_extractor(e); } } class Wav2Vec2ProcessorWithLM extends Processor { async _call(e) { return await this.feature_extractor(e); } } class SpeechT5Processor extends Processor { async _call(e) { return await this.feature_extractor(e); } } class OwlViTProcessor extends Processor {} class AutoProcessor { static FEATURE_EXTRACTOR_CLASS_MAPPING = { ImageFeatureExtractor, WhisperFeatureExtractor, ViTFeatureExtractor, MobileViTFeatureExtractor, OwlViTFeatureExtractor, Owlv2ImageProcessor, CLIPFeatureExtractor, ChineseCLIPFeatureExtractor, SiglipImageProcessor, ConvNextFeatureExtractor, ConvNextImageProcessor, SegformerFeatureExtractor, BitImageProcessor, DPTImageProcessor, DPTFeatureExtractor, GLPNFeatureExtractor, BeitFeatureExtractor, DeiTFeatureExtractor, DetrFeatureExtractor, YolosFeatureExtractor, DonutFeatureExtractor, NougatImageProcessor, ViTImageProcessor, VitMatteImageProcessor, SamImageProcessor, Swin2SRImageProcessor, Wav2Vec2FeatureExtractor, SeamlessM4TFeatureExtractor, SpeechT5FeatureExtractor, ASTFeatureExtractor, ClapFeatureExtractor, }; static PROCESSOR_CLASS_MAPPING = { WhisperProcessor, Wav2Vec2ProcessorWithLM, SamProcessor, SpeechT5Processor, OwlViTProcessor, }; static async from_pretrained( e, { progress_callback: o = null, config: i = null, cache_dir: u = null, local_files_only: n = !1, revision: s = 'main', } = {} ) { let d = i ?? (await getModelJSON(e, 'preprocessor_config.json', !0, { progress_callback: o, config: i, cache_dir: u, local_files_only: n, revision: s, })), f = d.feature_extractor_type ?? d.image_processor_type, r = this.FEATURE_EXTRACTOR_CLASS_MAPPING[f]; if (!r) if (d.size !== void 0) console.warn( `Feature extractor type "${f}" not found, assuming ImageFeatureExtractor due to size parameter in config.` ), (r = ImageFeatureExtractor); else throw new Error(`Unknown Feature Extractor type: ${f}`); let a = this.PROCESSOR_CLASS_MAPPING[d.processor_class] ?? Processor, l = new r(d); return new a(l); } } if (!navigator.gpu) { const t = 'WebGPU is not supported by this browser.'; throw (alert(t), Error(t)); } env.backends.onnx.wasm.proxy = !0; env.backends.onnx.wasm.wasmPaths = 'https://cdn.jsdelivr.net/npm/onnxruntime-web@1.17.1/dist/'; env.backends.onnx.wasm.numThreads = 1; env.experimental.useWebGPU = !0; const EXAMPLE_URL = 'https://images.pexels.com/photos/5965592/pexels-photo-5965592.jpeg?auto=compress&cs=tinysrgb&w=1024', status = document.getElementById('status'), fileUpload = document.getElementById('upload'), imageContainer = document.getElementById('container'), example = document.getElementById('example'); status.textContent = 'AI 모델 로딩중...'; let model; try { model = await AutoModel.from_pretrained('briaai/RMBG-1.4', { config: { model_type: 'custom' }, quantized: !1 }); } catch (t) { throw ((status.textContent = t.message), alert(t.message), t); } const processor = await AutoProcessor.from_pretrained('briaai/RMBG-1.4', { config: { do_normalize: !0, do_pad: !1, do_rescale: !0, do_resize: !0, image_mean: [0.5, 0.5, 0.5], feature_extractor_type: 'ImageFeatureExtractor', image_std: [1, 1, 1], resample: 2, rescale_factor: 0.00392156862745098, size: { width: 1024, height: 1024 }, }, }); status.textContent = 'AI 모델 설치중...'; const [b, c, h, w] = [1, 3, 1024, 1024], dummyData = new Float32Array(b * c * h * w); await model({ input: new Tensor('float32', dummyData, [b, c, h, w]) }); status.textContent = '준비 완료!'; example.addEventListener('click', (t) => { t.preventDefault(), predict(EXAMPLE_URL); }); fileUpload.addEventListener('change', function (t) { const e = t.target.files[0]; if (!e) return; const o = new FileReader(); (o.onload = (i) => predict(i.target.result)), o.readAsDataURL(e); }); async function predict(t) { const e = await RawImage.fromURL(t); (imageContainer.innerHTML = ''), (imageContainer.style.backgroundImage = `url(${t})`); const o = e.width / e.height, [i, u] = o > 720 / 480 ? [720, 720 / o] : [480 * o, 480]; (imageContainer.style.width = `${i}px`), (imageContainer.style.height = `${u}px`), (status.textContent = 'Analysing...'); const { pixel_values: n } = await processor(e), s = performance.now(), { output: d } = await model({ input: n }), f = performance.now(), r = await RawImage.fromTensor(d[0].mul(255).to('uint8')).resize(e.width, e.height), a = document.createElement('canvas'); (a.width = e.width), (a.height = e.height); const l = a.getContext('2d'); l.drawImage(e.toCanvas(), 0, 0); const p = l.getImageData(0, 0, e.width, e.height); for (let m = 0; m < r.data.length; ++m) p.data[4 * m + 3] = r.data[m]; l.putImageData(p, 0, 0), imageContainer.append(a), imageContainer.style.removeProperty('background-image'), (imageContainer.style.background = 'url("")'), (status.textContent = `Done! (Inference took ${Math.round(f - s)}ms)`); } function __vite__mapDeps(indexes) { if (!__vite__mapDeps.viteFileDeps) { __vite__mapDeps.viteFileDeps = []; } return indexes.map((i) => __vite__mapDeps.viteFileDeps[i]); }