diff --git "a/demo/ort-phi3/dist/esm/ort.min.js" "b/demo/ort-phi3/dist/esm/ort.min.js" new file mode 100644--- /dev/null +++ "b/demo/ort-phi3/dist/esm/ort.min.js" @@ -0,0 +1,1830 @@ +/*! + * ONNX Runtime Web v1.18.0 + * Copyright (c) Microsoft Corporation. All rights reserved. + * Licensed under the MIT License. + */ +var _d=Object.create;var Pn=Object.defineProperty;var Od=Object.getOwnPropertyDescriptor;var Id=Object.getOwnPropertyNames;var Sd=Object.getPrototypeOf,Ad=Object.prototype.hasOwnProperty;var P=(a,t)=>()=>(a&&(t=a(a=0)),t);var de=(a,t)=>()=>(t||a((t={exports:{}}).exports,t),t.exports),Ar=(a,t)=>{for(var o in t)Pn(a,o,{get:t[o],enumerable:!0})},za=(a,t,o,e)=>{if(t&&typeof t=="object"||typeof t=="function")for(let r of Id(t))!Ad.call(a,r)&&r!==o&&Pn(a,r,{get:()=>t[r],enumerable:!(e=Od(t,r))||e.enumerable});return a};var Er=(a,t,o)=>(o=a!=null?_d(Sd(a)):{},za(t||!a||!a.__esModule?Pn(o,"default",{value:a,enumerable:!0}):o,a)),rr=a=>za(Pn({},"__esModule",{value:!0}),a);var Dn,nr,Pr,Ed,Ln,Fn=P(()=>{"use strict";Dn=new Map,nr=[],Pr=(a,t,o)=>{if(t&&typeof t.init=="function"&&typeof t.createInferenceSessionHandler=="function"){let e=Dn.get(a);if(e===void 0)Dn.set(a,{backend:t,priority:o});else{if(e.priority>o)return;if(e.priority===o&&e.backend!==t)throw new Error(`cannot register backend "${a}" using priority ${o}`)}if(o>=0){let r=nr.indexOf(a);r!==-1&&nr.splice(r,1);for(let n=0;n{let t=Dn.get(a);if(!t)return"backend not found.";if(t.initialized)return t.backend;if(t.aborted)return t.error;{let o=!!t.initPromise;try{return o||(t.initPromise=t.backend.init(a)),await t.initPromise,t.initialized=!0,t.backend}catch(e){return o||(t.error=`${e}`,t.aborted=!0),t.error}finally{delete t.initPromise}}},Ln=async a=>{let t=a.executionProviders||[],o=t.map(u=>typeof u=="string"?u:u.name),e=o.length===0?nr:o,r,n=[],s=new Set;for(let u of e){let l=await Ed(u);typeof l=="string"?n.push({name:u,err:l}):(r||(r=l),r===l&&s.add(u))}if(!r)throw new Error(`no available backend found. ERR: ${n.map(u=>`[${u.name}] ${u.err}`).join(", ")}`);for(let{name:u,err:l}of n)o.includes(u)&&console.warn(`removing requested execution provider "${u}" from session options because it is not available: ${l}`);let i=t.filter(u=>s.has(typeof u=="string"?u:u.name));return[r,new Proxy(a,{get:(u,l)=>l==="executionProviders"?i:Reflect.get(u,l)})]}});var Va=P(()=>{"use strict";Fn()});var Wa,Ha=P(()=>{"use strict";Wa="1.18.0"});var qa,at,Vo=P(()=>{"use strict";Ha();qa="warning",at={wasm:{},webgl:{},webgpu:{},versions:{common:Wa},set logLevel(a){if(a!==void 0){if(typeof a!="string"||["verbose","info","warning","error","fatal"].indexOf(a)===-1)throw new Error(`Unsupported logging level: ${a}`);qa=a}},get logLevel(){return qa}};Object.defineProperty(at,"logLevel",{enumerable:!0})});var Z,ja=P(()=>{"use strict";Vo();Z=at});var Ya,Xa,Ka=P(()=>{"use strict";Ya=(a,t)=>{let o=typeof document<"u"?document.createElement("canvas"):new OffscreenCanvas(1,1);o.width=a.dims[3],o.height=a.dims[2];let e=o.getContext("2d");if(e!=null){let r,n;t?.tensorLayout!==void 0&&t.tensorLayout==="NHWC"?(r=a.dims[2],n=a.dims[3]):(r=a.dims[3],n=a.dims[2]);let s=t?.format!==void 0?t.format:"RGB",i=t?.norm,u,l;i===void 0||i.mean===void 0?u=[255,255,255,255]:typeof i.mean=="number"?u=[i.mean,i.mean,i.mean,i.mean]:(u=[i.mean[0],i.mean[1],i.mean[2],0],i.mean[3]!==void 0&&(u[3]=i.mean[3])),i===void 0||i.bias===void 0?l=[0,0,0,0]:typeof i.bias=="number"?l=[i.bias,i.bias,i.bias,i.bias]:(l=[i.bias[0],i.bias[1],i.bias[2],0],i.bias[3]!==void 0&&(l[3]=i.bias[3]));let f=n*r,p=0,d=f,T=f*2,v=-1;s==="RGBA"?(p=0,d=f,T=f*2,v=f*3):s==="RGB"?(p=0,d=f,T=f*2):s==="RBG"&&(p=0,T=f,d=f*2);for(let w=0;w{let o=typeof document<"u"?document.createElement("canvas").getContext("2d"):new OffscreenCanvas(1,1).getContext("2d"),e;if(o!=null){let r,n,s;t?.tensorLayout!==void 0&&t.tensorLayout==="NHWC"?(r=a.dims[2],n=a.dims[1],s=a.dims[3]):(r=a.dims[3],n=a.dims[2],s=a.dims[1]);let i=t!==void 0&&t.format!==void 0?t.format:"RGB",u=t?.norm,l,f;u===void 0||u.mean===void 0?l=[255,255,255,255]:typeof u.mean=="number"?l=[u.mean,u.mean,u.mean,u.mean]:(l=[u.mean[0],u.mean[1],u.mean[2],255],u.mean[3]!==void 0&&(l[3]=u.mean[3])),u===void 0||u.bias===void 0?f=[0,0,0,0]:typeof u.bias=="number"?f=[u.bias,u.bias,u.bias,u.bias]:(f=[u.bias[0],u.bias[1],u.bias[2],0],u.bias[3]!==void 0&&(f[3]=u.bias[3]));let p=n*r;if(t!==void 0&&(t.format!==void 0&&s===4&&t.format!=="RGBA"||s===3&&t.format!=="RGB"&&t.format!=="BGR"))throw new Error("Tensor format doesn't match input tensor dims");let d=4,T=0,v=1,w=2,I=3,L=0,F=p,C=p*2,X=-1;i==="RGBA"?(L=0,F=p,C=p*2,X=p*3):i==="RGB"?(L=0,F=p,C=p*2):i==="RBG"&&(L=0,C=p,F=p*2),e=o.createImageData(r,n);for(let N=0;N{"use strict";Cn();Wo=(a,t)=>{if(a===void 0)throw new Error("Image buffer must be defined");if(t.height===void 0||t.width===void 0)throw new Error("Image height and width must be defined");if(t.tensorLayout==="NHWC")throw new Error("NHWC Tensor layout is not supported yet");let{height:o,width:e}=t,r=t.norm??{mean:255,bias:0},n,s;typeof r.mean=="number"?n=[r.mean,r.mean,r.mean,r.mean]:n=[r.mean[0],r.mean[1],r.mean[2],r.mean[3]??255],typeof r.bias=="number"?s=[r.bias,r.bias,r.bias,r.bias]:s=[r.bias[0],r.bias[1],r.bias[2],r.bias[3]??0];let i=t.format!==void 0?t.format:"RGBA",u=t.tensorFormat!==void 0&&t.tensorFormat!==void 0?t.tensorFormat:"RGB",l=o*e,f=u==="RGBA"?new Float32Array(l*4):new Float32Array(l*3),p=4,d=0,T=1,v=2,w=3,I=0,L=l,F=l*2,C=-1;i==="RGB"&&(p=3,d=0,T=1,v=2,w=-1),u==="RGBA"?C=l*3:u==="RBG"?(I=0,F=l,L=l*2):u==="BGR"&&(F=0,L=l,I=l*2);for(let N=0;N{let o=typeof HTMLImageElement<"u"&&a instanceof HTMLImageElement,e=typeof ImageData<"u"&&a instanceof ImageData,r=typeof ImageBitmap<"u"&&a instanceof ImageBitmap,n=typeof a=="string",s,i=t??{},u=()=>{if(typeof document<"u")return document.createElement("canvas");if(typeof OffscreenCanvas<"u")return new OffscreenCanvas(1,1);throw new Error("Canvas is not supported")},l=f=>f instanceof HTMLCanvasElement||f instanceof OffscreenCanvas?f.getContext("2d"):null;if(o){let f=u();f.width=a.width,f.height=a.height;let p=l(f);if(p!=null){let d=a.height,T=a.width;if(t!==void 0&&t.resizedHeight!==void 0&&t.resizedWidth!==void 0&&(d=t.resizedHeight,T=t.resizedWidth),t!==void 0){if(i=t,t.tensorFormat!==void 0)throw new Error("Image input config format must be RGBA for HTMLImageElement");i.tensorFormat="RGBA",i.height=d,i.width=T}else i.tensorFormat="RGBA",i.height=d,i.width=T;p.drawImage(a,0,0),s=p.getImageData(0,0,T,d).data}else throw new Error("Can not access image data")}else if(e){let f,p;if(t!==void 0&&t.resizedWidth!==void 0&&t.resizedHeight!==void 0?(f=t.resizedHeight,p=t.resizedWidth):(f=a.height,p=a.width),t!==void 0&&(i=t),i.format="RGBA",i.height=f,i.width=p,t!==void 0){let d=u();d.width=p,d.height=f;let T=l(d);if(T!=null)T.putImageData(a,0,0),s=T.getImageData(0,0,p,f).data;else throw new Error("Can not access image data")}else s=a.data}else if(r){if(t===void 0)throw new Error("Please provide image config with format for Imagebitmap");let f=u();f.width=a.width,f.height=a.height;let p=l(f);if(p!=null){let d=a.height,T=a.width;return p.drawImage(a,0,0,T,d),s=p.getImageData(0,0,T,d).data,i.height=d,i.width=T,Wo(s,i)}else throw new Error("Can not access image data")}else{if(n)return new Promise((f,p)=>{let d=u(),T=l(d);if(!a||!T)return p();let v=new Image;v.crossOrigin="Anonymous",v.src=a,v.onload=()=>{d.width=v.width,d.height=v.height,T.drawImage(v,0,0,d.width,d.height);let w=T.getImageData(0,0,d.width,d.height);i.height=d.height,i.width=d.width,f(Wo(w.data,i))}});throw new Error("Input data provided is not supported - aborted tensor creation")}if(s!==void 0)return Wo(s,i);throw new Error("Input data provided is not supported - aborted tensor creation")},Za=(a,t)=>{let{width:o,height:e,download:r,dispose:n}=t,s=[1,e,o,4];return new Xe({location:"texture",type:"float32",texture:a,dims:s,download:r,dispose:n})},Qa=(a,t)=>{let{dataType:o,dims:e,download:r,dispose:n}=t;return new Xe({location:"gpu-buffer",type:o??"float32",gpuBuffer:a,dims:e,download:r,dispose:n})},es=(a,t,o)=>new Xe({location:"cpu-pinned",type:a,data:t,dims:o??[t.length]})});var or,nn,rs,ns,os=P(()=>{"use strict";or=new Map([["float32",Float32Array],["uint8",Uint8Array],["int8",Int8Array],["uint16",Uint16Array],["int16",Int16Array],["int32",Int32Array],["bool",Uint8Array],["float64",Float64Array],["uint32",Uint32Array]]),nn=new Map([[Float32Array,"float32"],[Uint8Array,"uint8"],[Int8Array,"int8"],[Uint16Array,"uint16"],[Int16Array,"int16"],[Int32Array,"int32"],[Float64Array,"float64"],[Uint32Array,"uint32"]]),rs=!1,ns=()=>{if(!rs){rs=!0;let a=typeof BigInt64Array<"u"&&BigInt64Array.from,t=typeof BigUint64Array<"u"&&BigUint64Array.from,o=typeof Float16Array<"u"&&Float16Array.from;a&&(or.set("int64",BigInt64Array),nn.set(BigInt64Array,"int64")),t&&(or.set("uint64",BigUint64Array),nn.set(BigUint64Array,"uint64")),o?(or.set("float16",Float16Array),nn.set(Float16Array,"float16")):or.set("float16",Uint16Array)}}});var is,as,ss=P(()=>{"use strict";Cn();is=a=>{let t=1;for(let o=0;o{switch(a.location){case"cpu":return new Xe(a.type,a.data,t);case"cpu-pinned":return new Xe({location:"cpu-pinned",data:a.data,type:a.type,dims:t});case"texture":return new Xe({location:"texture",texture:a.texture,type:a.type,dims:t});case"gpu-buffer":return new Xe({location:"gpu-buffer",gpuBuffer:a.gpuBuffer,type:a.type,dims:t});default:throw new Error(`tensorReshape: tensor location ${a.location} is not supported`)}}});var Xe,Cn=P(()=>{"use strict";Ka();ts();os();ss();Xe=class{constructor(t,o,e){ns();let r,n;if(typeof t=="object"&&"location"in t)switch(this.dataLocation=t.location,r=t.type,n=t.dims,t.location){case"cpu-pinned":{let i=or.get(r);if(!i)throw new TypeError(`unsupported type "${r}" to create tensor from pinned buffer`);if(!(t.data instanceof i))throw new TypeError(`buffer should be of type ${i.name}`);this.cpuData=t.data;break}case"texture":{if(r!=="float32")throw new TypeError(`unsupported type "${r}" to create tensor from texture`);this.gpuTextureData=t.texture,this.downloader=t.download,this.disposer=t.dispose;break}case"gpu-buffer":{if(r!=="float32"&&r!=="float16"&&r!=="int32"&&r!=="int64"&&r!=="uint32"&&r!=="uint8"&&r!=="bool")throw new TypeError(`unsupported type "${r}" 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 i,u;if(typeof t=="string")if(r=t,u=e,t==="string"){if(!Array.isArray(o))throw new TypeError("A string tensor's data must be a string array.");i=o}else{let l=or.get(t);if(l===void 0)throw new TypeError(`Unsupported tensor type: ${t}.`);if(Array.isArray(o)){if(t==="float16"&&l===Uint16Array)throw new TypeError("Creating a float16 tensor from number array is not supported. Please use Uint16Array as data.");t==="uint64"||t==="int64"?i=l.from(o,BigInt):i=l.from(o)}else if(o instanceof l)i=o;else throw new TypeError(`A ${r} tensor's data must be type of ${l}`)}else if(u=o,Array.isArray(t)){if(t.length===0)throw new TypeError("Tensor type cannot be inferred from an empty array.");let l=typeof t[0];if(l==="string")r="string",i=t;else if(l==="boolean")r="bool",i=Uint8Array.from(t);else throw new TypeError(`Invalid element type of data array: ${l}.`)}else{let l=nn.get(t.constructor);if(l===void 0)throw new TypeError(`Unsupported type for tensor data: ${t.constructor}.`);r=l,i=t}if(u===void 0)u=[i.length];else if(!Array.isArray(u))throw new TypeError("A tensor's dims must be a number array");n=u,this.cpuData=i,this.dataLocation="cpu"}let s=is(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=r,this.dims=n,this.size=s}static async fromImage(t,o){return Ja(t,o)}static fromTexture(t,o){return Za(t,o)}static fromGpuBuffer(t,o){return Qa(t,o)}static fromPinnedBuffer(t,o,e){return es(t,o,e)}toDataURL(t){return Ya(this,t)}toImageData(t){return Xa(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 o=await this.downloader();return this.downloader=void 0,this.dataLocation="cpu",this.cpuData=o,t&&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(t){if(this.ensureValid(),this.downloader||this.disposer)throw new Error("Cannot reshape a tensor that owns GPU resource.");return as(this,t)}}});var Me,kn=P(()=>{"use strict";Cn();Me=Xe});var us,ls,ir,ar,Ho=P(()=>{"use strict";Vo();us=(a,t)=>{(typeof at.trace>"u"?!at.wasm.trace:!at.trace)||console.timeStamp(`${a}::ORT::${t}`)},ls=(a,t)=>{let o=new Error().stack?.split(/\r\n|\r|\n/g)||[],e=!1;for(let r=0;r{(typeof at.trace>"u"?!at.wasm.trace:!at.trace)||ls("BEGIN",a)},ar=a=>{(typeof at.trace>"u"?!at.wasm.trace:!at.trace)||ls("END",a)}});var Bn,fs=P(()=>{"use strict";Fn();kn();Ho();Bn=class a{constructor(t){this.handler=t}async run(t,o,e){ir();let r={},n={};if(typeof t!="object"||t===null||t instanceof Me||Array.isArray(t))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 Me)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 l of o){if(typeof l!="string")throw new TypeError("'fetches' must be a string array or an object.");if(this.outputNames.indexOf(l)===-1)throw new RangeError(`'fetches' contains invalid output name: ${l}.`);r[l]=null}if(typeof e=="object"&&e!==null)n=e;else if(typeof e<"u")throw new TypeError("'options' must be an object.")}else{let l=!1,f=Object.getOwnPropertyNames(o);for(let p of this.outputNames)if(f.indexOf(p)!==-1){let d=o[p];(d===null||d instanceof Me)&&(l=!0,s=!1,r[p]=d)}if(l){if(typeof e=="object"&&e!==null)n=e;else if(typeof e<"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 l of this.inputNames)if(typeof t[l]>"u")throw new Error(`input '${l}' is missing in 'feeds'.`);if(s)for(let l of this.outputNames)r[l]=null;let i=await this.handler.run(t,r,n),u={};for(let l in i)if(Object.hasOwnProperty.call(i,l)){let f=i[l];f instanceof Me?u[l]=f:u[l]=new Me(f.type,f.data,f.dims)}return ar(),u}async release(){return this.handler.dispose()}static async create(t,o,e,r){ir();let n,s={};if(typeof t=="string"){if(n=t,typeof o=="object"&&o!==null)s=o;else if(typeof o<"u")throw new TypeError("'options' must be an object.")}else if(t instanceof Uint8Array){if(n=t,typeof o=="object"&&o!==null)s=o;else if(typeof o<"u")throw new TypeError("'options' must be an object.")}else if(t instanceof ArrayBuffer||typeof SharedArrayBuffer<"u"&&t instanceof SharedArrayBuffer){let f=t,p=0,d=t.byteLength;if(typeof o=="object"&&o!==null)s=o;else if(typeof o=="number"){if(p=o,!Number.isSafeInteger(p))throw new RangeError("'byteOffset' must be an integer.");if(p<0||p>=f.byteLength)throw new RangeError(`'byteOffset' is out of range [0, ${f.byteLength}).`);if(d=t.byteLength-p,typeof e=="number"){if(d=e,!Number.isSafeInteger(d))throw new RangeError("'byteLength' must be an integer.");if(d<=0||p+d>f.byteLength)throw new RangeError(`'byteLength' is out of range (0, ${f.byteLength-p}].`);if(typeof r=="object"&&r!==null)s=r;else if(typeof r<"u")throw new TypeError("'options' must be an object.")}else if(typeof e<"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(f,p,d)}else throw new TypeError("Unexpected argument[0]: must be 'path' or 'buffer'.");let[i,u]=await Ln(s),l=await i.createInferenceSessionHandler(n,u);return ar(),new a(l)}startProfiling(){this.handler.startProfiling()}endProfiling(){this.handler.endProfiling()}get inputNames(){return this.handler.inputNames}get outputNames(){return this.handler.outputNames}}});var Pd,cs=P(()=>{"use strict";fs();Pd=Bn});var ps=P(()=>{"use strict"});var ds=P(()=>{"use strict"});var hs=P(()=>{"use strict"});var ms=P(()=>{"use strict"});var Dd,$n,bs=P(()=>{"use strict";Fn();kn();Dd="Training backend could not be resolved. Make sure you're using the correct configuration & WebAssembly files.",$n=class a{constructor(t,o,e){this.handler=t,this.hasOptimizerModel=o,this.hasEvalModel=e}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(t,o){let e=t.evalModel||"",r=t.optimizerModel||"",n=o||{},[s,i]=await Ln(n);if(s.createTrainingSessionHandler){let u=await s.createTrainingSessionHandler(t.checkpointState,t.trainModel,e,r,i);return new a(u,!!t.optimizerModel,!!t.evalModel)}else throw new Error(Dd)}typeNarrowingForRunStep(t,o,e,r,n){let s={},i={};if(typeof e!="object"||e===null||e instanceof Me||Array.isArray(e))throw new TypeError("'feeds' must be an object that use input names as keys and OnnxValue as corresponding values.");let u=!0;if(typeof r=="object"){if(r===null)throw new TypeError("Unexpected argument[1]: cannot be null.");if(r instanceof Me)throw new TypeError("'fetches' cannot be a Tensor");if(Array.isArray(r)){if(r.length===0)throw new TypeError("'fetches' cannot be an empty array.");u=!1;for(let l of r){if(typeof l!="string")throw new TypeError("'fetches' must be a string array or an object.");if(o.indexOf(l)===-1)throw new RangeError(`'fetches' contains invalid output name: ${l}.`);s[l]=null}if(typeof n=="object"&&n!==null)i=n;else if(typeof n<"u")throw new TypeError("'options' must be an object.")}else{let l=!1,f=Object.getOwnPropertyNames(r);for(let p of o)if(f.indexOf(p)!==-1){let d=r[p];(d===null||d instanceof Me)&&(l=!0,u=!1,s[p]=d)}if(l){if(typeof n=="object"&&n!==null)i=n;else if(typeof n<"u")throw new TypeError("'options' must be an object.")}else i=r}}else if(typeof r<"u")throw new TypeError("Unexpected argument[1]: must be 'fetches' or 'options'.");for(let l of t)if(typeof e[l]>"u")throw new Error(`input '${l}' is missing in 'feeds'.`);if(u)for(let l of o)s[l]=null;return[s,i]}convertHandlerReturnTypeToMapOfTensors(t){let o={};for(let e in t)if(Object.hasOwnProperty.call(t,e)){let r=t[e];r instanceof Me?o[e]=r:o[e]=new Me(r.type,r.data,r.dims)}return o}async lazyResetGrad(){await this.handler.lazyResetGrad()}async runTrainStep(t,o,e){let[r,n]=this.typeNarrowingForRunStep(this.trainingInputNames,this.trainingOutputNames,t,o,e),s=await this.handler.runTrainStep(t,r,n);return this.convertHandlerReturnTypeToMapOfTensors(s)}async runOptimizerStep(t){if(this.hasOptimizerModel)await this.handler.runOptimizerStep(t||{});else throw new Error("This TrainingSession has no OptimizerModel loaded.")}async runEvalStep(t,o,e){if(this.hasEvalModel){let[r,n]=this.typeNarrowingForRunStep(this.evalInputNames,this.evalOutputNames,t,o,e),s=await this.handler.runEvalStep(t,r,n);return this.convertHandlerReturnTypeToMapOfTensors(s)}else throw new Error("This TrainingSession has no EvalModel loaded.")}async getParametersSize(t=!0){return this.handler.getParametersSize(t)}async loadParametersBuffer(t,o=!0){let e=await this.getParametersSize(o);if(t.length!==4*e)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(t,o)}async getContiguousParameters(t=!0){return this.handler.getContiguousParameters(t)}async release(){return this.handler.dispose()}}});var Ld,gs=P(()=>{"use strict";bs();Ld=$n});var qo={};Ar(qo,{InferenceSession:()=>Pd,TRACE:()=>us,TRACE_FUNC_BEGIN:()=>ir,TRACE_FUNC_END:()=>ar,Tensor:()=>Me,TrainingSession:()=>Ld,env:()=>Z,registerBackend:()=>Pr});var Tt=P(()=>{"use strict";Va();ja();cs();kn();ps();ds();Ho();hs();ms();gs()});function Wt(a,t,o,e){if(t===void 0)return Cd(a);if(o===void 0)Nn(a,t,1);else if(typeof o=="number"&&e===void 0)Nn(a,t,o);else if(typeof o=="string"&&e===void 0)Nn(a,o,1,t);else if(typeof o=="string"&&typeof e=="number")Nn(a,o,e,t);else throw new TypeError("input is valid")}function Cd(a){return{verbose:Wt.verbose.bind(null,a),info:Wt.info.bind(null,a),warning:Wt.warning.bind(null,a),error:Wt.error.bind(null,a),fatal:Wt.fatal.bind(null,a)}}function Nn(a,t,o,e){let r=on[e||""]||on[""];Ts[a]{"use strict";jo=class{log(t,o,e){}},Yo=class{log(t,o,e){console.log(`${this.color(t)} ${e?"\x1B[35m"+e+"\x1B[0m ":""}${o}`)}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},Fd={none:new jo,console:new Yo},xs={provider:"console",minimalSeverity:"warning",logDateTime:!0,logSourceLocation:!1},on={"":xs};(u=>{function a(l,f){u("verbose",l,f)}u.verbose=a;function t(l,f){u("info",l,f)}u.info=t;function o(l,f){u("warning",l,f)}u.warning=o;function e(l,f){u("error",l,f)}u.error=e;function r(l,f){u("fatal",l,f)}u.fatal=r;function n(l){on={},s("",l||{})}u.reset=n;function s(l,f){if(l==="*")n(f);else{let p=on[l]||xs;on[l]={provider:f.provider||p.provider,minimalSeverity:f.minimalSeverity||p.minimalSeverity,logDateTime:f.logDateTime===void 0?p.logDateTime:f.logDateTime,logSourceLocation:f.logSourceLocation===void 0?p.logSourceLocation:f.logSourceLocation}}}u.set=s;function i(l){let f={};l.logLevel&&(f.minimalSeverity=l.logLevel),s("",f)}u.setWithEnv=i})(Wt||={});fe=Wt,Mn=class{constructor(t,o,e,r,n,s){this.category=t;this.name=o;this.startTime=e;this.endCallback=r;this.timer=n;this.ctx=s}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)}},Gn=class{constructor(t,o,e,r){this.category=t;this.name=o;this.startTime=e;this.endTime=r}},Un=class{constructor(t,o,e){this._started=!1;this._flushPointer=0;this._started=!1,this._maxNumberEvents=t===void 0?1e4:t,this._flushBatchSize=o===void 0?10:o,this._flushIntervalInMilliseconds=e===void 0?5e3:e}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=Rn(),this._flushPointer=0}stop(){for(this._started=!1;this._flushPointer{i.then(async f=>{n&&await n.end(),u(f)},async f=>{n&&await n.end(),l(f)})});if(!s&&n){let u=n.end();if(u&&typeof u.then=="function")return new Promise((l,f)=>{u.then(()=>{l(i)},p=>{f(p)})})}return i}begin(t,o,e){if(!this._started)throw new Error("profiler is not started yet");if(e===void 0){let r=Rn();return this.flush(r),new Mn(t,o,r,n=>this.endSync(n))}else{let r=e.beginTimer();return new Mn(t,o,0,async n=>this.end(n),r,e)}}async end(t){let o=await t.checkTimer();this._timingEvents.length=this._flushBatchSize||t-this._flushTime>=this._flushIntervalInMilliseconds){for(let o=this._flushPointer;this._flushPointerperformance.now():Date.now});function ws(a,t,o){for(let e of o){let r=e[0],n=e[1],s=e[2],i=e[3],u=e[4];if(a.opType===r){for(let l of t)if((l.domain===n||l.domain==="ai.onnx"&&n==="")&&kd(l.version,s))return{opImpl:i,opInit:u}}}throw new TypeError(`cannot resolve operator '${a.opType}' with opsets: ${t.map(e=>`${e.domain||"ai.onnx"} v${e.version}`).join(", ")}`)}function kd(a,t){if(t.endsWith("+")){let o=Number.parseInt(t.substring(0,t.length-1),10);return!isNaN(o)&&o<=a}else if(t.split("-").length===2){let o=t.split("-"),e=Number.parseInt(o[0],10),r=Number.parseInt(o[1],10);return!isNaN(e)&&!isNaN(r)&&e<=a&&a<=r}else return Number.parseInt(t,10)===a}var vs=P(()=>{"use strict"});var _s=de(Xo=>{"use strict";Xo.__esModule=!0;var Bd=function(){function a(t){if(!t)throw new TypeError("Invalid argument; `value` has no value.");this.value=a.EMPTY,t&&a.isGuid(t)&&(this.value=t)}return a.isGuid=function(t){var o=t.toString();return t&&(t instanceof a||a.validator.test(o))},a.create=function(){return new a([a.gen(2),a.gen(1),a.gen(1),a.gen(1),a.gen(3)].join("-"))},a.createEmpty=function(){return new a("emptyguid")},a.parse=function(t){return new a(t)},a.raw=function(){return[a.gen(2),a.gen(1),a.gen(1),a.gen(1),a.gen(3)].join("-")},a.gen=function(t){for(var o="",e=0;e>>=0,(r=0<=a&&a<256)&&(e=Ss[a],e)?e:(o=ue(a,0,!0),r&&(Ss[a]=o),o)):(a|=0,(r=-128<=a&&a<128)&&(e=Is[a],e)?e:(o=ue(a,a<0?-1:0,!1),r&&(Is[a]=o),o))}function pt(a,t){if(isNaN(a))return t?Rt:xt;if(t){if(a<0)return Rt;if(a>=Ds)return Cs}else{if(a<=-Es)return tt;if(a+1>=Es)return Fs}return a<0?pt(-a,t).neg():ue(a%Lr|0,a/Lr|0,t)}function ue(a,t,o){return new he(a,t,o)}function Jo(a,t,o){if(a.length===0)throw Error("empty string");if(typeof t=="number"?(o=t,t=!1):t=!!t,a==="NaN"||a==="Infinity"||a==="+Infinity"||a==="-Infinity")return t?Rt:xt;if(o=o||10,o<2||360)throw Error("interior hyphen");if(e===0)return Jo(a.substring(1),t,o).neg();for(var r=pt(zn(o,8)),n=xt,s=0;s{ct=null;try{ct=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{}he.prototype.__isLong__;Object.defineProperty(he.prototype,"__isLong__",{value:!0});he.isLong=He;Is={},Ss={};he.fromInt=sr;he.fromNumber=pt;he.fromBits=ue;zn=Math.pow;he.fromString=Jo;he.fromValue=wt;As=65536,$d=1<<24,Lr=As*As,Ds=Lr*Lr,Es=Ds/2,Ps=sr($d),xt=sr(0);he.ZERO=xt;Rt=sr(0,!0);he.UZERO=Rt;Dr=sr(1);he.ONE=Dr;Ls=sr(1,!0);he.UONE=Ls;Ko=sr(-1);he.NEG_ONE=Ko;Fs=ue(-1,2147483647,!1);he.MAX_VALUE=Fs;Cs=ue(-1,-1,!0);he.MAX_UNSIGNED_VALUE=Cs;tt=ue(0,-2147483648,!1);he.MIN_VALUE=tt;k=he.prototype;k.toInt=function(){return this.unsigned?this.low>>>0:this.low};k.toNumber=function(){return this.unsigned?(this.high>>>0)*Lr+(this.low>>>0):this.high*Lr+(this.low>>>0)};k.toString=function(t){if(t=t||10,t<2||36>>0,f=l.toString(t);if(s=u,s.isZero())return f+i;for(;f.length<6;)f="0"+f;i=""+f+i}};k.getHighBits=function(){return this.high};k.getHighBitsUnsigned=function(){return this.high>>>0};k.getLowBits=function(){return this.low};k.getLowBitsUnsigned=function(){return this.low>>>0};k.getNumBitsAbs=function(){if(this.isNegative())return this.eq(tt)?64:this.neg().getNumBitsAbs();for(var t=this.high!=0?this.high:this.low,o=31;o>0&&!(t&1<=0};k.isOdd=function(){return(this.low&1)===1};k.isEven=function(){return(this.low&1)===0};k.equals=function(t){return He(t)||(t=wt(t)),this.unsigned!==t.unsigned&&this.high>>>31===1&&t.high>>>31===1?!1:this.high===t.high&&this.low===t.low};k.eq=k.equals;k.notEquals=function(t){return!this.eq(t)};k.neq=k.notEquals;k.ne=k.notEquals;k.lessThan=function(t){return this.comp(t)<0};k.lt=k.lessThan;k.lessThanOrEqual=function(t){return this.comp(t)<=0};k.lte=k.lessThanOrEqual;k.le=k.lessThanOrEqual;k.greaterThan=function(t){return this.comp(t)>0};k.gt=k.greaterThan;k.greaterThanOrEqual=function(t){return this.comp(t)>=0};k.gte=k.greaterThanOrEqual;k.ge=k.greaterThanOrEqual;k.compare=function(t){if(He(t)||(t=wt(t)),this.eq(t))return 0;var o=this.isNegative(),e=t.isNegative();return o&&!e?-1:!o&&e?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};k.comp=k.compare;k.negate=function(){return!this.unsigned&&this.eq(tt)?tt:this.not().add(Dr)};k.neg=k.negate;k.add=function(t){He(t)||(t=wt(t));var o=this.high>>>16,e=this.high&65535,r=this.low>>>16,n=this.low&65535,s=t.high>>>16,i=t.high&65535,u=t.low>>>16,l=t.low&65535,f=0,p=0,d=0,T=0;return T+=n+l,d+=T>>>16,T&=65535,d+=r+u,p+=d>>>16,d&=65535,p+=e+i,f+=p>>>16,p&=65535,f+=o+s,f&=65535,ue(d<<16|T,f<<16|p,this.unsigned)};k.subtract=function(t){return He(t)||(t=wt(t)),this.add(t.neg())};k.sub=k.subtract;k.multiply=function(t){if(this.isZero())return this;if(He(t)||(t=wt(t)),ct){var o=ct.mul(this.low,this.high,t.low,t.high);return ue(o,ct.get_high(),this.unsigned)}if(t.isZero())return this.unsigned?Rt:xt;if(this.eq(tt))return t.isOdd()?tt:xt;if(t.eq(tt))return this.isOdd()?tt:xt;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(Ps)&&t.lt(Ps))return pt(this.toNumber()*t.toNumber(),this.unsigned);var e=this.high>>>16,r=this.high&65535,n=this.low>>>16,s=this.low&65535,i=t.high>>>16,u=t.high&65535,l=t.low>>>16,f=t.low&65535,p=0,d=0,T=0,v=0;return v+=s*f,T+=v>>>16,v&=65535,T+=n*f,d+=T>>>16,T&=65535,T+=s*l,d+=T>>>16,T&=65535,d+=r*f,p+=d>>>16,d&=65535,d+=n*l,p+=d>>>16,d&=65535,d+=s*u,p+=d>>>16,d&=65535,p+=e*f+r*l+n*u+s*i,p&=65535,ue(T<<16|v,p<<16|d,this.unsigned)};k.mul=k.multiply;k.divide=function(t){if(He(t)||(t=wt(t)),t.isZero())throw Error("division by zero");if(ct){if(!this.unsigned&&this.high===-2147483648&&t.low===-1&&t.high===-1)return this;var o=(this.unsigned?ct.div_u:ct.div_s)(this.low,this.high,t.low,t.high);return ue(o,ct.get_high(),this.unsigned)}if(this.isZero())return this.unsigned?Rt:xt;var e,r,n;if(this.unsigned){if(t.unsigned||(t=t.toUnsigned()),t.gt(this))return Rt;if(t.gt(this.shru(1)))return Ls;n=Rt}else{if(this.eq(tt)){if(t.eq(Dr)||t.eq(Ko))return tt;if(t.eq(tt))return Dr;var s=this.shr(1);return e=s.div(t).shl(1),e.eq(xt)?t.isNegative()?Dr:Ko:(r=this.sub(t.mul(e)),n=e.add(r.div(t)),n)}else if(t.eq(tt))return this.unsigned?Rt:xt;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();n=xt}for(r=this;r.gte(t);){e=Math.max(1,Math.floor(r.toNumber()/t.toNumber()));for(var i=Math.ceil(Math.log(e)/Math.LN2),u=i<=48?1:zn(2,i-48),l=pt(e),f=l.mul(t);f.isNegative()||f.gt(r);)e-=u,l=pt(e,this.unsigned),f=l.mul(t);l.isZero()&&(l=Dr),n=n.add(l),r=r.sub(f)}return n};k.div=k.divide;k.modulo=function(t){if(He(t)||(t=wt(t)),ct){var o=(this.unsigned?ct.rem_u:ct.rem_s)(this.low,this.high,t.low,t.high);return ue(o,ct.get_high(),this.unsigned)}return this.sub(this.div(t).mul(t))};k.mod=k.modulo;k.rem=k.modulo;k.not=function(){return ue(~this.low,~this.high,this.unsigned)};k.countLeadingZeros=function(){return this.high?Math.clz32(this.high):Math.clz32(this.low)+32};k.clz=k.countLeadingZeros;k.countTrailingZeros=function(){return this.low?Os(this.low):Os(this.high)+32};k.ctz=k.countTrailingZeros;k.and=function(t){return He(t)||(t=wt(t)),ue(this.low&t.low,this.high&t.high,this.unsigned)};k.or=function(t){return He(t)||(t=wt(t)),ue(this.low|t.low,this.high|t.high,this.unsigned)};k.xor=function(t){return He(t)||(t=wt(t)),ue(this.low^t.low,this.high^t.high,this.unsigned)};k.shiftLeft=function(t){return He(t)&&(t=t.toInt()),(t&=63)===0?this:t<32?ue(this.low<>>32-t,this.unsigned):ue(0,this.low<>>t|this.high<<32-t,this.high>>t,this.unsigned):ue(this.high>>t-32,this.high>=0?0:-1,this.unsigned)};k.shr=k.shiftRight;k.shiftRightUnsigned=function(t){return He(t)&&(t=t.toInt()),(t&=63)===0?this:t<32?ue(this.low>>>t|this.high<<32-t,this.high>>>t,this.unsigned):t===32?ue(this.high,0,this.unsigned):ue(this.high>>>t-32,0,this.unsigned)};k.shru=k.shiftRightUnsigned;k.shr_u=k.shiftRightUnsigned;k.rotateLeft=function(t){var o;return He(t)&&(t=t.toInt()),(t&=63)===0?this:t===32?ue(this.high,this.low,this.unsigned):t<32?(o=32-t,ue(this.low<>>o,this.high<>>o,this.unsigned)):(t-=32,o=32-t,ue(this.high<>>o,this.low<>>o,this.unsigned))};k.rotl=k.rotateLeft;k.rotateRight=function(t){var o;return He(t)&&(t=t.toInt()),(t&=63)===0?this:t===32?ue(this.high,this.low,this.unsigned):t<32?(o=32-t,ue(this.high<>>t,this.low<>>t,this.unsigned)):(t-=32,o=32-t,ue(this.low<>>t,this.high<>>t,this.unsigned))};k.rotr=k.rotateRight;k.toSigned=function(){return this.unsigned?ue(this.low,this.high,!1):this};k.toUnsigned=function(){return this.unsigned?this:ue(this.low,this.high,!0)};k.toBytes=function(t){return t?this.toBytesLE():this.toBytesBE()};k.toBytesLE=function(){var t=this.high,o=this.low;return[o&255,o>>>8&255,o>>>16&255,o>>>24,t&255,t>>>8&255,t>>>16&255,t>>>24]};k.toBytesBE=function(){var t=this.high,o=this.low;return[t>>>24,t>>>16&255,t>>>8&255,t&255,o>>>24,o>>>16&255,o>>>8&255,o&255]};he.fromBytes=function(t,o,e){return e?he.fromBytesLE(t,o):he.fromBytesBE(t,o)};he.fromBytesLE=function(t,o){return new he(t[0]|t[1]<<8|t[2]<<16|t[3]<<24,t[4]|t[5]<<8|t[6]<<16|t[7]<<24,o)};he.fromBytesBE=function(t,o){return new he(t[4]<<24|t[5]<<16|t[6]<<8|t[7],t[0]<<24|t[1]<<16|t[2]<<8|t[3],o)};Mt=he});var _,Vn=P(()=>{_={};_.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(a,t){this.low=a|0,this.high=t|0};_.Long.create=function(a,t){return a==0&&t==0?_.Long.ZERO:new _.Long(a,t)};_.Long.prototype.toFloat64=function(){return(this.low>>>0)+this.high*4294967296};_.Long.prototype.equals=function(a){return this.low==a.low&&this.high==a.high};_.Long.ZERO=new _.Long(0,0);_.Builder=function(a){if(a)var t=a;else var t=1024;this.bb=_.ByteBuffer.allocate(t),this.space=t,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(a){this.force_defaults=a};_.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(a,t){a>this.minalign&&(this.minalign=a);for(var o=~(this.bb.capacity()-this.space+t)+1&a-1;this.space=0&&this.vtable[t]==0;t--);for(var o=t+1;t>=0;t--)this.addInt16(this.vtable[t]!=0?a-this.vtable[t]:0);var e=2;this.addInt16(a-this.object_start);var r=(o+e)*_.SIZEOF_SHORT;this.addInt16(r);var n=0,s=this.space;e:for(t=0;t=0;n--)this.writeInt8(r.charCodeAt(n))}this.prep(this.minalign,_.SIZEOF_INT+e),this.addOffset(a),e&&this.addInt32(this.bb.capacity()-this.space),this.bb.setPosition(this.space)};_.Builder.prototype.finishSizePrefixed=function(a,t){this.finish(a,t,!0)};_.Builder.prototype.requiredField=function(a,t){var o=this.bb.capacity()-a,e=o-this.bb.readInt32(o),r=this.bb.readInt16(e+t)!=0;if(!r)throw new Error("FlatBuffers: field "+t+" must be set")};_.Builder.prototype.startVector=function(a,t,o){this.notNested(),this.vector_num_elems=t,this.prep(_.SIZEOF_INT,a*t),this.prep(o,a*t)};_.Builder.prototype.endVector=function(){return this.writeInt32(this.vector_num_elems),this.offset()};_.Builder.prototype.createString=function(a){if(a instanceof Uint8Array)var t=a;else for(var t=[],o=0;o=56320)e=r;else{var n=a.charCodeAt(o++);e=(r<<10)+n+(65536-56623104-56320)}e<128?t.push(e):(e<2048?t.push(e>>6&31|192):(e<65536?t.push(e>>12&15|224):t.push(e>>18&7|240,e>>12&63|128),t.push(e>>6&63|128)),t.push(e&63|128))}this.addInt8(0),this.startVector(1,t.length,1),this.bb.setPosition(this.space-=t.length);for(var o=0,s=this.space,i=this.bb.bytes();o>24};_.ByteBuffer.prototype.readUint8=function(a){return this.bytes_[a]};_.ByteBuffer.prototype.readInt16=function(a){return this.readUint16(a)<<16>>16};_.ByteBuffer.prototype.readUint16=function(a){return this.bytes_[a]|this.bytes_[a+1]<<8};_.ByteBuffer.prototype.readInt32=function(a){return this.bytes_[a]|this.bytes_[a+1]<<8|this.bytes_[a+2]<<16|this.bytes_[a+3]<<24};_.ByteBuffer.prototype.readUint32=function(a){return this.readInt32(a)>>>0};_.ByteBuffer.prototype.readInt64=function(a){return new _.Long(this.readInt32(a),this.readInt32(a+4))};_.ByteBuffer.prototype.readUint64=function(a){return new _.Long(this.readUint32(a),this.readUint32(a+4))};_.ByteBuffer.prototype.readFloat32=function(a){return _.int32[0]=this.readInt32(a),_.float32[0]};_.ByteBuffer.prototype.readFloat64=function(a){return _.int32[_.isLittleEndian?0:1]=this.readInt32(a),_.int32[_.isLittleEndian?1:0]=this.readInt32(a+4),_.float64[0]};_.ByteBuffer.prototype.writeInt8=function(a,t){this.bytes_[a]=t};_.ByteBuffer.prototype.writeUint8=function(a,t){this.bytes_[a]=t};_.ByteBuffer.prototype.writeInt16=function(a,t){this.bytes_[a]=t,this.bytes_[a+1]=t>>8};_.ByteBuffer.prototype.writeUint16=function(a,t){this.bytes_[a]=t,this.bytes_[a+1]=t>>8};_.ByteBuffer.prototype.writeInt32=function(a,t){this.bytes_[a]=t,this.bytes_[a+1]=t>>8,this.bytes_[a+2]=t>>16,this.bytes_[a+3]=t>>24};_.ByteBuffer.prototype.writeUint32=function(a,t){this.bytes_[a]=t,this.bytes_[a+1]=t>>8,this.bytes_[a+2]=t>>16,this.bytes_[a+3]=t>>24};_.ByteBuffer.prototype.writeInt64=function(a,t){this.writeInt32(a,t.low),this.writeInt32(a+4,t.high)};_.ByteBuffer.prototype.writeUint64=function(a,t){this.writeUint32(a,t.low),this.writeUint32(a+4,t.high)};_.ByteBuffer.prototype.writeFloat32=function(a,t){_.float32[0]=t,this.writeInt32(a,_.int32[0])};_.ByteBuffer.prototype.writeFloat64=function(a,t){_.float64[0]=t,this.writeInt32(a,_.int32[_.isLittleEndian?0:1]),this.writeInt32(a+4,_.int32[_.isLittleEndian?1:0])};_.ByteBuffer.prototype.getBufferIdentifier=function(){if(this.bytes_.length>10)+55296,(n&1024-1)+56320))}return e};_.ByteBuffer.prototype.__indirect=function(a){return a+this.readInt32(a)};_.ByteBuffer.prototype.__vector=function(a){return a+this.readInt32(a)+_.SIZEOF_INT};_.ByteBuffer.prototype.__vector_len=function(a){return this.readInt32(a+this.readInt32(a))};_.ByteBuffer.prototype.__has_identifier=function(a){if(a.length!=_.FILE_IDENTIFIER_LENGTH)throw new Error("FlatBuffers: file identifier must be length "+_.FILE_IDENTIFIER_LENGTH);for(var t=0;t<_.FILE_IDENTIFIER_LENGTH;t++)if(a.charCodeAt(t)!=this.readInt8(this.position_+_.SIZEOF_INT+t))return!1;return!0};_.ByteBuffer.prototype.createLong=function(a,t){return _.Long.create(a,t)}});var H,an=P(()=>{"use strict";Vn();(t=>{let a;(e=>{let o;(n=>{let r;(C=>(C[C.UNDEFINED=0]="UNDEFINED",C[C.FLOAT=1]="FLOAT",C[C.INT=2]="INT",C[C.STRING=3]="STRING",C[C.TENSOR=4]="TENSOR",C[C.GRAPH=5]="GRAPH",C[C.FLOATS=6]="FLOATS",C[C.INTS=7]="INTS",C[C.STRINGS=8]="STRINGS",C[C.TENSORS=9]="TENSORS",C[C.GRAPHS=10]="GRAPHS",C[C.SPARSE_TENSOR=11]="SPARSE_TENSOR",C[C.SPARSE_TENSORS=12]="SPARSE_TENSORS"))(r=n.AttributeType||={})})(o=e.fbs||={})})(a=t.experimental||={})})(H||={});(t=>{let a;(e=>{let o;(n=>{let r;(l=>(l[l.UNKNOWN=0]="UNKNOWN",l[l.VALUE=1]="VALUE",l[l.PARAM=2]="PARAM"))(r=n.DimensionValueType||={})})(o=e.fbs||={})})(a=t.experimental||={})})(H||={});(t=>{let a;(e=>{let o;(n=>{let r;(W=>(W[W.UNDEFINED=0]="UNDEFINED",W[W.FLOAT=1]="FLOAT",W[W.UINT8=2]="UINT8",W[W.INT8=3]="INT8",W[W.UINT16=4]="UINT16",W[W.INT16=5]="INT16",W[W.INT32=6]="INT32",W[W.INT64=7]="INT64",W[W.STRING=8]="STRING",W[W.BOOL=9]="BOOL",W[W.FLOAT16=10]="FLOAT16",W[W.DOUBLE=11]="DOUBLE",W[W.UINT32=12]="UINT32",W[W.UINT64=13]="UINT64",W[W.COMPLEX64=14]="COMPLEX64",W[W.COMPLEX128=15]="COMPLEX128",W[W.BFLOAT16=16]="BFLOAT16",W[W.FLOAT8E4M3FN=17]="FLOAT8E4M3FN",W[W.FLOAT8E4M3FNUZ=18]="FLOAT8E4M3FNUZ",W[W.FLOAT8E5M2=19]="FLOAT8E5M2",W[W.FLOAT8E5M2FNUZ=20]="FLOAT8E5M2FNUZ"))(r=n.TensorDataType||={})})(o=e.fbs||={})})(a=t.experimental||={})})(H||={});(t=>{let a;(e=>{let o;(n=>{let r;(u=>(u[u.Primitive=0]="Primitive",u[u.Fused=1]="Fused"))(r=n.NodeType||={})})(o=e.fbs||={})})(a=t.experimental||={})})(H||={});(t=>{let a;(e=>{let o;(n=>{let r;(f=>(f[f.NONE=0]="NONE",f[f.tensor_type=1]="tensor_type",f[f.sequence_type=2]="sequence_type",f[f.map_type=3]="map_type"))(r=n.TypeInfoValue||={})})(o=e.fbs||={})})(a=t.experimental||={})})(H||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsShape(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsShape(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}dim(i,u){let l=this.bb.__offset(this.bb_pos,4);return l?(u||new t.experimental.fbs.Dimension).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+l)+i*4),this.bb):null}dimLength(){let i=this.bb.__offset(this.bb_pos,4);return i?this.bb.__vector_len(this.bb_pos+i):0}static startShape(i){i.startObject(1)}static addDim(i,u){i.addFieldOffset(0,u,0)}static createDimVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addOffset(u[l]);return i.endVector()}static startDimVector(i,u){i.startVector(4,u,4)}static endShape(i){return i.endObject()}static createShape(i,u){return r.startShape(i),r.addDim(i,u),r.endShape(i)}}n.Shape=r})(o=e.fbs||={})})(a=t.experimental||={})})(H||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsDimension(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsDimension(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}value(i){let u=this.bb.__offset(this.bb_pos,4);return u?(i||new t.experimental.fbs.DimensionValue).__init(this.bb.__indirect(this.bb_pos+u),this.bb):null}denotation(i){let u=this.bb.__offset(this.bb_pos,6);return u?this.bb.__string(this.bb_pos+u,i):null}static startDimension(i){i.startObject(2)}static addValue(i,u){i.addFieldOffset(0,u,0)}static addDenotation(i,u){i.addFieldOffset(1,u,0)}static endDimension(i){return i.endObject()}static createDimension(i,u,l){return r.startDimension(i),r.addValue(i,u),r.addDenotation(i,l),r.endDimension(i)}}n.Dimension=r})(o=e.fbs||={})})(a=t.experimental||={})})(H||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsDimensionValue(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsDimensionValue(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}dimType(){let i=this.bb.__offset(this.bb_pos,4);return i?this.bb.readInt8(this.bb_pos+i):0}dimValue(){let i=this.bb.__offset(this.bb_pos,6);return i?this.bb.readInt64(this.bb_pos+i):this.bb.createLong(0,0)}dimParam(i){let u=this.bb.__offset(this.bb_pos,8);return u?this.bb.__string(this.bb_pos+u,i):null}static startDimensionValue(i){i.startObject(3)}static addDimType(i,u){i.addFieldInt8(0,u,0)}static addDimValue(i,u){i.addFieldInt64(1,u,i.createLong(0,0))}static addDimParam(i,u){i.addFieldOffset(2,u,0)}static endDimensionValue(i){return i.endObject()}static createDimensionValue(i,u,l,f){return r.startDimensionValue(i),r.addDimType(i,u),r.addDimValue(i,l),r.addDimParam(i,f),r.endDimensionValue(i)}}n.DimensionValue=r})(o=e.fbs||={})})(a=t.experimental||={})})(H||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsTensorTypeAndShape(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsTensorTypeAndShape(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}elemType(){let i=this.bb.__offset(this.bb_pos,4);return i?this.bb.readInt32(this.bb_pos+i):0}shape(i){let u=this.bb.__offset(this.bb_pos,6);return u?(i||new t.experimental.fbs.Shape).__init(this.bb.__indirect(this.bb_pos+u),this.bb):null}static startTensorTypeAndShape(i){i.startObject(2)}static addElemType(i,u){i.addFieldInt32(0,u,0)}static addShape(i,u){i.addFieldOffset(1,u,0)}static endTensorTypeAndShape(i){return i.endObject()}static createTensorTypeAndShape(i,u,l){return r.startTensorTypeAndShape(i),r.addElemType(i,u),r.addShape(i,l),r.endTensorTypeAndShape(i)}}n.TensorTypeAndShape=r})(o=e.fbs||={})})(a=t.experimental||={})})(H||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsMapType(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsMapType(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}keyType(){let i=this.bb.__offset(this.bb_pos,4);return i?this.bb.readInt32(this.bb_pos+i):0}valueType(i){let u=this.bb.__offset(this.bb_pos,6);return u?(i||new t.experimental.fbs.TypeInfo).__init(this.bb.__indirect(this.bb_pos+u),this.bb):null}static startMapType(i){i.startObject(2)}static addKeyType(i,u){i.addFieldInt32(0,u,0)}static addValueType(i,u){i.addFieldOffset(1,u,0)}static endMapType(i){return i.endObject()}static createMapType(i,u,l){return r.startMapType(i),r.addKeyType(i,u),r.addValueType(i,l),r.endMapType(i)}}n.MapType=r})(o=e.fbs||={})})(a=t.experimental||={})})(H||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsSequenceType(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsSequenceType(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}elemType(i){let u=this.bb.__offset(this.bb_pos,4);return u?(i||new t.experimental.fbs.TypeInfo).__init(this.bb.__indirect(this.bb_pos+u),this.bb):null}static startSequenceType(i){i.startObject(1)}static addElemType(i,u){i.addFieldOffset(0,u,0)}static endSequenceType(i){return i.endObject()}static createSequenceType(i,u){return r.startSequenceType(i),r.addElemType(i,u),r.endSequenceType(i)}}n.SequenceType=r})(o=e.fbs||={})})(a=t.experimental||={})})(H||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,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(i,u,l,f){return i.prep(4,12),i.writeInt32(f),i.writeInt32(l),i.writeInt32(u),i.offset()}}n.EdgeEnd=r})(o=e.fbs||={})})(a=t.experimental||={})})(H||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsNodeEdge(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsNodeEdge(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}nodeIndex(){let i=this.bb.__offset(this.bb_pos,4);return i?this.bb.readUint32(this.bb_pos+i):0}inputEdges(i,u){let l=this.bb.__offset(this.bb_pos,6);return l?(u||new t.experimental.fbs.EdgeEnd).__init(this.bb.__vector(this.bb_pos+l)+i*12,this.bb):null}inputEdgesLength(){let i=this.bb.__offset(this.bb_pos,6);return i?this.bb.__vector_len(this.bb_pos+i):0}outputEdges(i,u){let l=this.bb.__offset(this.bb_pos,8);return l?(u||new t.experimental.fbs.EdgeEnd).__init(this.bb.__vector(this.bb_pos+l)+i*12,this.bb):null}outputEdgesLength(){let i=this.bb.__offset(this.bb_pos,8);return i?this.bb.__vector_len(this.bb_pos+i):0}static startNodeEdge(i){i.startObject(3)}static addNodeIndex(i,u){i.addFieldInt32(0,u,0)}static addInputEdges(i,u){i.addFieldOffset(1,u,0)}static startInputEdgesVector(i,u){i.startVector(12,u,4)}static addOutputEdges(i,u){i.addFieldOffset(2,u,0)}static startOutputEdgesVector(i,u){i.startVector(12,u,4)}static endNodeEdge(i){return i.endObject()}static createNodeEdge(i,u,l,f){return r.startNodeEdge(i),r.addNodeIndex(i,u),r.addInputEdges(i,l),r.addOutputEdges(i,f),r.endNodeEdge(i)}}n.NodeEdge=r})(o=e.fbs||={})})(a=t.experimental||={})})(H||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsNode(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsNode(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}name(i){let u=this.bb.__offset(this.bb_pos,4);return u?this.bb.__string(this.bb_pos+u,i):null}docString(i){let u=this.bb.__offset(this.bb_pos,6);return u?this.bb.__string(this.bb_pos+u,i):null}domain(i){let u=this.bb.__offset(this.bb_pos,8);return u?this.bb.__string(this.bb_pos+u,i):null}sinceVersion(){let i=this.bb.__offset(this.bb_pos,10);return i?this.bb.readInt32(this.bb_pos+i):0}index(){let i=this.bb.__offset(this.bb_pos,12);return i?this.bb.readUint32(this.bb_pos+i):0}opType(i){let u=this.bb.__offset(this.bb_pos,14);return u?this.bb.__string(this.bb_pos+u,i):null}type(){let i=this.bb.__offset(this.bb_pos,16);return i?this.bb.readInt32(this.bb_pos+i):0}executionProviderType(i){let u=this.bb.__offset(this.bb_pos,18);return u?this.bb.__string(this.bb_pos+u,i):null}inputs(i,u){let l=this.bb.__offset(this.bb_pos,20);return l?this.bb.__string(this.bb.__vector(this.bb_pos+l)+i*4,u):null}inputsLength(){let i=this.bb.__offset(this.bb_pos,20);return i?this.bb.__vector_len(this.bb_pos+i):0}outputs(i,u){let l=this.bb.__offset(this.bb_pos,22);return l?this.bb.__string(this.bb.__vector(this.bb_pos+l)+i*4,u):null}outputsLength(){let i=this.bb.__offset(this.bb_pos,22);return i?this.bb.__vector_len(this.bb_pos+i):0}attributes(i,u){let l=this.bb.__offset(this.bb_pos,24);return l?(u||new t.experimental.fbs.Attribute).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+l)+i*4),this.bb):null}attributesLength(){let i=this.bb.__offset(this.bb_pos,24);return i?this.bb.__vector_len(this.bb_pos+i):0}inputArgCounts(i){let u=this.bb.__offset(this.bb_pos,26);return u?this.bb.readInt32(this.bb.__vector(this.bb_pos+u)+i*4):0}inputArgCountsLength(){let i=this.bb.__offset(this.bb_pos,26);return i?this.bb.__vector_len(this.bb_pos+i):0}inputArgCountsArray(){let i=this.bb.__offset(this.bb_pos,26);return i?new Int32Array(this.bb.bytes().buffer,this.bb.bytes().byteOffset+this.bb.__vector(this.bb_pos+i),this.bb.__vector_len(this.bb_pos+i)):null}implicitInputs(i,u){let l=this.bb.__offset(this.bb_pos,28);return l?this.bb.__string(this.bb.__vector(this.bb_pos+l)+i*4,u):null}implicitInputsLength(){let i=this.bb.__offset(this.bb_pos,28);return i?this.bb.__vector_len(this.bb_pos+i):0}static startNode(i){i.startObject(13)}static addName(i,u){i.addFieldOffset(0,u,0)}static addDocString(i,u){i.addFieldOffset(1,u,0)}static addDomain(i,u){i.addFieldOffset(2,u,0)}static addSinceVersion(i,u){i.addFieldInt32(3,u,0)}static addIndex(i,u){i.addFieldInt32(4,u,0)}static addOpType(i,u){i.addFieldOffset(5,u,0)}static addType(i,u){i.addFieldInt32(6,u,0)}static addExecutionProviderType(i,u){i.addFieldOffset(7,u,0)}static addInputs(i,u){i.addFieldOffset(8,u,0)}static createInputsVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addOffset(u[l]);return i.endVector()}static startInputsVector(i,u){i.startVector(4,u,4)}static addOutputs(i,u){i.addFieldOffset(9,u,0)}static createOutputsVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addOffset(u[l]);return i.endVector()}static startOutputsVector(i,u){i.startVector(4,u,4)}static addAttributes(i,u){i.addFieldOffset(10,u,0)}static createAttributesVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addOffset(u[l]);return i.endVector()}static startAttributesVector(i,u){i.startVector(4,u,4)}static addInputArgCounts(i,u){i.addFieldOffset(11,u,0)}static createInputArgCountsVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addInt32(u[l]);return i.endVector()}static startInputArgCountsVector(i,u){i.startVector(4,u,4)}static addImplicitInputs(i,u){i.addFieldOffset(12,u,0)}static createImplicitInputsVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addOffset(u[l]);return i.endVector()}static startImplicitInputsVector(i,u){i.startVector(4,u,4)}static endNode(i){return i.endObject()}static createNode(i,u,l,f,p,d,T,v,w,I,L,F,C,X){return r.startNode(i),r.addName(i,u),r.addDocString(i,l),r.addDomain(i,f),r.addSinceVersion(i,p),r.addIndex(i,d),r.addOpType(i,T),r.addType(i,v),r.addExecutionProviderType(i,w),r.addInputs(i,I),r.addOutputs(i,L),r.addAttributes(i,F),r.addInputArgCounts(i,C),r.addImplicitInputs(i,X),r.endNode(i)}}n.Node=r})(o=e.fbs||={})})(a=t.experimental||={})})(H||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsValueInfo(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsValueInfo(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}name(i){let u=this.bb.__offset(this.bb_pos,4);return u?this.bb.__string(this.bb_pos+u,i):null}docString(i){let u=this.bb.__offset(this.bb_pos,6);return u?this.bb.__string(this.bb_pos+u,i):null}type(i){let u=this.bb.__offset(this.bb_pos,8);return u?(i||new t.experimental.fbs.TypeInfo).__init(this.bb.__indirect(this.bb_pos+u),this.bb):null}static startValueInfo(i){i.startObject(3)}static addName(i,u){i.addFieldOffset(0,u,0)}static addDocString(i,u){i.addFieldOffset(1,u,0)}static addType(i,u){i.addFieldOffset(2,u,0)}static endValueInfo(i){return i.endObject()}static createValueInfo(i,u,l,f){return r.startValueInfo(i),r.addName(i,u),r.addDocString(i,l),r.addType(i,f),r.endValueInfo(i)}}n.ValueInfo=r})(o=e.fbs||={})})(a=t.experimental||={})})(H||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsTypeInfo(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsTypeInfo(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}denotation(i){let u=this.bb.__offset(this.bb_pos,4);return u?this.bb.__string(this.bb_pos+u,i):null}valueType(){let i=this.bb.__offset(this.bb_pos,6);return i?this.bb.readUint8(this.bb_pos+i):0}value(i){let u=this.bb.__offset(this.bb_pos,8);return u?this.bb.__union(i,this.bb_pos+u):null}static startTypeInfo(i){i.startObject(3)}static addDenotation(i,u){i.addFieldOffset(0,u,0)}static addValueType(i,u){i.addFieldInt8(1,u,0)}static addValue(i,u){i.addFieldOffset(2,u,0)}static endTypeInfo(i){return i.endObject()}static createTypeInfo(i,u,l,f){return r.startTypeInfo(i),r.addDenotation(i,u),r.addValueType(i,l),r.addValue(i,f),r.endTypeInfo(i)}}n.TypeInfo=r})(o=e.fbs||={})})(a=t.experimental||={})})(H||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsOperatorSetId(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsOperatorSetId(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}domain(i){let u=this.bb.__offset(this.bb_pos,4);return u?this.bb.__string(this.bb_pos+u,i):null}version(){let i=this.bb.__offset(this.bb_pos,6);return i?this.bb.readInt64(this.bb_pos+i):this.bb.createLong(0,0)}static startOperatorSetId(i){i.startObject(2)}static addDomain(i,u){i.addFieldOffset(0,u,0)}static addVersion(i,u){i.addFieldInt64(1,u,i.createLong(0,0))}static endOperatorSetId(i){return i.endObject()}static createOperatorSetId(i,u,l){return r.startOperatorSetId(i),r.addDomain(i,u),r.addVersion(i,l),r.endOperatorSetId(i)}}n.OperatorSetId=r})(o=e.fbs||={})})(a=t.experimental||={})})(H||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsTensor(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsTensor(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}name(i){let u=this.bb.__offset(this.bb_pos,4);return u?this.bb.__string(this.bb_pos+u,i):null}docString(i){let u=this.bb.__offset(this.bb_pos,6);return u?this.bb.__string(this.bb_pos+u,i):null}dims(i){let u=this.bb.__offset(this.bb_pos,8);return u?this.bb.readInt64(this.bb.__vector(this.bb_pos+u)+i*8):this.bb.createLong(0,0)}dimsLength(){let i=this.bb.__offset(this.bb_pos,8);return i?this.bb.__vector_len(this.bb_pos+i):0}dataType(){let i=this.bb.__offset(this.bb_pos,10);return i?this.bb.readInt32(this.bb_pos+i):0}rawData(i){let u=this.bb.__offset(this.bb_pos,12);return u?this.bb.readUint8(this.bb.__vector(this.bb_pos+u)+i):0}rawDataLength(){let i=this.bb.__offset(this.bb_pos,12);return i?this.bb.__vector_len(this.bb_pos+i):0}rawDataArray(){let i=this.bb.__offset(this.bb_pos,12);return i?new Uint8Array(this.bb.bytes().buffer,this.bb.bytes().byteOffset+this.bb.__vector(this.bb_pos+i),this.bb.__vector_len(this.bb_pos+i)):null}stringData(i,u){let l=this.bb.__offset(this.bb_pos,14);return l?this.bb.__string(this.bb.__vector(this.bb_pos+l)+i*4,u):null}stringDataLength(){let i=this.bb.__offset(this.bb_pos,14);return i?this.bb.__vector_len(this.bb_pos+i):0}static startTensor(i){i.startObject(6)}static addName(i,u){i.addFieldOffset(0,u,0)}static addDocString(i,u){i.addFieldOffset(1,u,0)}static addDims(i,u){i.addFieldOffset(2,u,0)}static createDimsVector(i,u){i.startVector(8,u.length,8);for(let l=u.length-1;l>=0;l--)i.addInt64(u[l]);return i.endVector()}static startDimsVector(i,u){i.startVector(8,u,8)}static addDataType(i,u){i.addFieldInt32(3,u,0)}static addRawData(i,u){i.addFieldOffset(4,u,0)}static createRawDataVector(i,u){i.startVector(1,u.length,1);for(let l=u.length-1;l>=0;l--)i.addInt8(u[l]);return i.endVector()}static startRawDataVector(i,u){i.startVector(1,u,1)}static addStringData(i,u){i.addFieldOffset(5,u,0)}static createStringDataVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addOffset(u[l]);return i.endVector()}static startStringDataVector(i,u){i.startVector(4,u,4)}static endTensor(i){return i.endObject()}static createTensor(i,u,l,f,p,d,T){return r.startTensor(i),r.addName(i,u),r.addDocString(i,l),r.addDims(i,f),r.addDataType(i,p),r.addRawData(i,d),r.addStringData(i,T),r.endTensor(i)}}n.Tensor=r})(o=e.fbs||={})})(a=t.experimental||={})})(H||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsSparseTensor(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsSparseTensor(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}values(i){let u=this.bb.__offset(this.bb_pos,4);return u?(i||new t.experimental.fbs.Tensor).__init(this.bb.__indirect(this.bb_pos+u),this.bb):null}indices(i){let u=this.bb.__offset(this.bb_pos,6);return u?(i||new t.experimental.fbs.Tensor).__init(this.bb.__indirect(this.bb_pos+u),this.bb):null}dims(i){let u=this.bb.__offset(this.bb_pos,8);return u?this.bb.readInt64(this.bb.__vector(this.bb_pos+u)+i*8):this.bb.createLong(0,0)}dimsLength(){let i=this.bb.__offset(this.bb_pos,8);return i?this.bb.__vector_len(this.bb_pos+i):0}static startSparseTensor(i){i.startObject(3)}static addValues(i,u){i.addFieldOffset(0,u,0)}static addIndices(i,u){i.addFieldOffset(1,u,0)}static addDims(i,u){i.addFieldOffset(2,u,0)}static createDimsVector(i,u){i.startVector(8,u.length,8);for(let l=u.length-1;l>=0;l--)i.addInt64(u[l]);return i.endVector()}static startDimsVector(i,u){i.startVector(8,u,8)}static endSparseTensor(i){return i.endObject()}static createSparseTensor(i,u,l,f){return r.startSparseTensor(i),r.addValues(i,u),r.addIndices(i,l),r.addDims(i,f),r.endSparseTensor(i)}}n.SparseTensor=r})(o=e.fbs||={})})(a=t.experimental||={})})(H||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsAttribute(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsAttribute(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}name(i){let u=this.bb.__offset(this.bb_pos,4);return u?this.bb.__string(this.bb_pos+u,i):null}docString(i){let u=this.bb.__offset(this.bb_pos,6);return u?this.bb.__string(this.bb_pos+u,i):null}type(){let i=this.bb.__offset(this.bb_pos,8);return i?this.bb.readInt32(this.bb_pos+i):0}f(){let i=this.bb.__offset(this.bb_pos,10);return i?this.bb.readFloat32(this.bb_pos+i):0}i(){let i=this.bb.__offset(this.bb_pos,12);return i?this.bb.readInt64(this.bb_pos+i):this.bb.createLong(0,0)}s(i){let u=this.bb.__offset(this.bb_pos,14);return u?this.bb.__string(this.bb_pos+u,i):null}t(i){let u=this.bb.__offset(this.bb_pos,16);return u?(i||new t.experimental.fbs.Tensor).__init(this.bb.__indirect(this.bb_pos+u),this.bb):null}g(i){let u=this.bb.__offset(this.bb_pos,18);return u?(i||new t.experimental.fbs.Graph).__init(this.bb.__indirect(this.bb_pos+u),this.bb):null}floats(i){let u=this.bb.__offset(this.bb_pos,20);return u?this.bb.readFloat32(this.bb.__vector(this.bb_pos+u)+i*4):0}floatsLength(){let i=this.bb.__offset(this.bb_pos,20);return i?this.bb.__vector_len(this.bb_pos+i):0}floatsArray(){let i=this.bb.__offset(this.bb_pos,20);return i?new Float32Array(this.bb.bytes().buffer,this.bb.bytes().byteOffset+this.bb.__vector(this.bb_pos+i),this.bb.__vector_len(this.bb_pos+i)):null}ints(i){let u=this.bb.__offset(this.bb_pos,22);return u?this.bb.readInt64(this.bb.__vector(this.bb_pos+u)+i*8):this.bb.createLong(0,0)}intsLength(){let i=this.bb.__offset(this.bb_pos,22);return i?this.bb.__vector_len(this.bb_pos+i):0}strings(i,u){let l=this.bb.__offset(this.bb_pos,24);return l?this.bb.__string(this.bb.__vector(this.bb_pos+l)+i*4,u):null}stringsLength(){let i=this.bb.__offset(this.bb_pos,24);return i?this.bb.__vector_len(this.bb_pos+i):0}tensors(i,u){let l=this.bb.__offset(this.bb_pos,26);return l?(u||new t.experimental.fbs.Tensor).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+l)+i*4),this.bb):null}tensorsLength(){let i=this.bb.__offset(this.bb_pos,26);return i?this.bb.__vector_len(this.bb_pos+i):0}graphs(i,u){let l=this.bb.__offset(this.bb_pos,28);return l?(u||new t.experimental.fbs.Graph).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+l)+i*4),this.bb):null}graphsLength(){let i=this.bb.__offset(this.bb_pos,28);return i?this.bb.__vector_len(this.bb_pos+i):0}static startAttribute(i){i.startObject(13)}static addName(i,u){i.addFieldOffset(0,u,0)}static addDocString(i,u){i.addFieldOffset(1,u,0)}static addType(i,u){i.addFieldInt32(2,u,0)}static addF(i,u){i.addFieldFloat32(3,u,0)}static addI(i,u){i.addFieldInt64(4,u,i.createLong(0,0))}static addS(i,u){i.addFieldOffset(5,u,0)}static addT(i,u){i.addFieldOffset(6,u,0)}static addG(i,u){i.addFieldOffset(7,u,0)}static addFloats(i,u){i.addFieldOffset(8,u,0)}static createFloatsVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addFloat32(u[l]);return i.endVector()}static startFloatsVector(i,u){i.startVector(4,u,4)}static addInts(i,u){i.addFieldOffset(9,u,0)}static createIntsVector(i,u){i.startVector(8,u.length,8);for(let l=u.length-1;l>=0;l--)i.addInt64(u[l]);return i.endVector()}static startIntsVector(i,u){i.startVector(8,u,8)}static addStrings(i,u){i.addFieldOffset(10,u,0)}static createStringsVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addOffset(u[l]);return i.endVector()}static startStringsVector(i,u){i.startVector(4,u,4)}static addTensors(i,u){i.addFieldOffset(11,u,0)}static createTensorsVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addOffset(u[l]);return i.endVector()}static startTensorsVector(i,u){i.startVector(4,u,4)}static addGraphs(i,u){i.addFieldOffset(12,u,0)}static createGraphsVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addOffset(u[l]);return i.endVector()}static startGraphsVector(i,u){i.startVector(4,u,4)}static endAttribute(i){return i.endObject()}static createAttribute(i,u,l,f,p,d,T,v,w,I,L,F,C,X){return r.startAttribute(i),r.addName(i,u),r.addDocString(i,l),r.addType(i,f),r.addF(i,p),r.addI(i,d),r.addS(i,T),r.addT(i,v),r.addG(i,w),r.addFloats(i,I),r.addInts(i,L),r.addStrings(i,F),r.addTensors(i,C),r.addGraphs(i,X),r.endAttribute(i)}}n.Attribute=r})(o=e.fbs||={})})(a=t.experimental||={})})(H||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsGraph(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsGraph(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}initializers(i,u){let l=this.bb.__offset(this.bb_pos,4);return l?(u||new t.experimental.fbs.Tensor).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+l)+i*4),this.bb):null}initializersLength(){let i=this.bb.__offset(this.bb_pos,4);return i?this.bb.__vector_len(this.bb_pos+i):0}nodeArgs(i,u){let l=this.bb.__offset(this.bb_pos,6);return l?(u||new t.experimental.fbs.ValueInfo).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+l)+i*4),this.bb):null}nodeArgsLength(){let i=this.bb.__offset(this.bb_pos,6);return i?this.bb.__vector_len(this.bb_pos+i):0}nodes(i,u){let l=this.bb.__offset(this.bb_pos,8);return l?(u||new t.experimental.fbs.Node).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+l)+i*4),this.bb):null}nodesLength(){let i=this.bb.__offset(this.bb_pos,8);return i?this.bb.__vector_len(this.bb_pos+i):0}maxNodeIndex(){let i=this.bb.__offset(this.bb_pos,10);return i?this.bb.readUint32(this.bb_pos+i):0}nodeEdges(i,u){let l=this.bb.__offset(this.bb_pos,12);return l?(u||new t.experimental.fbs.NodeEdge).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+l)+i*4),this.bb):null}nodeEdgesLength(){let i=this.bb.__offset(this.bb_pos,12);return i?this.bb.__vector_len(this.bb_pos+i):0}inputs(i,u){let l=this.bb.__offset(this.bb_pos,14);return l?this.bb.__string(this.bb.__vector(this.bb_pos+l)+i*4,u):null}inputsLength(){let i=this.bb.__offset(this.bb_pos,14);return i?this.bb.__vector_len(this.bb_pos+i):0}outputs(i,u){let l=this.bb.__offset(this.bb_pos,16);return l?this.bb.__string(this.bb.__vector(this.bb_pos+l)+i*4,u):null}outputsLength(){let i=this.bb.__offset(this.bb_pos,16);return i?this.bb.__vector_len(this.bb_pos+i):0}sparseInitializers(i,u){let l=this.bb.__offset(this.bb_pos,18);return l?(u||new t.experimental.fbs.SparseTensor).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+l)+i*4),this.bb):null}sparseInitializersLength(){let i=this.bb.__offset(this.bb_pos,18);return i?this.bb.__vector_len(this.bb_pos+i):0}static startGraph(i){i.startObject(8)}static addInitializers(i,u){i.addFieldOffset(0,u,0)}static createInitializersVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addOffset(u[l]);return i.endVector()}static startInitializersVector(i,u){i.startVector(4,u,4)}static addNodeArgs(i,u){i.addFieldOffset(1,u,0)}static createNodeArgsVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addOffset(u[l]);return i.endVector()}static startNodeArgsVector(i,u){i.startVector(4,u,4)}static addNodes(i,u){i.addFieldOffset(2,u,0)}static createNodesVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addOffset(u[l]);return i.endVector()}static startNodesVector(i,u){i.startVector(4,u,4)}static addMaxNodeIndex(i,u){i.addFieldInt32(3,u,0)}static addNodeEdges(i,u){i.addFieldOffset(4,u,0)}static createNodeEdgesVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addOffset(u[l]);return i.endVector()}static startNodeEdgesVector(i,u){i.startVector(4,u,4)}static addInputs(i,u){i.addFieldOffset(5,u,0)}static createInputsVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addOffset(u[l]);return i.endVector()}static startInputsVector(i,u){i.startVector(4,u,4)}static addOutputs(i,u){i.addFieldOffset(6,u,0)}static createOutputsVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addOffset(u[l]);return i.endVector()}static startOutputsVector(i,u){i.startVector(4,u,4)}static addSparseInitializers(i,u){i.addFieldOffset(7,u,0)}static createSparseInitializersVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addOffset(u[l]);return i.endVector()}static startSparseInitializersVector(i,u){i.startVector(4,u,4)}static endGraph(i){return i.endObject()}static createGraph(i,u,l,f,p,d,T,v,w){return r.startGraph(i),r.addInitializers(i,u),r.addNodeArgs(i,l),r.addNodes(i,f),r.addMaxNodeIndex(i,p),r.addNodeEdges(i,d),r.addInputs(i,T),r.addOutputs(i,v),r.addSparseInitializers(i,w),r.endGraph(i)}}n.Graph=r})(o=e.fbs||={})})(a=t.experimental||={})})(H||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsModel(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsModel(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}irVersion(){let i=this.bb.__offset(this.bb_pos,4);return i?this.bb.readInt64(this.bb_pos+i):this.bb.createLong(0,0)}opsetImport(i,u){let l=this.bb.__offset(this.bb_pos,6);return l?(u||new t.experimental.fbs.OperatorSetId).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+l)+i*4),this.bb):null}opsetImportLength(){let i=this.bb.__offset(this.bb_pos,6);return i?this.bb.__vector_len(this.bb_pos+i):0}producerName(i){let u=this.bb.__offset(this.bb_pos,8);return u?this.bb.__string(this.bb_pos+u,i):null}producerVersion(i){let u=this.bb.__offset(this.bb_pos,10);return u?this.bb.__string(this.bb_pos+u,i):null}domain(i){let u=this.bb.__offset(this.bb_pos,12);return u?this.bb.__string(this.bb_pos+u,i):null}modelVersion(){let i=this.bb.__offset(this.bb_pos,14);return i?this.bb.readInt64(this.bb_pos+i):this.bb.createLong(0,0)}docString(i){let u=this.bb.__offset(this.bb_pos,16);return u?this.bb.__string(this.bb_pos+u,i):null}graph(i){let u=this.bb.__offset(this.bb_pos,18);return u?(i||new t.experimental.fbs.Graph).__init(this.bb.__indirect(this.bb_pos+u),this.bb):null}graphDocString(i){let u=this.bb.__offset(this.bb_pos,20);return u?this.bb.__string(this.bb_pos+u,i):null}static startModel(i){i.startObject(9)}static addIrVersion(i,u){i.addFieldInt64(0,u,i.createLong(0,0))}static addOpsetImport(i,u){i.addFieldOffset(1,u,0)}static createOpsetImportVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addOffset(u[l]);return i.endVector()}static startOpsetImportVector(i,u){i.startVector(4,u,4)}static addProducerName(i,u){i.addFieldOffset(2,u,0)}static addProducerVersion(i,u){i.addFieldOffset(3,u,0)}static addDomain(i,u){i.addFieldOffset(4,u,0)}static addModelVersion(i,u){i.addFieldInt64(5,u,i.createLong(0,0))}static addDocString(i,u){i.addFieldOffset(6,u,0)}static addGraph(i,u){i.addFieldOffset(7,u,0)}static addGraphDocString(i,u){i.addFieldOffset(8,u,0)}static endModel(i){return i.endObject()}static createModel(i,u,l,f,p,d,T,v,w,I){return r.startModel(i),r.addIrVersion(i,u),r.addOpsetImport(i,l),r.addProducerName(i,f),r.addProducerVersion(i,p),r.addDomain(i,d),r.addModelVersion(i,T),r.addDocString(i,v),r.addGraph(i,w),r.addGraphDocString(i,I),r.endModel(i)}}n.Model=r})(o=e.fbs||={})})(a=t.experimental||={})})(H||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsKernelCreateInfos(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsKernelCreateInfos(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}nodeIndices(i){let u=this.bb.__offset(this.bb_pos,4);return u?this.bb.readUint32(this.bb.__vector(this.bb_pos+u)+i*4):0}nodeIndicesLength(){let i=this.bb.__offset(this.bb_pos,4);return i?this.bb.__vector_len(this.bb_pos+i):0}nodeIndicesArray(){let i=this.bb.__offset(this.bb_pos,4);return i?new Uint32Array(this.bb.bytes().buffer,this.bb.bytes().byteOffset+this.bb.__vector(this.bb_pos+i),this.bb.__vector_len(this.bb_pos+i)):null}kernelDefHashes(i){let u=this.bb.__offset(this.bb_pos,6);return u?this.bb.readUint64(this.bb.__vector(this.bb_pos+u)+i*8):this.bb.createLong(0,0)}kernelDefHashesLength(){let i=this.bb.__offset(this.bb_pos,6);return i?this.bb.__vector_len(this.bb_pos+i):0}static startKernelCreateInfos(i){i.startObject(2)}static addNodeIndices(i,u){i.addFieldOffset(0,u,0)}static createNodeIndicesVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addInt32(u[l]);return i.endVector()}static startNodeIndicesVector(i,u){i.startVector(4,u,4)}static addKernelDefHashes(i,u){i.addFieldOffset(1,u,0)}static createKernelDefHashesVector(i,u){i.startVector(8,u.length,8);for(let l=u.length-1;l>=0;l--)i.addInt64(u[l]);return i.endVector()}static startKernelDefHashesVector(i,u){i.startVector(8,u,8)}static endKernelCreateInfos(i){return i.endObject()}static createKernelCreateInfos(i,u,l){return r.startKernelCreateInfos(i),r.addNodeIndices(i,u),r.addKernelDefHashes(i,l),r.endKernelCreateInfos(i)}}n.KernelCreateInfos=r})(o=e.fbs||={})})(a=t.experimental||={})})(H||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsSubGraphSessionState(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsSubGraphSessionState(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}graphId(i){let u=this.bb.__offset(this.bb_pos,4);return u?this.bb.__string(this.bb_pos+u,i):null}sessionState(i){let u=this.bb.__offset(this.bb_pos,6);return u?(i||new t.experimental.fbs.SessionState).__init(this.bb.__indirect(this.bb_pos+u),this.bb):null}static startSubGraphSessionState(i){i.startObject(2)}static addGraphId(i,u){i.addFieldOffset(0,u,0)}static addSessionState(i,u){i.addFieldOffset(1,u,0)}static endSubGraphSessionState(i){let u=i.endObject();return i.requiredField(u,4),u}static createSubGraphSessionState(i,u,l){return r.startSubGraphSessionState(i),r.addGraphId(i,u),r.addSessionState(i,l),r.endSubGraphSessionState(i)}}n.SubGraphSessionState=r})(o=e.fbs||={})})(a=t.experimental||={})})(H||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsSessionState(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsSessionState(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}kernels(i){let u=this.bb.__offset(this.bb_pos,4);return u?(i||new t.experimental.fbs.KernelCreateInfos).__init(this.bb.__indirect(this.bb_pos+u),this.bb):null}subGraphSessionStates(i,u){let l=this.bb.__offset(this.bb_pos,6);return l?(u||new t.experimental.fbs.SubGraphSessionState).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+l)+i*4),this.bb):null}subGraphSessionStatesLength(){let i=this.bb.__offset(this.bb_pos,6);return i?this.bb.__vector_len(this.bb_pos+i):0}static startSessionState(i){i.startObject(2)}static addKernels(i,u){i.addFieldOffset(0,u,0)}static addSubGraphSessionStates(i,u){i.addFieldOffset(1,u,0)}static createSubGraphSessionStatesVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addOffset(u[l]);return i.endVector()}static startSubGraphSessionStatesVector(i,u){i.startVector(4,u,4)}static endSessionState(i){return i.endObject()}static createSessionState(i,u,l){return r.startSessionState(i),r.addKernels(i,u),r.addSubGraphSessionStates(i,l),r.endSessionState(i)}}n.SessionState=r})(o=e.fbs||={})})(a=t.experimental||={})})(H||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsInferenceSession(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsInferenceSession(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static bufferHasIdentifier(i){return i.__has_identifier("ORTM")}ortVersion(i){let u=this.bb.__offset(this.bb_pos,4);return u?this.bb.__string(this.bb_pos+u,i):null}model(i){let u=this.bb.__offset(this.bb_pos,6);return u?(i||new t.experimental.fbs.Model).__init(this.bb.__indirect(this.bb_pos+u),this.bb):null}sessionState(i){let u=this.bb.__offset(this.bb_pos,8);return u?(i||new t.experimental.fbs.SessionState).__init(this.bb.__indirect(this.bb_pos+u),this.bb):null}static startInferenceSession(i){i.startObject(3)}static addOrtVersion(i,u){i.addFieldOffset(0,u,0)}static addModel(i,u){i.addFieldOffset(1,u,0)}static addSessionState(i,u){i.addFieldOffset(2,u,0)}static endInferenceSession(i){return i.endObject()}static finishInferenceSessionBuffer(i,u){i.finish(u,"ORTM")}static finishSizePrefixedInferenceSessionBuffer(i,u){i.finish(u,"ORTM",!0)}static createInferenceSession(i,u,l,f){return r.startInferenceSession(i),r.addOrtVersion(i,u),r.addModel(i,l),r.addSessionState(i,f),r.endInferenceSession(i)}}n.InferenceSession=r})(o=e.fbs||={})})(a=t.experimental||={})})(H||={})});var Bs=de((_y,ks)=>{"use strict";ks.exports=Nd;function Nd(a,t){for(var o=new Array(arguments.length-1),e=0,r=2,n=!0;r{"use strict";var Wn=Rs;Wn.length=function(t){var o=t.length;if(!o)return 0;for(var e=0;--o%4>1&&t.charAt(o)==="=";)++e;return Math.ceil(t.length*3)/4-e};var Fr=new Array(64),Ns=new Array(123);for(vt=0;vt<64;)Ns[Fr[vt]=vt<26?vt+65:vt<52?vt+71:vt<62?vt-4:vt-59|43]=vt++;var vt;Wn.encode=function(t,o,e){for(var r=null,n=[],s=0,i=0,u;o>2],u=(l&3)<<4,i=1;break;case 1:n[s++]=Fr[u|l>>4],u=(l&15)<<2,i=2;break;case 2:n[s++]=Fr[u|l>>6],n[s++]=Fr[l&63],i=0;break}s>8191&&((r||(r=[])).push(String.fromCharCode.apply(String,n)),s=0)}return i&&(n[s++]=Fr[u],n[s++]=61,i===1&&(n[s++]=61)),r?(s&&r.push(String.fromCharCode.apply(String,n.slice(0,s))),r.join("")):String.fromCharCode.apply(String,n.slice(0,s))};var $s="invalid encoding";Wn.decode=function(t,o,e){for(var r=e,n=0,s,i=0;i1)break;if((u=Ns[u])===void 0)throw Error($s);switch(n){case 0:s=u,n=1;break;case 1:o[e++]=s<<2|(u&48)>>4,s=u,n=2;break;case 2:o[e++]=(s&15)<<4|(u&60)>>2,s=u,n=3;break;case 3:o[e++]=(s&3)<<6|u,n=0;break}}if(n===1)throw Error($s);return e-r};Wn.test=function(t){return/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/.test(t)}});var Us=de((Iy,Gs)=>{"use strict";Gs.exports=Hn;function Hn(){this._listeners={}}Hn.prototype.on=function(t,o,e){return(this._listeners[t]||(this._listeners[t]=[])).push({fn:o,ctx:e||this}),this};Hn.prototype.off=function(t,o){if(t===void 0)this._listeners={};else if(o===void 0)this._listeners[t]=[];else for(var e=this._listeners[t],r=0;r{"use strict";js.exports=zs(zs);function zs(a){return typeof Float32Array<"u"?function(){var t=new Float32Array([-0]),o=new Uint8Array(t.buffer),e=o[3]===128;function r(u,l,f){t[0]=u,l[f]=o[0],l[f+1]=o[1],l[f+2]=o[2],l[f+3]=o[3]}function n(u,l,f){t[0]=u,l[f]=o[3],l[f+1]=o[2],l[f+2]=o[1],l[f+3]=o[0]}a.writeFloatLE=e?r:n,a.writeFloatBE=e?n:r;function s(u,l){return o[0]=u[l],o[1]=u[l+1],o[2]=u[l+2],o[3]=u[l+3],t[0]}function i(u,l){return o[3]=u[l],o[2]=u[l+1],o[1]=u[l+2],o[0]=u[l+3],t[0]}a.readFloatLE=e?s:i,a.readFloatBE=e?i:s}():function(){function t(e,r,n,s){var i=r<0?1:0;if(i&&(r=-r),r===0)e(1/r>0?0:2147483648,n,s);else if(isNaN(r))e(2143289344,n,s);else if(r>34028234663852886e22)e((i<<31|2139095040)>>>0,n,s);else if(r<11754943508222875e-54)e((i<<31|Math.round(r/1401298464324817e-60))>>>0,n,s);else{var u=Math.floor(Math.log(r)/Math.LN2),l=Math.round(r*Math.pow(2,-u)*8388608)&8388607;e((i<<31|u+127<<23|l)>>>0,n,s)}}a.writeFloatLE=t.bind(null,Vs),a.writeFloatBE=t.bind(null,Ws);function o(e,r,n){var s=e(r,n),i=(s>>31)*2+1,u=s>>>23&255,l=s&8388607;return u===255?l?NaN:i*(1/0):u===0?i*1401298464324817e-60*l:i*Math.pow(2,u-150)*(l+8388608)}a.readFloatLE=o.bind(null,Hs),a.readFloatBE=o.bind(null,qs)}(),typeof Float64Array<"u"?function(){var t=new Float64Array([-0]),o=new Uint8Array(t.buffer),e=o[7]===128;function r(u,l,f){t[0]=u,l[f]=o[0],l[f+1]=o[1],l[f+2]=o[2],l[f+3]=o[3],l[f+4]=o[4],l[f+5]=o[5],l[f+6]=o[6],l[f+7]=o[7]}function n(u,l,f){t[0]=u,l[f]=o[7],l[f+1]=o[6],l[f+2]=o[5],l[f+3]=o[4],l[f+4]=o[3],l[f+5]=o[2],l[f+6]=o[1],l[f+7]=o[0]}a.writeDoubleLE=e?r:n,a.writeDoubleBE=e?n:r;function s(u,l){return o[0]=u[l],o[1]=u[l+1],o[2]=u[l+2],o[3]=u[l+3],o[4]=u[l+4],o[5]=u[l+5],o[6]=u[l+6],o[7]=u[l+7],t[0]}function i(u,l){return o[7]=u[l],o[6]=u[l+1],o[5]=u[l+2],o[4]=u[l+3],o[3]=u[l+4],o[2]=u[l+5],o[1]=u[l+6],o[0]=u[l+7],t[0]}a.readDoubleLE=e?s:i,a.readDoubleBE=e?i:s}():function(){function t(e,r,n,s,i,u){var l=s<0?1:0;if(l&&(s=-s),s===0)e(0,i,u+r),e(1/s>0?0:2147483648,i,u+n);else if(isNaN(s))e(0,i,u+r),e(2146959360,i,u+n);else if(s>17976931348623157e292)e(0,i,u+r),e((l<<31|2146435072)>>>0,i,u+n);else{var f;if(s<22250738585072014e-324)f=s/5e-324,e(f>>>0,i,u+r),e((l<<31|f/4294967296)>>>0,i,u+n);else{var p=Math.floor(Math.log(s)/Math.LN2);p===1024&&(p=1023),f=s*Math.pow(2,-p),e(f*4503599627370496>>>0,i,u+r),e((l<<31|p+1023<<20|f*1048576&1048575)>>>0,i,u+n)}}}a.writeDoubleLE=t.bind(null,Vs,0,4),a.writeDoubleBE=t.bind(null,Ws,4,0);function o(e,r,n,s,i){var u=e(s,i+r),l=e(s,i+n),f=(l>>31)*2+1,p=l>>>20&2047,d=4294967296*(l&1048575)+u;return p===2047?d?NaN:f*(1/0):p===0?f*5e-324*d:f*Math.pow(2,p-1075)*(d+4503599627370496)}a.readDoubleLE=o.bind(null,Hs,0,4),a.readDoubleBE=o.bind(null,qs,4,0)}(),a}function Vs(a,t,o){t[o]=a&255,t[o+1]=a>>>8&255,t[o+2]=a>>>16&255,t[o+3]=a>>>24}function Ws(a,t,o){t[o]=a>>>24,t[o+1]=a>>>16&255,t[o+2]=a>>>8&255,t[o+3]=a&255}function Hs(a,t){return(a[t]|a[t+1]<<8|a[t+2]<<16|a[t+3]<<24)>>>0}function qs(a,t){return(a[t]<<24|a[t+1]<<16|a[t+2]<<8|a[t+3])>>>0}});var Xs=de((exports,module)=>{"use strict";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(a){}return null}});var Js=de(Ks=>{"use strict";var Qo=Ks;Qo.length=function(t){for(var o=0,e=0,r=0;r191&&u<224?s[i++]=(u&31)<<6|t[o++]&63:u>239&&u<365?(u=((u&7)<<18|(t[o++]&63)<<12|(t[o++]&63)<<6|t[o++]&63)-65536,s[i++]=55296+(u>>10),s[i++]=56320+(u&1023)):s[i++]=(u&15)<<12|(t[o++]&63)<<6|t[o++]&63,i>8191&&((n||(n=[])).push(String.fromCharCode.apply(String,s)),i=0);return n?(i&&n.push(String.fromCharCode.apply(String,s.slice(0,i))),n.join("")):String.fromCharCode.apply(String,s.slice(0,i))};Qo.write=function(t,o,e){for(var r=e,n,s,i=0;i>6|192,o[e++]=n&63|128):(n&64512)===55296&&((s=t.charCodeAt(i+1))&64512)===56320?(n=65536+((n&1023)<<10)+(s&1023),++i,o[e++]=n>>18|240,o[e++]=n>>12&63|128,o[e++]=n>>6&63|128,o[e++]=n&63|128):(o[e++]=n>>12|224,o[e++]=n>>6&63|128,o[e++]=n&63|128);return e-r}});var Qs=de((Ey,Zs)=>{"use strict";Zs.exports=Rd;function Rd(a,t,o){var e=o||8192,r=e>>>1,n=null,s=e;return function(u){if(u<1||u>r)return a(u);s+u>e&&(n=a(e),s=0);var l=t.call(n,s,s+=u);return s&7&&(s=(s|7)+1),l}}});var tu=de((Py,eu)=>{"use strict";eu.exports=Ge;var sn=qt();function Ge(a,t){this.lo=a>>>0,this.hi=t>>>0}var ur=Ge.zero=new Ge(0,0);ur.toNumber=function(){return 0};ur.zzEncode=ur.zzDecode=function(){return this};ur.length=function(){return 1};var Md=Ge.zeroHash="\0\0\0\0\0\0\0\0";Ge.fromNumber=function(t){if(t===0)return ur;var o=t<0;o&&(t=-t);var e=t>>>0,r=(t-e)/4294967296>>>0;return o&&(r=~r>>>0,e=~e>>>0,++e>4294967295&&(e=0,++r>4294967295&&(r=0))),new Ge(e,r)};Ge.from=function(t){if(typeof t=="number")return Ge.fromNumber(t);if(sn.isString(t))if(sn.Long)t=sn.Long.fromString(t);else return Ge.fromNumber(parseInt(t,10));return t.low||t.high?new Ge(t.low>>>0,t.high>>>0):ur};Ge.prototype.toNumber=function(t){if(!t&&this.hi>>>31){var o=~this.lo+1>>>0,e=~this.hi>>>0;return o||(e=e+1>>>0),-(o+e*4294967296)}return this.lo+this.hi*4294967296};Ge.prototype.toLong=function(t){return sn.Long?new sn.Long(this.lo|0,this.hi|0,!!t):{low:this.lo|0,high:this.hi|0,unsigned:!!t}};var Ht=String.prototype.charCodeAt;Ge.fromHash=function(t){return t===Md?ur:new Ge((Ht.call(t,0)|Ht.call(t,1)<<8|Ht.call(t,2)<<16|Ht.call(t,3)<<24)>>>0,(Ht.call(t,4)|Ht.call(t,5)<<8|Ht.call(t,6)<<16|Ht.call(t,7)<<24)>>>0)};Ge.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)};Ge.prototype.zzEncode=function(){var t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this};Ge.prototype.zzDecode=function(){var t=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this};Ge.prototype.length=function(){var t=this.lo,o=(this.lo>>>28|this.hi<<4)>>>0,e=this.hi>>>24;return e===0?o===0?t<16384?t<128?1:2:t<2097152?3:4:o<16384?o<128?5:6:o<2097152?7:8:e<128?9:10}});var qt=de(ei=>{"use strict";var q=ei;q.asPromise=Bs();q.base64=Ms();q.EventEmitter=Us();q.float=Ys();q.inquire=Xs();q.utf8=Js();q.pool=Qs();q.LongBits=tu();q.isNode=!!(typeof global<"u"&&global&&global.process&&global.process.versions&&global.process.versions.node);q.global=q.isNode&&global||typeof window<"u"&&window||typeof self<"u"&&self||ei;q.emptyArray=Object.freeze?Object.freeze([]):[];q.emptyObject=Object.freeze?Object.freeze({}):{};q.isInteger=Number.isInteger||function(t){return typeof t=="number"&&isFinite(t)&&Math.floor(t)===t};q.isString=function(t){return typeof t=="string"||t instanceof String};q.isObject=function(t){return t&&typeof t=="object"};q.isset=q.isSet=function(t,o){var e=t[o];return e!=null&&t.hasOwnProperty(o)?typeof e!="object"||(Array.isArray(e)?e.length:Object.keys(e).length)>0:!1};q.Buffer=function(){try{var a=q.inquire("buffer").Buffer;return a.prototype.utf8Write?a:null}catch{return null}}();q._Buffer_from=null;q._Buffer_allocUnsafe=null;q.newBuffer=function(t){return typeof t=="number"?q.Buffer?q._Buffer_allocUnsafe(t):new q.Array(t):q.Buffer?q._Buffer_from(t):typeof Uint8Array>"u"?t:new Uint8Array(t)};q.Array=typeof Uint8Array<"u"?Uint8Array:Array;q.Long=q.global.dcodeIO&&q.global.dcodeIO.Long||q.global.Long||q.inquire("long");q.key2Re=/^true|false|0|1$/;q.key32Re=/^-?(?:0|[1-9][0-9]*)$/;q.key64Re=/^(?:[\\x00-\\xff]{8}|-?(?:0|[1-9][0-9]*))$/;q.longToHash=function(t){return t?q.LongBits.from(t).toHash():q.LongBits.zeroHash};q.longFromHash=function(t,o){var e=q.LongBits.fromHash(t);return q.Long?q.Long.fromBits(e.lo,e.hi,o):e.toNumber(!!o)};function ru(a,t,o){for(var e=Object.keys(t),r=0;r-1;--n)if(o[r[n]]===1&&this[r[n]]!==void 0&&this[r[n]]!==null)return r[n]}};q.oneOfSetter=function(t){return function(o){for(var e=0;e{"use strict";su.exports=ie;var dt=qt(),ti,qn=dt.LongBits,ou=dt.base64,iu=dt.utf8;function un(a,t,o){this.fn=a,this.len=t,this.next=void 0,this.val=o}function ni(){}function Gd(a){this.head=a.head,this.tail=a.tail,this.len=a.len,this.next=a.states}function ie(){this.len=0,this.head=new un(ni,0,0),this.tail=this.head,this.states=null}var au=function(){return dt.Buffer?function(){return(ie.create=function(){return new ti})()}:function(){return new ie}};ie.create=au();ie.alloc=function(t){return new dt.Array(t)};dt.Array!==Array&&(ie.alloc=dt.pool(ie.alloc,dt.Array.prototype.subarray));ie.prototype._push=function(t,o,e){return this.tail=this.tail.next=new un(t,o,e),this.len+=o,this};function oi(a,t,o){t[o]=a&255}function Ud(a,t,o){for(;a>127;)t[o++]=a&127|128,a>>>=7;t[o]=a}function ii(a,t){this.len=a,this.next=void 0,this.val=t}ii.prototype=Object.create(un.prototype);ii.prototype.fn=Ud;ie.prototype.uint32=function(t){return this.len+=(this.tail=this.tail.next=new ii((t=t>>>0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this};ie.prototype.int32=function(t){return t<0?this._push(ai,10,qn.fromNumber(t)):this.uint32(t)};ie.prototype.sint32=function(t){return this.uint32((t<<1^t>>31)>>>0)};function ai(a,t,o){for(;a.hi;)t[o++]=a.lo&127|128,a.lo=(a.lo>>>7|a.hi<<25)>>>0,a.hi>>>=7;for(;a.lo>127;)t[o++]=a.lo&127|128,a.lo=a.lo>>>7;t[o++]=a.lo}ie.prototype.uint64=function(t){var o=qn.from(t);return this._push(ai,o.length(),o)};ie.prototype.int64=ie.prototype.uint64;ie.prototype.sint64=function(t){var o=qn.from(t).zzEncode();return this._push(ai,o.length(),o)};ie.prototype.bool=function(t){return this._push(oi,1,t?1:0)};function ri(a,t,o){t[o]=a&255,t[o+1]=a>>>8&255,t[o+2]=a>>>16&255,t[o+3]=a>>>24}ie.prototype.fixed32=function(t){return this._push(ri,4,t>>>0)};ie.prototype.sfixed32=ie.prototype.fixed32;ie.prototype.fixed64=function(t){var o=qn.from(t);return this._push(ri,4,o.lo)._push(ri,4,o.hi)};ie.prototype.sfixed64=ie.prototype.fixed64;ie.prototype.float=function(t){return this._push(dt.float.writeFloatLE,4,t)};ie.prototype.double=function(t){return this._push(dt.float.writeDoubleLE,8,t)};var zd=dt.Array.prototype.set?function(t,o,e){o.set(t,e)}:function(t,o,e){for(var r=0;r>>0;if(!o)return this._push(oi,1,0);if(dt.isString(t)){var e=ie.alloc(o=ou.length(t));ou.decode(t,e,0),t=e}return this.uint32(o)._push(zd,o,t)};ie.prototype.string=function(t){var o=iu.length(t);return o?this.uint32(o)._push(iu.write,o,t):this._push(oi,1,0)};ie.prototype.fork=function(){return this.states=new Gd(this),this.head=this.tail=new un(ni,0,0),this.len=0,this};ie.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 un(ni,0,0),this.len=0),this};ie.prototype.ldelim=function(){var t=this.head,o=this.tail,e=this.len;return this.reset().uint32(e),e&&(this.tail.next=t.next,this.tail=o,this.len+=e),this};ie.prototype.finish=function(){for(var t=this.head.next,o=this.constructor.alloc(this.len),e=0;t;)t.fn(t.val,o,e),e+=t.len,t=t.next;return o};ie._configure=function(a){ti=a,ie.create=au(),ti._configure()}});var fu=de((Fy,lu)=>{"use strict";lu.exports=Ft;var uu=si();(Ft.prototype=Object.create(uu.prototype)).constructor=Ft;var jt=qt();function Ft(){uu.call(this)}Ft._configure=function(){Ft.alloc=jt._Buffer_allocUnsafe,Ft.writeBytesBuffer=jt.Buffer&&jt.Buffer.prototype instanceof Uint8Array&&jt.Buffer.prototype.set.name==="set"?function(t,o,e){o.set(t,e)}:function(t,o,e){if(t.copy)t.copy(o,e,0,t.length);else for(var r=0;r>>0;return this.uint32(o),o&&this._push(Ft.writeBytesBuffer,o,t),this};function Vd(a,t,o){a.length<40?jt.utf8.write(a,t,o):t.utf8Write?t.utf8Write(a,o):t.write(a,o)}Ft.prototype.string=function(t){var o=jt.Buffer.byteLength(t);return this.uint32(o),o&&this._push(Vd,o,t),this};Ft._configure()});var fi=de((Cy,mu)=>{"use strict";mu.exports=Pe;var _t=qt(),li,du=_t.LongBits,Wd=_t.utf8;function Ot(a,t){return RangeError("index out of range: "+a.pos+" + "+(t||1)+" > "+a.len)}function Pe(a){this.buf=a,this.pos=0,this.len=a.length}var cu=typeof Uint8Array<"u"?function(t){if(t instanceof Uint8Array||Array.isArray(t))return new Pe(t);throw Error("illegal buffer")}:function(t){if(Array.isArray(t))return new Pe(t);throw Error("illegal buffer")},hu=function(){return _t.Buffer?function(o){return(Pe.create=function(r){return _t.Buffer.isBuffer(r)?new li(r):cu(r)})(o)}:cu};Pe.create=hu();Pe.prototype._slice=_t.Array.prototype.subarray||_t.Array.prototype.slice;Pe.prototype.uint32=function(){var t=4294967295;return function(){if(t=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(t=(t|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return t;if((this.pos+=5)>this.len)throw this.pos=this.len,Ot(this,10);return t}}();Pe.prototype.int32=function(){return this.uint32()|0};Pe.prototype.sint32=function(){var t=this.uint32();return t>>>1^-(t&1)|0};function ui(){var a=new du(0,0),t=0;if(this.len-this.pos>4){for(;t<4;++t)if(a.lo=(a.lo|(this.buf[this.pos]&127)<>>0,this.buf[this.pos++]<128)return a;if(a.lo=(a.lo|(this.buf[this.pos]&127)<<28)>>>0,a.hi=(a.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return a;t=0}else{for(;t<3;++t){if(this.pos>=this.len)throw Ot(this);if(a.lo=(a.lo|(this.buf[this.pos]&127)<>>0,this.buf[this.pos++]<128)return a}return a.lo=(a.lo|(this.buf[this.pos++]&127)<>>0,a}if(this.len-this.pos>4){for(;t<5;++t)if(a.hi=(a.hi|(this.buf[this.pos]&127)<>>0,this.buf[this.pos++]<128)return a}else for(;t<5;++t){if(this.pos>=this.len)throw Ot(this);if(a.hi=(a.hi|(this.buf[this.pos]&127)<>>0,this.buf[this.pos++]<128)return a}throw Error("invalid varint encoding")}Pe.prototype.bool=function(){return this.uint32()!==0};function jn(a,t){return(a[t-4]|a[t-3]<<8|a[t-2]<<16|a[t-1]<<24)>>>0}Pe.prototype.fixed32=function(){if(this.pos+4>this.len)throw Ot(this,4);return jn(this.buf,this.pos+=4)};Pe.prototype.sfixed32=function(){if(this.pos+4>this.len)throw Ot(this,4);return jn(this.buf,this.pos+=4)|0};function pu(){if(this.pos+8>this.len)throw Ot(this,8);return new du(jn(this.buf,this.pos+=4),jn(this.buf,this.pos+=4))}Pe.prototype.float=function(){if(this.pos+4>this.len)throw Ot(this,4);var t=_t.float.readFloatLE(this.buf,this.pos);return this.pos+=4,t};Pe.prototype.double=function(){if(this.pos+8>this.len)throw Ot(this,4);var t=_t.float.readDoubleLE(this.buf,this.pos);return this.pos+=8,t};Pe.prototype.bytes=function(){var t=this.uint32(),o=this.pos,e=this.pos+t;if(e>this.len)throw Ot(this,t);if(this.pos+=t,Array.isArray(this.buf))return this.buf.slice(o,e);if(o===e){var r=_t.Buffer;return r?r.alloc(0):new this.buf.constructor(0)}return this._slice.call(this.buf,o,e)};Pe.prototype.string=function(){var t=this.bytes();return Wd.read(t,0,t.length)};Pe.prototype.skip=function(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Ot(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Ot(this);while(this.buf[this.pos++]&128);return this};Pe.prototype.skipType=function(a){switch(a){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(a=this.uint32()&7)!==4;)this.skipType(a);break;case 5:this.skip(4);break;default:throw Error("invalid wire type "+a+" at offset "+this.pos)}return this};Pe._configure=function(a){li=a,Pe.create=hu(),li._configure();var t=_t.Long?"toLong":"toNumber";_t.merge(Pe.prototype,{int64:function(){return ui.call(this)[t](!1)},uint64:function(){return ui.call(this)[t](!0)},sint64:function(){return ui.call(this).zzDecode()[t](!1)},fixed64:function(){return pu.call(this)[t](!0)},sfixed64:function(){return pu.call(this)[t](!1)}})}});var Tu=de((ky,yu)=>{"use strict";yu.exports=lr;var gu=fi();(lr.prototype=Object.create(gu.prototype)).constructor=lr;var bu=qt();function lr(a){gu.call(this,a)}lr._configure=function(){bu.Buffer&&(lr.prototype._slice=bu.Buffer.prototype.slice)};lr.prototype.string=function(){var t=this.uint32();return this.buf.utf8Slice?this.buf.utf8Slice(this.pos,this.pos=Math.min(this.pos+t,this.len)):this.buf.toString("utf-8",this.pos,this.pos=Math.min(this.pos+t,this.len))};lr._configure()});var wu=de((By,xu)=>{"use strict";xu.exports=ln;var ci=qt();(ln.prototype=Object.create(ci.EventEmitter.prototype)).constructor=ln;function ln(a,t,o){if(typeof a!="function")throw TypeError("rpcImpl must be a function");ci.EventEmitter.call(this),this.rpcImpl=a,this.requestDelimited=!!t,this.responseDelimited=!!o}ln.prototype.rpcCall=function a(t,o,e,r,n){if(!r)throw TypeError("request must be specified");var s=this;if(!n)return ci.asPromise(a,s,t,o,e,r);if(!s.rpcImpl){setTimeout(function(){n(Error("already ended"))},0);return}try{return s.rpcImpl(t,o[s.requestDelimited?"encodeDelimited":"encode"](r).finish(),function(u,l){if(u)return s.emit("error",u,t),n(u);if(l===null){s.end(!0);return}if(!(l instanceof e))try{l=e[s.responseDelimited?"decodeDelimited":"decode"](l)}catch(f){return s.emit("error",f,t),n(f)}return s.emit("data",l,t),n(null,l)})}catch(i){s.emit("error",i,t),setTimeout(function(){n(i)},0);return}};ln.prototype.end=function(t){return this.rpcImpl&&(t||this.rpcImpl(null,null,null),this.rpcImpl=null,this.emit("end").off()),this}});var _u=de(vu=>{"use strict";var Hd=vu;Hd.Service=wu()});var Iu=de((Ny,Ou)=>{"use strict";Ou.exports={}});var Eu=de(Au=>{"use strict";var rt=Au;rt.build="minimal";rt.Writer=si();rt.BufferWriter=fu();rt.Reader=fi();rt.BufferReader=Tu();rt.util=qt();rt.rpc=_u();rt.roots=Iu();rt.configure=Su;function Su(){rt.util._configure(),rt.Writer._configure(rt.BufferWriter),rt.Reader._configure(rt.BufferReader)}Su()});var Du=de((My,Pu)=>{"use strict";Pu.exports=Eu()});var Cr=de((Gy,Lu)=>{"use strict";var me=Du(),$=me.Reader,De=me.Writer,g=me.util,h=me.roots.default||(me.roots.default={});h.onnx=function(){var a={};return a.Version=function(){var t={},o=Object.create(t);return o[t[0]="_START_VERSION"]=0,o[t[1]="IR_VERSION_2017_10_10"]=1,o[t[2]="IR_VERSION_2017_10_30"]=2,o[t[3]="IR_VERSION_2017_11_3"]=3,o[t[4]="IR_VERSION_2019_1_22"]=4,o[t[5]="IR_VERSION_2019_3_18"]=5,o[t[6]="IR_VERSION_2019_9_19"]=6,o[t[7]="IR_VERSION_2020_5_8"]=7,o[t[8]="IR_VERSION_2021_7_30"]=8,o[t[9]="IR_VERSION"]=9,o}(),a.AttributeProto=function(){function t(o){if(this.floats=[],this.ints=[],this.strings=[],this.tensors=[],this.graphs=[],this.sparseTensors=[],this.typeProtos=[],o)for(var e=Object.keys(o),r=0;r>>3){case 1:{s.name=e.string();break}case 21:{s.refAttrName=e.string();break}case 13:{s.docString=e.string();break}case 20:{s.type=e.int32();break}case 2:{s.f=e.float();break}case 3:{s.i=e.int64();break}case 4:{s.s=e.bytes();break}case 5:{s.t=h.onnx.TensorProto.decode(e,e.uint32());break}case 6:{s.g=h.onnx.GraphProto.decode(e,e.uint32());break}case 22:{s.sparseTensor=h.onnx.SparseTensorProto.decode(e,e.uint32());break}case 14:{s.tp=h.onnx.TypeProto.decode(e,e.uint32());break}case 7:{if(s.floats&&s.floats.length||(s.floats=[]),(i&7)===2)for(var u=e.uint32()+e.pos;e.pos>>0,e.i.high>>>0).toNumber())),e.s!=null&&(typeof e.s=="string"?g.base64.decode(e.s,r.s=g.newBuffer(g.base64.length(e.s)),0):e.s.length>=0&&(r.s=e.s)),e.t!=null){if(typeof e.t!="object")throw TypeError(".onnx.AttributeProto.t: object expected");r.t=h.onnx.TensorProto.fromObject(e.t)}if(e.g!=null){if(typeof e.g!="object")throw TypeError(".onnx.AttributeProto.g: object expected");r.g=h.onnx.GraphProto.fromObject(e.g)}if(e.sparseTensor!=null){if(typeof e.sparseTensor!="object")throw TypeError(".onnx.AttributeProto.sparseTensor: object expected");r.sparseTensor=h.onnx.SparseTensorProto.fromObject(e.sparseTensor)}if(e.tp!=null){if(typeof e.tp!="object")throw TypeError(".onnx.AttributeProto.tp: object expected");r.tp=h.onnx.TypeProto.fromObject(e.tp)}if(e.floats){if(!Array.isArray(e.floats))throw TypeError(".onnx.AttributeProto.floats: array expected");r.floats=[];for(var n=0;n>>0,e.ints[n].high>>>0).toNumber())}if(e.strings){if(!Array.isArray(e.strings))throw TypeError(".onnx.AttributeProto.strings: array expected");r.strings=[];for(var n=0;n=0&&(r.strings[n]=e.strings[n])}if(e.tensors){if(!Array.isArray(e.tensors))throw TypeError(".onnx.AttributeProto.tensors: array expected");r.tensors=[];for(var n=0;n>>0,e.i.high>>>0).toNumber():e.i),e.s!=null&&e.hasOwnProperty("s")&&(n.s=r.bytes===String?g.base64.encode(e.s,0,e.s.length):r.bytes===Array?Array.prototype.slice.call(e.s):e.s),e.t!=null&&e.hasOwnProperty("t")&&(n.t=h.onnx.TensorProto.toObject(e.t,r)),e.g!=null&&e.hasOwnProperty("g")&&(n.g=h.onnx.GraphProto.toObject(e.g,r)),e.floats&&e.floats.length){n.floats=[];for(var i=0;i>>0,e.ints[i].high>>>0).toNumber():e.ints[i]}if(e.strings&&e.strings.length){n.strings=[];for(var i=0;i>>3){case 1:{s.name=e.string();break}case 2:{s.type=h.onnx.TypeProto.decode(e,e.uint32());break}case 3:{s.docString=e.string();break}default:e.skipType(i&7);break}}return s},t.decodeDelimited=function(e){return e instanceof $||(e=new $(e)),this.decode(e,e.uint32())},t.verify=function(e){if(typeof e!="object"||e===null)return"object expected";if(e.name!=null&&e.hasOwnProperty("name")&&!g.isString(e.name))return"name: string expected";if(e.type!=null&&e.hasOwnProperty("type")){var r=h.onnx.TypeProto.verify(e.type);if(r)return"type."+r}return e.docString!=null&&e.hasOwnProperty("docString")&&!g.isString(e.docString)?"docString: string expected":null},t.fromObject=function(e){if(e instanceof h.onnx.ValueInfoProto)return e;var r=new h.onnx.ValueInfoProto;if(e.name!=null&&(r.name=String(e.name)),e.type!=null){if(typeof e.type!="object")throw TypeError(".onnx.ValueInfoProto.type: object expected");r.type=h.onnx.TypeProto.fromObject(e.type)}return e.docString!=null&&(r.docString=String(e.docString)),r},t.toObject=function(e,r){r||(r={});var n={};return r.defaults&&(n.name="",n.type=null,n.docString=""),e.name!=null&&e.hasOwnProperty("name")&&(n.name=e.name),e.type!=null&&e.hasOwnProperty("type")&&(n.type=h.onnx.TypeProto.toObject(e.type,r)),e.docString!=null&&e.hasOwnProperty("docString")&&(n.docString=e.docString),n},t.prototype.toJSON=function(){return this.constructor.toObject(this,me.util.toJSONOptions)},t.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/onnx.ValueInfoProto"},t}(),a.NodeProto=function(){function t(o){if(this.input=[],this.output=[],this.attribute=[],o)for(var e=Object.keys(o),r=0;r>>3){case 1:{s.input&&s.input.length||(s.input=[]),s.input.push(e.string());break}case 2:{s.output&&s.output.length||(s.output=[]),s.output.push(e.string());break}case 3:{s.name=e.string();break}case 4:{s.opType=e.string();break}case 7:{s.domain=e.string();break}case 5:{s.attribute&&s.attribute.length||(s.attribute=[]),s.attribute.push(h.onnx.AttributeProto.decode(e,e.uint32()));break}case 6:{s.docString=e.string();break}default:e.skipType(i&7);break}}return s},t.decodeDelimited=function(e){return e instanceof $||(e=new $(e)),this.decode(e,e.uint32())},t.verify=function(e){if(typeof e!="object"||e===null)return"object expected";if(e.input!=null&&e.hasOwnProperty("input")){if(!Array.isArray(e.input))return"input: array expected";for(var r=0;r>>3){case 1:{s.initialization=h.onnx.GraphProto.decode(e,e.uint32());break}case 2:{s.algorithm=h.onnx.GraphProto.decode(e,e.uint32());break}case 3:{s.initializationBinding&&s.initializationBinding.length||(s.initializationBinding=[]),s.initializationBinding.push(h.onnx.StringStringEntryProto.decode(e,e.uint32()));break}case 4:{s.updateBinding&&s.updateBinding.length||(s.updateBinding=[]),s.updateBinding.push(h.onnx.StringStringEntryProto.decode(e,e.uint32()));break}default:e.skipType(i&7);break}}return s},t.decodeDelimited=function(e){return e instanceof $||(e=new $(e)),this.decode(e,e.uint32())},t.verify=function(e){if(typeof e!="object"||e===null)return"object expected";if(e.initialization!=null&&e.hasOwnProperty("initialization")){var r=h.onnx.GraphProto.verify(e.initialization);if(r)return"initialization."+r}if(e.algorithm!=null&&e.hasOwnProperty("algorithm")){var r=h.onnx.GraphProto.verify(e.algorithm);if(r)return"algorithm."+r}if(e.initializationBinding!=null&&e.hasOwnProperty("initializationBinding")){if(!Array.isArray(e.initializationBinding))return"initializationBinding: array expected";for(var n=0;n>>3){case 1:{s.irVersion=e.int64();break}case 8:{s.opsetImport&&s.opsetImport.length||(s.opsetImport=[]),s.opsetImport.push(h.onnx.OperatorSetIdProto.decode(e,e.uint32()));break}case 2:{s.producerName=e.string();break}case 3:{s.producerVersion=e.string();break}case 4:{s.domain=e.string();break}case 5:{s.modelVersion=e.int64();break}case 6:{s.docString=e.string();break}case 7:{s.graph=h.onnx.GraphProto.decode(e,e.uint32());break}case 14:{s.metadataProps&&s.metadataProps.length||(s.metadataProps=[]),s.metadataProps.push(h.onnx.StringStringEntryProto.decode(e,e.uint32()));break}case 20:{s.trainingInfo&&s.trainingInfo.length||(s.trainingInfo=[]),s.trainingInfo.push(h.onnx.TrainingInfoProto.decode(e,e.uint32()));break}case 25:{s.functions&&s.functions.length||(s.functions=[]),s.functions.push(h.onnx.FunctionProto.decode(e,e.uint32()));break}default:e.skipType(i&7);break}}return s},t.decodeDelimited=function(e){return e instanceof $||(e=new $(e)),this.decode(e,e.uint32())},t.verify=function(e){if(typeof e!="object"||e===null)return"object expected";if(e.irVersion!=null&&e.hasOwnProperty("irVersion")&&!g.isInteger(e.irVersion)&&!(e.irVersion&&g.isInteger(e.irVersion.low)&&g.isInteger(e.irVersion.high)))return"irVersion: integer|Long expected";if(e.opsetImport!=null&&e.hasOwnProperty("opsetImport")){if(!Array.isArray(e.opsetImport))return"opsetImport: array expected";for(var r=0;r>>0,e.irVersion.high>>>0).toNumber())),e.opsetImport){if(!Array.isArray(e.opsetImport))throw TypeError(".onnx.ModelProto.opsetImport: array expected");r.opsetImport=[];for(var n=0;n>>0,e.modelVersion.high>>>0).toNumber())),e.docString!=null&&(r.docString=String(e.docString)),e.graph!=null){if(typeof e.graph!="object")throw TypeError(".onnx.ModelProto.graph: object expected");r.graph=h.onnx.GraphProto.fromObject(e.graph)}if(e.metadataProps){if(!Array.isArray(e.metadataProps))throw TypeError(".onnx.ModelProto.metadataProps: array expected");r.metadataProps=[];for(var n=0;n>>0,e.irVersion.high>>>0).toNumber():e.irVersion),e.producerName!=null&&e.hasOwnProperty("producerName")&&(n.producerName=e.producerName),e.producerVersion!=null&&e.hasOwnProperty("producerVersion")&&(n.producerVersion=e.producerVersion),e.domain!=null&&e.hasOwnProperty("domain")&&(n.domain=e.domain),e.modelVersion!=null&&e.hasOwnProperty("modelVersion")&&(typeof e.modelVersion=="number"?n.modelVersion=r.longs===String?String(e.modelVersion):e.modelVersion:n.modelVersion=r.longs===String?g.Long.prototype.toString.call(e.modelVersion):r.longs===Number?new g.LongBits(e.modelVersion.low>>>0,e.modelVersion.high>>>0).toNumber():e.modelVersion),e.docString!=null&&e.hasOwnProperty("docString")&&(n.docString=e.docString),e.graph!=null&&e.hasOwnProperty("graph")&&(n.graph=h.onnx.GraphProto.toObject(e.graph,r)),e.opsetImport&&e.opsetImport.length){n.opsetImport=[];for(var i=0;i>>3){case 1:{s.key=e.string();break}case 2:{s.value=e.string();break}default:e.skipType(i&7);break}}return s},t.decodeDelimited=function(e){return e instanceof $||(e=new $(e)),this.decode(e,e.uint32())},t.verify=function(e){return typeof e!="object"||e===null?"object expected":e.key!=null&&e.hasOwnProperty("key")&&!g.isString(e.key)?"key: string expected":e.value!=null&&e.hasOwnProperty("value")&&!g.isString(e.value)?"value: string expected":null},t.fromObject=function(e){if(e instanceof h.onnx.StringStringEntryProto)return e;var r=new h.onnx.StringStringEntryProto;return e.key!=null&&(r.key=String(e.key)),e.value!=null&&(r.value=String(e.value)),r},t.toObject=function(e,r){r||(r={});var n={};return r.defaults&&(n.key="",n.value=""),e.key!=null&&e.hasOwnProperty("key")&&(n.key=e.key),e.value!=null&&e.hasOwnProperty("value")&&(n.value=e.value),n},t.prototype.toJSON=function(){return this.constructor.toObject(this,me.util.toJSONOptions)},t.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/onnx.StringStringEntryProto"},t}(),a.TensorAnnotation=function(){function t(o){if(this.quantParameterTensorNames=[],o)for(var e=Object.keys(o),r=0;r>>3){case 1:{s.tensorName=e.string();break}case 2:{s.quantParameterTensorNames&&s.quantParameterTensorNames.length||(s.quantParameterTensorNames=[]),s.quantParameterTensorNames.push(h.onnx.StringStringEntryProto.decode(e,e.uint32()));break}default:e.skipType(i&7);break}}return s},t.decodeDelimited=function(e){return e instanceof $||(e=new $(e)),this.decode(e,e.uint32())},t.verify=function(e){if(typeof e!="object"||e===null)return"object expected";if(e.tensorName!=null&&e.hasOwnProperty("tensorName")&&!g.isString(e.tensorName))return"tensorName: string expected";if(e.quantParameterTensorNames!=null&&e.hasOwnProperty("quantParameterTensorNames")){if(!Array.isArray(e.quantParameterTensorNames))return"quantParameterTensorNames: array expected";for(var r=0;r>>3){case 1:{s.node&&s.node.length||(s.node=[]),s.node.push(h.onnx.NodeProto.decode(e,e.uint32()));break}case 2:{s.name=e.string();break}case 5:{s.initializer&&s.initializer.length||(s.initializer=[]),s.initializer.push(h.onnx.TensorProto.decode(e,e.uint32()));break}case 15:{s.sparseInitializer&&s.sparseInitializer.length||(s.sparseInitializer=[]),s.sparseInitializer.push(h.onnx.SparseTensorProto.decode(e,e.uint32()));break}case 10:{s.docString=e.string();break}case 11:{s.input&&s.input.length||(s.input=[]),s.input.push(h.onnx.ValueInfoProto.decode(e,e.uint32()));break}case 12:{s.output&&s.output.length||(s.output=[]),s.output.push(h.onnx.ValueInfoProto.decode(e,e.uint32()));break}case 13:{s.valueInfo&&s.valueInfo.length||(s.valueInfo=[]),s.valueInfo.push(h.onnx.ValueInfoProto.decode(e,e.uint32()));break}case 14:{s.quantizationAnnotation&&s.quantizationAnnotation.length||(s.quantizationAnnotation=[]),s.quantizationAnnotation.push(h.onnx.TensorAnnotation.decode(e,e.uint32()));break}default:e.skipType(i&7);break}}return s},t.decodeDelimited=function(e){return e instanceof $||(e=new $(e)),this.decode(e,e.uint32())},t.verify=function(e){if(typeof e!="object"||e===null)return"object expected";if(e.node!=null&&e.hasOwnProperty("node")){if(!Array.isArray(e.node))return"node: array expected";for(var r=0;r>>3){case 1:{if(s.dims&&s.dims.length||(s.dims=[]),(i&7)===2)for(var u=e.uint32()+e.pos;e.pos>>0,e.dims[n].high>>>0).toNumber())}if(e.dataType!=null&&(r.dataType=e.dataType|0),e.segment!=null){if(typeof e.segment!="object")throw TypeError(".onnx.TensorProto.segment: object expected");r.segment=h.onnx.TensorProto.Segment.fromObject(e.segment)}if(e.floatData){if(!Array.isArray(e.floatData))throw TypeError(".onnx.TensorProto.floatData: array expected");r.floatData=[];for(var n=0;n=0&&(r.stringData[n]=e.stringData[n])}if(e.int64Data){if(!Array.isArray(e.int64Data))throw TypeError(".onnx.TensorProto.int64Data: array expected");r.int64Data=[];for(var n=0;n>>0,e.int64Data[n].high>>>0).toNumber())}if(e.name!=null&&(r.name=String(e.name)),e.docString!=null&&(r.docString=String(e.docString)),e.rawData!=null&&(typeof e.rawData=="string"?g.base64.decode(e.rawData,r.rawData=g.newBuffer(g.base64.length(e.rawData)),0):e.rawData.length>=0&&(r.rawData=e.rawData)),e.externalData){if(!Array.isArray(e.externalData))throw TypeError(".onnx.TensorProto.externalData: array expected");r.externalData=[];for(var n=0;n>>0,e.uint64Data[n].high>>>0).toNumber(!0))}return r},t.toObject=function(e,r){r||(r={});var n={};if((r.arrays||r.defaults)&&(n.dims=[],n.floatData=[],n.int32Data=[],n.stringData=[],n.int64Data=[],n.doubleData=[],n.uint64Data=[],n.externalData=[]),r.defaults&&(n.dataType=0,n.segment=null,n.name="",r.bytes===String?n.rawData="":(n.rawData=[],r.bytes!==Array&&(n.rawData=g.newBuffer(n.rawData))),n.docString="",n.dataLocation=r.enums===String?"DEFAULT":0),e.dims&&e.dims.length){n.dims=[];for(var s=0;s>>0,e.dims[s].high>>>0).toNumber():e.dims[s]}if(e.dataType!=null&&e.hasOwnProperty("dataType")&&(n.dataType=e.dataType),e.segment!=null&&e.hasOwnProperty("segment")&&(n.segment=h.onnx.TensorProto.Segment.toObject(e.segment,r)),e.floatData&&e.floatData.length){n.floatData=[];for(var s=0;s>>0,e.int64Data[s].high>>>0).toNumber():e.int64Data[s]}if(e.name!=null&&e.hasOwnProperty("name")&&(n.name=e.name),e.rawData!=null&&e.hasOwnProperty("rawData")&&(n.rawData=r.bytes===String?g.base64.encode(e.rawData,0,e.rawData.length):r.bytes===Array?Array.prototype.slice.call(e.rawData):e.rawData),e.doubleData&&e.doubleData.length){n.doubleData=[];for(var s=0;s>>0,e.uint64Data[s].high>>>0).toNumber(!0):e.uint64Data[s]}if(e.docString!=null&&e.hasOwnProperty("docString")&&(n.docString=e.docString),e.externalData&&e.externalData.length){n.externalData=[];for(var s=0;s>>3){case 1:{i.begin=r.int64();break}case 2:{i.end=r.int64();break}default:r.skipType(u&7);break}}return i},o.decodeDelimited=function(r){return r instanceof $||(r=new $(r)),this.decode(r,r.uint32())},o.verify=function(r){return typeof r!="object"||r===null?"object expected":r.begin!=null&&r.hasOwnProperty("begin")&&!g.isInteger(r.begin)&&!(r.begin&&g.isInteger(r.begin.low)&&g.isInteger(r.begin.high))?"begin: integer|Long expected":r.end!=null&&r.hasOwnProperty("end")&&!g.isInteger(r.end)&&!(r.end&&g.isInteger(r.end.low)&&g.isInteger(r.end.high))?"end: integer|Long expected":null},o.fromObject=function(r){if(r instanceof h.onnx.TensorProto.Segment)return r;var n=new h.onnx.TensorProto.Segment;return r.begin!=null&&(g.Long?(n.begin=g.Long.fromValue(r.begin)).unsigned=!1:typeof r.begin=="string"?n.begin=parseInt(r.begin,10):typeof r.begin=="number"?n.begin=r.begin:typeof r.begin=="object"&&(n.begin=new g.LongBits(r.begin.low>>>0,r.begin.high>>>0).toNumber())),r.end!=null&&(g.Long?(n.end=g.Long.fromValue(r.end)).unsigned=!1:typeof r.end=="string"?n.end=parseInt(r.end,10):typeof r.end=="number"?n.end=r.end:typeof r.end=="object"&&(n.end=new g.LongBits(r.end.low>>>0,r.end.high>>>0).toNumber())),n},o.toObject=function(r,n){n||(n={});var s={};if(n.defaults){if(g.Long){var i=new g.Long(0,0,!1);s.begin=n.longs===String?i.toString():n.longs===Number?i.toNumber():i}else s.begin=n.longs===String?"0":0;if(g.Long){var i=new g.Long(0,0,!1);s.end=n.longs===String?i.toString():n.longs===Number?i.toNumber():i}else s.end=n.longs===String?"0":0}return r.begin!=null&&r.hasOwnProperty("begin")&&(typeof r.begin=="number"?s.begin=n.longs===String?String(r.begin):r.begin:s.begin=n.longs===String?g.Long.prototype.toString.call(r.begin):n.longs===Number?new g.LongBits(r.begin.low>>>0,r.begin.high>>>0).toNumber():r.begin),r.end!=null&&r.hasOwnProperty("end")&&(typeof r.end=="number"?s.end=n.longs===String?String(r.end):r.end:s.end=n.longs===String?g.Long.prototype.toString.call(r.end):n.longs===Number?new g.LongBits(r.end.low>>>0,r.end.high>>>0).toNumber():r.end),s},o.prototype.toJSON=function(){return this.constructor.toObject(this,me.util.toJSONOptions)},o.getTypeUrl=function(r){return r===void 0&&(r="type.googleapis.com"),r+"/onnx.TensorProto.Segment"},o}(),t.DataLocation=function(){var o={},e=Object.create(o);return e[o[0]="DEFAULT"]=0,e[o[1]="EXTERNAL"]=1,e}(),t}(),a.SparseTensorProto=function(){function t(o){if(this.dims=[],o)for(var e=Object.keys(o),r=0;r>>3){case 1:{s.values=h.onnx.TensorProto.decode(e,e.uint32());break}case 2:{s.indices=h.onnx.TensorProto.decode(e,e.uint32());break}case 3:{if(s.dims&&s.dims.length||(s.dims=[]),(i&7)===2)for(var u=e.uint32()+e.pos;e.pos>>0,e.dims[n].high>>>0).toNumber())}return r},t.toObject=function(e,r){r||(r={});var n={};if((r.arrays||r.defaults)&&(n.dims=[]),r.defaults&&(n.values=null,n.indices=null),e.values!=null&&e.hasOwnProperty("values")&&(n.values=h.onnx.TensorProto.toObject(e.values,r)),e.indices!=null&&e.hasOwnProperty("indices")&&(n.indices=h.onnx.TensorProto.toObject(e.indices,r)),e.dims&&e.dims.length){n.dims=[];for(var s=0;s>>0,e.dims[s].high>>>0).toNumber():e.dims[s]}return n},t.prototype.toJSON=function(){return this.constructor.toObject(this,me.util.toJSONOptions)},t.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/onnx.SparseTensorProto"},t}(),a.TensorShapeProto=function(){function t(o){if(this.dim=[],o)for(var e=Object.keys(o),r=0;r>>3){case 1:{s.dim&&s.dim.length||(s.dim=[]),s.dim.push(h.onnx.TensorShapeProto.Dimension.decode(e,e.uint32()));break}default:e.skipType(i&7);break}}return s},t.decodeDelimited=function(e){return e instanceof $||(e=new $(e)),this.decode(e,e.uint32())},t.verify=function(e){if(typeof e!="object"||e===null)return"object expected";if(e.dim!=null&&e.hasOwnProperty("dim")){if(!Array.isArray(e.dim))return"dim: array expected";for(var r=0;r>>3){case 1:{u.dimValue=n.int64();break}case 2:{u.dimParam=n.string();break}case 3:{u.denotation=n.string();break}default:n.skipType(l&7);break}}return u},o.decodeDelimited=function(n){return n instanceof $||(n=new $(n)),this.decode(n,n.uint32())},o.verify=function(n){if(typeof n!="object"||n===null)return"object expected";var s={};if(n.dimValue!=null&&n.hasOwnProperty("dimValue")&&(s.value=1,!g.isInteger(n.dimValue)&&!(n.dimValue&&g.isInteger(n.dimValue.low)&&g.isInteger(n.dimValue.high))))return"dimValue: integer|Long expected";if(n.dimParam!=null&&n.hasOwnProperty("dimParam")){if(s.value===1)return"value: multiple values";if(s.value=1,!g.isString(n.dimParam))return"dimParam: string expected"}return n.denotation!=null&&n.hasOwnProperty("denotation")&&!g.isString(n.denotation)?"denotation: string expected":null},o.fromObject=function(n){if(n instanceof h.onnx.TensorShapeProto.Dimension)return n;var s=new h.onnx.TensorShapeProto.Dimension;return n.dimValue!=null&&(g.Long?(s.dimValue=g.Long.fromValue(n.dimValue)).unsigned=!1:typeof n.dimValue=="string"?s.dimValue=parseInt(n.dimValue,10):typeof n.dimValue=="number"?s.dimValue=n.dimValue:typeof n.dimValue=="object"&&(s.dimValue=new g.LongBits(n.dimValue.low>>>0,n.dimValue.high>>>0).toNumber())),n.dimParam!=null&&(s.dimParam=String(n.dimParam)),n.denotation!=null&&(s.denotation=String(n.denotation)),s},o.toObject=function(n,s){s||(s={});var i={};return s.defaults&&(i.denotation=""),n.dimValue!=null&&n.hasOwnProperty("dimValue")&&(typeof n.dimValue=="number"?i.dimValue=s.longs===String?String(n.dimValue):n.dimValue:i.dimValue=s.longs===String?g.Long.prototype.toString.call(n.dimValue):s.longs===Number?new g.LongBits(n.dimValue.low>>>0,n.dimValue.high>>>0).toNumber():n.dimValue,s.oneofs&&(i.value="dimValue")),n.dimParam!=null&&n.hasOwnProperty("dimParam")&&(i.dimParam=n.dimParam,s.oneofs&&(i.value="dimParam")),n.denotation!=null&&n.hasOwnProperty("denotation")&&(i.denotation=n.denotation),i},o.prototype.toJSON=function(){return this.constructor.toObject(this,me.util.toJSONOptions)},o.getTypeUrl=function(n){return n===void 0&&(n="type.googleapis.com"),n+"/onnx.TensorShapeProto.Dimension"},o}(),t}(),a.TypeProto=function(){function t(e){if(e)for(var r=Object.keys(e),n=0;n>>3){case 1:{i.tensorType=h.onnx.TypeProto.Tensor.decode(r,r.uint32());break}case 4:{i.sequenceType=h.onnx.TypeProto.Sequence.decode(r,r.uint32());break}case 5:{i.mapType=h.onnx.TypeProto.Map.decode(r,r.uint32());break}case 9:{i.optionalType=h.onnx.TypeProto.Optional.decode(r,r.uint32());break}case 8:{i.sparseTensorType=h.onnx.TypeProto.SparseTensor.decode(r,r.uint32());break}case 6:{i.denotation=r.string();break}default:r.skipType(u&7);break}}return i},t.decodeDelimited=function(r){return r instanceof $||(r=new $(r)),this.decode(r,r.uint32())},t.verify=function(r){if(typeof r!="object"||r===null)return"object expected";var n={};if(r.tensorType!=null&&r.hasOwnProperty("tensorType")){n.value=1;{var s=h.onnx.TypeProto.Tensor.verify(r.tensorType);if(s)return"tensorType."+s}}if(r.sequenceType!=null&&r.hasOwnProperty("sequenceType")){if(n.value===1)return"value: multiple values";n.value=1;{var s=h.onnx.TypeProto.Sequence.verify(r.sequenceType);if(s)return"sequenceType."+s}}if(r.mapType!=null&&r.hasOwnProperty("mapType")){if(n.value===1)return"value: multiple values";n.value=1;{var s=h.onnx.TypeProto.Map.verify(r.mapType);if(s)return"mapType."+s}}if(r.optionalType!=null&&r.hasOwnProperty("optionalType")){if(n.value===1)return"value: multiple values";n.value=1;{var s=h.onnx.TypeProto.Optional.verify(r.optionalType);if(s)return"optionalType."+s}}if(r.sparseTensorType!=null&&r.hasOwnProperty("sparseTensorType")){if(n.value===1)return"value: multiple values";n.value=1;{var s=h.onnx.TypeProto.SparseTensor.verify(r.sparseTensorType);if(s)return"sparseTensorType."+s}}return r.denotation!=null&&r.hasOwnProperty("denotation")&&!g.isString(r.denotation)?"denotation: string expected":null},t.fromObject=function(r){if(r instanceof h.onnx.TypeProto)return r;var n=new h.onnx.TypeProto;if(r.tensorType!=null){if(typeof r.tensorType!="object")throw TypeError(".onnx.TypeProto.tensorType: object expected");n.tensorType=h.onnx.TypeProto.Tensor.fromObject(r.tensorType)}if(r.sequenceType!=null){if(typeof r.sequenceType!="object")throw TypeError(".onnx.TypeProto.sequenceType: object expected");n.sequenceType=h.onnx.TypeProto.Sequence.fromObject(r.sequenceType)}if(r.mapType!=null){if(typeof r.mapType!="object")throw TypeError(".onnx.TypeProto.mapType: object expected");n.mapType=h.onnx.TypeProto.Map.fromObject(r.mapType)}if(r.optionalType!=null){if(typeof r.optionalType!="object")throw TypeError(".onnx.TypeProto.optionalType: object expected");n.optionalType=h.onnx.TypeProto.Optional.fromObject(r.optionalType)}if(r.sparseTensorType!=null){if(typeof r.sparseTensorType!="object")throw TypeError(".onnx.TypeProto.sparseTensorType: object expected");n.sparseTensorType=h.onnx.TypeProto.SparseTensor.fromObject(r.sparseTensorType)}return r.denotation!=null&&(n.denotation=String(r.denotation)),n},t.toObject=function(r,n){n||(n={});var s={};return n.defaults&&(s.denotation=""),r.tensorType!=null&&r.hasOwnProperty("tensorType")&&(s.tensorType=h.onnx.TypeProto.Tensor.toObject(r.tensorType,n),n.oneofs&&(s.value="tensorType")),r.sequenceType!=null&&r.hasOwnProperty("sequenceType")&&(s.sequenceType=h.onnx.TypeProto.Sequence.toObject(r.sequenceType,n),n.oneofs&&(s.value="sequenceType")),r.mapType!=null&&r.hasOwnProperty("mapType")&&(s.mapType=h.onnx.TypeProto.Map.toObject(r.mapType,n),n.oneofs&&(s.value="mapType")),r.denotation!=null&&r.hasOwnProperty("denotation")&&(s.denotation=r.denotation),r.sparseTensorType!=null&&r.hasOwnProperty("sparseTensorType")&&(s.sparseTensorType=h.onnx.TypeProto.SparseTensor.toObject(r.sparseTensorType,n),n.oneofs&&(s.value="sparseTensorType")),r.optionalType!=null&&r.hasOwnProperty("optionalType")&&(s.optionalType=h.onnx.TypeProto.Optional.toObject(r.optionalType,n),n.oneofs&&(s.value="optionalType")),s},t.prototype.toJSON=function(){return this.constructor.toObject(this,me.util.toJSONOptions)},t.getTypeUrl=function(r){return r===void 0&&(r="type.googleapis.com"),r+"/onnx.TypeProto"},t.Tensor=function(){function e(r){if(r)for(var n=Object.keys(r),s=0;s>>3){case 1:{u.elemType=n.int32();break}case 2:{u.shape=h.onnx.TensorShapeProto.decode(n,n.uint32());break}default:n.skipType(l&7);break}}return u},e.decodeDelimited=function(n){return n instanceof $||(n=new $(n)),this.decode(n,n.uint32())},e.verify=function(n){if(typeof n!="object"||n===null)return"object expected";if(n.elemType!=null&&n.hasOwnProperty("elemType")&&!g.isInteger(n.elemType))return"elemType: integer expected";if(n.shape!=null&&n.hasOwnProperty("shape")){var s=h.onnx.TensorShapeProto.verify(n.shape);if(s)return"shape."+s}return null},e.fromObject=function(n){if(n instanceof h.onnx.TypeProto.Tensor)return n;var s=new h.onnx.TypeProto.Tensor;if(n.elemType!=null&&(s.elemType=n.elemType|0),n.shape!=null){if(typeof n.shape!="object")throw TypeError(".onnx.TypeProto.Tensor.shape: object expected");s.shape=h.onnx.TensorShapeProto.fromObject(n.shape)}return s},e.toObject=function(n,s){s||(s={});var i={};return s.defaults&&(i.elemType=0,i.shape=null),n.elemType!=null&&n.hasOwnProperty("elemType")&&(i.elemType=n.elemType),n.shape!=null&&n.hasOwnProperty("shape")&&(i.shape=h.onnx.TensorShapeProto.toObject(n.shape,s)),i},e.prototype.toJSON=function(){return this.constructor.toObject(this,me.util.toJSONOptions)},e.getTypeUrl=function(n){return n===void 0&&(n="type.googleapis.com"),n+"/onnx.TypeProto.Tensor"},e}(),t.Sequence=function(){function e(r){if(r)for(var n=Object.keys(r),s=0;s>>3){case 1:{u.elemType=h.onnx.TypeProto.decode(n,n.uint32());break}default:n.skipType(l&7);break}}return u},e.decodeDelimited=function(n){return n instanceof $||(n=new $(n)),this.decode(n,n.uint32())},e.verify=function(n){if(typeof n!="object"||n===null)return"object expected";if(n.elemType!=null&&n.hasOwnProperty("elemType")){var s=h.onnx.TypeProto.verify(n.elemType);if(s)return"elemType."+s}return null},e.fromObject=function(n){if(n instanceof h.onnx.TypeProto.Sequence)return n;var s=new h.onnx.TypeProto.Sequence;if(n.elemType!=null){if(typeof n.elemType!="object")throw TypeError(".onnx.TypeProto.Sequence.elemType: object expected");s.elemType=h.onnx.TypeProto.fromObject(n.elemType)}return s},e.toObject=function(n,s){s||(s={});var i={};return s.defaults&&(i.elemType=null),n.elemType!=null&&n.hasOwnProperty("elemType")&&(i.elemType=h.onnx.TypeProto.toObject(n.elemType,s)),i},e.prototype.toJSON=function(){return this.constructor.toObject(this,me.util.toJSONOptions)},e.getTypeUrl=function(n){return n===void 0&&(n="type.googleapis.com"),n+"/onnx.TypeProto.Sequence"},e}(),t.Map=function(){function e(r){if(r)for(var n=Object.keys(r),s=0;s>>3){case 1:{u.keyType=n.int32();break}case 2:{u.valueType=h.onnx.TypeProto.decode(n,n.uint32());break}default:n.skipType(l&7);break}}return u},e.decodeDelimited=function(n){return n instanceof $||(n=new $(n)),this.decode(n,n.uint32())},e.verify=function(n){if(typeof n!="object"||n===null)return"object expected";if(n.keyType!=null&&n.hasOwnProperty("keyType")&&!g.isInteger(n.keyType))return"keyType: integer expected";if(n.valueType!=null&&n.hasOwnProperty("valueType")){var s=h.onnx.TypeProto.verify(n.valueType);if(s)return"valueType."+s}return null},e.fromObject=function(n){if(n instanceof h.onnx.TypeProto.Map)return n;var s=new h.onnx.TypeProto.Map;if(n.keyType!=null&&(s.keyType=n.keyType|0),n.valueType!=null){if(typeof n.valueType!="object")throw TypeError(".onnx.TypeProto.Map.valueType: object expected");s.valueType=h.onnx.TypeProto.fromObject(n.valueType)}return s},e.toObject=function(n,s){s||(s={});var i={};return s.defaults&&(i.keyType=0,i.valueType=null),n.keyType!=null&&n.hasOwnProperty("keyType")&&(i.keyType=n.keyType),n.valueType!=null&&n.hasOwnProperty("valueType")&&(i.valueType=h.onnx.TypeProto.toObject(n.valueType,s)),i},e.prototype.toJSON=function(){return this.constructor.toObject(this,me.util.toJSONOptions)},e.getTypeUrl=function(n){return n===void 0&&(n="type.googleapis.com"),n+"/onnx.TypeProto.Map"},e}(),t.Optional=function(){function e(r){if(r)for(var n=Object.keys(r),s=0;s>>3){case 1:{u.elemType=h.onnx.TypeProto.decode(n,n.uint32());break}default:n.skipType(l&7);break}}return u},e.decodeDelimited=function(n){return n instanceof $||(n=new $(n)),this.decode(n,n.uint32())},e.verify=function(n){if(typeof n!="object"||n===null)return"object expected";if(n.elemType!=null&&n.hasOwnProperty("elemType")){var s=h.onnx.TypeProto.verify(n.elemType);if(s)return"elemType."+s}return null},e.fromObject=function(n){if(n instanceof h.onnx.TypeProto.Optional)return n;var s=new h.onnx.TypeProto.Optional;if(n.elemType!=null){if(typeof n.elemType!="object")throw TypeError(".onnx.TypeProto.Optional.elemType: object expected");s.elemType=h.onnx.TypeProto.fromObject(n.elemType)}return s},e.toObject=function(n,s){s||(s={});var i={};return s.defaults&&(i.elemType=null),n.elemType!=null&&n.hasOwnProperty("elemType")&&(i.elemType=h.onnx.TypeProto.toObject(n.elemType,s)),i},e.prototype.toJSON=function(){return this.constructor.toObject(this,me.util.toJSONOptions)},e.getTypeUrl=function(n){return n===void 0&&(n="type.googleapis.com"),n+"/onnx.TypeProto.Optional"},e}(),t.SparseTensor=function(){function e(r){if(r)for(var n=Object.keys(r),s=0;s>>3){case 1:{u.elemType=n.int32();break}case 2:{u.shape=h.onnx.TensorShapeProto.decode(n,n.uint32());break}default:n.skipType(l&7);break}}return u},e.decodeDelimited=function(n){return n instanceof $||(n=new $(n)),this.decode(n,n.uint32())},e.verify=function(n){if(typeof n!="object"||n===null)return"object expected";if(n.elemType!=null&&n.hasOwnProperty("elemType")&&!g.isInteger(n.elemType))return"elemType: integer expected";if(n.shape!=null&&n.hasOwnProperty("shape")){var s=h.onnx.TensorShapeProto.verify(n.shape);if(s)return"shape."+s}return null},e.fromObject=function(n){if(n instanceof h.onnx.TypeProto.SparseTensor)return n;var s=new h.onnx.TypeProto.SparseTensor;if(n.elemType!=null&&(s.elemType=n.elemType|0),n.shape!=null){if(typeof n.shape!="object")throw TypeError(".onnx.TypeProto.SparseTensor.shape: object expected");s.shape=h.onnx.TensorShapeProto.fromObject(n.shape)}return s},e.toObject=function(n,s){s||(s={});var i={};return s.defaults&&(i.elemType=0,i.shape=null),n.elemType!=null&&n.hasOwnProperty("elemType")&&(i.elemType=n.elemType),n.shape!=null&&n.hasOwnProperty("shape")&&(i.shape=h.onnx.TensorShapeProto.toObject(n.shape,s)),i},e.prototype.toJSON=function(){return this.constructor.toObject(this,me.util.toJSONOptions)},e.getTypeUrl=function(n){return n===void 0&&(n="type.googleapis.com"),n+"/onnx.TypeProto.SparseTensor"},e}(),t}(),a.OperatorSetIdProto=function(){function t(o){if(o)for(var e=Object.keys(o),r=0;r>>3){case 1:{s.domain=e.string();break}case 2:{s.version=e.int64();break}default:e.skipType(i&7);break}}return s},t.decodeDelimited=function(e){return e instanceof $||(e=new $(e)),this.decode(e,e.uint32())},t.verify=function(e){return typeof e!="object"||e===null?"object expected":e.domain!=null&&e.hasOwnProperty("domain")&&!g.isString(e.domain)?"domain: string expected":e.version!=null&&e.hasOwnProperty("version")&&!g.isInteger(e.version)&&!(e.version&&g.isInteger(e.version.low)&&g.isInteger(e.version.high))?"version: integer|Long expected":null},t.fromObject=function(e){if(e instanceof h.onnx.OperatorSetIdProto)return e;var r=new h.onnx.OperatorSetIdProto;return e.domain!=null&&(r.domain=String(e.domain)),e.version!=null&&(g.Long?(r.version=g.Long.fromValue(e.version)).unsigned=!1:typeof e.version=="string"?r.version=parseInt(e.version,10):typeof e.version=="number"?r.version=e.version:typeof e.version=="object"&&(r.version=new g.LongBits(e.version.low>>>0,e.version.high>>>0).toNumber())),r},t.toObject=function(e,r){r||(r={});var n={};if(r.defaults)if(n.domain="",g.Long){var s=new g.Long(0,0,!1);n.version=r.longs===String?s.toString():r.longs===Number?s.toNumber():s}else n.version=r.longs===String?"0":0;return e.domain!=null&&e.hasOwnProperty("domain")&&(n.domain=e.domain),e.version!=null&&e.hasOwnProperty("version")&&(typeof e.version=="number"?n.version=r.longs===String?String(e.version):e.version:n.version=r.longs===String?g.Long.prototype.toString.call(e.version):r.longs===Number?new g.LongBits(e.version.low>>>0,e.version.high>>>0).toNumber():e.version),n},t.prototype.toJSON=function(){return this.constructor.toObject(this,me.util.toJSONOptions)},t.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/onnx.OperatorSetIdProto"},t}(),a.OperatorStatus=function(){var t={},o=Object.create(t);return o[t[0]="EXPERIMENTAL"]=0,o[t[1]="STABLE"]=1,o}(),a.FunctionProto=function(){function t(o){if(this.input=[],this.output=[],this.attribute=[],this.attributeProto=[],this.node=[],this.opsetImport=[],o)for(var e=Object.keys(o),r=0;r>>3){case 1:{s.name=e.string();break}case 4:{s.input&&s.input.length||(s.input=[]),s.input.push(e.string());break}case 5:{s.output&&s.output.length||(s.output=[]),s.output.push(e.string());break}case 6:{s.attribute&&s.attribute.length||(s.attribute=[]),s.attribute.push(e.string());break}case 11:{s.attributeProto&&s.attributeProto.length||(s.attributeProto=[]),s.attributeProto.push(h.onnx.AttributeProto.decode(e,e.uint32()));break}case 7:{s.node&&s.node.length||(s.node=[]),s.node.push(h.onnx.NodeProto.decode(e,e.uint32()));break}case 8:{s.docString=e.string();break}case 9:{s.opsetImport&&s.opsetImport.length||(s.opsetImport=[]),s.opsetImport.push(h.onnx.OperatorSetIdProto.decode(e,e.uint32()));break}case 10:{s.domain=e.string();break}default:e.skipType(i&7);break}}return s},t.decodeDelimited=function(e){return e instanceof $||(e=new $(e)),this.decode(e,e.uint32())},t.verify=function(e){if(typeof e!="object"||e===null)return"object expected";if(e.name!=null&&e.hasOwnProperty("name")&&!g.isString(e.name))return"name: string expected";if(e.input!=null&&e.hasOwnProperty("input")){if(!Array.isArray(e.input))return"input: array expected";for(var r=0;r{"use strict";Vn();Zo();be=Er(Cr());hr();fr=class{static arraysEqual(t,o){if(t.length!==o.length)return!1;for(let e=0;e1&&f>1)return;i[s-u]=Math.max(l,f)}return i}static index(t,o){let e=new Array(o.length);return a.fillIndex(t,o,e),e}static fillIndex(t,o,e){let r=t.length-o.length;for(let n=0;n=0;F--)l[F]=I%s[F],I=Math.floor(I/s[F]);v||(a.fillIndex(l,t.dims,f),d=t.get(f)),w||(a.fillIndex(l,o.dims,p),T=o.get(p)),u.set(l,e(d,T))}}return u}}static isValidBroadcast(t,o){let e=t.length,r=o.length;if(e>r)return!1;for(let n=1;n<=e;n++)if(t[e-n]!==1&&t[e-n]!==o[r-n])return!1;return!0}static getBroadcastDims(t,o){let e=t.length,r=[];for(let n=0;n1&&i===1&&r.unshift(s)}return r}},Yn=class{static getShapeOfGemmResult(t,o,e,r,n){if(t.length!==2||e.length!==2)throw new Error("shape need to be of size 2");let s,i,u;o?(s=t[1],i=t[0]):(s=t[0],i=t[1]);let l=-1;if(r?(u=e[0],l=1):(u=e[1],l=0),e[l]!==i)throw new Error("dimension mismatch");if(s<=0||u<=0||i<=0)throw new Error("invalid shape specified");if(n&&!Ke.isValidBroadcast(n,[s,u]))throw new Error("gemm: invalid bias shape for broadcast");return[s,u,i]}},We=class a{static tensorDataTypeFromProto(t){switch(t){case be.onnx.TensorProto.DataType.INT8:return"int8";case be.onnx.TensorProto.DataType.UINT8:return"uint8";case be.onnx.TensorProto.DataType.BOOL:return"bool";case be.onnx.TensorProto.DataType.INT16:return"int16";case be.onnx.TensorProto.DataType.UINT16:return"uint16";case be.onnx.TensorProto.DataType.INT32:return"int32";case be.onnx.TensorProto.DataType.UINT32:return"uint32";case be.onnx.TensorProto.DataType.FLOAT:return"float32";case be.onnx.TensorProto.DataType.DOUBLE:return"float64";case be.onnx.TensorProto.DataType.STRING:return"string";case be.onnx.TensorProto.DataType.INT64:return"int32";case be.onnx.TensorProto.DataType.UINT64:return"uint32";default:throw new Error(`unsupported data type: ${be.onnx.TensorProto.DataType[t]}`)}}static tensorDataTypeStringToEnum(t){switch(t){case"int8":return be.onnx.TensorProto.DataType.INT8;case"uint8":return be.onnx.TensorProto.DataType.UINT8;case"bool":return be.onnx.TensorProto.DataType.BOOL;case"int16":return be.onnx.TensorProto.DataType.INT16;case"uint16":return be.onnx.TensorProto.DataType.UINT16;case"int32":return be.onnx.TensorProto.DataType.INT32;case"uint32":return be.onnx.TensorProto.DataType.UINT32;case"float32":return be.onnx.TensorProto.DataType.FLOAT;case"float64":return be.onnx.TensorProto.DataType.DOUBLE;case"string":return be.onnx.TensorProto.DataType.STRING;case"int64":return be.onnx.TensorProto.DataType.INT64;case"uint64":return be.onnx.TensorProto.DataType.UINT64;default:throw new Error(`unsupported data type: ${t}`)}}static tensorDimsFromProto(t){return t.map(o=>Mt.isLong(o)?o.toNumber():o)}static tensorValueTypeFromProto(t){return{tensorType:a.tensorDataTypeFromProto(t.elemType),shape:{dims:a.tensorDimsFromProto(t.shape.dim.map(o=>o.dimValue))}}}static tensorDimsFromORTFormat(t){let o=[];for(let e=0;et.length)throw new Error(`invalid dimension of ${o} for sizeFromDimension as Tensor has ${t.length} dimensions.`);return a.getSizeFromDimensionRange(t,o,t.length)}static sizeToDimension(t,o){if(o<0||o>t.length)throw new Error(`invalid dimension of ${o} for sizeToDimension as Tensor has ${t.length} dimensions.`);return a.getSizeFromDimensionRange(t,0,o)}static getSizeFromDimensionRange(t,o,e){let r=1;for(let n=o;n=0;--r)e[r]=e[r+1]*t[r+1];return e}static transpose(t){return t.slice().reverse()}static indicesToOffset(t,o,e){e===void 0&&(e=t.length);let r=0;for(let n=0;n=o)throw new Error("unsupported axis for this operation.");return t<0?t+o:t}static normalizeAxes(t,o){return t.map(e=>this.normalizeAxis(e,o))}static incrementIndex(t,o,e){if(o.length===0||t.length===0)throw new Error("Index incrementing unsupported for scalar Tensor");if(e===void 0)e=o.length;else if(e<=0||e>o.length)throw new Error("Incorrect axis to increment on");for(let r=e-1;r>=0&&(t[r]++,!(t[r]=t.length)throw new Error("the dimension with value zero exceeds the dimension size of the input tensor");r[u]=t[u]}else r[u]=o[u];s*=r[u]}}let i=a.size(t);if(n!==-1){if(i%s!==0)throw new Error(`the input tensor cannot be reshaped to the requested shape. Input shape: [${t}] Output shape: [${o}]`);r[n]=i/s}else if(s!==i)throw new Error("reshapedDims and originalDims don't have matching sizes");return r}static sortBasedOnPerm(t,o){return o?o.map(e=>t[e]):t.slice().reverse()}static padShape(t,o){let e=t.length;return t.map((r,n)=>r+o[n]+o[n+e])}static areEqual(t,o){return t.length!==o.length?!1:t.every((e,r)=>e===o[r])}static validateDimsAndCalcSize(t){if(t.length>6)throw new TypeError("Only rank 0 to 6 is supported for tensor shape.");let o=1;for(let e of t){if(!Number.isInteger(e))throw new TypeError(`Invalid shape: ${e} is not an integer`);if(e<0||e>2147483647)throw new TypeError(`Invalid shape: length ${e} is not allowed`);o*=e}return o}static flattenShape(t,o){o<0&&(o+=t.length);let e=t.reduce((s,i)=>s*i,1),r=t.slice(o).reduce((s,i)=>s*i,1);return[e/r,r]}static squeezeShape(t,o){let e=new Array;o=a.normalizeAxes(o,t.length);for(let r=0;r=0;if(n&&t[r]!==1)throw new Error("squeeze an axis of size different than 1");(o.length===0&&t[r]>1||o.length>0&&!n)&&e.push(t[r])}return e}static unsqueezeShape(t,o){let e=new Array(t.length+o.length);e.fill(0);for(let n=0;n=e.length)throw new Error("'axes' has an out of range axis");if(e[s]!==0)throw new Error("'axes' has a duplicate axis");e[s]=1}let r=0;for(let n=0;n=e.length?e.push(o[i+2]):e[i]=o[i+2];for(let i=0;i=e[i]||s[i+e.length]>=e[i])throw new Error("pads should be smaller than kernel")}}static adjustPadsBasedOnAutoPad(t,o,e,r,n,s){if(s){if(n.length!==2*(t.length-2))throw new Error("length of pads should be twice the length of data dimensions");if(o.length!==t.length-2)throw new Error("length of strides should be the length of data dimensions");if(r.length!==t.length-2)throw new Error("length of kernel shapes should be the length of data dimensions");for(let i=0;i{"use strict";ku=Er(_s());Zo();an();ee=Er(Cr());le();di=H.experimental.fbs,ke=class a{constructor(t,o,e,r,n,s=ku.Guid.create()){this.dims=t;this.type=o;this.dataProvider=e;this.asyncDataProvider=r;this.cache=n;this.dataId=s;this.size=U.validateDimsAndCalcSize(t);let i=this.size,u=e===void 0&&r===void 0&&n===void 0;if(n!==void 0&&n.length!==i)throw new RangeError("Input dims doesn't match data length.");if(o==="string"){if(n!==void 0&&(!Array.isArray(n)||!n.every(l=>typeof l=="string")))throw new TypeError("cache should be a string array");u&&(this.cache=new Array(i))}else{if(n!==void 0){let l=Bu(o);if(!(n instanceof l))throw new TypeError(`cache should be type ${l.name}`)}if(u){let l=new ArrayBuffer(i*qd(o));this.cache=jd(l,o)}}}get data(){if(this.cache===void 0){let t=this.dataProvider(this.dataId);if(t.length!==this.size)throw new Error("Length of data provided by the Data Provider is inconsistent with the dims of this Tensor.");this.cache=t}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(t){return this.data[U.indicesToOffset(t,this.strides)]}set(t,o){this.data[U.indicesToOffset(t,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(t){if(!t)throw new Error("cannot construct Value from an empty tensor");let o=We.tensorDataTypeFromProto(t.dataType),e=We.tensorDimsFromProto(t.dims),r=new a(e,o);if(o==="string")t.stringData.forEach((n,s)=>{r.data[s]=cn(n)});else if(t.rawData&&typeof t.rawData.byteLength=="number"&&t.rawData.byteLength>0){let n=r.data,s=new DataView(t.rawData.buffer,t.rawData.byteOffset,t.rawData.byteLength),i=Fu(t.dataType),u=t.rawData.byteLength/i;if(t.rawData.byteLength%i!==0)throw new Error("invalid buffer length");if(n.length!==u)throw new Error("buffer length mismatch");for(let l=0;l0){let n=r.data,s=new DataView(t.rawDataArray().buffer,t.rawDataArray().byteOffset,t.rawDataLength()),i=Fu(t.dataType()),u=t.rawDataLength()/i;if(t.rawDataLength()%i!==0)throw new Error("invalid buffer length");if(n.length!==u)throw new Error("buffer length mismatch");for(let l=0;l{"use strict";Yd={version:"",attribute:"attribute",varyingVertex:"varying",varyingFrag:"varying",texture2D:"texture2D",output:"gl_FragColor",outputDeclaration:""},Xd={version:"#version 300 es",attribute:"in",varyingVertex:"out",varyingFrag:"in",texture2D:"texture",output:"outputColor",outputDeclaration:"out vec4 outputColor;"}});var oe=P(()=>{"use strict"});async function mi(a,t=e=>0,o){return new Promise((e,r)=>{let n=0,s=()=>{if(a()){e();return}n++;let i=t(n);if(o!=null&&n>=o){r();return}setTimeout(s,i)};s()})}function Xn(a){return kr(typeof a<"u"&&a.length!==0,()=>"empty string found for sampler name"),"get"+a.charAt(0).toUpperCase()+a.slice(1)}function Mu(a){return kr(typeof a<"u"&&a.length!==0,()=>"empty string found for sampler name"),"get"+a.charAt(0).toUpperCase()+a.slice(1)+"AtOutCoords"}function Br(a,t){let o=JSON.parse(JSON.stringify(a));return o=t,o}function $r(a,t){return t.map(o=>a[o]).join(", ")}function Je(a){if(a<=1)return"int";if(a===2)return"ivec2";if(a===3)return"ivec3";if(a===4)return"ivec4";if(a===5)return"ivec5";if(a===6)return"ivec6";throw Error(`GPU for rank ${a} is not yet supported`)}function It(a=6){return["x","y","z","w","u","v"].slice(0,a)}var Ct=P(()=>{"use strict";le()});function Kd(a,t){return It(t).map(o=>`${a}.${o}`)}function Nr(a,t){return t===1?[a]:Kd(a,t)}function kt(){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 mr=P(()=>{"use strict";Ct()});function Zd(a,t,o){if(a===0)return"false";if(a===1)return`rc > ${t[0]}`;let e="";for(let r=a-2;r= ${t[r-a+2]}`,r= ${a[0]} ? 0. : getA(rc + 1), + 0, 0`;let e="r, c",r="r, cp1",n="rp1, c",s="rp1, cp1",i="";if(o>2)for(let u=0;u= ${e}; + bool cEdge = cp1 >= ${o}; + `}var Gu,Jd,Uu,zu=P(()=>{"use strict";we();oe();Ct();mr();Gu={name:"pack",inputNames:["A"],inputTypes:[1]},Jd=(a,t)=>{let o=j(a.session.backend.glContext.version),e=t.dims,r=e.length,n=t.dims.length,s=Je(n),i=Nr("rc",n),u=eh(n,i,e[e.length-2],e[e.length-1]),l;r===0?l=[1,1]:r===1?l=[e[0],1]:l=[e[n-1],e[n-2]];let f=Zd(n,l,i),p=Qd(e,i),d=` + void main() { + ${s} rc = getOutputCoords(); + + if(${f}) { + ${o.output} = vec4(0); + } else { + ${u} + + ${o.output} = vec4(${p}); + } + } + `;return{...Gu,hasMain:!0,output:{dims:t.dims,type:t.type,textureType:2},shaderSource:d}},Uu=(a,t)=>({...Gu,get:()=>Jd(a,t)})});function bi(a){if(a.length===0)return[1,1,1];let t=1;for(let o=0;o1?a[a.length-2]:1,a[a.length-1]]}function Wu(a,t){let o=!1;return a.length===0||t.length===0?o=!0:a.length<2||t.length<2?o=a[a.length-1]===t[t.length-1]:o=a[a.length-1]===t[t.length-1]&&a[a.length-2]===t[t.length-2],o}function nh(a){let t=U.computeStrides(a),o=["b","r","c"],e="index";return` + ivec3 inputCoordsFromReshapedOutCoords(int index) { + ${t.map((n,s)=>{let i=`int ${o[s]} = ${e} / ${n}`,u=s===t.length-1?`int ${o[s+1]} = ${e} - ${o[s]} * ${n}`:`index -= ${o[s]} * ${n}`;return`${i}; ${u};`}).join("")} + return ivec3(b, r, c); + } + `}function oh(a){let t=U.computeStrides(a);return` + int getFlattenedIndex(ivec3 coords) { + // reverse y, z order + return coords.x * ${t[0]} + coords.z * ${t[1]} + coords.y; + } +`}var th,rh,Vu,Hu=P(()=>{"use strict";le();we();oe();mr();th=a=>({name:"Reshape (packed)",inputTypes:[2],inputNames:["A"],cacheHint:`${a}`}),rh=(a,t,o,e)=>{let r=t.dims,n=e,s="";for(let l=0;l<4;l++){let f="";switch(l){case 0:f="outputCoords = rc;";break;case 1:f="outputCoords = ivec3(rc.x, rc.y+1, rc.z);";break;case 2:f="outputCoords = ivec3(rc.x, rc.y, rc.z+1);";break;case 3:f="outputCoords = ivec3(rc.x, rc.y+1, rc.z+1);";break;default:throw new Error}s+=` + ${f} + ${l>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[${l}] = getChannel(getA(inputRC.x, inputRC.y, inputRC.z), innerDims); + + ${l>0?"}":""} + `}let i=j(a.session.backend.glContext.version),u=` + ${nh(r)} + ${oh(n)} + ${kt()} + + void main() { + ivec3 rc = getOutputCoords(); + + vec4 result = vec4(0.0); + + ivec3 outputCoords; + int rows = ${n[2]}; + int cols = ${n[1]}; + + ${s} + ${i.output} = result; + } + `;return{...o,output:{dims:n,type:t.type,textureType:2},shaderSource:u,hasMain:!0}},Vu=(a,t,o)=>{let e=th(o);return{...e,get:()=>rh(a,t,e,o)}}});var gi,qu=P(()=>{"use strict";we();oe();gi=(a,t)=>{let o=t.shape,e=j(a.session.backend.glContext.version),r=` + 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 = ${e.texture2D}(X,TexCoords).r; + ${e.output} = encodeAsUint8(value); + }`,n={name:"Uint8Encode",inputTypes:[0],inputNames:["X"],output:{dims:o,type:t.tensor.type,textureType:3},shaderSource:r,hasMain:!0};return a.executeProgram(n,[t.tensor])}});function ah(a,t){if(a===1)return"rc";let o="";for(let e=0;e{"use strict";we();oe();Ct();mr();ju={name:"unpack",inputNames:["A"],inputTypes:[2]},ih=(a,t)=>{let o=t.dims.length,e=Nr("rc",o),r=e.slice(-2),n=Je(o),s=kt(),u=t.dims.length===0?"":ah(o,e),l=o<=1?"rc":`vec2(${r.join(",")})`,f=j(a.session.backend.glContext.version),p=` + ${s} + void main() { + ${n} rc = getOutputCoords(); + + // Sample the texture with the coords to get the rgba channel value. + vec4 packedInput = getA(${u}); + + ${f.output} = vec4(getChannel(packedInput, ${l}), 0, 0, 0); + } + `;return{...ju,hasMain:!0,output:{dims:t.dims,type:t.type,textureType:0},shaderSource:p}},Yu=(a,t)=>({...ju,get:()=>ih(a,t)})});var Kn,pn,Jn,dn=P(()=>{"use strict";ft();Kn=class{constructor(t,o=1){if(o===1)this.internalFormat=t.R32F,this.format=t.RED,this.textureType=t.FLOAT,this.channelSize=o;else if(o===4)this.internalFormat=t.RGBA32F,this.format=t.RGBA,this.textureType=t.FLOAT,this.channelSize=o;else throw new Error(`Invalid number of channels: ${o}`)}encode(t,o){let e,r;return t.constructor!==Float32Array&&(fe.warning("Encoder","data was not of type Float32; creating new Float32Array"),r=new Float32Array(t)),o*this.channelSize>t.length?(fe.warning("Encoder","Source data too small. Allocating larger array"),r=t,e=this.allocate(o*this.channelSize),r.forEach((n,s)=>e[s]=n)):(r=t,e=r),e}allocate(t){return new Float32Array(t*4)}decode(t,o){return this.channelSize===1?t.filter((r,n)=>n%4===0).subarray(0,o):t.subarray(0,o)}},pn=class{constructor(t,o=1,e){if(o!==1&&o!==4)throw new Error(`Invalid number of channels: ${o}`);this.internalFormat=t.RGBA,this.format=t.RGBA,this.channelSize=o,this.textureType=e||t.FLOAT}encode(t,o){let e=t;return this.channelSize===1&&(fe.verbose("Encoder","Exploding into a larger array"),e=this.allocate(o),t.forEach((r,n)=>e[n*4]=r)),e}allocate(t){return new Float32Array(t*4)}decode(t,o){return this.channelSize===1?t.filter((r,n)=>n%4===0).subarray(0,o):t.subarray(0,o)}},Jn=class{constructor(t,o=1){this.channelSize=4;if(o===1)this.internalFormat=t.ALPHA,this.format=t.ALPHA,this.textureType=t.UNSIGNED_BYTE,this.channelSize=o;else if(o===4)this.internalFormat=t.RGBA,this.format=t.RGBA,this.textureType=t.UNSIGNED_BYTE,this.channelSize=o;else throw new Error(`Invalid number of channels: ${o}`)}encode(t,o){return new Uint8Array(t.buffer,t.byteOffset,t.byteLength)}allocate(t){return new Uint8Array(t*this.channelSize)}decode(t,o){if(t instanceof Uint8Array)return t.subarray(0,o);throw new Error(`Invalid array type: ${t.constructor}`)}}});var hn,Ku,yi,Ju=P(()=>{"use strict";le();oe();hn=(a,t,o)=>{let e=o===0||o===1?1:4,r=o===2,n=o===1||o===2,s=o===4?t.length-1:void 0,i=o===4?t.map((u,l)=>l===t.length-1?u*4:u):void 0;return yi(a,t,e,i,{isPacked:r,reverseWH:n,breakAxis:s})},Ku=(a,t,o)=>{let e=hn(a,t,o);return[e.width,e.height]},yi=(a,t,o=1,e,r)=>{let n=!!(r&&r.isPacked),[s,i]=a.computeTextureWH(n&&e||t,r),u=t.length,l=t.slice(0);if(u===0&&(l=[1]),o===1)e=t;else if(n){if(o!==4)throw new Error("a packed texture must be 4-channel");e=t,u>0&&(l[u-1]=Math.ceil(l[u-1]/2)),u>1&&(l[u-2]=Math.ceil(l[u-2]/2))}else if(!e)throw new Error("Unpacked shape is needed when using channels > 1");return{width:s,height:i,channels:o,isPacked:n,shape:l,strides:U.computeStrides(l),unpackedShape:e,reversedWH:r&&r.reverseWH}}});var uh,Zn,Qu=P(()=>{"use strict";ft();hr();le();zu();Hu();qu();Xu();dn();Ju();oe();uh=(a,t)=>{let o=t.map(r=>`${r.unpackedShape.join(",")};${r.width}x${r.height}`).join("_"),e=a.name;return a.cacheHint&&(e+="["+a.cacheHint+"]"),e+=":"+o,e},Zn=class{constructor(t){this.session=t;this.packedTextureDataCache=new Map,this.unpackedTextureDataCache=new Map}calculateTextureWidthAndHeight(t,o){return Ku(this.session.layoutStrategy,t,o)}executeProgram(t,o){if(o.lengththis.readTexture(s),async i=>this.readTextureAsync(s),void 0,n),texture:e};return this.setTextureData(s.tensor.dataId,s,t.isPacked),s}getTextureData(t,o=!1){return this.session.isInitializer(t)?this.session.getTextureData(t,o):o?this.packedTextureDataCache.get(t):this.unpackedTextureDataCache.get(t)}setTextureData(t,o,e=!1){this.session.isInitializer(t)?this.session.setTextureData(t,o,e):(e?this.packedTextureDataCache:this.unpackedTextureDataCache).set(t,o)}isTextureLayoutCached(t,o=!1){return!!this.getTextureData(t.dataId,o)}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(gi(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(gi(this,t))}pack(t){return this.executeProgram(Uu(this,t.tensor),[t.tensor])}unpack(t){return this.executeProgram(Yu(this,t.tensor),[t.tensor])}}});var Ti,Q,Ue=P(()=>{"use strict";Ti=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}},Q=a=>new Ti(a)});var el,tl,rl,lh,fh,nl=P(()=>{"use strict";Ue();we();oe();el={name:"BatchNormalization",inputNames:["A","Scale","B","Mean","Variance"],inputTypes:[0,0,0,0,0]},tl=(a,t,o)=>(fh(t),[a.run({...el,cacheHint:o.cacheKey,get:()=>lh(a,t,o)},t)]),rl=a=>{let t=a.attributes.getFloat("epsilon",1e-5),o=a.attributes.getFloat("momentum",.9),e=a.attributes.getInt("spatial",1);return Q({epsilon:t,momentum:o,spatial:e})},lh=(a,t,o)=>{let e=j(a.session.backend.glContext.version),r=t[0].dims.length,[n,s]=a.calculateTextureWidthAndHeight(t[1].dims,0),i=` + float process(int[${r}] indices) { + vec2 position = offsetToCoords(indices[1], ${n}, ${s}); + float scale = getColorAsFloat(${e.texture2D}(Scale, position)); + float mean = getColorAsFloat(${e.texture2D}(Mean, position)); + float variance = getColorAsFloat(${e.texture2D}(Variance, position)); + float b = getColorAsFloat(${e.texture2D}(B, position)); + + return scale * ( (_A(indices) - mean) / sqrt(variance + float(${o.epsilon})) ) + b; + }`;return{...el,output:{dims:t[0].dims,type:t[0].type,textureType:0},shaderSource:i}},fh=a=>{if(!a||a.length!==5)throw new Error("BatchNormalization requires 5 inputs.");let t=a[0],o=a[1],e=a[2],r=a[3],n=a[4];if(t.dims.length<3||o.dims.length!==1||e.dims.length!==1||r.dims.length!==1||n.dims.length!==1)throw new Error("invalid input shape.");if(o.dims[0]!==t.dims[1]||e.dims[0]!==t.dims[1]||r.dims[0]!==t.dims[1]||n.dims[0]!==t.dims[1])throw new Error("invalid input shape.");if(t.type!=="float32"&&t.type!=="float64"||o.type!=="float32"&&o.type!=="float64"||e.type!=="float32"&&e.type!=="float64"||r.type!=="float32"&&r.type!=="float64"||n.type!=="float32"&&n.type!=="float64")throw new Error("invalid input tensor types.")}});var Qn,ht,M,mn,eo,Gt=P(()=>{"use strict";Qn=class{constructor(t,o,e,r){this.glContext=t;this.programInfo=o;this.inputTextureLayouts=e;this.outputTextureLayout=r}},ht=class{constructor(t){this.context=t}},M=class{constructor(t,o){this.routineBody=t;this.dependencies=o}},mn=class{constructor(t,o,e){this.name=t;e?this.dependencies=e:this.dependencies=[],o&&(this.routineBody=o)}addDependency(t){t&&this.dependencies.push(t)}},eo=class{static returnOrderedNodes(t){if(!t||t.length===0)return[];if(t.length===1)return t;let o=new Set,e=new Set,r=new Array;return this.createOrderedNodes(t,o,e,r),r}static createOrderedNodes(t,o,e,r){for(let n=0;n0)for(let s=0;s b); + } + vec4 ${a}(vec4 v1, vec4 v2) { + return vec4( v1.r > v2.r , + v1.g > v2.g, + v1.b > v2.b, + v1.a > v2.a ); + } + `,name:a,type:0}}function yh(){let a="less_";return{body:` + float ${a}(float a, float b) { + return float(a < b); + } + vec4 ${a}(vec4 v1, vec4 v2) { + return vec4( v1.r < v2.r , + v1.g < v2.g, + v1.b < v2.b, + v1.a < v2.a ); + } + `,name:a,type:0}}function Th(){let a="and_";return{body:` + float ${a}(float a, float b) { + return float( bool(a) && bool(b) ); + } + vec4 ${a}(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:a,type:0}}function xh(){let a="or_";return{body:` + float ${a}(float a, float b) { + return float( bool(a) || bool(b) ); + } + vec4 ${a}(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:a,type:0}}function wh(){let a="xor_";return{body:` + float ${a}(float a, float b) { + return float( bool(a) ^^ bool(b) ); + } + vec4 ${a}(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:a,type:0}}function vh(){return Oh("pow")}function _h(){let a="prelu_";return{body:` + float ${a}(float a, float b) { + return a < 0.0 ? a * b: a; + } + vec4 ${a}(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:a,type:0}}function Oh(a){let t=`${a}_`;return{body:` + float ${t}(float a, float b) { + return ${a}(a, b); + } + vec4 ${t}(vec4 v1, vec4 v2) { + return ${a}(v1, v2); + } + `,name:t,type:0}}var mt,Ih,ol,il,al,sl,ul,ll,fl,cl,pl,dl,hl,ml,bl=P(()=>{"use strict";le();Gt();we();oe();mt=(a,t,o,e=t[0].type,r)=>{let n=a.session.pack?2:0;return{name:o.name,inputNames:["A","B"],inputTypes:[n,n],cacheHint:r,get:()=>Ih(a,t,o,e)}},Ih=(a,t,o,e=t[0].type)=>{let r=a.session.pack?2:0,n=!U.areEqual(t[0].dims,t[1].dims),s=t[0].dims,i=a.session.pack;if(n){let f=Ke.calcShape(t[0].dims,t[1].dims,!1);if(!f)throw new Error("Can't perform binary op on the given tensors");s=f;let p=s.length,d=t[0].dims.length!==0?t[0].dims.length:1,T=t[1].dims.length!==0?t[1].dims.length:1,v=t[0].dims.length!==0?"bcastIndices_A(indices, aindices);":"aindices[0] = 0;",w=t[1].dims.length!==0?"bcastIndices_B(indices, bindices);":"bindices[0] = 0;",I=j(a.session.backend.glContext.version),L=i?` + ${o.body} + void main() { + vec4 a = getAAtOutCoords(); + vec4 b = getBAtOutCoords(); + vec4 result = ${o.name}(a, b); + ${I.output} = result; + }`:` + ${o.body} + float process(int indices[${p}]) { + int aindices[${d}]; + int bindices[${T}]; + ${v} + ${w} + return ${o.name}(_A(aindices), _B(bindices)); + }`;return{name:o.name,inputNames:["A","B"],inputTypes:[r,r],output:{dims:s,type:e,textureType:r},shaderSource:L,hasMain:i}}let u=j(a.session.backend.glContext.version),l=` + ${o.body} + void main() { + vec4 v1 = ${u.texture2D}(A, TexCoords); + vec4 v2 = ${u.texture2D}(B, TexCoords); + vec4 result = ${o.name}(v1, v2); + ${u.output} = result; + } + `;return{name:o.name,inputNames:["A","B"],inputTypes:[r,r],output:{dims:t[0].dims,type:e,textureType:r},shaderSource:l,hasMain:!0}},ol=(a,t)=>[a.run(mt(a,t,ph()),t)],il=(a,t)=>[a.run(mt(a,t,Th(),"bool"),t)],al=(a,t)=>[a.run(mt(a,t,dh()),t)],sl=(a,t)=>[a.run(mt(a,t,bh(),"bool"),t)],ul=(a,t)=>[a.run(mt(a,t,gh(),"bool"),t)],ll=(a,t)=>[a.run(mt(a,t,yh(),"bool"),t)],fl=(a,t)=>[a.run(mt(a,t,hh()),t)],cl=(a,t)=>[a.run(mt(a,t,xh(),"bool"),t)],pl=(a,t)=>[a.run(mt(a,t,vh()),t)],dl=(a,t)=>[a.run(mt(a,t,_h()),t)],hl=(a,t)=>[a.run(mt(a,t,mh()),t)],ml=(a,t)=>[a.run(mt(a,t,wh(),"bool"),t)]});var gl,yl,Ah,Tl=P(()=>{"use strict";le();gl=(a,t,o)=>(Ah(t),[a.cast(t[0],o)]),yl=a=>We.tensorDataTypeFromProto(a.attributes.getInt("to")),Ah=a=>{if(!a||a.length!==1)throw new Error("Cast requires 1 input.");if(a[0].type==="string")throw new Error("Invalid input type.")}});var Eh,Ph,xl,to,wl=P(()=>{"use strict";we();oe();Ct();mr();Eh=(a,t)=>({name:"Concat (packed)",inputNames:Array.from({length:a},(o,e)=>`X${e}`),inputTypes:Array(a).fill(2),cacheHint:t}),Ph=(a,t,o,e)=>{let r=o[0].dims.slice();if(e>=r.length||e<-1*r.length)throw new Error("axis specified for concat doesn't match input dimensionality");e<0&&(e=r.length+e);let n=r.slice(0);for(let N=1;NN.dims),p=It(s),d=new Array(f.length-1);d[0]=f[0][e];for(let N=1;N= ${d[N-1]}) { + return getChannel( + getX${N}(${to(p,T,ge)}), + vec2(${to(v,T,ge)})); + }`}let L=d.length,F=d[d.length-1];I+=` + return getChannel( + getX${L}(${to(p,T,F)}), + vec2(${to(v,T,F)}));`;let C=j(a.session.backend.glContext.version),X=` + ${l} + float getValue(${p.map(N=>"int "+N)}) { + ${I} + } + + void main() { + ${u} coords = getOutputCoords(); + int lastDim = coords.${p[s-1]}; + coords.${p[s-1]} = coords.${p[s-2]}; + coords.${p[s-2]} = lastDim; + + vec4 result = vec4(getValue(${i}), 0., 0., 0.); + + ${i[s-1]} = ${i[s-1]} + 1; + if (${i[s-1]} < ${n[s-1]}) { + result.g = getValue(${i}); + } + + ${i[s-2]} = ${i[s-2]} + 1; + if (${i[s-2]} < ${n[s-2]}) { + result.a = getValue(${i}); + } + + ${i[s-1]} = ${i[s-1]} - 1; + if (${i[s-2]} < ${n[s-2]} && + ${i[s-1]} < ${n[s-1]}) { + result.b = getValue(${i}); + } + ${C.output} = result; + } + `;return{...t,output:{dims:n,type:o[0].type,textureType:2},shaderSource:X,hasMain:!0}},xl=(a,t,o)=>{let e=Eh(t.length,o.cacheKey);return{...e,get:()=>Ph(a,e,t,o.axis)}},to=(a,t,o)=>{let e=a.indexOf(t);return a.map((n,s)=>s===e?`${n} - ${o}`:n).join()}});var vl,Dh,Lh,Fh,_l,Ch,kh,Bh,Ol,$h,Il=P(()=>{"use strict";Ue();oe();wl();vl=(a,t,o)=>($h(t),a.session.pack&&t[0].dims.length>1?[a.run(xl(a,t,o),t)]:[a.run(Fh(a,t,o),t)]),Dh=(a,t)=>({name:"Concat",inputNames:Array.from({length:a},(o,e)=>`X${e}`),inputTypes:Array(a).fill(0),cacheHint:t}),Lh=(a,t,o,e)=>{let r=o[0].dims.slice();if(e>=r.length||e<-1*r.length)throw new Error("axis specified for concat doesn't match input dimensionality");e<0&&(e=r.length+e);let n=r.slice(0);for(let T=1;T{let e=Dh(t.length,o.cacheKey);return{...e,get:()=>Lh(a,e,t,o.axis)}},_l=a=>`int getTextureWhereDataResides(int index) { + ${a.map((o,e)=>`if(index<${o}) {return ${e};} +`).join("")} + }`,Ch=a=>_l(a),kh=(a,t)=>{let o=[`float fetchDataFromCorrectTexture(int textureIndex, int indices[${t}]) {`];for(let e=0;e{let t=["int getSizeInConcatAxisValueFromIndex(int index) {"];for(let o=0;oQ({axis:a.attributes.getInt("axis")}),$h=a=>{if(!a||a.length<1)throw new Error("too few inputs");let t=a[0].type,o=a[0].dims.length;if(t==="string")throw new Error("string tensor is not supported yet");for(let e of a){if(e.type!==t)throw new Error("input tensors should be one type");if(e.dims.length!==o)throw new Error("input tensors should have the same shape")}}});function Nh(){return bt("abs")}function Rh(){return bt("acos")}function Mh(){return bt("asin")}function Gh(){return bt("atan")}function Uh(){return bt("ceil")}function zh(){return bt("cos")}function Vh(a){let t="elu";return{body:` + const float alpha = float(${a}); + + float ${t}_(float a) { + return a >= 0.0 ? a: (exp(a) - 1.0) * alpha; + } + vec4 ${t}_(vec4 v) { + return vec4(${t}_(v.x), ${t}_(v.y), ${t}_(v.z), ${t}_(v.w)); + } + `,name:t,type:0}}function Wh(){return bt("exp")}function Hh(){return bt("floor")}function xi(a,t){let o="clip";return{body:` + const float min = float(${a}); + const float max = float(${t}); + + float ${o}_(float a) { + return clamp(a, min, max); + } + vec4 ${o}_(vec4 v) { + return clamp(v, min, max); + } + `,name:o,type:0}}function qh(){let a="indentity";return{body:` + float ${a}_(float a) { + return a; + } + vec4 ${a}_(vec4 v) { + return v; + } + `,name:a,type:0}}function jh(a){let t="leakyRelu";return{body:` + const float alpha = float(${a}); + + float ${t}_(float a) { + return a < 0.0 ? a * alpha : a; + } + vec4 ${t}_(vec4 v) { + return vec4(${t}_(v.x), ${t}_(v.y), ${t}_(v.z), ${t}_(v.w)); + } + `,name:t,type:0}}function Yh(){return bt("log")}function Xh(){let a="neg";return{body:` + float ${a}_(float a) { + return -a; + } + vec4 ${a}_(vec4 v) { + return -v; + } + `,name:a,type:0}}function Kh(){let a="not";return{body:` + float ${a}_(float a) { + return float( ! bool(a) ); + } + bool ${a}_(bool a) { + return !a; + } + vec4 ${a}_(vec4 v) { + return vec4(!bool(v.x), !bool(v.y), !bool(v.z), !bool(v.w)); + } + bvec4 ${a}_(bvec4 v) { + return bvec4(!v.x, !v.y, !v.z, !v.w); + } + `,name:a,type:0}}function Jh(){return bt("sin")}function wi(){let a="relu";return{body:` + float ${a}_(float a) { + return max( a, 0.0 ); + } + vec4 ${a}_(vec4 v) { + return max( v, 0.0 ); + } + `,name:a,type:0}}function vi(){let a="sigmoid";return{body:` + float ${a}_(float a) { + return 1.0 / (1.0 + exp(-a)); + } + vec4 ${a}_(vec4 v) { + return 1.0 / (1.0 + exp(-v)); + } + `,name:a,type:0}}function Zh(){return bt("sqrt")}function Qh(){return bt("tan")}function em(){let a="tanh";return{body:` + float ${a}_(float a) { + a = clamp(a, -10., 10.); + a = exp(2.*a); + return (a - 1.) / (a + 1.); + } + vec4 ${a}_(vec4 v) { + v = clamp(v, -10., 10.); + v = exp(2.*v); + return (v - 1.) / (v + 1.); + } + `,name:a,type:0}}function bt(a){return{body:` + float ${a}_(float a) { + return ${a}(a); + } + vec4 ${a}_(vec4 v) { + return ${a}(v); + } + `,name:a,type:0}}var tm,Le,Sl,Al,El,Pl,_i,Dl,Ll,rm,Fl,Cl,kl,Bl,$l,Nl,Oi,Rl,Ml,Gl,Ul,zl,Vl,Wl,Hl,ql,jl,Yl,Ii=P(()=>{"use strict";Ue();le();Gt();we();oe();tm=(a,t,o,e)=>{let r=a.session.pack?2:0,n=j(a.session.backend.glContext.version);return{...t,output:{dims:o.dims,type:o.type,textureType:r},shaderSource:` + ${e.body} + void main() { + vec4 v = ${n.texture2D}(A, TexCoords); + v = ${e.name}_(v); + ${n.output} = v; + } + `,hasMain:!0}},Le=(a,t,o,e)=>{let r=a.session.pack?2:0,n={name:o.name,inputTypes:[r],inputNames:["A"],cacheHint:e};return{...n,get:()=>tm(a,n,t,o)}},Sl=(a,t)=>[a.run(Le(a,t[0],Nh()),t)],Al=(a,t)=>[a.run(Le(a,t[0],Rh()),t)],El=(a,t)=>[a.run(Le(a,t[0],Mh()),t)],Pl=(a,t)=>[a.run(Le(a,t[0],Gh()),t)],_i=(a,t,o)=>[a.run(Le(a,t[0],xi(o.min,o.max),o.cacheKey),t)],Dl=a=>Q({min:a.attributes.getFloat("min",pr),max:a.attributes.getFloat("max",dr)}),Ll=(a,t)=>{let o=rm(a,t);return _i(a,[t[0]],o)},rm=(a,t)=>{if(t.length>=3&&(!a.session.isInitializer(t[1].dataId)||!a.session.isInitializer(t[2].dataId)))throw new Error("dynamic clip attributes are not allowed");let o=t.length>=3?t[1].numberData[0]:pr,e=t.length>=3?t[2].numberData[0]:dr;return Q({min:o,max:e})},Fl=(a,t)=>[a.run(Le(a,t[0],Uh()),t)],Cl=(a,t)=>[a.run(Le(a,t[0],zh()),t)],kl=(a,t,o)=>[a.run(Le(a,t[0],Vh(o.alpha),o.cacheKey),t)],Bl=a=>Q({alpha:a.attributes.getFloat("alpha",1)}),$l=(a,t)=>[a.run(Le(a,t[0],Wh()),t)],Nl=(a,t)=>[a.run(Le(a,t[0],Hh()),t)],Oi=(a,t)=>[a.run(Le(a,t[0],qh()),t)],Rl=(a,t,o)=>[a.run(Le(a,t[0],jh(o.alpha),o.cacheKey),t)],Ml=a=>Q({alpha:a.attributes.getFloat("alpha",.01)}),Gl=(a,t)=>[a.run(Le(a,t[0],Yh()),t)],Ul=(a,t)=>[a.run(Le(a,t[0],Xh()),t)],zl=(a,t)=>[a.run(Le(a,t[0],Kh()),t)],Vl=(a,t)=>[a.run(Le(a,t[0],wi()),t)],Wl=(a,t)=>[a.run(Le(a,t[0],vi()),t)],Hl=(a,t)=>[a.run(Le(a,t[0],Jh()),t)],ql=(a,t)=>[a.run(Le(a,t[0],Zh()),t)],jl=(a,t)=>[a.run(Le(a,t[0],Qh()),t)],Yl=(a,t)=>[a.run(Le(a,t[0],em()),t)]});function Bt(a){let t;switch(a.activation){case"Relu":t=wi();break;case"Sigmoid":t=vi();break;case"Clip":t=xi(a.clipMin,a.clipMax);break;default:return{activationFunction:"",applyActivation:""}}let o=t.name,e=t.body,r=`value = ${o}_(value);`;return{activationFunction:e,applyActivation:r}}var Rr,br=P(()=>{"use strict";le();Ii();Rr=a=>{let t=a.getString("activation","");if(t==="Clip"){let[o,e]=a.getFloats("activation_params",[pr,dr]);return{activation:t,clipMax:e,clipMin:o,activationCacheKey:`${t}:${o},${e}`}}return{activation:t,activationCacheKey:t}}});var om,im,Xl,Kl=P(()=>{"use strict";ft();we();oe();ro();br();om=(a,t)=>({name:"GroupedConv",inputNames:a?["X","W","Bias"]:["X","W"],inputTypes:a?[0,0,0]:[0,0],cacheHint:t}),im=(a,t,o,e)=>{let n=t.length>2?"value += getBias(output_channel);":"",s=t[0].dims.slice(),i=t[1].dims.slice(),u=i[0]/e.group;fe.verbose("GroupedConv",`autpPad:${e.autoPad}, dilations:${e.dilations}, group:${e.group}, kernelShape:${e.kernelShape}, pads:${e.pads}, strides:${e.strides}`);let l=Mr(s,i,e.dilations,e.pads,e.strides),f=j(a.session.backend.glContext.version),{activationFunction:p,applyActivation:d}=Bt(e),T=` + const ivec2 strides = ivec2(${e.strides[0]}, ${e.strides[1]}); + const ivec2 pads = ivec2(${e.pads[0]}, ${e.pads[1]}); + ${p} + 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 / ${u}; + + float value = 0.0; + for (int wInChannel = 0; wInChannel < ${i[1]}; wInChannel++) { + int input_channel = group_id * ${i[1]} + wInChannel; + for (int wHeight = 0; wHeight < ${i[2]}; wHeight++) { + int xHeight = xRCCorner.x + wHeight * ${e.dilations[0]}; + + if (xHeight < 0 || xHeight >= ${s[2]}) { + continue; + } + + for (int wWidth = 0; wWidth < ${i[3]}; wWidth++) { + int xWidth = xRCCorner.y + wWidth * ${e.dilations[1]}; + if (xWidth < 0 || xWidth >= ${s[3]}) { + continue; + } + + float xVal = getX(batch, input_channel, xWidth, xHeight); + float wVal = getW(output_channel, wInChannel, wWidth, wHeight); + value += xVal*wVal; + } + } + } + ${n} + ${d} + ${f.output} = vec4(value, .0, .0, .0); + } +`;return{...o,output:{dims:l,type:t[0].type,textureType:0},shaderSource:T,hasMain:!0}},Xl=(a,t,o)=>{let e=om(t.length>2,o.cacheKey);return{...e,get:()=>im(a,t,e,o)}}});var am,sm,Jl,Zl=P(()=>{"use strict";we();oe();mr();am=a=>({name:"Im2Col (packed)",inputNames:["A"],inputTypes:[2],cacheHint:a}),sm=(a,t,o,e,r,n)=>{let s=o.dims,i=e.dims,u=2,l=3,f=r.length,p=[i[1]*i[2]*i[3],r[2]*r[3]],d=i[2]*i[3],T=kt(),v=j(a.session.backend.glContext.version),w="";for(let L=0;L<=1;L++)for(let F=0;F<=1;F++)w+=` + blockIndex = rc.x + ${F}; + pos = rc.y + ${L}; + + if(blockIndex < ${p[1]} && pos < ${p[0]}) { + offsetY = int(blockIndex / (${r[f-1]})) * ${n.strides[0]} - + ${n.pads[0]}; + d0 = offsetY + ${n.dilations[0]} * (imod(pos, ${d}) / ${i[2]}); + + if(d0 < ${s[u]} && d0 >= 0) { + offsetX = imod(blockIndex, ${r[f-1]}) * ${n.strides[1]} - + ${n.pads[1]}; + d1 = offsetX + ${n.dilations[1]} * imod(imod(pos, ${d}), ${i[2]}); + + if(d1 < ${s[l]} && d1 >= 0) { + + ch = int(float(pos)/ ${d}.); + innerDims = vec2(d0, d1); + result[${L*2+F}] = getChannel( + getA(0, ch, int(innerDims.x), + int(innerDims.y)), innerDims); + } + } + } + + `;let I=` + ${T} + + void main() { + ivec2 rc = getOutputCoords(); + vec4 result = vec4(0.0); + int blockIndex, pos, offsetY, d0, offsetX, d1, ch; + vec2 innerDims; + ${w} + ${v.output} = result; + } + `;return{...t,output:{dims:p,type:o.type,textureType:2},shaderSource:I,hasMain:!0}},Jl=(a,t,o,e,r)=>{let n=am(r.cacheKey);return{...n,get:()=>sm(a,n,t,o,e,r)}}});function lm(a,t,o){let e=t[0].dims,r=t[1].dims,n=Ke.calcShape(e,r,!0);if(!n)throw new Error("Can't use matmul on the given tensors");let s=Je(n.length),i=It(),{activationFunction:u,applyActivation:l}=Bt(o),f=t.length>2,p=f?"value += getBiasForMatmul();":"",d=f?`${Ai(s,i,t[2].dims,n,!1)}`:"",T=n.length,v=e.length,w=r.length,I=e[e.length-1],L=` + ${u} + ${d} + float process(int indices[${T}]) { + int a[${v}]; + int b[${w}]; + bcastMatmulIndices_A(indices, a); + bcastMatmulIndices_B(indices, b); + + float value; + for (int k=0; k<${I}; ++k) { + a[${v-1}] = k; + b[${w-2}] = k; + value += _A(a) * _B(b); + } + ${p} + ${l} + return value; + }`;return{...a,output:{dims:n,type:t[0].type,textureType:0},shaderSource:L}}function Si(a,t){let o=um(a.length>2,t.activationCacheKey);return{...o,get:()=>lm(o,a,t)}}function Ai(a,t,o,e,r){let n="",s=o.length,i=e.length,u=i-s;i<2&&s>0?n="coords":n=o.map((w,I)=>`coords.${t[I+u]}`).join(", ");let f=Ke.getBroadcastDims(o,e).map(w=>`coords.${t[w+u]} = 0;`).join(` +`),d=U.size(o)===1,T="vec4(outputValue.xx, outputValue.yy)";return d&&(T="vec4(outputValue.x)"),r?` +vec4 getBiasForMatmul() { + ${a} coords = getOutputCoords(); + ${f} + vec4 outputValue = getBias(${n}); + return ${T}; +}`:` +float getBiasForMatmul() { + ${a} coords = getOutputCoords(); + ${f} + return getBias(coords.x); +}`}var Ql,ef,um,fm,no=P(()=>{"use strict";le();oe();Ct();br();Ei();Ql=(a,t,o)=>(fm(t),a.session.pack?[a.run(oo(a,t,o),t)]:[a.run(Si(t,o),t)]),ef=a=>Rr(a.attributes),um=(a,t)=>({name:"MatMul",inputNames:a?["A","B","Bias"]:["A","B"],inputTypes:a?[0,0,0]:[0,0],cacheHint:t});fm=a=>{if(!a||a.length!==2)throw new Error("MatMul requires 2 inputs.");if(a[0].dims[a[0].dims.length-1]!==a[1].dims[a[1].dims.length-2])throw new Error("shared dimension does not match.");if(a[0].type!=="float32"&&a[0].type!=="float64"||a[1].type!=="float32"&&a[1].type!=="float64")throw new Error("inputs should be float type");if(a[0].type!==a[1].type)throw new Error("inputs types should match")}});function dm(a,t,o,e){let r=[],n=[],s=o[0].dims,i=o[1].dims,u=s.length,l=i.length,f=e.length,p=f-u,d=f-l;r=s.map((C,X)=>`coords.${t[X+p]}`),r[u-1]="i*2",r.join(", "),n=i.map((C,X)=>`coords.${t[X+d]}`),n[l-2]="i*2",n.join(", ");let T=Ke.getBroadcastDims(s,e),v=Ke.getBroadcastDims(i,e),w=T.map(C=>`coords.${t[C+p]} = 0;`).join(` +`),I=v.map(C=>`coords.${t[C+d]} = 0;`).join(` +`),L=`int lastDim = coords.${t[f-1]}; + coords.${t[f-1]} = coords.${t[f-2]}; + coords.${t[f-2]} = lastDim;`;return` +vec4 getAAtOutCoordsMatmul(int i) { + ${a} coords = getOutputCoords(); + ${L} + ${w} + vec4 outputValue = getA(${r}); + return outputValue; +} + +vec4 getBAtOutCoordsMatmul(int i) { + ${a} coords = getOutputCoords(); + ${L} + ${I} + vec4 outputValue = getB(${n}); + return outputValue; +}`}function hm(a,t){let o="";for(let e=0;e{"use strict";le();we();oe();Ct();br();no();cm=(a,t)=>({name:"MatMul (packed)",inputNames:a?["A","B","Bias"]:["A","B"],inputTypes:a?[2,2,2]:[2,2],cacheHint:t}),pm=(a,t,o,e)=>{let r=o.length>2,n=r?"value += getBiasForMatmul();":"",s=o[0].dims,i=o[1].dims,u=Ke.calcShape(s,i,!0),l=!U.areEqual(o[0].dims,o[1].dims);if(!u)throw new Error("Can't use matmul on the given tensors");let f=s[s.length-1],p=Math.ceil(f/2),d=s.length,T=i.length,v=j(a.session.backend.glContext.version),w=Je(u.length),I=u.length,L=It(),{activationFunction:F,applyActivation:C}=Bt(e),X=r?`${Ai(w,L,o[2].dims,u,!0)}`:"",N=l?`${dm(w,L,o,u)}`:"",ge=l?"getAAtOutCoordsMatmul(i)":`getA(${hm(L,d)})`,Oe=l?"getBAtOutCoordsMatmul(i)":`getB(${mm(L,T)})`,Ne=l?"":`${w} rc = + getOutputCoords(); int lastDim = rc.${L[I-1]}; rc.${L[I-1]} = + rc.${L[I-2]}; rc.${L[I-2]} = lastDim; + `,V=` + ${N} + ${X} + ${F} + void main() { + ${Ne} + + vec4 value = vec4(0); + for (int i = 0; i < ${p}; i++) { + vec4 a = ${ge}; + vec4 b = ${Oe}; + + value += (a.rrbb * b.rgrg); + value += (a.ggaa * b.baba); + } + ${n} + ${C} + ${v.output} = value; + }`;return{...t,output:{dims:u,type:o[0].type,textureType:2},shaderSource:V,hasMain:!0}},oo=(a,t,o)=>{let e=cm(t.length>2,o.activationCacheKey);return{...e,get:()=>pm(a,e,t,o)}}});var tf,rf=P(()=>{"use strict";ro();Zl();Ei();tf=(a,t,o)=>{let e=t[0].dims,r=t[1].dims,n=Mr(e,r,o.dilations,o.pads,o.strides),s=a.run(Jl(a,t[0],t[1],n,o),[t[0]]),i=a.reshapePacked(t[1],[r[0],r[1]*r[2]*r[3]]),u=t.length===3?[i,s,t[2]]:[i,s],l=a.run(oo(a,u,o),u);return a.reshapePacked(l,n)}});var bm,gm,nf,Pi,Di=P(()=>{"use strict";oe();bm=a=>({name:"Im2Col",inputNames:["X"],inputTypes:[0],cacheHint:a}),gm=(a,t,o,e,r,n)=>{let s=o.dims,i=e.dims,u=r.length,l=Pi(s,i,r,4),f=` + 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[${u}]) { + 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{...t,output:{dims:l,type:o.type,textureType:4},shaderSource:f}},nf=(a,t,o,e,r)=>{let n=bm(r.cacheKey);return{...n,get:()=>gm(a,n,t,o,e,r)}},Pi=(a,t,o,e=4)=>[o[0],o[2],o[3],Math.ceil(a[1]*t[2]*t[3]/e)]});var ym,Tm,of,af=P(()=>{"use strict";le();we();oe();br();Di();ym=(a,t)=>({name:"ConvDotProduct",inputNames:a?["Im2Col","K","B"]:["Im2Col","K"],inputTypes:a?[0,4,0]:[0,4],cacheKey:t.activationCacheKey}),Tm=(a,t,o,e,r)=>{let n=o[0].dims,s=o[1].dims,i=[s[0],Math.ceil(n[1]*s[2]*s[3]/4)],u=Pi(n,s,e),[l,f]=a.calculateTextureWidthAndHeight(i,4),p=U.computeStrides(u),[d,T]=a.calculateTextureWidthAndHeight(u,4),v=e.length,w=o.length<3?"0.0":"_B(b)",I=Math.ceil(n[1]*s[2]*s[3]/4),{activationFunction:L,applyActivation:F}=Bt(r),C=j(a.session.backend.glContext.version),X=` +${L} +float process(int indices[${v}]) { + 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] * ${p[0]} + im2col[1] * ${p[1]} + im2col[2] * ${p[2]}; + int kernelOffset = indices[1] * ${i[1]}; + float value = ${w}; + for (int i = 0; i < ${I}; ++i) { + vec2 im2colCoords = offsetToCoords(im2colOffset, ${d}, ${T}); + vec2 kernelCoords = offsetToCoords(kernelOffset, ${l}, ${f}); + value += dot(${C.texture2D}(Im2Col, im2colCoords), ${C.texture2D}(K, kernelCoords)); + ++im2colOffset; + ++kernelOffset; + } + ${F} + return value; +}`;return{...t,output:{dims:e,type:o[0].type,textureType:0},shaderSource:X}},of=(a,t,o,e)=>{let r=ym(t.length>2,e);return{...r,get:()=>Tm(a,r,t,o,e)}}});var Mr,Li,xm,wm,vm,_m,Fi,Om,ro=P(()=>{"use strict";Ue();le();Kl();rf();af();br();Di();no();Mr=(a,t,o,e,r)=>{let n=a[0],s=a.slice(2),i=s.length,u=t[0],f=t.slice(2).map((v,w)=>v+(v-1)*(o[w]-1)),d=s.map((v,w)=>v+e[w]+e[w+i]).map((v,w)=>Math.floor((v-f[w]+r[w])/r[w]));return[n,u].concat(...d)},Li=(a,t,o)=>(Om(t,o),xm(a,t,o)),xm=(a,t,o)=>{let e=_m(o,t),r=a.session.pack,n=e.kernelShape[0]===1&&e.kernelShape[1]===1;return e.group>1?[a.run(Xl(a,t,e),t)]:n&&r?[wm(a,t,e)]:r&&t[0].dims.length===4&&t[0].dims[0]===1&&!n?[tf(a,t,e)]:[vm(a,t,e)]},wm=(a,t,o)=>{let e=t[0].dims,r=t[1].dims,n=Mr(e,r,o.dilations,o.pads,o.strides),s=a.reshapeUnpacked(t[0],[e[1],e[2]*e[3]]),i=a.reshapeUnpacked(t[1],[r[0],r[1]]),u=t.length>2?[i,s,t[2]]:[i,s],l=a.run(Si(u,o),u);return a.reshapeUnpacked(l,n)},vm=(a,t,o)=>{let e=t[0].dims,r=t[1].dims,n=Mr(e,r,o.dilations,o.pads,o.strides),s=a.run(nf(a,t[0],t[1],n,o),[t[0]]),i=t.length===3?[s,t[1],t[2]]:[s,t[1]];return a.run(of(a,t,n,o),i)},_m=(a,t)=>{let o=a.kernelShape.slice();if(a.kernelShape.length===0)for(let n=2;n{let t=a.attributes,o=Rr(t),e=t.getString("auto_pad","NOTSET"),r=t.getInts("dilations",[1,1]),n=t.getInt("group",1),s=t.getInts("kernel_shape",[]),i=t.getInts("pads",[0,0,0,0]),u=t.getInts("strides",[1,1]);return Q({autoPad:e,dilations:r,group:n,kernelShape:s,pads:i,strides:u,...o})},Om=(a,t)=>{if(!a||a.length!==2&&a.length!==3)throw new Error("Conv requires 2 or 3 inputs");if(a[0].dims.length!==4||a[1].dims.length!==4)throw new Error("currently only support 2-dimensional conv");let o=a[0].dims[1],e=a[1].dims[1]*t.group;if(o!==e)throw new Error("FILTER_IN_CHANNEL should be equal to DATA_CHANNEL");if(a.length===3&&(a[2].dims.length!==1||a[1].dims[0]!==a[2].dims[0]))throw new Error("invalid bias");let r=a[0].dims.length-2;if(t.dilations.length!==r)throw new Error(`dilations should be ${r}D`);if(t.strides.length!==r)throw new Error(`strides should be ${r}D`);if(t.pads.length!==r*2)throw new Error(`pads should be ${r*2}D`);if(t.kernelShape.length!==0&&t.kernelShape.length!==a[1].dims.length-2)throw new Error("invalid kernel shape");if(a[0].type!=="float32"||a[1].type!=="float32")throw new Error("Conv input(X,W) should be float tensor");if(a.length===3&&a[2].type!=="float32")throw new Error("Conv input(bias) should be float tensor")}});var Im,Sm,Am,sf,Em,Pm,Dm,Lm,Fm,Cm,uf,km,lf=P(()=>{"use strict";Ue();we();oe();br();Im=(a,t,o,e,r,n)=>(a-1)*t+o+(e-1)*r+1-n,Sm=(a,t,o,e,r)=>{let n=Math.floor(a/2);t==="SAME_UPPER"?(o[e]=n,o[r]=a-n):t==="SAME_LOWER"&&(o[e]=a-n,o[r]=n)},Am=(a,t,o,e,r,n,s,i)=>{let u=a.length-2,l=i.length===0;for(let f=0;f(km(t,o),Em(a,t,o)),Em=(a,t,o)=>{let e=Cm(o,t);return[Fm(a,t,e)]},Pm=(a,t)=>({name:"ConvTranspose",inputNames:a?["X","W","B"]:["X","W"],inputTypes:a?[0,0,0]:[0,0],cacheHint:t}),Dm=(a,t,o,e)=>{let n=t.length>2?"getB(output_channel)":"0.0",s=t[0].dims,i=t[1].dims,u=i[1],l=i[0]/e.group,f=[t[0].dims[0],t[1].dims[1]*e.group,...e.outputShape],p=j(a.session.backend.glContext.version),{activationFunction:d,applyActivation:T}=Bt(e),v=` + const ivec2 strides = ivec2(${e.strides[0]}, ${e.strides[1]}); + const ivec2 pads = ivec2(${e.pads[0]}, ${e.pads[1]}); + ${d} + void main() { + ivec4 coords = getOutputCoords(); + int batch = coords.x; + int output_channel = coords.y; + + ivec2 loc = coords.zw + pads; + + int group_id = output_channel / ${u}; + int wOutChannel = output_channel - group_id * ${u}; + + float value = ${n}; + for (int inChannelOffset = 0; inChannelOffset < ${l}; inChannelOffset++) { + int input_channel = group_id * ${l} + inChannelOffset; + for (int wWOff = 0; wWOff < ${i[2]}; wWOff++) { + for (int wHOff = 0; wHOff < ${i[3]}; wHOff++) { + ivec2 wOff = ivec2(wWOff * ${e.dilations[0]}, wHOff * ${e.dilations[1]}); + ivec2 wLoc = loc - wOff; + ivec2 wLocIn = wLoc / strides; + if ( + wLocIn * strides == wLoc && + wLocIn.x >= 0 && wLocIn.x < ${s[2]} && + wLocIn.y >= 0 && wLocIn.y < ${s[3]} + ) { + float xVal = getX(batch, input_channel, wLocIn.y, wLocIn.x); + float wVal = getW(input_channel, wOutChannel, wHOff, wWOff); + value += xVal * wVal; + } + } + } + } + ${T} + ${p.output} = vec4(value, .0, .0, .0); + } +`;return{...o,output:{dims:f,type:t[0].type,textureType:0},shaderSource:v,hasMain:!0}},Lm=(a,t,o)=>{let e=Pm(t.length>2,o.cacheKey);return{...e,get:()=>Dm(a,t,e,o)}},Fm=(a,t,o)=>a.run(Lm(a,t,o),t),Cm=(a,t)=>{let o=a.kernelShape.slice();if(a.kernelShape.length===0)for(let i=2;i{let t=a.attributes,o=Rr(t),e=t.getString("auto_pad","NOTSET"),r=t.getInts("dilations",[1,1]),n=t.getInt("group",1),s=t.getInts("kernel_shape",[]),i=t.getInts("output_padding",[0,0]),u=t.getInts("output_shape",[]),l=t.getInts("pads",[0,0,0,0]),f=t.getInts("strides",[1,1]);return Q({autoPad:e,dilations:r,group:n,kernelShape:s,outputPadding:i,outputShape:u,pads:l,strides:f,...o})},km=(a,t)=>{if(!a||a.length!==2&&a.length!==3)throw new Error("Conv requires 2 or 3 inputs");if(a[0].dims.length!==4||a[1].dims.length!==4)throw new Error("currently only support 2-dimensional conv");let o=a[0].dims[1],e=a[1].dims[0];if(o!==e)throw new Error("FILTER_IN_CHANNEL should be equal to DATA_CHANNEL");let r=a[1].dims[1]*t.group;if(a.length===3&&(a[2].dims.length!==1||a[2].dims[0]!==r))throw new Error("invalid bias");let n=a[0].dims.length-2;if(t.dilations.length!==n)throw new Error(`dilations should be ${n}D`);if(t.strides.length!==n)throw new Error(`strides should be ${n}D`);if(t.pads.length!==n*2)throw new Error(`pads should be ${n*2}D`);if(t.outputPadding.length!==n)throw new Error(`output_padding should be ${n}D`);if(t.kernelShape.length!==0&&t.kernelShape.length!==a[1].dims.length-2)throw new Error("invalid kernel shape");if(t.outputShape.length!==0&&t.outputShape.length!==a[0].dims.length-2)throw new Error("invalid output shape");if(a[0].type!=="float32"||a[1].type!=="float32")throw new Error("ConvTranspose input(X,W) should be float tensor");if(a.length===3&&a[2].type!=="float32")throw new Error("ConvTranspose input(bias) should be float tensor")}});var ff,gr,cf,Bm,pf,$m,Nm,Rm,io=P(()=>{"use strict";Ue();le();oe();ff={name:"Transpose",inputNames:["A"],inputTypes:[0]},gr=(a,t,o)=>(Rm(t),[a.run({...ff,cacheHint:o.cacheKey,get:()=>Bm(a,t[0],o.perm)},t)]),cf=a=>Q({perm:a.attributes.getInts("perm",[])}),Bm=(a,t,o)=>{let e=t.dims;o=pf(e,o);let r=$m(e,o),n=e.length,s=` + ${Nm("perm",o,n)} + float process(int indices[${n}]) { + int a[${n}]; + perm(a, indices); + return _A(a); + }`;return{...ff,output:{dims:r,type:t.type,textureType:0},shaderSource:s}},pf=(a,t)=>(t&&t.length!==a.length&&(t=[...a.keys()].reverse()),t),$m=(a,t)=>(t=pf(a,t),U.sortBasedOnPerm(a,t)),Nm=(a,t,o)=>{let e=[];e.push(`void ${a}(out int a[${o}], int src[${o}]) {`);for(let r=0;r{if(!a||a.length!==1)throw new Error("Transpose requires 1 input.");if(a[0].type!=="float32"&&a[0].type!=="float64")throw new Error("input should be float tensor")}});var df,hf,Mm,mf=P(()=>{"use strict";io();df=(a,t,o)=>{Mm(t);let e=o.blocksize,r=e*e,n=o.mode==="DCR"?[0,3,4,1,5,2]:[0,1,4,2,5,3],s=o.mode==="DCR"?[t[0].dims[0],e,e,t[0].dims[1]/r,t[0].dims[2],t[0].dims[3]]:[t[0].dims[0],t[0].dims[1]/r,e,e,t[0].dims[2],t[0].dims[3]],i=a.reshapeUnpacked(t[0],s),u={perm:n,cacheKey:`${n}`},[l]=gr(a,[i],u),f=[t[0].dims[0],t[0].dims[1]/r,t[0].dims[2]*e,t[0].dims[3]*e];return[a.reshapeUnpacked(l,f)]},hf=a=>{let t=a.attributes.getInt("blocksize");if(t<1)throw new Error(`blocksize must be >= 1, but got : ${t} for DepthToSpace`);let o=a.attributes.getString("mode","DCR");if(o!=="DCR"&&o!=="CRD")throw new Error(`unrecognized mode: ${o} for DepthToSpace`);return{mode:o,blocksize:t}},Mm=a=>{if(a.length!==1)throw new Error(`DepthToSpace expect 1 inputs, but got ${a.length}`);if(a[0].type==="string"||a[0].dims.length!==4)throw new TypeError("DepthToSpace input should be a 4-D numeric tensor")}});var bf,gf,Gm,yf=P(()=>{"use strict";le();bf=(a,t,o)=>{Gm(t,o);let e=U.flattenShape(t[0].dims,o);return[a.reshapeUnpacked(t[0],e)]},gf=a=>a.attributes.getInt("axis",1),Gm=(a,t)=>{if(!a||a.length!==1)throw new Error("Flatten requires 1 input.");let o=a[0].dims.length;if(o===0)throw new Error("scalar tensor is not supported.");if(t<-o||t>o)throw new Error("Invalid axis");if(a[0].type==="string")throw new Error("string tensor is not supported.")}});var Yt,bn=P(()=>{"use strict";Yt=["float32","float64","int32","int16","int8","uint16","uint32","uint8"]});var Tf,xf,Um,zm,Vm,Wm,wf=P(()=>{"use strict";Ue();bn();le();oe();Tf=(a,t,o)=>(Wm(t,o.axis),[a.run(Vm(a,t,o),t)]),xf=a=>Q({axis:a.attributes.getInt("axis",0)}),Um={name:"Gather",inputNames:["A","B"],inputTypes:[0,0]},zm=(a,t,o,e)=>{let r=o[0].dims.slice(),n=o[1].dims.slice(),s=new Array(r.length+n.length-1);e=U.normalizeAxis(e,r.length);let i=[];for(let d=0;d{let e={...Um,cacheHint:o.cacheKey};return{...e,get:()=>zm(a,e,t,o.axis)}},Wm=(a,t)=>{if(!a||a.length!==2)throw new Error("Gather requires 2 inputs.");let o=a[0].dims.length;if(o<1)throw new Error("Invalid input shape.");if(t<-o||t>o-1)throw new Error("Invalid axis.");if(Yt.indexOf(a[0].type)===-1)throw new Error("Invaid input type.");if(a[1].type!=="int32"&&a[1].type!=="int16")throw new Error("Invaid input type.")}});var Ci,vf,_f,Of,Hm,qm,jm,If=P(()=>{"use strict";Ue();le();oe();Ci=(a,t,o)=>(jm(t,o),[a.run(Hm(t,o),t)]),vf=(a,t)=>{let o=a.attributes.getInt("transA",0)!==0,e=a.attributes.getInt("transB",0)!==0,r=a.attributes.getFloat("alpha",1),n=a.attributes.getFloat("beta",1);return Q({transA:o,transB:e,alpha:r,beta:n,isOptionalC:t})},_f=a=>vf(a,!1),Of=a=>vf(a,!0),Hm=(a,t)=>{let o={name:"Gemm",inputNames:a.length===3?["A","B","C"]:["A","B"],inputTypes:a.length===3?[0,0,0]:[0,0],key:t.cacheKey};return{...o,get:()=>qm(o,a,t)}},qm=(a,t,o)=>{let e=t[0].dims.slice(),r=t[1].dims.slice(),[n,s]=Yn.getShapeOfGemmResult(e,o.transA,r,o.transB,t.length===3?t[2].dims:void 0),i=[n,s];if(!i)throw new Error("Can't use gemm on the given tensors");let u=e[e.length-1],l="";o.transA&&(u=e[0]),o.transA&&o.transB?l="value += _A_T(a) * _B_T(b);":o.transA&&!o.transB?l="value += _A_T(a) * _B(b);":!o.transA&&o.transB?l="value += _A(a) * _B_T(b);":!o.transA&&!o.transB&&(l="value += _A(a) * _B(b);");let f=i.length,p=t.length===3?`int c[${t[2].dims.length}];`:"",d=t.length===3?"bcastIndices_C(indices, c);":"",T=t.length===3?"value += beta * _C(c);":"",v=` + float process(int indices[${f}]) { + int a[${f}]; + int b[${f}]; + ${p} + + copyVec(indices, a); + copyVec(indices, b); + ${d} + + float value = 0.0; + for (int k=0; k<${u}; ++k) { + a[${f-1}] = k; + b[${f-2}] = k; + ${l} + } + + value = value * alpha; + ${T} + return value; + }`;return{...a,output:{dims:i,type:t[0].type,textureType:0},variables:[{name:"alpha",type:"float",data:o.alpha},{name:"beta",type:"float",data:o.beta}],shaderSource:v}},jm=(a,t)=>{if(!a)throw new Error("Input is missing");if(t.isOptionalC&&(a.length<2||a.length>3))throw new Error("Invaid input shape.");if(!t.isOptionalC&&a.length!==3)throw new Error("Gemm requires 3 inputs");if(a.length===3&&a[2].dims.length!==1&&a[2].dims.length!==2)throw new Error("Invalid input shape of C");if(a[0].type!=="float32"&&a[0].type!=="float64"||a[1].type!=="float32"&&a[1].type!=="float64"||a.length===3&&a[2].type!=="float32"&&a[2].type!=="float64")throw new Error("Invalid input type.");if(a[0].type!==a[1].type||a.length===3&&a[0].type!==a[2].type)throw new Error("Input types are mismatched")}});var Sf,Af,Ym,Xm,Km,Jm,Zm,Ef=P(()=>{"use strict";Ue();oe();Sf=(a,t,o)=>(Zm(t),[a.run(Km(a,t,o),t)]),Af=a=>{let t=a.attributes.getFloat("scale"),o=a.attributes.getFloats("bias");return Q({scale:t,bias:o})},Ym={name:"ImageScaler",inputNames:["X"],inputTypes:[0]},Xm=(a,t,o,e)=>{let r=o[0].dims.slice(),n=r.length,i=` + ${Jm(e.bias.length)} + float process(int indices[${n}]) { + return _X(indices) * scale + getBias(bias, indices[1]); + }`;return{...t,output:{dims:r,type:o[0].type,textureType:0},variables:[{name:"bias",type:"float",arrayLength:e.bias.length,data:e.bias},{name:"scale",type:"float",data:e.scale}],shaderSource:i}},Km=(a,t,o)=>{let e={...Ym,cacheHint:o.cacheKey};return{...e,get:()=>Xm(a,e,t,o)}},Jm=a=>{let t=[`float getBias(float bias[${a}], int channel) {`];for(let o=0;o{if(!a||a.length!==1)throw new Error("ImageScaler requires 1 input.");if(a[0].dims.length!==4)throw new Error("Invalid input shape.");if(a[0].type!=="float32"&&a[0].type!=="float64")throw new Error("Invalid input type.")}});var Df,Lf,Pf,Qm,eb,tb,rb,nb,ob,Ff=P(()=>{"use strict";we();oe();Df=(a,t,o)=>{ob(t);let e=a.run(eb(t[0]),t);return[a.run(nb(a,t[0],o,e.dims),[t[0],e,t[1],t[2]])]},Lf=a=>a.attributes.getFloat("epsilon",1e-5),Pf={name:"InstanceNormalization_MeanAndVariance",inputNames:["X"],inputTypes:[0]},Qm=(a,t)=>{let o=t.dims.slice(),e=o[1],r=o[2]*o[3],n=[o[0],e],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(${r}); + 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(${r}); + + return v; + }`;return{...a,output:{dims:n,type:t.type,textureType:4},shaderSource:s}},eb=a=>({...Pf,get:()=>Qm(Pf,a)}),tb={name:"InstanceNormalization_ComputeOutput",inputNames:["X","MeanAndVariance","Scale","B"],inputTypes:[0,4,0,0]},rb=(a,t,o,e,r)=>{let n=j(a.session.backend.glContext.version),[s,i]=a.calculateTextureWidthAndHeight(r,4),[u,l]=[s/4,i],f=` + vec4 get_MeanAndVariance(int[2] mv) { + int offset = indicesToOffset_MeanAndVariance(mv); + vec2 coords = offsetToCoords(offset, ${u}, ${l}); + 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{...t,output:{dims:o.dims,type:o.type,textureType:0},variables:[{name:"epsilon",type:"float",data:e}],shaderSource:f}},nb=(a,t,o,e)=>{let r={...tb,cacheHint:`${o}`};return{...r,get:()=>rb(a,r,t,o,e)}},ob=a=>{if(!a||a.length!==3)throw new Error("InstanceNormalization requires 3 inputs.");let t=a[0],o=a[1],e=a[2];if(t.dims.length<3||o.dims.length!==1||e.dims.length!==1)throw new Error("Invalid input shape.");if(o.dims[0]!==t.dims[1]||e.dims[0]!==t.dims[1])throw new Error("Input shapes are mismatched.");if(t.type!=="float32"&&t.type!=="float64"||o.type!=="float32"&&o.type!=="float64"||e.type!=="float32"&&e.type!=="float64")throw new Error("Invalid input type.");if(a[0].dims.length!==4)throw new Error("Only support 4-D input shape.")}});function ib(a,t){let o=a[0].dims[1],e=a[0].dims.length,r=-Math.floor((t.size-1)/2),n=Math.ceil((t.size-1)/2),s=`float(${t.alpha}) / float(${t.size})`,i=`float(${t.bias})`,u=`float(${t.beta})`,l=` + float process(int indices[${e}]) { + int c = indices[1]; + float x = _X(indices); + float square_sum = 0.0; + + for (int i = ${r}; 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(${i} + ${s} * square_sum, ${u}); + }`;return{...Bf,cacheHint:t.cacheKey,output:{dims:a[0].dims,type:a[0].type,textureType:0},shaderSource:l}}function ab(a,t){return{...Bf,cacheHint:t.cacheKey,get:()=>ib(a,t)}}var Cf,kf,Bf,sb,$f=P(()=>{"use strict";Ue();oe();Cf=(a,t,o)=>(sb(t),[a.run(ab(t,o),t)]),kf=a=>{let t=a.attributes.getFloat("alpha",1e-4),o=a.attributes.getFloat("beta",.75),e=a.attributes.getFloat("bias",1),r=a.attributes.getInt("size");return Q({alpha:t,beta:o,bias:e,size:r})},Bf={name:"LRN",inputNames:["X"],inputTypes:[0]};sb=a=>{if(!a||a.length!==1)throw new Error("LRN requires 1 input.");if(a[0].dims.length!==4)throw new Error('currently only support LRN for input with "NCHW" format');if(a[0].type!=="float32")throw new Error("input should be float type")}});var ub,ki,Nf,Rf,Mf,lb,fb,cb,pb,db,hb,mb,bb,Gf=P(()=>{"use strict";Ue();le();we();oe();ub={name:"Pad",inputNames:["A"],inputTypes:[0]},ki=(a,t,o)=>(cb(t),[a.run({...ub,cacheHint:o.cacheKey,get:()=>fb(a,t[0],o)},t)]),Nf=a=>{let t=a.attributes.getString("mode","constant"),o=a.attributes.getFloat("value",0),e=a.attributes.getInts("pads");return Q({mode:t,value:o,pads:e})},Rf=(a,t,o)=>{pb(t);let e=lb(a,t,o);return ki(a,[t[0]],e)},Mf=a=>a.attributes.getString("mode","constant"),lb=(a,t,o)=>{if(!a.session.isInitializer(t[1].dataId)||t.length>=3&&!a.session.isInitializer(t[2].dataId))throw new Error("dynamic pad attributes are not allowed");let e=Array.from(t[1].integerData),r=t.length>=3?t[2].floatData[0]:0;return Q({mode:o,pads:e,value:r})},fb=(a,t,o)=>{let e=U.padShape(t.dims.slice(),o.pads),r=e.length,s=` + ${db(a,t,o)} + float process(int[${r}] indices) { + return padA(indices); + }`;return{name:"Pad",inputNames:["A"],inputTypes:[0],output:{dims:e,type:t.type,textureType:0},shaderSource:s}},cb=a=>{if(!a||a.length!==1)throw new Error("Pad requires 1 input");if(a[0].type!=="float32"&&a[0].type!=="float64")throw new Error("Invalid input type.")},pb=a=>{if(!a||a.length!==2&&a.length!==3)throw new Error("Pad requires 2 or 3 inputs");if(a[1].type!=="int32")throw new Error("Invalid input type.");if(a.length>=3&&a[2].type==="string")throw new Error("Invalid input type.")},db=(a,t,o)=>{let e=j(a.session.backend.glContext.version),[r,n]=a.calculateTextureWidthAndHeight(t.dims,0),s=U.computeStrides(t.dims);switch(o.mode){case"constant":return hb(e,t.dims,s,r,n,o.pads,o.value);case"reflect":return mb(e,t.dims,s,r,n,o.pads);case"edge":return bb(e,t.dims,s,r,n,o.pads);default:throw new Error("Invalid mode")}},hb=(a,t,o,e,r,n,s)=>{let i=t.length,u="";for(let l=i-1;l>=0;--l)u+=` + k = m[${l}] - ${n[l]}; + if (k < 0) return constant; + if (k >= ${t[l]}) return constant; + offset += k * ${o[l]}; + `;return` + float padA(int m[${i}]) { + const float constant = float(${s}); + int offset = 0; + int k = 0; + ${u} + vec2 coords = offsetToCoords(offset, ${e}, ${r}); + float value = getColorAsFloat(${a.texture2D}(A, coords)); + return value; + } + `},mb=(a,t,o,e,r,n)=>{let s=t.length,i="";for(let u=s-1;u>=0;--u)i+=` + k = m[${u}] - ${n[u]}; + if (k < 0) { k = -k; } + { + const int _2n_1 = ${2*(t[u]-1)}; + k = int( mod( float(k), float(_2n_1) ) ) ; + if(k >= ${t[u]}) { k = _2n_1 - k; } + } + offset += k * ${o[u]}; + `;return` + float padA(int m[${s}]) { + int offset = 0; + int k = 0; + ${i} + vec2 coords = offsetToCoords(offset, ${e}, ${r}); + float value = getColorAsFloat(${a.texture2D}(A, coords)); + return value; + } + `},bb=(a,t,o,e,r,n)=>{let s=t.length,i="";for(let u=s-1;u>=0;--u)i+=` + k = m[${u}] - ${n[u]}; + if (k < 0) k = 0; + if (k >= ${t[u]}) k = ${t[u]-1}; + offset += k * ${o[u]}; + `;return` + float padA(int m[${s}]) { + int offset = 0; + int k = 0; + ${i} + vec2 coords = offsetToCoords(offset, ${e}, ${r}); + float value = getColorAsFloat(${a.texture2D}(A, coords)); + return value; + } + `}});var zf,Vf,Wf,Hf,qf,jf,Yf,Xf,Kf,gb,Uf,Jf,so,Zf,ao,yb,Qf=P(()=>{"use strict";Ue();le();oe();zf=(a,t,o)=>{so(t);let e={name:"AveragePool",inputNames:["X"],inputTypes:[0],cacheHint:o.cacheKey};return[a.run({...e,get:()=>Wf(t,e,!1,o)},t)]},Vf=a=>{let t=a.attributes.getString("auto_pad","NOTSET"),o=a.attributes.getInt("ceil_mode",0),e=a.attributes.getInt("count_include_pad",0)!==0,r=a.attributes.getInts("kernel_shape"),n=a.attributes.getInts("strides",[]),s=a.attributes.getInts("pads",[]);if(o!==0)throw new Error("using ceil() in shape computation is not yet supported for AveragePool");return Q({autoPad:t,ceilMode:o,countIncludePad:e,kernelShape:r,strides:n,pads:s})},Wf=(a,t,o,e)=>{let[r,n]=Kf(a,e,o),s=U.size(r.kernelShape),i="value += _X(x);",u="";r.countIncludePad?u+=`value /= float(${s});`:u+=`value /= float(${s} - pad);`;let f=` + ${Zf(a[0].dims,r,i,u,"0.0")} + `;return{...t,output:{dims:n,type:a[0].type,textureType:0},shaderSource:f}},Hf=(a,t,o)=>{so(t);let e={name:"GlobalAveragePool",inputNames:["X"],inputTypes:[0],cacheHint:`${o.countIncludePad}`};return[a.run({...e,get:()=>Wf(t,e,!0,o)},t)]},qf=a=>{let t=a.attributes.getInt("count_include_pad",0)!==0;return Q({autoPad:"",ceilMode:0,countIncludePad:t,kernelShape:[],strides:[],pads:[]})},jf=(a,t,o)=>{so(t);let e={name:"MaxPool",inputNames:["X"],inputTypes:[0],cacheHint:o.cacheKey};return[a.run({...e,get:()=>Xf(t,e,!1,o)},t)]},Yf=a=>{let t=a.attributes.getString("auto_pad","NOTSET"),o=a.attributes.getInt("ceil_mode",0),e=a.attributes.getInts("kernel_shape"),r=a.attributes.getInts("strides",[]),n=a.attributes.getInts("pads",[]),s=a.attributes.getInt("storage_order",0),i=a.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 Q({autoPad:t,ceilMode:o,countIncludePad:!1,kernelShape:e,strides:r,pads:n,storageOrder:s,dilations:i})},Xf=(a,t,o,e)=>{let[r,n]=Kf(a,e,o),s=` + value = max(_X(x), value); + `,i="",l=` + ${Zf(a[0].dims,r,s,i,"-1e5")} + `;return{...t,output:{dims:n,type:a[0].type,textureType:0},shaderSource:l}},Kf=(a,t,o)=>{let e=a[0].dims.slice(),r=Object.hasOwnProperty.call(t,"dilations"),n=t.kernelShape.slice(),s=t.strides.slice(),i=r?t.dilations.slice():[],u=t.pads.slice();cr.adjustPoolAttributes(o,e,n,s,i,u);let l=cr.computePoolOutputShape(o,e,s,i,n,u,t.autoPad),f=Object.assign({},t);return r?Object.assign(f,{kernelShape:n,strides:s,pads:u,dilations:i,cacheKey:t.cacheKey}):Object.assign(f,{kernelShape:n,strides:s,pads:u,cacheKey:t.cacheKey}),[f,l]},gb={autoPad:"",ceilMode:0,countIncludePad:!1,kernelShape:[],strides:[],pads:[],storageOrder:0,dilations:[],cacheKey:""},Uf={name:"GlobalMaxPool",inputNames:["X"],inputTypes:[0]},Jf=(a,t)=>(so(t),[a.run({...Uf,get:()=>Xf(t,Uf,!0,gb)},t)]),so=a=>{if(!a||a.length!==1)throw new Error("Pool ops requires 1 input.");if(a[0].type!=="float32"&&a[0].type!=="float64")throw new Error("Invalid input type.")},Zf=(a,t,o,e,r)=>{let n=a.length;if(t.kernelShape.length<=2){let s=t.kernelShape[t.kernelShape.length-1],i=t.strides[t.strides.length-1],u=t.pads[t.pads.length/2-1],l=t.pads[t.pads.length-1],f=a[n-1],p="",d="",T="";if(u+l!==0?p=` + for (int i = 0; i < ${s}; i++) { + x[${n} - 1] = indices[${n} - 1] * ${i} - ${u} + i; + if (x[${n} - 1] < 0 || x[${n} - 1] >= ${f}) { + pad++; + continue; + } + ${o} + }`:p=` + for (int i = 0; i < ${s}; i++) { + x[${n} - 1] = indices[${n} - 1] * ${i} - ${u} + i; + ${o} + }`,t.kernelShape.length===2){let w=t.kernelShape[t.kernelShape.length-2],I=t.strides[t.strides.length-2],L=t.pads[t.pads.length/2-2],F=t.pads[t.pads.length-2],C=a[n-2];L+F!==0?d=` + for (int j = 0; j < ${w}; j++) { + x[${n} - 2] = indices[${n} - 2] * ${I} - ${L} + j; + if (x[${n} - 2] < 0 || x[${n} - 2] >= ${C}) { + pad+= ${s}; + continue; + } + `:d=` + for (int j = 0; j < ${w}; j++) { + x[${n} - 2] = indices[${n} - 2] * ${I} - ${L} + j; + `,T=` + } + `}return` + float process(int indices[${n}]) { + int x[${n}]; + copyVec(indices, x); + + float value = ${r}; + int pad = 0; + ${d} + ${p} + ${T} + ${e} + return value; + } + `}else{let s=U.size(t.kernelShape),i=U.computeStrides(t.kernelShape),u=i.length,l=t.pads.length,f=yb(u),p=ao(a,"inputDims"),d=ao(t.pads,"pads"),T=ao(i,"kernelStrides"),v=ao(t.strides,"strides"),w=t.pads.reduce((F,C)=>F+C),I="";return w?I=` + if (x[j] >= inputDims[j] || x[j] < 0) { + pad++; + isPad = true; + break; + } + } + if (!isPad) { + ${o} + }`:I=` + } + ${o} + `,` + ${f} + float process(int indices[${n}]) { + int x[${n}]; + copyVec(indices, x); + int offset[${u}]; + int pads[${l}]; + int inputDims[${n}]; + int kernelStrides[${u}]; + int strides[${u}]; + ${d} + ${p} + ${v} + ${T} + + float value = ${r}; + int pad = 0; + bool isPad = false; + for (int i = 0; i < ${s}; i++) { + offsetToIndices(i, kernelStrides, offset); + isPad = false; + for (int j = ${n} - ${u}; j < ${n}; j++) { + x[j] = indices[j] * strides[j - ${n} + ${u}] + + offset[j - ${n} + ${u}] - pads[j - 2]; + ${I} + } + ${e} + + return value; + } + `}},ao=(a,t)=>{let o="";for(let e=0;e` + void offsetToIndices(int offset, int[${a}] strides, out int[${a}] indices) { + if (${a} == 0) { + return; + } + for (int i = 0; i < ${a} - 1; ++i) { + indices[i] = offset / strides[i]; + offset -= indices[i] * strides[i]; + } + indices[${a} - 1] = offset; + }`});var yr,Xt,Tb,xb,ec,tc,rc,nc,oc,ic,ac,sc=P(()=>{"use strict";Ue();bn();le();oe();yr=(a,t,o,e,r)=>{xb(t);let n={name:e,inputNames:["A"],inputTypes:[0]};return[a.run({...n,cacheHint:o.cacheKey,get:()=>Tb(a,t,o,e,r,n)},t)]},Xt=a=>{let t=a.attributes.getInts("axes",[]),o=a.attributes.getInt("keepdims",1)===1;return Q({axes:t,keepDims:o})},Tb=(a,t,o,e,r,n)=>{let s=[],i=t[0].dims.length||1,u=[],l=U.normalizeAxes(o.axes,t[0].dims.length),f=r(t,l),p=f[1];for(let v=0;v=0||l.length===0?(o.keepDims&&s.push(1),p=` + for(int j${v} = 0; j${v} < ${t[0].dims[v]}; j${v}++) { + inputIdx[${v}] = j${v}; + ${p} + }`):(u.push(`inputIdx[${v}] = outputIdx[${s.length}];`),s.push(t[0].dims[v]));let T=` + float process(int outputIdx[${s.length||1}]) { + float value; // final result + int inputIdx[${i}]; // addressing input data + ${u.join(` +`)} + ${f[0]} // init ops for reduce max/min + ${p} + ${f[2]} // final computation for reduce mean + return value; + }`;return{...n,output:{dims:s,type:t[0].type,textureType:0},shaderSource:T}},xb=a=>{if(!a||a.length!==1)throw new Error("Reduce op requires 1 input.");if(Yt.indexOf(a[0].type)===-1)throw new Error("Invalid input type.")},ec=(a,t,o)=>yr(a,t,o,"ReduceSum",()=>["value = 0.0;","value += _A(inputIdx);",""]),tc=(a,t,o)=>yr(a,t,o,"ReduceMean",(r,n)=>{let s=1;for(let i=0;i=0||n.length===0)&&(s*=r[0].dims[i]);return["value = 0.0;","value += _A(inputIdx);",`value /= ${s}.;`]}),rc=(a,t,o)=>yr(a,t,o,"ReduceMax",(r,n)=>{let s=[];for(let i=0;i=0||n.length===0)&&s.push(`inputIdx[${i}] = 0;`);return[`${s.join(` +`)} +value = _A(inputIdx);`,"value = max(value, _A(inputIdx));",""]}),nc=(a,t,o)=>yr(a,t,o,"ReduceMin",(r,n)=>{let s=[];for(let i=0;i=0||n.length===0)&&s.push(`inputIdx[${i}] = 0;`);return[`${s.join(` +`)} +value = _A(inputIdx);`,"value = min(value, _A(inputIdx));",""]}),oc=(a,t,o)=>yr(a,t,o,"ReduceProd",()=>["value = 1.0;","value *= _A(inputIdx);",""]),ic=(a,t,o)=>yr(a,t,o,"ReduceLogSum",()=>["value = 0.0;","value += _A(inputIdx);","value = log(value);"]),ac=(a,t,o)=>yr(a,t,o,"ReduceLogSumSquare",()=>["float t; value = 0.0;","t = _A(inputIdx); value += t * t;",""])});var uc,lc=P(()=>{"use strict";le();uc=(a,t)=>{let o=U.calculateReshapedDims(t[0].dims,t[1].integerData);return a.session.pack?[a.reshapePacked(t[0],o)]:[a.reshapeUnpacked(t[0],o)]}});var fc,Bi,cc,pc,gn,wb,$i,uo,Ni=P(()=>{"use strict";Ue();we();oe();fc={name:"Upsample",inputNames:["X"],inputTypes:[0]},Bi=(a,t,o)=>($i(t,o),[a.run({...fc,cacheHint:o.cacheKey,get:()=>wb(a,t,o)},t)]),cc=a=>gn(a,7),pc=a=>gn(a,9),gn=(a,t)=>{let o=t>=10,e=a.attributes.getString("mode","nearest");if(e!=="nearest"&&e!=="linear"&&(t<11||e!=="cubic"))throw new Error(`unrecognized mode: ${e}`);let r=[];t<9&&(r=a.attributes.getFloats("scales"),uo(r,e,o));let n=a.attributes.getFloat("extrapolation_value",0),s=t>10?a.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 i=s==="tf_crop_and_resize",u=i,l=e==="nearest"&&t>=11?a.attributes.getString("nearest_mode","round_prefer_floor"):"";if(["round_prefer_floor","round_prefer_ceil","floor","ceil",""].indexOf(l)===-1)throw new Error(`nearest_mode '${l}' is not supported`);let f=a.attributes.getFloat("cubic_coeff_a",-.75),p=a.attributes.getInt("exclude_outside",0)!==0;if(p&&e!=="cubic")throw new Error("exclude_outside can be set to 1 only when mode is CUBIC.");let d=t<11?!0:e==="nearest"&&s==="asymmetric"&&l==="floor",T=0,v=0,w=0;return t>10?a.inputs.length>2?(T=1,v=2,w=3):(v=1,w=2):t===9&&(v=1),Q({opset:t,isResize:o,mode:e,scales:r,extrapolationValue:n,coordinateTransformMode:s,useExtrapolation:u,needRoiInput:i,nearestMode:l,cubicCoefficientA:f,excludeOutside:p,useNearest2xOptimization:d,roiInputIdx:T,scalesInputIdx:v,sizesInputIdx:w})},wb=(a,t,o)=>{let e=j(a.session.backend.glContext.version),[r,n]=a.calculateTextureWidthAndHeight(t[0].dims,0),s=t[0].dims.map((w,I)=>Math.floor(w*o.scales[I])),[i,u]=a.calculateTextureWidthAndHeight(s,0),l=s.length,f=new Array(l),p=new Array(l),d=` + int output_pitches[${l}]; + int input_pitches[${l}]; + `;for(let w=l-1;w>=0;w--)f[w]=w===l-1?1:f[w+1]*s[w+1],p[w]=w===l-1?1:p[w+1]*t[0].dims[w+1],d+=` + output_pitches[${w}] = ${f[w]}; + input_pitches[${w}] = ${p[w]}; + `;let T=` + float getInputFloat(int index) { + vec2 coords = offsetToCoords(index, ${r}, ${n}); + float value = getColorAsFloat(${e.texture2D}(X, coords)); + return value; + } + `,v=o.mode==="nearest"?` + ${T} + float process(int indices[${l}]) { + int input_index = 0; + int output_index = coordsToOffset(TexCoords, ${i}, ${u}); + + ${d} + + int d, m; + for (int dim = 0; dim < ${l}; ++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); + }`:l===4?` + ${T} + float process(int indices[4]) { + int input_index = 0; + int output_index = coordsToOffset(TexCoords, ${i}, ${u}); + + ${d} + + 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 == (${t[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]); + }`:` + ${T} + float process(int indices[2]) { + int input_index = 0; + int output_index = coordsToOffset(TexCoords, ${i}, ${u}); + + ${d} + + 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 == (${t[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:t[0].type,textureType:0},shaderSource:v,variables:[{name:"scales",type:"int",arrayLength:o.scales.length,data:o.scales.map(w=>Math.ceil(w))}]}},$i=(a,t)=>{if(!a||t.opset<9&&a.length!==1||t.opset>=9&&t.opset<11&&a.length!==2||t.opset>=11&&a.length<2)throw new Error("invalid inputs.");if(t.scales.length>0&&a[0].dims.length!==t.scales.length)throw new Error("Invalid input shape.");if(a[0].type==="string")throw new Error("Invalid input tensor types.")},uo=(a,t,o)=>{if(o){for(let e of a)if(e<=0)throw new Error("Scale value should be greater than 0.")}else for(let e of a)if(e<1)throw new Error("Scale value should be greater than or equal to 1.");if((t==="linear"||t==="cubic")&&a.length!==2&&(a.length!==4||a[0]!==1||a[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.`)}});var Ri,Mi,dc,hc,vb,_b,Ob,Ib,mc=P(()=>{"use strict";we();oe();Ct();mr();Ni();Ri={name:"Resize",inputNames:["A"],inputTypes:[2]},Mi=(a,t,o)=>($i(t,o),[a.run({...Ri,cacheHint:o.cacheKey,get:()=>vb(a,t,o)},t)]),dc=a=>gn(a,10),hc=a=>gn(a,11),vb=(a,t,o)=>{let e=j(a.session.backend.glContext.version),[r,n]=_b(t,o);if(r.every(C=>C===1)&&o.coordinateTransformMode!=="tf_crop_and_resize")return{...Ri,output:{dims:n,type:t[0].type,textureType:2},hasMain:!0,shaderSource:`void main() { + vec4 v = ${e.texture2D}(X, TexCoords); + ${e.output} = v; + }`};let i=n.length;if(i<2)throw new Error(`output dimension should be at least 2, but got ${i}`);let u=n[i-2],l=n[i-1],f=t[0].dims;if(i!==f.length)throw new Error(`output dimension should match input ${f.length}, but got ${i}`);let p=f[i-2],d=f[i-1],T=r[i-2],v=r[i-1],w="";if(o.mode!=="linear")throw new Error(`resize (packed) does not support mode: '${o.mode}'`);switch(o.coordinateTransformMode){case"asymmetric":w=` + vec4 getSourceFracIndex(ivec4 coords) { + return vec4(coords) / scaleWHWH; + } + `;break;case"half_pixel":w=` + vec4 getSourceFracIndex(ivec4 coords) { + return (vec4(coords) + 0.5) / scaleWHWH - 0.5; + } + `;break;case"pytorch_half_pixel":w=` + vec4 getSourceFracIndex(ivec4 coords) { + vec4 fcoords = vec4(coords); + return vec4( + ${l}.0 > 1.0 ? (fcoords.x + 0.5) / scaleWHWH.x - 0.5 : 0.0, + ${u}.0 > 1.0 ? (fcoords.y + 0.5) / scaleWHWH.y - 0.5 : 0.0, + ${l}.0 > 1.0 ? (fcoords.z + 0.5) / scaleWHWH.z - 0.5 : 0.0, + ${u}.0 > 1.0 ? (fcoords.w + 0.5) / scaleWHWH.w - 0.5 : 0.0 + ); + } + `;break;case"align_corners":w=` + vec4 getSourceFracIndex(ivec4 coords) { + vec4 resized = vec4(${l}.0 - 1.0, ${u}.0 - 1.0, ${l}.0 - 1.0, + ${u}.0 - 1.0); + vec4 original = vec4(${d}.0 - 1.0, ${p}.0 - 1.0, ${d}.0 - 1.0, + ${p}.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 I=Je(i),L=kt(),F=` + const vec2 inputWH = vec2(${p}.0, ${d}.0); + const vec4 scaleWHWH = vec4(float(${T}), float(${v}), float(${T}), float(${v})); + ${L} + ${w} + float getAValue(int x10, int r, int c, int d) { + return getChannel(getA(x10, r, c, d), vec2(c, d)); + } + void main() { + ${I} 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 < ${u-1}; + bool hasNextCol = rc.z < ${l-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); + + ${e.output} = vec4(newValue); + } + `;return{...Ri,output:{dims:n,type:t[0].type,textureType:2},hasMain:!0,shaderSource:F}},_b=(a,t)=>{let e=a[0].dims,r=t.scales,n;if(r.length===0){let i=a[t.scalesInputIdx];if(i&&i.size!==0){if(a[t.sizesInputIdx])throw new Error("Only one of scales or sizes must be provided as input.");r=Ob(i,t.mode,t.isResize)}else{let u=a[t.sizesInputIdx];if(!u||u.size===0)throw new Error("Either scales or sizes MUST be provided as input.");n=Array.from(u.integerData),r=Ib(n,e,t.mode,t.isResize)}}else if(a[t.sizesInputIdx])throw new Error("Only one of scales or sizes must be provided as input.");let s=n||e.map((i,u)=>Math.floor(i*r[u]));return[r,s]},Ob=(a,t,o)=>{let e=Array.from(a.floatData);return uo(e,t,o),e},Ib=(a,t,o,e)=>{let r=t.length,n=new Array(r);for(let s=0,i=r;s{"use strict";hr();bc=(a,t)=>(Sb(t),[new ke([t[0].dims.length],"int32",void 0,void 0,new Int32Array(t[0].dims))]),Sb=a=>{if(!a||a.length!==1)throw new Error("Shape requires 1 input.")}});var Gi,yc,Tc,xc,Ab,wc,Eb,Pb,vc=P(()=>{"use strict";Ue();bn();le();oe();Gi={name:"Slice",inputNames:["A"],inputTypes:[0]},yc=(a,t,o)=>(Ab(t),[a.run({...Gi,cacheHint:o.cacheKey,get:()=>xc(a,t[0],o)},t)]),Tc=a=>{let t=a.attributes.getInts("starts"),o=a.attributes.getInts("ends"),e=a.attributes.getInts("axes",[]);return Q({starts:t,ends:o,axes:e})},xc=(a,t,o)=>{let e=o.axes.length===0?t.dims.slice(0).map((p,d)=>d):o.axes,r=U.normalizeAxes(e,t.dims.length),n=o.starts.map((p,d)=>p>t.dims[r[d]]-1?t.dims[r[d]]:U.normalizeAxis(p,t.dims[r[d]])),s=o.ends.map((p,d)=>p>t.dims[r[d]]-1?t.dims[r[d]]:U.normalizeAxis(p,t.dims[r[d]])),i=t.dims.slice(),u=[];for(let p=0;p0&&u.push(`outputIdx[${r[p]}] += ${n[p]};`);let f=` + float process(int outputIdx[${i.length}]) { + ${u.join(` + `)} + return _A(outputIdx); + }`;return{...Gi,output:{dims:i,type:t.type,textureType:0},shaderSource:f}},Ab=a=>{if(!a||a.length!==1)throw new Error("Slice requires 1 input.");if(Yt.indexOf(a[0].type)===-1)throw new Error("Invalid input type.")},wc=(a,t)=>{Pb(t);let o=Eb(a,t);return[a.run({...Gi,cacheHint:o.cacheKey,get:()=>xc(a,t[0],o)},[t[0]])]},Eb=(a,t)=>{if(!a.session.isInitializer(t[1].dataId)||!a.session.isInitializer(t[2].dataId)||t.length>=4&&!a.session.isInitializer(t[3].dataId)||t.length>=5&&!a.session.isInitializer(t[4].dataId))throw new Error("dynamic slice attributes are not allowed");if(t.length>=5&&t[4].integerData.some(s=>s!==1))throw new Error("currently non-1 steps is not supported for Slice");let o=Array.from(t[1].integerData),e=Array.from(t[2].integerData),r=t.length>=4?Array.from(t[3].integerData):[],n=`${r};${o};${e}`;return{starts:o,ends:e,axes:r,cacheKey:n}},Pb=a=>{if(!a||a.length<3||a.length>5)throw new Error("Invalid input number.");if(a[1].type!=="int32"||a[1].dims.length!==1)throw new Error("Invalid input type.");if(a[2].type!=="int32"||a[2].dims.length!==1)throw new Error("Invalid input type.");if(a.length>=4&&(a[3].type!=="int32"||a[3].dims.length!==1))throw new Error("Invalid input type.");if(a.length>=5&&(a[4].type!=="int32"||a[4].dims.length!==1))throw new Error("Invalid input type.")}});var _c,Oc,Ic,Sc,Ac,Ec,Pc,Dc,Db,Lb,Fb,Lc,Fc=P(()=>{"use strict";Ue();le();we();oe();io();_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=(a,t,o)=>{Lc(t);let e=t[0].dims.slice(),r=U.normalizeAxis(o.axis,e.length),n=U.sizeToDimension(e,r),s=U.sizeFromDimension(e,r);return Dc(a,t,o,n,s)},Ac=a=>Q({axis:a.attributes.getInt("axis",1)}),Ec=a=>Q({axis:a.attributes.getInt("axis",-1)}),Pc=(a,t,o)=>{Lc(t);let e=t[0].dims.slice(),r=U.normalizeAxis(o.axis,e.length),n=e.length,s=r!==n-1,i=[],u=[],l=[],f;s&&(u=Array.from({length:n}).map((v,w)=>w),u[r]=n-1,u[n-1]=r,u.map(v=>i.push(e[v])),f=Q({perm:u}),l=gr(a,t,f));let p=s?U.sizeToDimension(i,n-1):U.sizeToDimension(e,n-1),d=s?U.sizeFromDimension(i,n-1):U.sizeFromDimension(e,n-1),T=Dc(a,s?l:t,o,p,d);return s?gr(a,T,f):T},Dc=(a,t,o,e,r)=>{let n=Db(a,t[0],e,r,[e]),s=a.run({..._c,cacheHint:o.cacheKey,get:()=>n},t),i=Lb(a,t[0],e,r,n.output.dims,[e]),u=a.run({...Oc,cacheHint:o.cacheKey,get:()=>i},[t[0],s]),l=Fb(a,t[0],e,r,n.output.dims,i.output.dims);return[a.run({...Ic,cacheHint:o.cacheKey,get:()=>l},[t[0],s,u])]},Db=(a,t,o,e,r)=>{let[n,s]=a.calculateTextureWidthAndHeight(t.dims,0),i=r.length;if(o<1||e<1)throw new Error("Logical row count N and feature count D must be greater than or equal to 1");if(r.length!==1)throw new Error("Dimensionality of the output should be 1");if(r[0]!==o)throw new Error("Shape of the output should be equal to logical row count");let u=j(a.session.backend.glContext.version),l=` + float process(int[${i}] indices) { + int logical_row_start_offset = indices[0] * ${e}; + + float max = getColorAsFloat(${u.texture2D}(A, offsetToCoords(logical_row_start_offset, ${n}, + ${s} ))); + for(int i=1; i<${e}; ++i) + { + float current = getColorAsFloat(${u.texture2D}(A, offsetToCoords(logical_row_start_offset + i, + ${n}, ${s}))); + if(current > max) + max = current; + } + + return max; + }`;return{..._c,output:{dims:r,type:t.type,textureType:0},shaderSource:l}},Lb=(a,t,o,e,r,n)=>{let[s,i]=a.calculateTextureWidthAndHeight(t.dims,0),u=n.length;if(o<1||e<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(r.length!==1)throw new Error("Dimensionality of the intermediate results should be 1");if(r[0]!==o)throw new Error("Shape of the intermediate results should be equal to logical row count");let l=j(a.session.backend.glContext.version),f=` + float process(int[${u}] indices) { + int logical_row_start_offset = indices[0] * ${e}; + + float norm_factor = 0.0; + float max = _Max(indices); + for(int i=0; i<${e}; ++i) + { + norm_factor += exp(getColorAsFloat(${l.texture2D}(A, offsetToCoords(logical_row_start_offset + i, + ${s}, ${i}))) - max); + } + + return norm_factor; + }`;return{...Oc,output:{dims:n,type:t.type,textureType:0},shaderSource:f}},Fb=(a,t,o,e,r,n)=>{let[s,i]=a.calculateTextureWidthAndHeight(t.dims,0),u=t.dims.length;if(o<1||e<1)throw new Error("Logical row count N and feature count D must be greater than or equal to 1");if(r.length!==1||n.length!==1)throw new Error("Dimensionality of the intermediate results should be 1");if(r[0]!==o||n[0]!==o)throw new Error("Shape of the intermediate results should be equal to logical row count");let l=` + float process(int[${u}] indices) { + + // get offset of current logical tensor index from the 2-D texture coordinates (TexCoords) + int offset = coordsToOffset(TexCoords, ${s}, ${i}); + + //determine the logical row for this index + int logical_row_index[1]; + logical_row_index[0] = offset / ${e}; + + 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:t.dims,type:t.type,textureType:0},shaderSource:l}},Lc=a=>{if(!a||a.length!==1)throw new Error("Softmax requires 1 input.");if(a[0].type!=="float32"&&a[0].type!=="float64")throw new Error("Invalid input type")}});var Cc,kc,Bc,Cb,kb,Bb,$c=P(()=>{"use strict";Ue();le();oe();Cc={name:"Split",inputNames:["A"],inputTypes:[0]},kc=(a,t,o)=>{Bb(t);let e=U.normalizeAxis(o.axis,t[0].dims.length),r=Cb(a,t,e,o),n=[];for(let s=0;skb(a,t[0],o,e,s)},t));return n},Bc=a=>{let t=a.attributes.getInt("axis",0),o=a.attributes.getInts("split",[]),e=a.outputs.length;return Q({axis:t,split:o,numOutputs:e})},Cb=(a,t,o,e)=>{let[,r]=fn.splitShape(t[0].dims,o,e.split,e.numOutputs);return r.length},kb=(a,t,o,e,r)=>{let[n,s]=fn.splitShape(t.dims,e,o.split,o.numOutputs),i=s[r],u=n[r],f=` + float process(int indices[${u.length}]) { + indices[${e}] += ${i}; + return _A(indices); + } + `;return{...Cc,cacheHint:`${o.cacheKey}:${r}`,output:{dims:u,type:t.type,textureType:0},shaderSource:f}},Bb=a=>{if(!a||a.length!==1)throw new Error("Split requires one input.");if(a[0].type!=="int8"&&a[0].type!=="uint8"&&a[0].type!=="int16"&&a[0].type!=="uint16"&&a[0].type!=="int32"&&a[0].type!=="uint32"&&a[0].type!=="float32"&&a[0].type!=="float64"&&a[0].type!=="bool")throw new Error("Invalid input type.")}});var Ui,Nc,Rc,$b,Nb,Mc=P(()=>{"use strict";le();Ui=(a,t,o)=>{$b(t);let e=U.squeezeShape(t[0].dims,o);return[a.reshapeUnpacked(t[0],e)]},Nc=(a,t)=>(Nb(t),Ui(a,[t[0]],Array.from(t[1].integerData))),Rc=a=>a.attributes.getInts("axes"),$b=a=>{if(!a||a.length!==1)throw new Error("Squeeze requires 1 input.");if(a[0].type==="string")throw new Error("invalid input tensor types.")},Nb=a=>{if(!a||a.length!==2)throw new Error("Squeeze requires 2 inputs.");if(a[1].type!=="int32")throw new Error("Invalid input type.")}});var Gc,Rb,Mb,Uc=P(()=>{"use strict";we();oe();Gc=(a,t)=>{Mb(t);let o={name:"Sum",inputNames:t.map((r,n)=>`X${n}`),inputTypes:new Array(t.length).fill(0)};return[a.run({...o,get:()=>Rb(a,t,o)},t)]},Rb=(a,t,o)=>{let e=j(a.session.backend.glContext.version),r=t[0].dims.slice(),s=` + void main() { + vec4 result = ${t.map((i,u)=>`${e.texture2D}(X${u},TexCoords)`).join(" + ")}; + ${e.output} = result; + } + `;return{...o,output:{dims:r,type:t[0].type,textureType:0},hasMain:!0,shaderSource:s}},Mb=a=>{if(!a||a.length===0)throw new Error("Sum requires inputs.");let t=a[0].dims.length;for(let o=1;o{"use strict";bn();oe();zc=(a,t)=>{Ub(t);let o={name:"Tile",inputNames:["A"],inputTypes:[0]};return[a.run({...o,get:()=>Gb(a,t,o)},t)]},Gb=(a,t,o)=>{let e=t[0].dims.slice(),r=new Array(e.length),n=[];for(let u=0;u{if(!a||a.length!==2)throw new Error("Tile requires 2 input.");if(a[1].dims.length!==1)throw new Error("The second input shape must 1 dimension.");if(a[1].dims[0]!==a[0].dims.length)throw new Error("Invalid input shape.");if(Yt.indexOf(a[0].type)===-1)throw new Error("Invalid input type.");if(a[1].type!=="int32"&&a[1].type!=="int16")throw new Error("Invalid repeat type.")}});var zi,Wc,Hc,zb,Vb,qc=P(()=>{"use strict";le();zi=(a,t,o)=>{zb(t);let e=U.unsqueezeShape(t[0].dims,o);return[a.reshapeUnpacked(t[0],e)]},Wc=(a,t)=>(Vb(t),zi(a,[t[0]],Array.from(t[1].integerData))),Hc=a=>a.attributes.getInts("axes"),zb=a=>{if(!a||a.length!==1)throw new Error("Unsqueeze requires 1 input.");if(a[0].type==="string")throw new Error("invalid input tensor types.")},Vb=a=>{if(!a||a.length!==2)throw new Error("Unsqueeze requires 2 inputs.");if(a[1].type!=="int32")throw new Error("Invalid input type.")}});var jc,Yc=P(()=>{"use strict";nl();bl();Tl();Il();ro();lf();mf();yf();wf();If();Ef();Ff();$f();no();Gf();Qf();sc();lc();mc();gc();vc();Fc();$c();Mc();Uc();Vc();io();Ii();qc();Ni();jc=[["Abs","","6+",Sl],["Acos","","7+",Al],["Add","","7+",ol],["And","","7+",il],["Asin","","7+",El],["Atan","","7+",Pl],["AveragePool","","7+",zf,Vf],["BatchNormalization","","7+",tl,rl],["Cast","","6+",gl,yl],["Ceil","","6+",Fl],["Clip","","6-10",_i,Dl],["Clip","","11+",Ll],["Concat","","4+",vl,Ol],["Conv","","1+",Li,Fi],["ConvTranspose","","1+",sf,uf],["Cos","","7+",Cl],["Div","","7+",al],["Dropout","","7+",Oi],["DepthToSpace","","1+",df,hf],["Equal","","7+",sl],["Elu","","6+",kl,Bl],["Exp","","6+",$l],["Flatten","","1+",bf,gf],["Floor","","6+",Nl],["FusedConv","com.microsoft","1+",Li,Fi],["Gather","","1+",Tf,xf],["Gemm","","7-10",Ci,_f],["Gemm","","11+",Ci,Of],["GlobalAveragePool","","1+",Hf,qf],["GlobalMaxPool","","1+",Jf],["Greater","","7+",ul],["Identity","","1+",Oi],["ImageScaler","","1+",Sf,Af],["InstanceNormalization","","6+",Df,Lf],["LeakyRelu","","6+",Rl,Ml],["Less","","7+",ll],["LRN","","1+",Cf,kf],["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",ki,Nf],["Pad","","11+",Rf,Mf],["Pow","","7+",pl],["PRelu","","7+",dl],["ReduceLogSum","","1+",ic,Xt],["ReduceMax","","1+",rc,Xt],["ReduceMean","","1+",tc,Xt],["ReduceMin","","1+",nc,Xt],["ReduceProd","","1+",oc,Xt],["ReduceSum","","1-12",ec,Xt],["ReduceSumSquare","","1+",ac,Xt],["Relu","","6+",Vl],["Reshape","","5+",uc],["Resize","","10",Mi,dc],["Resize","","11+",Mi,hc],["Shape","","1+",bc],["Sigmoid","","6+",Wl],["Sin","","7+",Hl],["Slice","","10+",wc],["Slice","","1-9",yc,Tc],["Softmax","","1-12",Sc,Ac],["Softmax","","13+",Pc,Ec],["Split","","2-12",kc,Bc],["Sqrt","","6+",ql],["Squeeze","","1-12",Ui,Rc],["Squeeze","","13+",Nc],["Sub","","7+",hl],["Sum","","6+",Gc],["Tan","","7+",jl],["Tanh","","6+",Yl],["Tile","","6+",zc],["Transpose","","1+",gr,cf],["Upsample","","7-8",Bi,cc],["Upsample","","9",Bi,pc],["Unsqueeze","","1-12",zi,Hc],["Unsqueeze","","13+",Wc],["Xor","","7+",ml]]});function Kc(a){let t={},o;for(;(o=Xc.exec(a))!==null;){let e=o[3].split(",").map(r=>{let n=r.trim().split(" ");return n&&n.length===2?{type:n[0],name:n[1]}:null}).filter(r=>r!==null);t[o[2]]={params:e,body:o[4]}}for(let e in t){let r=Wb.replace("__FUNC__",e),n=new RegExp(r,"gm");for(;(o=n.exec(a))!==null;){let s=o[1],i=o[2],u=o[3].split(","),l=s?`${s} ${i};`:"",f=t[e].body,p="";t[e].params.forEach((T,v)=>{T&&(p+=`${T.type} ${T.name} = ${u[v]}; +`)}),f=`${p} + ${f}`,f=f.replace("return",`${i} = `);let d=` + ${l} + { + ${f} + } + `;a=a.replace(o[0],d)}}return a=a.replace(Xc,""),a}var Xc,Wb,Jc=P(()=>{"use strict";Xc=/@inline[\s\n\r]+(\w+)[\s\n\r]+([0-9a-zA-Z_]+)\s*\(([^)]*)\)\s*{(([^}]|[\n\r])*)}/gm,Wb="(\\w+)?\\s+([_0-9a-zA-Z]+)\\s+=\\s+__FUNC__\\((.*)\\)\\s*;"});function Gr(a,t){let o=[],e=[],r=t!=null&&Array.isArray(t)&&t.length===0,n=t==null||r?null:Hb(t,a).sort(),s=0;for(let i=0;ii)&&a[i]===1&&(o.push(a[i]),e.push(i)),n[s]<=i&&s++}a[i]!==1&&(o.push(a[i]),e.push(i))}return{newShape:o,keptDims:e}}function Hb(a,t){let o=t.length;return a=a==null?t.map((e,r)=>r):[].concat(a),kr(a.every(e=>e>=-o&&e`All values in axis param must be in range [-${o}, ${o}) but got axis ${a}`),kr(a.every(qb),()=>`All values in axis param must be integers but got axis ${a}`),a.map(e=>e<0?o+e:e)}function qb(a){return a%1===0}function jb(a){if(a.length===0)return 1;let t=a[0];for(let o=1;o{"use strict";ft();le();lo=class{constructor(t){this.maxTextureSize=t}computeTextureWH(t,o){let e=this.computeTexture(t,o);return o&&o.isPacked&&(e[0]/=2,e[1]/=2),o&&o.reverseWH?[e[1],e[0]]:e}computeTexture(t,o){let e=o&&o.isPacked;if(t.length===0)return e?[2,2]:[1,1];let r=this.maxTextureSize;if(o&&o.breakAxis!==void 0){let i=o.breakAxis>=t.length?1:t.slice(o.breakAxis).reduce((l,f)=>l*f),u=o.breakAxis<=0?1:t.slice(0,o.breakAxis).reduce((l,f)=>l*f);if(i>r||u>r)fe.verbose("TextureLayout",`Given width/height preferences were unattainable: shape:${t}, breakAxis:${o.breakAxis}`);else return[i,u]}let n=t.slice(0);e&&(r=r*2,n=n.map((i,u)=>u>=n.length-2?n[u]%2===0?n[u]:n[u]+1:n[u]),n.length===1&&(n=[2,n[0]])),n.length!==2&&(n=Gr(n).newShape);let s=jb(n);return n.length<=1&&s<=r?[1,s]:n.length===2&&n[0]<=r&&n[1]<=r?n:n.length===3&&n[0]*n[1]<=r&&n[2]<=r?[n[0]*n[1],n[2]]:n.length===3&&n[0]<=r&&n[1]*n[2]<=r?[n[0],n[1]*n[2]]:n.length===4&&n[0]*n[1]*n[2]<=r&&n[3]<=r?[n[0]*n[1]*n[2],n[3]]:n.length===4&&n[0]<=r&&n[1]*n[2]*n[3]<=r?[n[0],n[1]*n[2]*n[3]]:e?Zc(s/4).map(i=>i*2):Zc(s)}}});var fo,Qc=P(()=>{"use strict";le();Gt();we();Vi();Ct();fo=class extends ht{constructor(o){super(o)}getFunctions(){return{...this.offsetToCoords(),...this.coordsToOffset(),...this.toVec(),...this.valueFrom(),...this.getCommonUtilFuncs(),...this.getInputsSamplingSnippets(),...this.getOutputSamplingSnippet()}}getCustomTypes(){return{}}offsetToCoords(){let o="offsetToCoords";return{offsetToCoords:new M(` + vec2 ${o}(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 o="coordsToOffset";return{coordsToOffset:new M(` + int ${o}(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 o=this.context.outputTextureLayout;return o.isPacked?this.getPackedOutputSamplingSnippet(o):this.getUnpackedOutputSamplingSnippet(o)}getPackedOutputSamplingSnippet(o){let e=o.unpackedShape,r=[o.width,o.height],n={},s="getOutputCoords";switch(e.length){case 0:n[s]=this.getOutputScalarCoords();break;case 1:n[s]=this.getOutputPacked1DCoords(e,r);break;case 2:n[s]=this.getOutputPacked2DCoords(e,r);break;case 3:n[s]=this.getOutputPacked3DCoords(e,r);break;default:n[s]=this.getOutputPackedNDCoords(e,r)}let u=` + void setOutput(vec4 val) { + ${j(this.context.glContext.version).output} = val; + } + `,l="floatTextureSetRGBA";return n[l]=new M(u),n}getUnpackedOutputSamplingSnippet(o){let e=o.unpackedShape,r=[o.width,o.height],n={},s="getOutputCoords";switch(e.length){case 0:n[s]=this.getOutputScalarCoords();break;case 1:n[s]=this.getOutputUnpacked1DCoords(e,r);break;case 2:n[s]=this.getOutputUnpacked2DCoords(e,r);break;case 3:n[s]=this.getOutputUnpacked3DCoords(e,r);break;case 4:n[s]=this.getOutputUnpacked4DCoords(e,r);break;case 5:n[s]=this.getOutputUnpacked5DCoords(e,r);break;case 6:n[s]=this.getOutputUnpacked6DCoords(e,r);break;default:throw new Error(`Unsupported output dimensionality: ${e.length}`)}let u=` + void setOutput(float val) { + ${j(this.context.glContext.version).output} = vec4(val, 0, 0, 0); + } + `,l="floatTextureSetR";return n[l]=new M(u),n}getOutputScalarCoords(){return new M(` + int getOutputCoords() { + return 0; + } + `)}getOutputPacked1DCoords(o,e){let r=e,n="";return r[0]===1?(n=` + int getOutputCoords() { + return 2 * int(TexCoords.y * ${r[1]}.0); + } + `,new M(n)):r[1]===1?(n=` + int getOutputCoords() { + return 2 * int(TexCoords.x * ${r[0]}.0); + } + `,new M(n)):(n=` + int getOutputCoords() { + ivec2 resTexRC = ivec2(TexCoords.xy * + vec2(${r[0]}, ${r[1]})); + return 2 * (resTexRC.y * ${r[0]} + resTexRC.x); + } + `,new M(n))}getOutputPacked2DCoords(o,e){let r="";if(fr.arraysEqual(o,e))return r=` + ivec2 getOutputCoords() { + return 2 * ivec2(TexCoords.xy * vec2(${e[0]}, ${e[1]})); + } + `,new M(r);let n=e,s=Math.ceil(o[1]/2);return r=` + ivec2 getOutputCoords() { + ivec2 resTexRC = ivec2(TexCoords.xy * + vec2(${n[0]}, ${n[1]})); + + int index = resTexRC.y * ${n[0]} + resTexRC.x; + + // reverse r and c order for packed texture + int r = imod(index, ${s}) * 2; + int c = 2 * (index / ${s}); + + return ivec2(r, c); + } + `,new M(r)}getOutputPacked3DCoords(o,e){let r=[e[0],e[1]],n=Math.ceil(o[2]/2),s=n*Math.ceil(o[1]/2),i=` + ivec3 getOutputCoords() { + ivec2 resTexRC = ivec2(TexCoords.xy * + vec2(${r[0]}, ${r[1]})); + int index = resTexRC.y * ${r[0]} + resTexRC.x; + + int b = index / ${s}; + index -= b * ${s}; + + // reverse r and c order for packed texture + int r = imod(index, ${n}) * 2; + int c = 2 * (index / ${n}); + + return ivec3(b, r, c); + } + `;return new M(i)}getOutputPackedNDCoords(o,e){let r=[e[0],e[1]],n=Math.ceil(o[o.length-1]/2),s=n*Math.ceil(o[o.length-2]/2),i=s,u="",l="b, r, c";for(let p=2;p=0;--l)s[l]=s[l+1]*o[l+1];let i=["r","c","d"],u=s.map((l,f)=>{let p=`int ${i[f]} = index / ${l}`,d=f===s.length-1?`int ${i[f+1]} = index - ${i[f]} * ${l}`:`index -= ${i[f]} * ${l}`;return`${p}; ${d};`}).join("");return r=` + ivec3 getOutputCoords() { + ivec2 resTexRC = ivec2(TexCoords.xy * + vec2(${e[0]}, ${e[1]})); + int index = resTexRC.y * ${e[0]} + resTexRC.x; + ${u} + return ivec3(r, c, d); + } + `,new M(r)}getOutputUnpacked4DCoords(o,e){let r="",n=o.length,s=null;n<2&&(s=[]),s=new Array(n-1),s[n-2]=o[n-1];for(let l=n-3;l>=0;--l)s[l]=s[l+1]*o[l+1];let i=["r","c","d","d2"],u=s.map((l,f)=>{let p=`int ${i[f]} = index / ${l}`,d=f===s.length-1?`int ${i[f+1]} = index - ${i[f]} * ${l}`:`index -= ${i[f]} * ${l}`;return`${p}; ${d};`}).join("");return r=` + ivec4 getOutputCoords() { + ivec2 resTexRC = ivec2(TexCoords.xy * + vec2(${e[0]}, ${e[1]})); + int index = resTexRC.y * ${e[0]} + resTexRC.x; + ${u} + return ivec4(r, c, d, d2); + } + `,new M(r)}getOutputUnpacked5DCoords(o,e){let r="",n=o.length,s=null;n<2&&(s=[]),s=new Array(n-1),s[n-2]=o[n-1];for(let l=n-3;l>=0;--l)s[l]=s[l+1]*o[l+1];let i=["r","c","d","d2","d3"],u=s.map((l,f)=>{let p=`int ${i[f]} = index / ${l}`,d=f===s.length-1?`int ${i[f+1]} = index - ${i[f]} * ${l}`:`index -= ${i[f]} * ${l}`;return`${p}; ${d};`}).join("");return r=` + ivec5 getOutputCoords() { + ivec2 resTexRC = ivec2(TexCoords.xy * + vec2(${e[0]}, ${e[1]})); + int index = resTexRC.y * ${e[0]} + resTexRC.x; + ${u} + return ivec5(r, c, d, d2, d3); + } + `,new M(r)}getOutputUnpacked6DCoords(o,e){let r="",n=o.length,s=null;n<2&&(s=[]),s=new Array(n-1),s[n-2]=o[n-1];for(let l=n-3;l>=0;--l)s[l]=s[l+1]*o[l+1];let i=["r","c","d","d2","d3","d4"],u=s.map((l,f)=>{let p=`int ${i[f]} = index / ${l}`,d=f===s.length-1?`int ${i[f+1]} = index - ${i[f]} * ${l}`:`index -= ${i[f]} * ${l}`;return`${p}; ${d};`}).join("");return r=` + ivec6 getOutputCoords() { + ivec2 resTexRC = ivec2(TexCoords.xy * + vec2(${e[0]}, ${e[1]})); + int index = resTexRC.y * ${e[0]} + resTexRC.x; + ${u} + return ivec6(r, c, d, d2, d3, d4); + } + `,new M(r)}getCommonUtilFuncs(){let o={},e="uvFromFlat";o[e]=new M(` + 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",o[e]=new M(` + 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",o[e]=new M(` + 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",o[e]=new M(` + 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 r=j(this.context.glContext.version);return o[e]=new M(` + float sampleTexture(sampler2D textureSampler, vec2 uv) { + return ${r.texture2D}(textureSampler, uv).r; + }`),o}getInputsSamplingSnippets(){let o={},e=this.context.outputTextureLayout;return this.context.programInfo.inputNames.forEach((r,n)=>{let s=this.context.inputTextureLayouts[n],i=Xn(r);s.isPacked?o[i]=this.getPackedSamplerFromInput(i,r,s):o[i]=this.getUnpackedSamplerFromInput(i,r,s);let u=Mu(r);s.unpackedShape.length<=e.unpackedShape.length&&(s.isPacked?o[u]=this.getPackedSamplerAtOutputCoords(u,s,e,r):o[u]=this.getUnpackedSamplerAtOutputCoords(u,s,e,r))}),o}getPackedSamplerAtOutputCoords(o,e,r,n){let s=e.unpackedShape,i=r.unpackedShape,l=Xn(n),f=s.length,p=i.length,d=Ke.getBroadcastDims(s,i),T=Je(p),v=p-f,w,I=It();f===0?w="":p<2&&d.length>=1?w="coords = 0;":w=d.map(V=>`coords.${I[V+v]} = 0;`).join(` +`);let L="";p<2&&f>0?L="coords":L=s.map((V,se)=>`coords.${I[se+v]}`).join(", ");let F="return outputValue;",X=U.size(s)===1,ge=U.size(i)===1;if(f===1&&!X&&!ge)F=` + return vec4(outputValue.xy, outputValue.xy); + `;else if(X&&!ge)p===1?F=` + return vec4(outputValue.x, outputValue.x, 0., 0.); + `:F=` + return vec4(outputValue.x); + `;else if(d.length){let V=f-2,se=f-1;d.indexOf(V)>-1&&d.indexOf(se)>-1?F="return vec4(outputValue.x);":d.indexOf(V)>-1?F="return vec4(outputValue.x, outputValue.y, outputValue.x, outputValue.y);":d.indexOf(se)>-1&&(F="return vec4(outputValue.xx, outputValue.zz);")}let Oe=` + int lastDim = coords.${I[p-1]}; + coords.${I[p-1]} = coords.${I[p-2]}; + coords.${I[p-2]} = lastDim; + `,Ne=` + vec4 ${o}() { + ${T} coords = getOutputCoords(); + ${Oe} + ${w} + vec4 outputValue = ${l}(${L}); + ${F} + } + `;return new M(Ne,["coordinates.getOutputCoords"])}getUnpackedSamplerAtOutputCoords(o,e,r,n){let s=[r.width,r.height],i=[e.width,e.height],u=e.unpackedShape.length,l=r.unpackedShape.length,f=e.unpackedShape,p=r.unpackedShape,d=Xn(n);if(u===l&&fr.arraysEqual(i,s)){let X=` + float ${o}() { + return sampleTexture(${n}, TexCoords); + } + `;return new M(X,["coordinates.sampleTexture"])}let T=Je(l),v=Ke.getBroadcastDims(f,p),w=l-u,I,L=It();u===0?I="":l<2&&v.length>=1?I="coords = 0;":I=v.map(X=>`coords.${L[X+w]} = 0;`).join(` +`);let F="";l<2&&u>0?F="coords":F=e.unpackedShape.map((X,N)=>`coords.${L[N+w]}`).join(", ");let C=` + float ${o}() { + ${T} coords = getOutputCoords(); + ${I} + return ${d}(${F}); + } + `;return new M(C,["coordinates.getOutputCoords"])}getPackedSamplerFromInput(o,e,r){switch(r.unpackedShape.length){case 0:return this.getPackedSamplerScalar(o,e);case 1:return this.getPackedSampler1D(o,e,r);case 2:return this.getPackedSampler2D(o,e,r);case 3:return this.getPackedSampler3D(o,e,r);default:return this.getPackedSamplerND(o,e,r)}}getUnpackedSamplerFromInput(o,e,r){let n=r.unpackedShape;switch(n.length){case 0:return this.getUnpackedSamplerScalar(o,e,r);case 1:return this.getUnpackedSampler1D(o,e,r);case 2:return this.getUnpackedSampler2D(o,e,r);case 3:return this.getUnpackedSampler3D(o,e,r);case 4:return this.getUnpackedSampler4D(o,e,r);case 5:return this.getUnpackedSampler5D(o,e,r);case 6:return this.getUnpackedSampler6D(o,e,r);default:throw new Error(`Unsupported dimension ${n.length}-D`)}}getPackedSamplerScalar(o,e){let r=j(this.context.glContext.version),n=` + vec4 ${o}() { + return ${r.texture2D}(${e}, halfCR); + } + `;return new M(n)}getPackedSampler1D(o,e,r){let n=[r.width,r.height],s=[n[1],n[0]],i=j(this.context.glContext.version),l=`vec4 ${o}(int index) { + vec2 uv = packedUVfrom1D( + ${s[0]}, ${s[1]}, index); + return ${i.texture2D}(${e}, uv); + }`;return new M(l,["coordinates.packedUVfrom1D"])}getPackedSampler2D(o,e,r){let n=r.unpackedShape,s=[r.width,r.height],i=j(this.context.glContext.version),u=s[0],l=s[1];if(s!=null&&fr.arraysEqual(n,s)){let v=`vec4 ${o}(int row, int col) { + vec2 uv = (vec2(col, row) + halfCR) / vec2(${l}.0, ${u}.0); + return ${i.texture2D}(${e}, uv); + }`;return new M(v)}let f=s,p=Math.ceil(n[1]/2),T=`vec4 ${o}(int row, int col) { + vec2 uv = packedUVfrom2D(${f[1]}, ${f[0]}, ${p}, row, col); + return ${i.texture2D}(${e}, uv); + }`;return new M(T,["coordinates.packedUVfrom2D"])}getPackedSampler3D(o,e,r){let n=r.unpackedShape,s=[r.width,r.height],i=[s[0],s[1]],u=j(this.context.glContext.version);if(n[0]===1){let w=n.slice(1),I=[1,2],L=Br(n,w),F=["b","row","col"],C=JSON.parse(JSON.stringify(r));C.unpackedShape=L;let X=this.getPackedSamplerFromInput(o,e,C),ge=`${X.routineBody} + vec4 ${o}(int b, int row, int col) { + return ${o}(${$r(F,I)}); + } `;return new M(ge,X.dependencies)}let l=i[0],f=i[1],p=Math.ceil(n[2]/2),d=p*Math.ceil(n[1]/2),v=`vec4 ${o}(int b, int row, int col) { + vec2 uv = packedUVfrom3D( + ${f}, ${l}, ${d}, ${p}, b, row, col); + return ${u.texture2D}(${e}, uv);}`;return new M(v,["coordinates.packedUVfrom3D"])}getPackedSamplerND(o,e,r){let n=r.unpackedShape,s=n.length,i=[r.width,r.height],u=j(this.context.glContext.version),l=[i[0],i[1]],f=l[1],p=l[0],d=Math.ceil(n[s-1]/2),T=d*Math.ceil(n[s-2]/2),v="int b, int row, int col",w=`b * ${T} + (row / 2) * ${d} + (col / 2)`;for(let F=2;F{let n=this.context.inputTextureLayouts[r],i=(n.unpackedShape.length>0?n.unpackedShape:n.shape).length,u=`_${e}`;o[u]=new M(this.getValueFromSingle(e,i,n.width,n.height,!1),[`shapeUtils.indicesToOffset${u}`,"coordinates.offsetToCoords","fragcolor.getColorAsFloat"]),u=u+"_T",o[u]=new M(this.getValueFromSingle(e,i,n.width,n.height,!0),[`shapeUtils.indicesToOffset${u}`,"coordinates.offsetToCoords","fragcolor.getColorAsFloat"])}),o}getValueFromSingle(o,e,r,n,s){let i=`_${o}`;s&&(i=i+"_T");let u=j(this.context.glContext.version);return` + float ${i}(int m[${e}]) { + int offset = indicesToOffset${i}(m); + vec2 coords = offsetToCoords(offset, ${r}, ${n}); + float value = getColorAsFloat(${u.texture2D}(${o}, coords)); + return value; + } + `}getPackedValueFrom(o,e,r,n,s){let i=`_${o}_Pack`;s&&(i=i+"_T");let u=j(this.context.glContext.version);return` + vec4 ${i}(int m[${e}]) { + int offset = indicesToOffset_${o}(m); + vec2 coords = offsetToCoords(offset, ${r}, ${n}); + return ${u.texture2D}(${o}, coords); + } + `}}});var co,ep=P(()=>{"use strict";Gt();co=class a extends ht{constructor(t){super(t)}getFunctions(){return{...this.encodeFloat32(),...this.decodeFloat32()}}getCustomTypes(){return{}}encodeFloat32(){return{encode:new M(`highp vec4 encode(highp float f) { + return vec4(f, 0.0, 0.0, 0.0); + } + `)}}decodeFloat32(){return{decode:new M(`highp float decode(highp vec4 rgba) { + return rgba.r; + } + `)}}encodeUint8(){let t=a.isLittleEndian()?"rgba.rgba=rgba.abgr;":"";return{encode:new M(` + 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))); + ${t} + rgba = rgba / 255.0; // values need to be normalized to [0,1] + return rgba; + } + `)}}decodeUint8(){let t=a.isLittleEndian()?"rgba.rgba=rgba.abgr;":"";return{decode:new M(` + highp float decode(highp vec4 rgba) { + rgba = rgba * 255.0; // values need to be de-normalized from [0,1] to [0,255] + ${t} + 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 t=new ArrayBuffer(4),o=new Uint32Array(t),e=new Uint8Array(t);if(o[0]=3735928559,e[0]===239)return!0;if(e[0]===222)return!1;throw new Error("unknown endianness")}}});var po,tp=P(()=>{"use strict";Gt();we();po=class extends ht{constructor(t){super(t)}getFunctions(){return{...this.setFragColor(),...this.getColorAsFloat()}}getCustomTypes(){return{}}setFragColor(){let t=j(this.context.glContext.version);return{setFragColor:new M(` + void setFragColor(float value) { + ${t.output} = encode(value); + } + `,["encoding.encode"])}}getColorAsFloat(){return{getColorAsFloat:new M(` + float getColorAsFloat(vec4 color) { + return decode(color); + } + `,["encoding.decode"])}}}});var ho,rp=P(()=>{"use strict";Gt();ho=class a extends ht{constructor(t){super(t)}getFunctions(){return{...this.bcastIndex(),...this.bcastMatmulIndex(),...this.offsetToIndices(),...this.indicesToOffset(),...this.incrementIndices()}}getCustomTypes(){return{}}bcastIndex(){let t=this.context.outputTextureLayout.shape.length,o={};return this.context.programInfo.inputNames.forEach((e,r)=>{let n=this.context.inputTextureLayouts[r].unpackedShape;if(n.length<=t){let s=n.length,i=t-s,u=`bcastIndices_${e}`,l="";for(let p=0;p{let n=this.context.inputTextureLayouts[r].shape;if(!(n.length<2||n.length>t)){let s=n.length,i=t-s,u=`bcastMatmulIndices_${e}`,l="";for(let p=0;p{let r=this.context.inputTextureLayouts[e].shape,n=this.context.inputTextureLayouts[e].strides,s=r.length,i=`indicesToOffset_${o}`;t[i]=new M(a.indexToOffsetSingle(i,s,n)),i=`indicesToOffset_${o}_T`,t[i]=new M(a.indexToOffsetSingle(i,s,n.slice().reverse()))}),t}static indexToOffsetSingle(t,o,e){let r="";for(let n=o-1;n>=0;--n)r+=` + offset += indices[${n}] * ${e[n]}; + `;return` + int ${t}(int indices[${o}]) { + int offset = 0; + ${r} + return offset; + } + `}offsetToIndices(){let t={};return this.context.programInfo.inputNames.forEach((o,e)=>{let r=this.context.inputTextureLayouts[e].shape,n=this.context.inputTextureLayouts[e].strides,s=r.length,i=`offsetToIndices_${o}`;t[i]=new M(a.offsetToIndicesSingle(i,s,n)),i=`offsetToIndices_${o}_T`,t[i]=new M(a.offsetToIndicesSingle(i,s,n.slice().reverse()))}),t}static offsetToIndicesSingle(t,o,e){let r=[];for(let n=0;n{let r=this.context.inputTextureLayouts[e].shape,n=r.length,s=`incrementIndices_${o}`,i="";for(let l=0;l= 0; --i) { + if(i > axis) continue; + indices[i] += 1; + if(indices[i] < shape[i]) { + break; + } + indices[i] = 0; + } + } + `;t[s]=new M(u)}),t}}});var mo,np=P(()=>{"use strict";Gt();mo=class extends ht{constructor(t){super(t)}getCustomTypes(){return{}}getFunctions(){return{...this.binaryVecFunctions(),...this.copyVec(),...this.setVecItem(),...this.getVecItem()}}binaryVecFunctions(){let o=this.context.outputTextureLayout.shape.length,e={add:"+=",sub:"-=",mul:"*=",div:"/="},r={};for(let n in e){let s=`${n}Vec`,i="";for(let l=0;l{"use strict";Qc();ep();tp();rp();np();Wi={encoding:co,fragcolor:po,vec:mo,shapeUtils:ho,coordinates:fo}});var bo,ip=P(()=>{"use strict";Gt();Jc();op();we();bo=class{constructor(t,o,e,r){this.libs={};this.glslLibRoutineDependencyGraph={};this.context=new Qn(t,o,e,r),Object.keys(Wi).forEach(s=>{let i=new Wi[s](this.context);this.libs[s]=i});let n=this.glslLibRoutineDependencyGraph;for(let s in this.libs){let u=this.libs[s].getFunctions();for(let l in u){let f=s+"."+l,p;n[f]?(p=n[f],p.routineBody=u[l].routineBody):(p=new mn(f,u[l].routineBody),n[f]=p);let d=u[l].dependencies;if(d)for(let T=0;T{let r=e.split(".")[1];t.indexOf(r)!==-1&&o.push(this.glslLibRoutineDependencyGraph[e])}),eo.returnOrderedNodes(o)}getUniforms(t,o){let e=[];if(t)for(let r of t)e.push(`uniform sampler2D ${r};`);if(o)for(let r of o)e.push(`uniform ${r.type} ${r.name}${r.arrayLength?`[${r.arrayLength}]`:""};`);return e.join(` +`)}}});var go,ap=P(()=>{"use strict";Tt();ft();ip();we();go=class{constructor(t,o,e){this.profiler=t;this.glContext=o;this.textureLayoutStrategy=e;this.repo=new Map,this.attributesBound=!1}getArtifact(t){return this.repo.get(t)}setArtifact(t,o){this.repo.set(t,o)}run(t,o,e){this.profiler.event("op",`ProgramManager.run ${t.programInfo.name??"unknown kernel"}`,()=>{let r=this.glContext.gl,n=t.program;r.useProgram(n);try{this.bindOutput(e),this.attributesBound||this.bindAttributes(t.attribLocations),this.bindUniforms(t.uniformLocations,t.programInfo.variables??[],o)}catch(s){throw fe.error("ProgramManager",t.programInfo.shaderSource),s}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,o,e){return this.profiler.event("backend","ProgramManager.build",()=>{let r=new bo(this.glContext,t,o,e),n=r.preprocess(),s=this.compile(n);return{programInfo:t,program:s,uniformLocations:this.getUniformLocations(s,r.context.programInfo.inputNames,r.context.programInfo.variables),attribLocations:this.getAttribLocations(s)}})}compile(t){if(!this.vertexShader){fe.verbose("ProrgramManager","Compiling and caching Vertex shader for the first time");let r=$u(this.glContext.version);this.vertexShader=this.glContext.compileShader(r,this.glContext.gl.VERTEX_SHADER)}Z.debug&&fe.verbose("ProrgramManager",`FragShader: +${t} +`);let o=this.glContext.compileShader(t,this.glContext.gl.FRAGMENT_SHADER),e=this.glContext.createProgram(this.vertexShader,o);return this.glContext.deleteShader(o),e}bindOutput(t){let o=t.width,e=t.height;fe.verbose("ProrgramManager",`Binding output texture to Framebuffer: w/h=${o}/${e}, shape=${t.shape}, type=${t.tensor.type}`),this.glContext.attachFramebuffer(t.texture,o,e)}bindAttributes(t){let o=t.position,e=t.textureCoord;this.glContext.setVertexAttributes(o,e),this.attributesBound=!0}bindUniforms(t,o,e){let r=this.glContext.gl,n=0;for(let{name:s,type:i,location:u,arrayLength:l}of t){let f=o.find(p=>p.name===s)?.data;if(i!=="sampler2D"&&!f)throw new Error(`variable '${s}' does not have data defined in program info`);switch(i){case"sampler2D":this.bindTexture(e[n],u,n),n++;break;case"float":l?r.uniform1fv(u,f):r.uniform1f(u,f);break;case"int":l?r.uniform1iv(u,f):r.uniform1i(u,f);break;default:throw new Error(`Uniform not implemented: ${i}`)}}}bindTexture(t,o,e){this.glContext.bindTextureToUniform(t.texture,e,o)}getAttribLocations(t){return{position:this.getAttribLocation(t,"position"),textureCoord:this.getAttribLocation(t,"textureCoord")}}getUniformLocations(t,o,e){let r=[];if(o)for(let n of o)r.push({name:n,type:"sampler2D",location:this.getUniformLocation(t,n)});if(e)for(let n of e)r.push({...n,location:this.getUniformLocation(t,n.name)});return r}getUniformLocation(t,o){let r=this.glContext.gl.getUniformLocation(t,o);if(r===null)throw new Error(`Uniform ${o} not found.`);return r}getAttribLocation(t,o){return this.glContext.gl.getAttribLocation(t,o)}}});var yo,sp=P(()=>{"use strict";ft();dn();yo=class{constructor(t,o,e,r){this.glContext=t;this.layoutStrategy=o;this.profiler=e;this.config=r;this.pendingRead=new Map;r.reuseTextures&&(this.inUseTextures=new Map,this.idleTextures=new Map,this.textureLookup=new Map)}createTextureFromLayout(t,o,e,r){let n=this.toEncoderType(t),s=this.glContext.getEncoder(n,o.channels||1,r);if(o.isPacked&&r===1)throw new Error("not implemented");let i=o.width,u=o.height,l,f;if(this.config.reuseTextures){l=`${i}x${u}_${s.format}_${s.internalFormat}_${s.textureType}`,f=this.inUseTextures.get(l),f||(f=[],this.inUseTextures.set(l,f));let d=this.idleTextures.get(l);if(d&&d.length>0){let T=d.pop();return f.push(T),r===1&&this.glContext.updateTexture(T,i,u,s,this.toTextureData(t,e)),T}}fe.verbose("TextureManager",`Creating new texture of size ${o.width}x${o.height}`);let p=this.glContext.allocateTexture(i,u,s,this.toTextureData(t,e));return this.config.reuseTextures&&(f.push(p),this.textureLookup.set(p,l)),p}readTexture(t,o,e){return e||(e=1),this.profiler.event("backend","TextureManager.readTexture",()=>{let r=t.shape.reduce((s,i)=>s*i)*e,n=this.glContext.readTexture(t.texture,t.width,t.height,r,this.toEncoderType(o),e);return this.toTensorData(o,n)})}async readTextureAsync(t,o,e){let r=t.tensor.dataId;if(e||(e=1),this.pendingRead.has(r)){let n=this.pendingRead.get(r);return new Promise(s=>n?.push(s))}return this.profiler.event("backend","TextureManager.readTextureAsync",async()=>{this.pendingRead.set(r,[]);let n=t.shape.reduce((l,f)=>l*f)*e;await this.glContext.createAndWaitForFence();let s=this.glContext.readTexture(t.texture,t.width,t.height,n,this.toEncoderType(o),e),i=this.toTensorData(o,s),u=this.pendingRead.get(r);return this.pendingRead.delete(r),u?.forEach(l=>l(i)),i})}readUint8TextureAsFloat(t){return this.profiler.event("backend","TextureManager.readUint8TextureAsFloat",()=>{let o=t.shape.reduce((r,n)=>r*n),e=this.glContext.readTexture(t.texture,t.width,t.height,o*4,"byte",4);return new Float32Array(e.buffer,e.byteOffset,o)})}releaseTexture(t,o){let e;if(this.config.reuseTextures&&(e=this.textureLookup.get(t.texture),e)){o&&this.textureLookup.delete(e);let r=this.inUseTextures.get(e);if(r){let n=r.indexOf(t.texture);if(n!==-1){r.splice(n,1);let s=this.idleTextures.get(e);s||(s=[],this.idleTextures.set(e,s)),s.push(t.texture)}}}(!e||o)&&(fe.verbose("TextureManager",`Deleting texture of size ${t.width}x${t.height}`),this.glContext.deleteTexture(t.texture))}toTensorData(t,o){switch(t){case"int16":return o instanceof Int16Array?o:Int16Array.from(o);case"int32":return o instanceof Int32Array?o:Int32Array.from(o);case"int8":return o instanceof Int8Array?o:Int8Array.from(o);case"uint16":return o instanceof Uint16Array?o:Uint16Array.from(o);case"uint32":return o instanceof Uint32Array?o:Uint32Array.from(o);case"uint8":case"bool":return o instanceof Uint8Array?o:Uint8Array.from(o);case"float32":return o instanceof Float32Array?o:Float32Array.from(o);case"float64":return o instanceof Float64Array?o:Float64Array.from(o);default:throw new Error(`TensorData type ${t} is not supported`)}}toTextureData(t,o){if(o)return o instanceof Float32Array?o:new Float32Array(o)}toEncoderType(t){return"float"}clearActiveTextures(){this.glContext.clearActiveTextures()}}});var To,up=P(()=>{"use strict";ft();vs();Qu();Yc();ap();Vi();sp();To=class{constructor(t,o){this.backend=t;this.context=o;this.layoutStrategy=new lo(t.glContext.maxTextureSize),this.programManager=new go(this.context.profiler,t.glContext,this.layoutStrategy),this.textureManager=new yo(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 Zn(this)}onGraphInitialized(t){let o=t.getValues().filter(e=>e.from===-1&&e.tensor).map(e=>e.tensor.dataId);this.initializers=new Set(o)}isInitializer(t){return this.initializers?this.initializers.has(t):!1}addInitializer(t){this.initializers.add(t)}getTextureData(t,o){return o?this.packedTextureDataCache.get(t):this.unpackedTextureDataCache.get(t)}setTextureData(t,o,e=!1){fe.verbose("WebGLSessionHandler","Storing Texture data in cache"),e?this.packedTextureDataCache.set(t,o):this.unpackedTextureDataCache.set(t,o)}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,o,e){let r=ws(t,o,jc);return{impl:r.opImpl,context:r.opInit?r.opInit(t,e):t}}}});function Yb(a){let t=0;for(;t{"use strict";Tt();dn();dn();Ct();yn=class{constructor(t,o){this.frameBufferBound=!1;this.itemsToPoll=[];this.gl=t,this.version=o,this.getExtensions(),this.vertexbuffer=this.createVertexbuffer(),this.framebuffer=this.createFramebuffer(),this.queryVitalParameters()}allocateTexture(t,o,e,r){let n=this.gl,s=n.createTexture();n.bindTexture(n.TEXTURE_2D,s),n.texParameteri(n.TEXTURE_2D,n.TEXTURE_MIN_FILTER,n.NEAREST),n.texParameteri(n.TEXTURE_2D,n.TEXTURE_MAG_FILTER,n.NEAREST),n.texParameteri(n.TEXTURE_2D,n.TEXTURE_WRAP_S,n.CLAMP_TO_EDGE),n.texParameteri(n.TEXTURE_2D,n.TEXTURE_WRAP_T,n.CLAMP_TO_EDGE);let i=r?e.encode(r,t*o):null;return n.texImage2D(n.TEXTURE_2D,0,e.internalFormat,t,o,0,e.format,e.textureType,i),this.checkError(),s}updateTexture(t,o,e,r,n){let s=this.gl;s.bindTexture(s.TEXTURE_2D,t);let i=r.encode(n,o*e);s.texSubImage2D(s.TEXTURE_2D,0,0,0,o,e,r.format,r.textureType,i),this.checkError()}attachFramebuffer(t,o,e){let r=this.gl;r.bindTexture(r.TEXTURE_2D,t),r.bindFramebuffer(r.FRAMEBUFFER,this.framebuffer),r.framebufferTexture2D(r.FRAMEBUFFER,r.COLOR_ATTACHMENT0,r.TEXTURE_2D,t,0),this.checkError(),r.viewport(0,0,o,e),r.scissor(0,0,o,e)}readTexture(t,o,e,r,n,s){let i=this.gl;s||(s=1),this.frameBufferBound||this.attachFramebuffer(t,o,e);let u=this.getEncoder(n,s),l=u.allocate(o*e);return i.bindTexture(i.TEXTURE_2D,t),i.framebufferTexture2D(i.FRAMEBUFFER,i.COLOR_ATTACHMENT0,i.TEXTURE_2D,t,0),i.readPixels(0,0,o,e,i.RGBA,u.textureType,l),this.checkError(),u.decode(l,r)}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,o){let e=this.gl;e.vertexAttribPointer(t,3,e.FLOAT,!1,20,0),e.enableVertexAttribArray(t),o!==-1&&(e.vertexAttribPointer(o,2,e.FLOAT,!1,20,12),e.enableVertexAttribArray(o)),this.checkError()}createProgram(t,o){let e=this.gl,r=e.createProgram();return e.attachShader(r,t),e.attachShader(r,o),e.linkProgram(r),r}compileShader(t,o){let e=this.gl,r=e.createShader(o);if(!r)throw new Error(`createShader() returned null with type ${o}`);if(e.shaderSource(r,t),e.compileShader(r),e.getShaderParameter(r,e.COMPILE_STATUS)===!1)throw new Error(`Failed to compile shader: ${e.getShaderInfoLog(r)} +Shader source: +${t}`);return r}deleteShader(t){this.gl.deleteShader(t)}bindTextureToUniform(t,o,e){let r=this.gl;r.activeTexture(r.TEXTURE0+o),this.checkError(),r.bindTexture(r.TEXTURE_2D,t),this.checkError(),r.uniform1i(e,o),this.checkError()}draw(){this.gl.drawArrays(this.gl.TRIANGLE_STRIP,0,4),this.checkError()}checkError(){if(Z.debug){let t=this.gl,o=t.getError(),e="";switch(o){case t.NO_ERROR:return;case t.INVALID_ENUM:e="INVALID_ENUM";break;case t.INVALID_VALUE:e="INVALID_VALUE";break;case t.INVALID_OPERATION:e="INVALID_OPERATION";break;case t.INVALID_FRAMEBUFFER_OPERATION:e="INVALID_FRAMEBUFFER_OPERATION";break;case t.OUT_OF_MEMORY:e="OUT_OF_MEMORY";break;case t.CONTEXT_LOST_WEBGL:e="CONTEXT_LOST_WEBGL";break;default:e=`Unknown WebGL Error: ${o.toString(16)}`}throw new Error(e)}}deleteTexture(t){this.gl.deleteTexture(t)}deleteProgram(t){this.gl.deleteProgram(t)}getEncoder(t,o,e=0){if(this.version===2)return new Kn(this.gl,o);switch(t){case"float":return e===1||this.isRenderFloat32Supported?new pn(this.gl,o):new pn(this.gl,o,this.textureHalfFloatExtension.HALF_FLOAT_OES);case"int":throw new Error("not implemented");case"byte":return new Jn(this.gl,o);default:throw new Error(`Invalid dataType: ${t}`)}}clearActiveTextures(){let t=this.gl;for(let o=0;othis.isTimerResultAvailable(t)),this.getTimerResult(t)}async createAndWaitForFence(){let t=this.createFence(this.gl);return this.pollFence(t)}createFence(t){let o,e=t,r=e.fenceSync(e.SYNC_GPU_COMMANDS_COMPLETE,0);return t.flush(),r===null?o=()=>!0:o=()=>{let n=e.clientWaitSync(r,0,0);return n===e.ALREADY_SIGNALED||n===e.CONDITION_SATISFIED},{query:r,isFencePassed:o}}async pollFence(t){return new Promise(o=>{this.addItemToPoll(()=>t.isFencePassed(),()=>o())})}pollItems(){let t=Yb(this.itemsToPoll.map(o=>o.isDoneFn));for(let o=0;o<=t;++o){let{resolveFn:e}=this.itemsToPoll[o];e()}this.itemsToPoll=this.itemsToPoll.slice(t+1)}async addItemToPoll(t,o){this.itemsToPoll.push({isDoneFn:t,resolveFn:o}),!(this.itemsToPoll.length>1)&&await mi(()=>(this.pollItems(),this.itemsToPoll.length===0))}}});function Hi(a){let t;if((!a||a==="webgl2")&&"webgl2"in Ur?t=Ur.webgl2:(!a||a==="webgl")&&"webgl"in Ur&&(t=Ur.webgl),!t)try{let e=Kb();t=fp(e,a)}catch{let r=Xb();t=fp(r,a)}a=a||t.version===1?"webgl":"webgl2";let o=t.gl;return Ur[a]=t,o.isContextLost()?(delete Ur[a],Hi(a)):(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),t)}function fp(a,t){let o={alpha:!1,depth:!1,antialias:!1,stencil:!1,preserveDrawingBuffer:!1,premultipliedAlpha:!1,failIfMajorPerformanceCaveat:!1},e,r=o;if((!t||t==="webgl2")&&(e=a.getContext("webgl2",r),e))try{return new yn(e,2)}catch(n){fe.warning("GlContextFactory",`failed to create WebGLContext using contextId 'webgl2'. Error: ${n}`)}if((!t||t==="webgl")&&(e=a.getContext("webgl",r)||a.getContext("experimental-webgl",r),e))try{return new yn(e,1)}catch(n){fe.warning("GlContextFactory",`failed to create WebGLContext using contextId 'webgl' or 'experimental-webgl'. Error: ${n}`)}throw new Error("WebGL is not supported")}function Xb(){if(typeof document>"u")throw new TypeError("failed to create canvas: document is not supported");let a=document.createElement("canvas");return a.width=1,a.height=1,a}function Kb(){if(typeof OffscreenCanvas>"u")throw new TypeError("failed to create offscreen canvas: OffscreenCanvas is not supported");return new OffscreenCanvas(1,1)}var Ur,cp=P(()=>{"use strict";ft();lp();Ur={}});var xo,pp=P(()=>{"use strict";Tt();ft();up();cp();xo=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=Hi(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),fe.setWithEnv(Z),Z.webgl.context||Object.defineProperty(Z.webgl,"context",{value:this.glContext.gl}),fe.verbose("WebGLBackend",`Created WebGLContext: ${typeof this.glContext} with matmulMaxBatchSize: ${this.matmulMaxBatchSize}; textureCacheMode: ${this.textureCacheMode}; pack: ${this.pack}; async: ${this.async}.`),!0}catch(t){return fe.warning("WebGLBackend",`Unable to initialize WebGLBackend. ${t}`),!1}}createSessionHandler(t){return new To(this,t)}dispose(){this.glContext.dispose()}}});async function qi(a){if(a){let t=typeof a=="string"?[a]:a;for(let o of t){let e=dp.get(o);if(e)return e;let r=await Zb(o);if(r)return r}}else return qi(["webgl"]);throw new Error("no available backend to use")}async function Zb(a){let t=Jb;if(typeof t[a]<"u"&&Qb(t[a])){let o=t[a],e=o.initialize();if(typeof e=="object"&&"then"in e&&(e=await e),e)return dp.set(a,o),o}}function Qb(a){let t=a;return"initialize"in t&&typeof t.initialize=="function"&&"createSessionHandler"in t&&typeof t.createSessionHandler=="function"&&"dispose"in t&&typeof t.dispose=="function"}var dp,Jb,hp=P(()=>{"use strict";pp();dp=new Map,Jb={webgl:new xo}});var ji,wo,mp=P(()=>{"use strict";ft();ji=class{constructor(t,o){this.op=t;this.node=o}},wo=class{constructor(t,o,e){this.graph=t;this.profiler=e;this.initialize(o)}initialize(t){this.profiler.event("session","ExecutionPlan.initialize",()=>{let o=this.graph.getNodes();if(o.length!==t.length)throw new Error("The size of nodes and OPs do not match.");this._ops=t.map((e,r)=>new ji(e,o[r])),this.reset(),this._starter=[],this._ops.forEach((e,r)=>{let n=!0;for(let s of e.node.inputs)if(!this._values[s]&&this.graph.getInputIndices().indexOf(s)===-1){n=!1;break}n&&this._starter.push(r)})})}reset(){this._values=this.graph.getValues().map(t=>t.tensor)}async execute(t,o){return this.profiler.event("session","ExecutionPlan.execute",async()=>{this.reset();let e=t.createInferenceHandler(),r=this.graph.getInputIndices();if(o.length!==r.length)throw new Error(`number of input tensors don't match the number of inputs to the model: actual: ${o.length} expected: ${r.length}`);o.forEach((f,p)=>{let d=r[p];this._values[d]=f});let n=this._starter.slice(0),s=this.graph.getValues(),i=this.graph.getNodes(),u=0;for(;uthis._values[I]);if(d.indexOf(void 0)!==-1)throw new Error(`unresolved input detected: op: ${p.node}`);let T=d;fe.verbose("ExecPlan",`Runing op:${p.node.name} (${T.map((I,L)=>`'${p.node.inputs[L]}': ${I.type}[${I.dims.join(",")}]`).join(", ")})`);let v=await this.profiler.event("node",p.node.name,async()=>p.op.impl(e,T,p.op.context));if(v.length!==p.node.outputs.length)throw new Error("the size of output does not match model definition.");v.forEach((I,L)=>{let F=p.node.outputs[L];if(this._values[F])throw new Error(`output [${F}] already has value: op:${p.node.name}`);this._values[F]=I});let w=new Set;v.forEach((I,L)=>{let F=p.node.outputs[L];for(let C of s[F].to){let X=i[C],N=!0;for(let ge of X.inputs)if(!this._values[ge]){N=!1;break}N&&w.add(C)}}),n.push(...w)}let l=[];for(let f=0;f{"use strict";an();ne=Er(Cr());hr();le();gt=H.experimental.fbs,Tn=class a{constructor(t){if(this._attributes=new Map,t!=null){for(let o of t)o instanceof ne.onnx.AttributeProto?this._attributes.set(o.name,[a.getValue(o),a.getType(o)]):o instanceof gt.Attribute&&this._attributes.set(o.name(),[a.getValue(o),a.getType(o)]);if(this._attributes.sizeke.fromProto(n));if(t instanceof gt.Attribute)return e.map(n=>ke.fromOrtTensor(n))}return o===ne.onnx.AttributeProto.AttributeType.STRING&&t instanceof ne.onnx.AttributeProto?cn(e):o===ne.onnx.AttributeProto.AttributeType.STRINGS&&t instanceof ne.onnx.AttributeProto?e.map(cn):e}static getValueNoCheck(t){return t instanceof ne.onnx.AttributeProto?this.getValueNoCheckFromOnnxFormat(t):this.getValueNoCheckFromOrtFormat(t)}static getValueNoCheckFromOnnxFormat(t){switch(t.type){case ne.onnx.AttributeProto.AttributeType.FLOAT:return t.f;case ne.onnx.AttributeProto.AttributeType.INT:return t.i;case ne.onnx.AttributeProto.AttributeType.STRING:return t.s;case ne.onnx.AttributeProto.AttributeType.TENSOR:return t.t;case ne.onnx.AttributeProto.AttributeType.GRAPH:return t.g;case ne.onnx.AttributeProto.AttributeType.FLOATS:return t.floats;case ne.onnx.AttributeProto.AttributeType.INTS:return t.ints;case ne.onnx.AttributeProto.AttributeType.STRINGS:return t.strings;case ne.onnx.AttributeProto.AttributeType.TENSORS:return t.tensors;case ne.onnx.AttributeProto.AttributeType.GRAPHS:return t.graphs;default:throw new Error(`unsupported attribute type: ${ne.onnx.AttributeProto.AttributeType[t.type]}`)}}static getValueNoCheckFromOrtFormat(t){switch(t.type()){case gt.AttributeType.FLOAT:return t.f();case gt.AttributeType.INT:return t.i();case gt.AttributeType.STRING:return t.s();case gt.AttributeType.TENSOR:return t.t();case gt.AttributeType.GRAPH:return t.g();case gt.AttributeType.FLOATS:return t.floatsArray();case gt.AttributeType.INTS:{let o=[];for(let e=0;e{"use strict";bp();an();Xi=Er(Cr());hr();le();vo=H.experimental.fbs,Ki={from:(a,t)=>new Yi(a,t)},$t=class{constructor(t){this._from=void 0,this._to=[],this.tensor=void 0,this.type=void 0,t&&(this.type=We.tensorValueTypeFromProto(t.type.tensorType))}get from(){return this._from}get to(){return this._to}},_o=class{constructor(t,o){t instanceof Xi.onnx.NodeProto?(this.name=t.name,this.opType=t.opType,this.attributes=new Tn(t.attribute)):t instanceof vo.Node&&(this.name=o??t.name(),this.opType=t.opType(),this.attributes=new Tn(We.tensorAttributesFromORTFormat(t))),this.inputs=[],this.outputs=[],this.executeNode=!0}},Yi=class{constructor(t,o){if(!t)throw new TypeError("graph is empty");this.buildGraph(t),this.transformGraph(o),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 Xi.onnx.GraphProto)this.buildGraphFromOnnxFormat(t);else if(t instanceof vo.Graph)this.buildGraphFromOrtFormat(t);else throw new TypeError("Graph type is not supported.")}buildGraphFromOnnxFormat(t){let o=new Map;this._allData=[],this._allInputIndices=[],this._allInputNames=[],this._allOutputIndices=[],this._allOutputNames=[],this._nodes=[];let e=new Map;if(!t.input)throw new Error("missing information in graph: input");let r=[];for(let n of t.input){if(o.has(n.name))throw new Error(`duplicated input name: ${n.name}`);let s=this._allData.push(new $t(n))-1;o.set(n.name,s),r.push(n.name)}if(!t.initializer)throw new Error("missing information in graph: initializer");for(let n of t.initializer){let s=o.get(n.name);if(s===void 0){let i=new $t;i.type={shape:{dims:We.tensorDimsFromProto(n.dims)},tensorType:We.tensorDataTypeFromProto(n.dataType)},s=this._allData.push(i)-1,o.set(n.name,s)}this._allData[s]._from=-1,this._allData[s].tensor=ke.fromProto(n)}for(let n=0;n"u"&&(l=this._allData.push(new $t)-1,o.set(u,l)),s.outputs.push(l),this._allData[l]._from!==void 0)throw new Error(`multiple nodes output to one data value: ${l}`);if(this._allData[l]._from=n,i.opType==="Constant"){if(!i.attribute||i.attribute.length!==1||!i.attribute[0].t)throw new Error("missing attributes or missing tensor value in attributes for this Constant operator");if(!i.output||i.output.length!==1)throw new Error("missing output or incorrect number of outputs for this Constant operator");s.outputs.pop(),s.executeNode=!1,this._allData[l]._from=-1,this._allData[l].tensor=ke.fromProto(i.attribute[0].t)}}}for(let n=0;n"u"){if(u===""&&(i.input.length===3||i.input.length===4)&&i.opType==="Resize")continue;throw new Error(`unrecognized input '${u}' for node: ${i.name}`)}s.inputs.push(l),this._allData[l]._to.push(n)}}return!0}buildGraphFromOrtFormat(t){let o=new Map;this._allData=[],this._allInputIndices=[],this._allInputNames=[],this._allOutputIndices=[],this._allOutputNames=[],this._nodes=[];let e=new Map,r=[];for(let n=0;n"u"&&(f=this._allData.push(new $t)-1,o.set(l,f)),s.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=n,i.opType()==="Constant"){if(i.attributesLength()!==1||!i.attributes(0).t())throw new Error("missing attributes or missing tensor value in attributes for this Constant operator");if(i.outputsLength()!==1)throw new Error("missing output or incorrect number of outputs for this Constant operator");s.outputs.pop(),s.executeNode=!1,this._allData[f]._from=-1,this._allData[f].tensor=ke.fromOrtTensor(i.attributes(0).t())}}}for(let n=0;n"u")throw new Error(`unrecognized input '${l}' for node: ${i.name()}`);s.inputs.push(f),this._allData[f]._to.push(n)}}}checkIsAcyclic(){let t=new Set;this._allInputIndices.forEach(r=>{this._allData[r]._to.forEach(s=>{t.add(s)})});let o=Array.from(t),e=new Array(this._nodes.length).fill("white");for(;o.length>0;){let r=o.pop();e[r]==="gray"?e[r]="black":(o.push(r),e[r]="gray",this._nodes[r].outputs.forEach(n=>{let s=this._allData[n];if(typeof s.tensor<"u")throw new Error("node outputs should not be initialized");if(s._from!==r)throw new Error("from property of the Value object doesn't match index of Node being processed");s._to.forEach(i=>{if(e[i]==="gray")throw new Error("model graph is cyclic");e[i]==="white"&&o.push(i)})}))}}transformGraph(t){this.removeAllIdentityNodes(),this.removeAllDropoutNodes(),this.fuseConvActivationNodes(),t&&t.transformGraph(this),this.finalizeGraph()}finalizeGraph(){let t=0,o=new Array(this._nodes.length,0),e=0;for(let r=0;r{this._allData[n]._from=-2});this._nodes.splice(e,this._nodes.length-e);for(let r=0;r=0)n._to[s]=o[n._to[s]];else throw new Error("Trying to update a removed node")}t=0;for(let r=0;r0){let n=-1;this._allData[r].from!==void 0&&this._allData[r].from!==-1?(n=this._nodes[this._allData[r].from].outputs.indexOf(r+t),n!==-1&&(this._nodes[this._allData[r].from].outputs[n]=r)):(n=this._allInputIndices.indexOf(r+t),n!==-1&&(this._allInputIndices[n]=r)),this._allData[r].to.forEach(s=>{n=this._nodes[s].inputs.indexOf(r+t),n!==-1&&(this._nodes[s].inputs[n]=r)}),this._allData[r].to.length===0&&(n=this._allOutputIndices.indexOf(r+t),n!==-1&&(this._allOutputIndices[n]=r))}}}deleteNode(t){let o=this._nodes[t];if(o.outputs.length>1){for(let i=1;i0)throw new Error("Node deletion with more than one output connected to other nodes is not supported. ")}o.executeNode=!1;let e=o.inputs[0],r=o.outputs[0],n=this._allData[r].to;for(let i=0;i0)for(let i of n){let u=this._nodes[i].inputs.indexOf(r);if(u===-1)throw new Error("The Node object doesn't have the output Value in it's 'inputs' property ");this._nodes[i].inputs[u]=e,this._allData[e].to.push(i)}}removeAllDropoutNodes(){let t=0;for(let o of this._nodes){if(o.opType==="Dropout"){if(o.inputs.length!==1)throw new Error("Dropout nodes should only contain one input. ");if(o.outputs.length!==1&&o.outputs.length!==2)throw new Error("Dropout nodes should contain either 1 or 2 output(s)");if(o.outputs.length===2&&this._allData[o.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 o of this._nodes)o.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 o=this._allData[t.outputs[0]]._to;if(o.length===1&&this.isActivation(this._nodes[o[0]])){let e=this._nodes[o[0]];if(e.opType==="Clip")if(e.inputs.length===1)try{t.attributes.set("activation_params","floats",[e.attributes.getFloat("min"),e.attributes.getFloat("max")])}catch{t.attributes.set("activation_params","floats",[pr,dr])}else if(e.inputs.length>=3&&this._allData[e.inputs[1]].tensor!==void 0&&this._allData[e.inputs[2]].tensor!==void 0)t.attributes.set("activation_params","floats",[this._allData[e.inputs[1]].tensor.floatData[0],this._allData[e.inputs[2]].tensor.floatData[0]]);else continue;t.attributes.set("activation","string",e.opType),this.deleteNode(o[0])}}}}});var yp,eg,Oo,Tp=P(()=>{"use strict";Vn();gp();an();yp=Er(Cr());le();eg=H.experimental.fbs,Oo=class{constructor(){}load(t,o,e){let r;if(!e)try{this.loadFromOnnxFormat(t,o);return}catch(n){if(e!==void 0)throw n;r=n}try{this.loadFromOrtFormat(t,o)}catch(n){throw e!==void 0?n:new Error(`Failed to load model as ONNX format: ${r} +as ORT format: ${n}`)}}loadFromOnnxFormat(t,o){let e=yp.onnx.ModelProto.decode(t);if(nt.longToNumber(e.irVersion)<3)throw new Error("only support ONNX model with IR_VERSION>=3");this._opsets=e.opsetImport.map(n=>({domain:n.domain,version:nt.longToNumber(n.version)})),this._graph=Ki.from(e.graph,o)}loadFromOrtFormat(t,o){let e=new _.ByteBuffer(t),r=eg.InferenceSession.getRootAsInferenceSession(e).model();if(nt.longToNumber(r.irVersion())<3)throw new Error("only support ONNX model with IR_VERSION>=3");this._opsets=[];for(let s=0;s{"use strict";hp();mp();ft();Tp();Io=class{constructor(t={}){this._initialized=!1,this.backendHint=t.backendHint,this.profiler=Un.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,o,e){await this.profiler.event("session","Session.loadModel",async()=>{let r=await qi(this.backendHint);if(this.sessionHandler=r.createSessionHandler(this.context),this._model=new Oo,typeof t=="string"){let n=t.endsWith(".ort");if(typeof process<"u"&&process.versions&&process.versions.node){let s=await(void 0)(t);this.initialize(s,n)}else{let i=await(await fetch(t)).arrayBuffer();this.initialize(new Uint8Array(i),n)}}else if(ArrayBuffer.isView(t))this.initialize(t);else{let n=new Uint8Array(t,o||0,e||t.byteLength);this.initialize(n)}})}initialize(t,o){if(this._initialized)throw new Error("already initialized");this.profiler.event("session","Session.initialize",()=>{let e=this.sessionHandler.transformGraph?this.sessionHandler:void 0;this._model.load(t,e,o),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 o=this.normalizeAndValidateInputs(t),e=await this._executionPlan.execute(this.sessionHandler,o);return this.createOutput(e)})}normalizeAndValidateInputs(t){let o=this._model.graph.getInputNames();if(Array.isArray(t)){if(t.length!==o.length)throw new Error(`incorrect input array length: expected ${o.length} but got ${t.length}`)}else{if(t.size!==o.length)throw new Error(`incorrect input map size: expected ${o.length} but got ${t.size}`);let e=new Array(t.size),r=0;for(let n=0;n{"use strict";Tt();hr();So=class{constructor(t){this.session=t;this.inputNames=this.session.inputNames,this.outputNames=this.session.outputNames}async dispose(){}async run(t,o,e){let r=new Map;for(let i in t)if(Object.hasOwnProperty.call(t,i)){let u=t[i];r.set(i,new ke(u.dims,u.type,void 0,void 0,u.data))}let n=await this.session.run(r),s={};return n.forEach((i,u)=>{s[u]=new Me(i.type,i.data,i.dims)}),s}startProfiling(){this.session.startProfiling()}endProfiling(){this.session.endProfiling()}}});var vp={};Ar(vp,{onnxjsBackend:()=>rg});var Ji,rg,_p=P(()=>{"use strict";xp();wp();Ji=class{async init(){}async createInferenceSessionHandler(t,o){let e=new Io(o);return typeof t=="string"?await e.loadModel(t):await e.loadModel(t),new So(e)}},rg=new Ji});var Zi={};Ar(Zi,{createReadStream:()=>Op,readFile:()=>ng,readFileSync:()=>og});var ng,og,Op,Qi=P(()=>{ng=void 0,og=void 0,Op=void 0});var ea={};Ar(ea,{join:()=>ig});var ig,ta=P(()=>{ig=void 0});var Ap=de((Sp,ra)=>{"use strict";var Ip=(()=>{var a=typeof document<"u"&&document.currentScript?document.currentScript.src:void 0;return typeof __filename<"u"&&(a=a||__filename),function(t={}){var o=t,e,r;o.ready=new Promise((b,x)=>{e=b,r=x});var n=Object.assign({},o),s="./this.program",i=typeof window=="object",u=typeof importScripts=="function",l=typeof process=="object"&&typeof process.versions=="object"&&typeof process.versions.node=="string",f="",p,d,T;if(l){var v=(Qi(),rr(Zi)),w=(ta(),rr(ea));f=u?w.dirname(f)+"/":__dirname+"/",p=(b,x)=>(b=b.startsWith("file://")?new URL(b):w.normalize(b),v.readFileSync(b,x?void 0:"utf8")),T=b=>(b=p(b,!0),b.buffer||(b=new Uint8Array(b)),b),d=(b,x,O,D=!0)=>{b=b.startsWith("file://")?new URL(b):w.normalize(b),v.readFile(b,D?void 0:"utf8",(G,K)=>{G?O(G):x(D?K.buffer:K)})},!o.thisProgram&&1"[Emscripten Module object]"}else(i||u)&&(u?f=self.location.href:typeof document<"u"&&document.currentScript&&(f=document.currentScript.src),a&&(f=a),f.indexOf("blob:")!==0?f=f.substr(0,f.replace(/[?#].*/,"").lastIndexOf("/")+1):f="",p=b=>{var x=new XMLHttpRequest;return x.open("GET",b,!1),x.send(null),x.responseText},u&&(T=b=>{var x=new XMLHttpRequest;return x.open("GET",b,!1),x.responseType="arraybuffer",x.send(null),new Uint8Array(x.response)}),d=(b,x,O)=>{var D=new XMLHttpRequest;D.open("GET",b,!0),D.responseType="arraybuffer",D.onload=()=>{D.status==200||D.status==0&&D.response?x(D.response):O()},D.onerror=O,D.send(null)});var I=o.print||console.log.bind(console),L=o.printErr||console.error.bind(console);Object.assign(o,n),n=null,o.thisProgram&&(s=o.thisProgram);var F;o.wasmBinary&&(F=o.wasmBinary);var C=o.noExitRuntime||!0;typeof WebAssembly!="object"&&Be("no native wasm support detected");var X,N,ge=!1,Oe,Ne,V,se;function W(){var b=X.buffer;o.HEAP8=Oe=new Int8Array(b),o.HEAP16=new Int16Array(b),o.HEAP32=V=new Int32Array(b),o.HEAPU8=Ne=new Uint8Array(b),o.HEAPU16=new Uint16Array(b),o.HEAPU32=se=new Uint32Array(b),o.HEAPF32=new Float32Array(b),o.HEAPF64=new Float64Array(b)}var St=[],Kt=[],Ie=[];function Y(){var b=o.preRun.shift();St.unshift(b)}var te=0,Ze=null,qe=null;function Be(b){throw o.onAbort&&o.onAbort(b),b="Aborted("+b+")",L(b),ge=!0,b=new WebAssembly.RuntimeError(b+". Build with -sASSERTIONS for more info."),r(b),b}function At(b){return b.startsWith("data:application/octet-stream;base64,")}var Se;if(Se="ort-wasm.wasm",!At(Se)){var je=Se;Se=o.locateFile?o.locateFile(je,f):f+je}function xr(b){if(b==Se&&F)return new Uint8Array(F);if(T)return T(b);throw"both async and sync fetching of the wasm failed"}function Qe(b){if(!F&&(i||u)){if(typeof fetch=="function"&&!b.startsWith("file://"))return fetch(b,{credentials:"same-origin"}).then(x=>{if(!x.ok)throw"failed to load wasm binary file at '"+b+"'";return x.arrayBuffer()}).catch(()=>xr(b));if(d)return new Promise((x,O)=>{d(b,D=>x(new Uint8Array(D)),O)})}return Promise.resolve().then(()=>xr(b))}function Et(b,x,O){return Qe(b).then(D=>WebAssembly.instantiate(D,x)).then(D=>D).then(O,D=>{L("failed to asynchronously prepare wasm: "+D),Be(D)})}function Jt(b,x){var O=Se;return F||typeof WebAssembly.instantiateStreaming!="function"||At(O)||O.startsWith("file://")||l||typeof fetch!="function"?Et(O,b,x):fetch(O,{credentials:"same-origin"}).then(D=>WebAssembly.instantiateStreaming(D,b).then(x,function(G){return L("wasm streaming compile failed: "+G),L("falling back to ArrayBuffer instantiation"),Et(O,b,x)}))}var st,ot=b=>{for(;0>2>>>0]=x},this.za=function(x){se[this.va+8>>2>>>0]=x},this.xa=function(x,O){this.ya(),this.Ea(x),this.za(O)},this.ya=function(){se[this.va+16>>2>>>0]=0}}var Ut=0,Ce=0,Te=typeof TextDecoder<"u"?new TextDecoder("utf8"):void 0,it=(b,x,O)=>{x>>>=0;var D=x+O;for(O=x;b[O]&&!(O>=D);)++O;if(16G?D+=String.fromCharCode(G):(G-=65536,D+=String.fromCharCode(55296|G>>10,56320|G&1023))}}else D+=String.fromCharCode(G)}return D},ut=(b,x)=>(b>>>=0)?it(Ne,b,x):"",zt=b=>{for(var x=0,O=0;O=D?x++:2047>=D?x+=2:55296<=D&&57343>=D?(x+=4,++O):x+=3}return x},wr=(b,x,O,D)=>{if(O>>>=0,!(0=re){var $e=b.charCodeAt(++K);re=65536+((re&1023)<<10)|$e&1023}if(127>=re){if(O>=D)break;x[O++>>>0]=re}else{if(2047>=re){if(O+1>=D)break;x[O++>>>0]=192|re>>6}else{if(65535>=re){if(O+2>=D)break;x[O++>>>0]=224|re>>12}else{if(O+3>=D)break;x[O++>>>0]=240|re>>18,x[O++>>>0]=128|re>>12&63}x[O++>>>0]=128|re>>6&63}x[O++>>>0]=128|re&63}}return x[O>>>0]=0,O-G},lt=b=>b%4===0&&(b%100!==0||b%400===0),qr=[0,31,60,91,121,152,182,213,244,274,305,335],Nt=[0,31,59,90,120,151,181,212,243,273,304,334],jr=b=>{var x=zt(b)+1,O=Zr(x);return O&&wr(b,Ne,O,x),O},Yr={},Xr=()=>{if(!Kr){var b={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",_:s||"./this.program"},x;for(x in Yr)Yr[x]===void 0?delete b[x]:b[x]=Yr[x];var O=[];for(x in b)O.push(`${x}=${b[x]}`);Kr=O}return Kr},Kr,Vt=[null,[],[]],Zt=[31,29,31,30,31,30,31,31,30,31,30,31],vr=[31,28,31,30,31,30,31,31,30,31,30,31];function _n(b){var x=Array(zt(b)+1);return wr(b,x,0,x.length),x}function Jr(b,x,O,D){function G(A,ce,ye){for(A=typeof A=="number"?A.toString():A||"";A.lengthrn?-1:0Dt-A.getDate())ce-=Dt-A.getDate()+1,A.setDate(1),11>ye?A.setMonth(ye+1):(A.setMonth(0),A.setFullYear(A.getFullYear()+1));else{A.setDate(A.getDate()+ce);break}}return ye=new Date(A.getFullYear()+1,0,4),ce=$e(new Date(A.getFullYear(),0,4)),ye=$e(ye),0>=re(ce,A)?0>=re(ye,A)?A.getFullYear()+1:A.getFullYear():A.getFullYear()-1}b>>>=0,x>>>=0,O>>>=0,D>>>=0;var ze=V[D+40>>2>>>0];D={Ca:V[D>>2>>>0],Ba:V[D+4>>2>>>0],ta:V[D+8>>2>>>0],wa:V[D+12>>2>>>0],ua:V[D+16>>2>>>0],sa:V[D+20>>2>>>0],ma:V[D+24>>2>>>0],ra:V[D+28>>2>>>0],Fa:V[D+32>>2>>>0],Aa:V[D+36>>2>>>0],Da:ze?ut(ze):""},O=ut(O),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 Ve in ze)O=O.replace(new RegExp(Ve,"g"),ze[Ve]);var en="Sunday Monday Tuesday Wednesday Thursday Friday Saturday".split(" "),tn="January February March April May June July August September October November December".split(" ");ze={"%a":A=>en[A.ma].substring(0,3),"%A":A=>en[A.ma],"%b":A=>tn[A.ua].substring(0,3),"%B":A=>tn[A.ua],"%C":A=>K((A.sa+1900)/100|0,2),"%d":A=>K(A.wa,2),"%e":A=>G(A.wa,2," "),"%g":A=>Ye(A).toString().substring(2),"%G":A=>Ye(A),"%H":A=>K(A.ta,2),"%I":A=>(A=A.ta,A==0?A=12:12{for(var ce=0,ye=0;ye<=A.ua-1;ce+=(lt(A.sa+1900)?Zt:vr)[ye++]);return K(A.wa+ce,3)},"%m":A=>K(A.ua+1,2),"%M":A=>K(A.Ba,2),"%n":()=>` +`,"%p":A=>0<=A.ta&&12>A.ta?"AM":"PM","%S":A=>K(A.Ca,2),"%t":()=>" ","%u":A=>A.ma||7,"%U":A=>K(Math.floor((A.ra+7-A.ma)/7),2),"%V":A=>{var ce=Math.floor((A.ra+7-(A.ma+6)%7)/7);if(2>=(A.ma+371-A.ra-2)%7&&ce++,ce)ce==53&&(ye=(A.ma+371-A.ra)%7,ye==4||ye==3&<(A.sa)||(ce=1));else{ce=52;var ye=(A.ma+7-A.ra-1)%7;(ye==4||ye==5&<(A.sa%400-1))&&ce++}return K(ce,2)},"%w":A=>A.ma,"%W":A=>K(Math.floor((A.ra+7-(A.ma+6)%7)/7),2),"%y":A=>(A.sa+1900).toString().substring(2),"%Y":A=>A.sa+1900,"%z":A=>{A=A.Aa;var ce=0<=A;return A=Math.abs(A)/60,(ce?"+":"-")+("0000"+(A/60*100+A%60)).slice(-4)},"%Z":A=>A.Da,"%%":()=>"%"},O=O.replace(/%%/g,"\0\0");for(Ve in ze)O.includes(Ve)&&(O=O.replace(new RegExp(Ve,"g"),ze[Ve](D)));return O=O.replace(/\0\0/g,"%"),Ve=_n(O),Ve.length>x?0:(Oe.set(Ve,b>>>0),Ve.length-1)}var On={a:function(b,x,O){throw b>>>=0,new Pt(b).xa(x>>>0,O>>>0),Ut=b,Ce++,Ut},e:function(){return 0},H:function(){},x:function(){},z:function(){},k:function(){return 0},F:function(){},B:function(){},E:function(){},g:function(){},y:function(){},v:function(){},G:function(){},w:function(){},l:()=>!0,o:function(b,x,O){b=x+2097152>>>0<4194305-!!b?(b>>>0)+4294967296*x:NaN,O>>>=0,b=new Date(1e3*b),V[O>>2>>>0]=b.getUTCSeconds(),V[O+4>>2>>>0]=b.getUTCMinutes(),V[O+8>>2>>>0]=b.getUTCHours(),V[O+12>>2>>>0]=b.getUTCDate(),V[O+16>>2>>>0]=b.getUTCMonth(),V[O+20>>2>>>0]=b.getUTCFullYear()-1900,V[O+24>>2>>>0]=b.getUTCDay(),V[O+28>>2>>>0]=(b.getTime()-Date.UTC(b.getUTCFullYear(),0,1,0,0,0,0))/864e5|0},p:function(b,x,O){b=x+2097152>>>0<4194305-!!b?(b>>>0)+4294967296*x:NaN,O>>>=0,b=new Date(1e3*b),V[O>>2>>>0]=b.getSeconds(),V[O+4>>2>>>0]=b.getMinutes(),V[O+8>>2>>>0]=b.getHours(),V[O+12>>2>>>0]=b.getDate(),V[O+16>>2>>>0]=b.getMonth(),V[O+20>>2>>>0]=b.getFullYear()-1900,V[O+24>>2>>>0]=b.getDay(),V[O+28>>2>>>0]=(lt(b.getFullYear())?qr:Nt)[b.getMonth()]+b.getDate()-1|0,V[O+36>>2>>>0]=-(60*b.getTimezoneOffset()),x=new Date(b.getFullYear(),6,1).getTimezoneOffset();var D=new Date(b.getFullYear(),0,1).getTimezoneOffset();V[O+32>>2>>>0]=(x!=D&&b.getTimezoneOffset()==Math.min(D,x))|0},q:function(b){b>>>=0;var x=new Date(V[b+20>>2>>>0]+1900,V[b+16>>2>>>0],V[b+12>>2>>>0],V[b+8>>2>>>0],V[b+4>>2>>>0],V[b>>2>>>0],0),O=V[b+32>>2>>>0],D=x.getTimezoneOffset(),G=new Date(x.getFullYear(),6,1).getTimezoneOffset(),K=new Date(x.getFullYear(),0,1).getTimezoneOffset(),re=Math.min(K,G);return 0>O?V[b+32>>2>>>0]=+(G!=K&&re==D):0>2>>>0]=x.getDay(),V[b+28>>2>>>0]=(lt(x.getFullYear())?qr:Nt)[x.getMonth()]+x.getDate()-1|0,V[b>>2>>>0]=x.getSeconds(),V[b+4>>2>>>0]=x.getMinutes(),V[b+8>>2>>>0]=x.getHours(),V[b+12>>2>>>0]=x.getDate(),V[b+16>>2>>>0]=x.getMonth(),V[b+20>>2>>>0]=x.getYear(),b=x.getTime()/1e3,_r((st=b,1<=+Math.abs(st)?0>>0:~~+Math.ceil((st-+(~~st>>>0))/4294967296)>>>0:0)),b>>>0},m:function(){return-52},n:function(){},t:function(b,x,O){function D(Ye){return(Ye=Ye.toTimeString().match(/\(([A-Za-z ]+)\)$/))?Ye[1]:"GMT"}O>>>=0;var G=new Date().getFullYear(),K=new Date(G,0,1),re=new Date(G,6,1);G=K.getTimezoneOffset();var $e=re.getTimezoneOffset();se[b>>>0>>2>>>0]=60*Math.max(G,$e),V[x>>>0>>2>>>0]=+(G!=$e),b=D(K),x=D(re),b=jr(b),x=jr(x),$e>2>>>0]=b,se[O+4>>2>>>0]=x):(se[O>>2>>>0]=x,se[O+4>>2>>>0]=b)},d:()=>{Be("")},h:function(){return Date.now()},u:function(){return 4294901760},b:()=>performance.now(),I:function(b,x,O){return x>>>=0,Ne.copyWithin(b>>>0>>>0,x>>>0,x+(O>>>0)>>>0)},s:function(b){b>>>=0;var x=Ne.length;if(4294901760=O;O*=2){var D=x*(1+.2/O);D=Math.min(D,b+100663296);var G=Math;D=Math.max(b,D);e:{G=G.min.call(G,4294901760,D+(65536-D%65536)%65536)-X.buffer.byteLength+65535>>>16;try{X.grow(G),W();var K=1;break e}catch{}K=void 0}if(K)return!0}return!1},C:function(b,x){b>>>=0,x>>>=0;var O=0;return Xr().forEach(function(D,G){var K=x+O;for(G=se[b+4*G>>2>>>0]=K,K=0;K>0>>>0]=D.charCodeAt(K);Oe[G>>0>>>0]=0,O+=D.length+1}),0},D:function(b,x){b>>>=0,x>>>=0;var O=Xr();se[b>>2>>>0]=O.length;var D=0;return O.forEach(function(G){D+=G.length+1}),se[x>>2>>>0]=D,0},f:()=>52,j:function(){return 52},r:function(){return 70},i:function(b,x,O,D){x>>>=0,O>>>=0,D>>>=0;for(var G=0,K=0;K>2>>>0],$e=se[x+4>>2>>>0];x+=8;for(var Ye=0;Ye<$e;Ye++){var ze=Ne[re+Ye>>>0],Ve=Vt[b];ze===0||ze===10?((b===1?I:L)(it(Ve,0)),Ve.length=0):Ve.push(ze)}G+=$e}return se[D>>2>>>0]=G,0},A:Jr,c:function(b,x,O,D){return Jr(b>>>0,x>>>0,O>>>0,D>>>0)}};(function(){function b(O){if(O=O.exports,N=O=Ir(O),X=N.J,W(),Kt.unshift(N.K),te--,o.monitorRunDependencies&&o.monitorRunDependencies(te),te==0&&(Ze!==null&&(clearInterval(Ze),Ze=null),qe)){var D=qe;qe=null,D()}return O}var x={a:On};if(te++,o.monitorRunDependencies&&o.monitorRunDependencies(te),o.instantiateWasm)try{return o.instantiateWasm(x,b)}catch(O){L("Module.instantiateWasm callback failed with error: "+O),r(O)}return Jt(x,function(O){b(O.instance)}).catch(r),{}})(),o._OrtInit=(b,x)=>(o._OrtInit=N.L)(b,x),o._OrtGetLastError=(b,x)=>(o._OrtGetLastError=N.M)(b,x),o._OrtCreateSessionOptions=(b,x,O,D,G,K,re,$e,Ye,ze)=>(o._OrtCreateSessionOptions=N.N)(b,x,O,D,G,K,re,$e,Ye,ze),o._OrtAppendExecutionProvider=(b,x)=>(o._OrtAppendExecutionProvider=N.O)(b,x),o._OrtAddFreeDimensionOverride=(b,x,O)=>(o._OrtAddFreeDimensionOverride=N.P)(b,x,O),o._OrtAddSessionConfigEntry=(b,x,O)=>(o._OrtAddSessionConfigEntry=N.Q)(b,x,O),o._OrtReleaseSessionOptions=b=>(o._OrtReleaseSessionOptions=N.R)(b),o._OrtCreateSession=(b,x,O)=>(o._OrtCreateSession=N.S)(b,x,O),o._OrtReleaseSession=b=>(o._OrtReleaseSession=N.T)(b),o._OrtGetInputOutputCount=(b,x,O)=>(o._OrtGetInputOutputCount=N.U)(b,x,O),o._OrtGetInputName=(b,x)=>(o._OrtGetInputName=N.V)(b,x),o._OrtGetOutputName=(b,x)=>(o._OrtGetOutputName=N.W)(b,x),o._OrtFree=b=>(o._OrtFree=N.X)(b),o._OrtCreateTensor=(b,x,O,D,G,K)=>(o._OrtCreateTensor=N.Y)(b,x,O,D,G,K),o._OrtGetTensorData=(b,x,O,D,G)=>(o._OrtGetTensorData=N.Z)(b,x,O,D,G),o._OrtReleaseTensor=b=>(o._OrtReleaseTensor=N._)(b),o._OrtCreateRunOptions=(b,x,O,D)=>(o._OrtCreateRunOptions=N.$)(b,x,O,D),o._OrtAddRunConfigEntry=(b,x,O)=>(o._OrtAddRunConfigEntry=N.aa)(b,x,O),o._OrtReleaseRunOptions=b=>(o._OrtReleaseRunOptions=N.ba)(b),o._OrtCreateBinding=b=>(o._OrtCreateBinding=N.ca)(b),o._OrtBindInput=(b,x,O)=>(o._OrtBindInput=N.da)(b,x,O),o._OrtBindOutput=(b,x,O,D)=>(o._OrtBindOutput=N.ea)(b,x,O,D),o._OrtClearBoundOutputs=b=>(o._OrtClearBoundOutputs=N.fa)(b),o._OrtReleaseBinding=b=>(o._OrtReleaseBinding=N.ga)(b),o._OrtRunWithBinding=(b,x,O,D,G)=>(o._OrtRunWithBinding=N.ha)(b,x,O,D,G),o._OrtRun=(b,x,O,D,G,K,re,$e)=>(o._OrtRun=N.ia)(b,x,O,D,G,K,re,$e),o._OrtEndProfiling=b=>(o._OrtEndProfiling=N.ja)(b);var Zr=o._malloc=b=>(Zr=o._malloc=N.ka)(b);o._free=b=>(o._free=N.la)(b);var _r=b=>(_r=N.na)(b),Qr=()=>(Qr=N.oa)(),Or=b=>(Or=N.pa)(b),J=b=>(J=N.qa)(b);function Ir(b){b=Object.assign({},b);var x=D=>()=>D()>>>0,O=D=>G=>D(G)>>>0;return b.__errno_location=x(b.__errno_location),b.malloc=O(b.malloc),b.stackSave=x(b.stackSave),b.stackAlloc=O(b.stackAlloc),b}o.stackAlloc=J,o.stackSave=Qr,o.stackRestore=Or,o.UTF8ToString=ut,o.stringToUTF8=(b,x,O)=>wr(b,Ne,x,O),o.lengthBytesUTF8=zt;var Qt;qe=function b(){Qt||er(),Qt||(qe=b)};function er(){function b(){if(!Qt&&(Qt=!0,o.calledRun=!0,!ge)){if(ot(Kt),e(o),o.onRuntimeInitialized&&o.onRuntimeInitialized(),o.postRun)for(typeof o.postRun=="function"&&(o.postRun=[o.postRun]);o.postRun.length;){var x=o.postRun.shift();Ie.unshift(x)}ot(Ie)}}if(!(0Ip)});var Ep=de(()=>{});var Pp=de(()=>{});var Dp={};Ar(Dp,{cpus:()=>ag});var ag,Lp=P(()=>{ag=void 0});var kp=de((Cp,na)=>{"use strict";var Fp=(()=>{var a=typeof document<"u"&&document.currentScript?document.currentScript.src:void 0;return typeof __filename<"u"&&(a=a||__filename),function(t={}){function o(){return Ie.buffer!=Be.buffer&&Qe(),Be}function e(){return Ie.buffer!=Be.buffer&&Qe(),At}function r(){return Ie.buffer!=Be.buffer&&Qe(),Se}function n(){return Ie.buffer!=Be.buffer&&Qe(),je}function s(){return Ie.buffer!=Be.buffer&&Qe(),xr}var i=t,u,l;i.ready=new Promise((c,m)=>{u=c,l=m});var f=Object.assign({},i),p="./this.program",d=(c,m)=>{throw m},T=typeof window=="object",v=typeof importScripts=="function",w=typeof process=="object"&&typeof process.versions=="object"&&typeof process.versions.node=="string",I=i.ENVIRONMENT_IS_PTHREAD||!1,L="";function F(c){return i.locateFile?i.locateFile(c,L):L+c}var C,X,N;if(w){var ge=(Qi(),rr(Zi)),Oe=(ta(),rr(ea));L=v?Oe.dirname(L)+"/":__dirname+"/",C=(m,y)=>(m=m.startsWith("file://")?new URL(m):Oe.normalize(m),ge.readFileSync(m,y?void 0:"utf8")),N=m=>(m=C(m,!0),m.buffer||(m=new Uint8Array(m)),m),X=(m,y,S,R=!0)=>{m=m.startsWith("file://")?new URL(m):Oe.normalize(m),ge.readFile(m,R?void 0:"utf8",(B,z)=>{B?S(B):y(R?z.buffer:z)})},!i.thisProgram&&1{throw process.exitCode=m,y},i.inspect=()=>"[Emscripten Module object]";let c;try{c=Ep()}catch(m){throw console.error('The "worker_threads" module is not supported in this node.js build - perhaps a newer version is needed?'),m}global.Worker=c.Worker}else(T||v)&&(v?L=self.location.href:typeof document<"u"&&document.currentScript&&(L=document.currentScript.src),typeof a<"u"&&a&&(L=a),L.indexOf("blob:")!==0?L=L.substr(0,L.replace(/[?#].*/,"").lastIndexOf("/")+1):L="",w||(C=c=>{var m=new XMLHttpRequest;return m.open("GET",c,!1),m.send(null),m.responseText},v&&(N=c=>{var m=new XMLHttpRequest;return m.open("GET",c,!1),m.responseType="arraybuffer",m.send(null),new Uint8Array(m.response)}),X=(c,m,y)=>{var S=new XMLHttpRequest;S.open("GET",c,!0),S.responseType="arraybuffer",S.onload=()=>{S.status==200||S.status==0&&S.response?m(S.response):y()},S.onerror=y,S.send(null)}));w&&typeof performance>"u"&&(global.performance=Pp().performance);var Ne=console.log.bind(console),V=console.error.bind(console);w&&(Ne=(...c)=>ge.writeSync(1,c.join(" ")+` +`),V=(...c)=>ge.writeSync(2,c.join(" ")+` +`));var se=i.print||Ne,W=i.printErr||V;Object.assign(i,f),f=null,i.thisProgram&&(p=i.thisProgram),i.quit&&(d=i.quit);var St;i.wasmBinary&&(St=i.wasmBinary);var Kt=i.noExitRuntime||!0;typeof WebAssembly!="object"&<("no native wasm support detected");var Ie,Y,te,Ze=!1,qe,Be,At,Se,je,xr;function Qe(){var c=Ie.buffer;i.HEAP8=Be=new Int8Array(c),i.HEAP16=new Int16Array(c),i.HEAP32=Se=new Int32Array(c),i.HEAPU8=At=new Uint8Array(c),i.HEAPU16=new Uint16Array(c),i.HEAPU32=je=new Uint32Array(c),i.HEAPF32=new Float32Array(c),i.HEAPF64=xr=new Float64Array(c)}var Et=i.INITIAL_MEMORY||16777216;if(5242880<=Et||lt("INITIAL_MEMORY should be larger than STACK_SIZE, was "+Et+"! (STACK_SIZE=5242880)"),I)Ie=i.wasmMemory;else if(i.wasmMemory)Ie=i.wasmMemory;else if(Ie=new WebAssembly.Memory({initial:Et/65536,maximum:65536,shared:!0}),!(Ie.buffer instanceof SharedArrayBuffer))throw W("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"),w&&W("(on node you may need: --experimental-wasm-threads --experimental-wasm-bulk-memory and/or recent version)"),Error("bad memory");Qe(),Et=Ie.buffer.byteLength;var Jt,st=[],ot=[],Pt=[],Ut=0;function Ce(){return Kt||0{if(!m.ok)throw"failed to load wasm binary file at '"+c+"'";return m.arrayBuffer()}).catch(()=>jr(c));if(X)return new Promise((m,y)=>{X(c,S=>m(new Uint8Array(S)),y)})}return Promise.resolve().then(()=>jr(c))}function Xr(c,m,y){return Yr(c).then(S=>WebAssembly.instantiate(S,m)).then(S=>S).then(y,S=>{W("failed to asynchronously prepare wasm: "+S),lt(S)})}function Kr(c,m){var y=Nt;return St||typeof WebAssembly.instantiateStreaming!="function"||qr(y)||y.startsWith("file://")||w||typeof fetch!="function"?Xr(y,c,m):fetch(y,{credentials:"same-origin"}).then(S=>WebAssembly.instantiateStreaming(S,c).then(m,function(R){return W("wasm streaming compile failed: "+R),W("falling back to ArrayBuffer instantiation"),Xr(y,c,m)}))}var Vt;function Zt(c){this.name="ExitStatus",this.message=`Program terminated with exit(${c})`,this.status=c}function vr(c){c.terminate(),c.onmessage=()=>{}}function _n(c){(c=J.La[c])||lt(),J.lb(c)}function Jr(c){var m=J.fb();if(!m)return 6;J.Oa.push(m),J.La[c.Na]=m,m.Na=c.Na;var y={cmd:"run",start_routine:c.mb,arg:c.eb,pthread_ptr:c.Na};return w&&m.unref(),m.postMessage(y,c.sb),0}var On=typeof TextDecoder<"u"?new TextDecoder("utf8"):void 0,Zr=(c,m,y)=>{m>>>=0;var S=m+y;for(y=m;c[y]&&!(y>=S);)++y;if(16R?S+=String.fromCharCode(R):(R-=65536,S+=String.fromCharCode(55296|R>>10,56320|R&1023))}}else S+=String.fromCharCode(R)}return S},_r=(c,m)=>(c>>>=0)?Zr(e(),c,m):"";function Qr(c){if(I)return xe(1,1,c);qe=c,Ce()||(J.nb(),i.onExit&&i.onExit(c),Ze=!0),d(c,new Zt(c))}var Or=c=>{if(qe=c,I)throw Qt(c),"unwind";Qr(c)},J={Ra:[],Oa:[],Za:[],La:{},Va:function(){I?J.hb():J.gb()},gb:function(){st.unshift(()=>{zt(),J.ib(()=>wr())})},hb:function(){J.receiveObjectTransfer=J.kb,J.threadInitTLS=J.Ya,J.setExitStatus=J.Xa,Kt=!1},Xa:function(c){qe=c},xb:["$terminateWorker"],nb:function(){for(var c of J.Oa)vr(c);for(c of J.Ra)vr(c);J.Ra=[],J.Oa=[],J.La=[]},lb:function(c){var m=c.Na;delete J.La[m],J.Ra.push(c),J.Oa.splice(J.Oa.indexOf(c),1),c.Na=0,Mo(m)},kb:function(){},Ya:function(){J.Za.forEach(c=>c())},jb:c=>new Promise(m=>{c.onmessage=B=>{B=B.data;var z=B.cmd;if(B.targetThread&&B.targetThread!=Sn()){var Ae=J.La[B.wb];Ae?Ae.postMessage(B,B.transferList):W('Internal error! Worker sent a message "'+z+'" to target pthread '+B.targetThread+", but that thread no longer exists!")}else z==="checkMailbox"?In():z==="spawnThread"?Jr(B):z==="cleanupThread"?_n(B.thread):z==="killThread"?(B=B.thread,z=J.La[B],delete J.La[B],vr(z),Mo(B),J.Oa.splice(J.Oa.indexOf(z),1),z.Na=0):z==="cancelThread"?J.La[B.thread].postMessage({cmd:"cancel"}):z==="loaded"?(c.loaded=!0,m(c)):z==="alert"?alert("Thread "+B.threadId+": "+B.text):B.target==="setimmediate"?c.postMessage(B):z==="callHandler"?i[B.handler](...B.args):z&&W("worker sent an unknown command "+z)},c.onerror=B=>{throw W("worker sent an error! "+B.filename+":"+B.lineno+": "+B.message),B},w&&(c.on("message",function(B){c.onmessage({data:B})}),c.on("error",function(B){c.onerror(B)}));var y=[],S=["onExit","onAbort","print","printErr"],R;for(R of S)i.hasOwnProperty(R)&&y.push(R);c.postMessage({cmd:"load",handlers:y,urlOrBlob:i.mainScriptUrlOrBlob||a,wasmMemory:Ie,wasmModule:te})}),ib:function(c){c()},cb:function(){var c=F("ort-wasm-threaded.worker.js");c=new Worker(c),J.Ra.push(c)},fb:function(){return J.Ra.length==0&&(J.cb(),J.jb(J.Ra[0])),J.Ra.pop()}};i.PThread=J;var Ir=c=>{for(;0>2>>>0];c=r()[c+56>>2>>>0],Na(m,m-c),An(m)};function Qt(c){if(I)return xe(2,0,c);Or(c)}var er=[];i.invokeEntryPoint=function(c,m){var y=er[c];y||(c>=er.length&&(er.length=c+1),er[c]=y=Jt.get(c)),c=y(m),Ce()?J.Xa(c):Go(c)};function b(c){this.Ua=c-24,this.bb=function(m){n()[this.Ua+4>>2>>>0]=m},this.ab=function(m){n()[this.Ua+8>>2>>>0]=m},this.Va=function(m,y){this.$a(),this.bb(m),this.ab(y)},this.$a=function(){n()[this.Ua+16>>2>>>0]=0}}var x=0,O=0;function D(c,m,y,S){return I?xe(3,1,c,m,y,S):G(c,m,y,S)}function G(c,m,y,S){if(c>>>=0,m>>>=0,y>>>=0,S>>>=0,typeof SharedArrayBuffer>"u")return W("Current environment does not support SharedArrayBuffer, pthreads are not available!"),6;var R=[];return I&&R.length===0?D(c,m,y,S):(c={mb:y,Na:c,eb:S,sb:R},I?(c.ub="spawnThread",postMessage(c,R),0):Jr(c))}function K(c,m,y){return I?xe(4,1,c,m,y):0}function re(c,m){if(I)return xe(5,1,c,m)}var $e=c=>{for(var m=0,y=0;y=S?m++:2047>=S?m+=2:55296<=S&&57343>=S?(m+=4,++y):m+=3}return m},Ye=(c,m,y,S)=>{if(y>>>=0,!(0=z){var Ae=c.charCodeAt(++B);z=65536+((z&1023)<<10)|Ae&1023}if(127>=z){if(y>=S)break;m[y++>>>0]=z}else{if(2047>=z){if(y+1>=S)break;m[y++>>>0]=192|z>>6}else{if(65535>=z){if(y+2>=S)break;m[y++>>>0]=224|z>>12}else{if(y+3>=S)break;m[y++>>>0]=240|z>>18,m[y++>>>0]=128|z>>12&63}m[y++>>>0]=128|z>>6&63}m[y++>>>0]=128|z&63}}return m[y>>>0]=0,y-R},ze=(c,m,y)=>Ye(c,e(),m,y);function Ve(c,m){if(I)return xe(6,1,c,m)}function en(c,m,y){if(I)return xe(7,1,c,m,y)}function tn(c,m,y){return I?xe(8,1,c,m,y):0}function A(c,m){if(I)return xe(9,1,c,m)}function ce(c,m,y){if(I)return xe(10,1,c,m,y)}function ye(c,m,y,S){if(I)return xe(11,1,c,m,y,S)}function Dt(c,m,y,S){if(I)return xe(12,1,c,m,y,S)}function rn(c,m,y,S){if(I)return xe(13,1,c,m,y,S)}function ha(c){if(I)return xe(14,1,c)}function ma(c,m){if(I)return xe(15,1,c,m)}function ba(c,m,y){if(I)return xe(16,1,c,m,y)}var md=c=>{if(!Ze)try{if(c(),!Ce())try{I?Go(qe):Or(qe)}catch(m){m instanceof Zt||m=="unwind"||d(1,m)}}catch(m){m instanceof Zt||m=="unwind"||d(1,m)}};function Bo(c){c>>>=0,typeof Atomics.tb=="function"&&(Atomics.tb(r(),c>>2,c).value.then(In),c+=128,Atomics.store(r(),c>>2,1))}i.__emscripten_thread_mailbox_await=Bo;function In(){var c=Sn();c&&(Bo(c),md(()=>Ba()))}i.checkMailbox=In;var Sr=c=>c%4===0&&(c%100!==0||c%400===0),ga=[0,31,60,91,121,152,182,213,244,274,305,335],ya=[0,31,59,90,120,151,181,212,243,273,304,334];function Ta(c,m,y,S,R,B,z,Ae){return I?xe(17,1,c,m,y,S,R,B,z,Ae):-52}function xa(c,m,y,S,R,B,z){if(I)return xe(18,1,c,m,y,S,R,B,z)}var wa=c=>{var m=$e(c)+1,y=Fa(m);return y&&ze(c,y,m),y},bd=c=>{var m=Uo();return c=c(),An(m),c};function xe(c,m){var y=arguments.length-2,S=arguments;return bd(()=>{for(var R=zo(8*y),B=R>>3,z=0;z>>0]=Ae}return ka(c,y,R,m)})}var $o=[],No={},va=()=>{if(!Ro){var c={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",_:p||"./this.program"},m;for(m in No)No[m]===void 0?delete c[m]:c[m]=No[m];var y=[];for(m in c)y.push(`${m}=${c[m]}`);Ro=y}return Ro},Ro;function _a(c,m){if(I)return xe(19,1,c,m);c>>>=0,m>>>=0;var y=0;return va().forEach(function(S,R){var B=m+y;for(R=n()[c+4*R>>2>>>0]=B,B=0;B>0>>>0]=S.charCodeAt(B);o()[R>>0>>>0]=0,y+=S.length+1}),0}function Oa(c,m){if(I)return xe(20,1,c,m);c>>>=0,m>>>=0;var y=va();n()[c>>2>>>0]=y.length;var S=0;return y.forEach(function(R){S+=R.length+1}),n()[m>>2>>>0]=S,0}function Ia(c){return I?xe(21,1,c):52}function Sa(c,m,y,S){return I?xe(22,1,c,m,y,S):52}function Aa(c,m,y,S,R){return I?xe(23,1,c,m,y,S,R):70}var gd=[null,[],[]];function Ea(c,m,y,S){if(I)return xe(24,1,c,m,y,S);m>>>=0,y>>>=0,S>>>=0;for(var R=0,B=0;B>2>>>0],Ae=n()[m+4>>2>>>0];m+=8;for(var Lt=0;Lt>>0],et=gd[c];Re===0||Re===10?((c===1?se:W)(Zr(et,0)),et.length=0):et.push(Re)}R+=Ae}return n()[S>>2>>>0]=R,0}var Pa=[31,29,31,30,31,30,31,31,30,31,30,31],Da=[31,28,31,30,31,30,31,31,30,31,30,31];function yd(c){var m=Array($e(c)+1);return Ye(c,m,0,m.length),m}var Td=(c,m)=>{o().set(c,m>>>0)};function La(c,m,y,S){function R(E,pe,Ee){for(E=typeof E=="number"?E.toString():E||"";E.lengthUa?-1:0tr-E.getDate())pe-=tr-E.getDate()+1,E.setDate(1),11>Ee?E.setMonth(Ee+1):(E.setMonth(0),E.setFullYear(E.getFullYear()+1));else{E.setDate(E.getDate()+pe);break}}return Ee=new Date(E.getFullYear()+1,0,4),pe=Ae(new Date(E.getFullYear(),0,4)),Ee=Ae(Ee),0>=z(pe,E)?0>=z(Ee,E)?E.getFullYear()+1:E.getFullYear():E.getFullYear()-1}c>>>=0,m>>>=0,y>>>=0,S>>>=0;var Re=r()[S+40>>2>>>0];S={qb:r()[S>>2>>>0],pb:r()[S+4>>2>>>0],Sa:r()[S+8>>2>>>0],Wa:r()[S+12>>2>>>0],Ta:r()[S+16>>2>>>0],Qa:r()[S+20>>2>>>0],Ma:r()[S+24>>2>>>0],Pa:r()[S+28>>2>>>0],yb:r()[S+32>>2>>>0],ob:r()[S+36>>2>>>0],rb:Re?_r(Re):""},y=_r(y),Re={"%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 et in Re)y=y.replace(new RegExp(et,"g"),Re[et]);var Ma="Sunday Monday Tuesday Wednesday Thursday Friday Saturday".split(" "),Ga="January February March April May June July August September October November December".split(" ");Re={"%a":E=>Ma[E.Ma].substring(0,3),"%A":E=>Ma[E.Ma],"%b":E=>Ga[E.Ta].substring(0,3),"%B":E=>Ga[E.Ta],"%C":E=>B((E.Qa+1900)/100|0,2),"%d":E=>B(E.Wa,2),"%e":E=>R(E.Wa,2," "),"%g":E=>Lt(E).toString().substring(2),"%G":E=>Lt(E),"%H":E=>B(E.Sa,2),"%I":E=>(E=E.Sa,E==0?E=12:12{for(var pe=0,Ee=0;Ee<=E.Ta-1;pe+=(Sr(E.Qa+1900)?Pa:Da)[Ee++]);return B(E.Wa+pe,3)},"%m":E=>B(E.Ta+1,2),"%M":E=>B(E.pb,2),"%n":()=>` +`,"%p":E=>0<=E.Sa&&12>E.Sa?"AM":"PM","%S":E=>B(E.qb,2),"%t":()=>" ","%u":E=>E.Ma||7,"%U":E=>B(Math.floor((E.Pa+7-E.Ma)/7),2),"%V":E=>{var pe=Math.floor((E.Pa+7-(E.Ma+6)%7)/7);if(2>=(E.Ma+371-E.Pa-2)%7&&pe++,pe)pe==53&&(Ee=(E.Ma+371-E.Pa)%7,Ee==4||Ee==3&&Sr(E.Qa)||(pe=1));else{pe=52;var Ee=(E.Ma+7-E.Pa-1)%7;(Ee==4||Ee==5&&Sr(E.Qa%400-1))&&pe++}return B(pe,2)},"%w":E=>E.Ma,"%W":E=>B(Math.floor((E.Pa+7-(E.Ma+6)%7)/7),2),"%y":E=>(E.Qa+1900).toString().substring(2),"%Y":E=>E.Qa+1900,"%z":E=>{E=E.ob;var pe=0<=E;return E=Math.abs(E)/60,(pe?"+":"-")+("0000"+(E/60*100+E%60)).slice(-4)},"%Z":E=>E.rb,"%%":()=>"%"},y=y.replace(/%%/g,"\0\0");for(et in Re)y.includes(et)&&(y=y.replace(new RegExp(et,"g"),Re[et](S)));return y=y.replace(/\0\0/g,"%"),et=yd(y),et.length>m?0:(Td(et,c),et.length-1)}J.Va();var xd=[null,Qr,Qt,D,K,re,Ve,en,tn,A,ce,ye,Dt,rn,ha,ma,ba,Ta,xa,_a,Oa,Ia,Sa,Aa,Ea],wd={b:function(c,m,y){throw c>>>=0,new b(c).Va(m>>>0,y>>>0),x=c,O++,x},N:function(c){Ca(c>>>0,!v,1,!T,131072,!1),J.Ya()},j:function(c){c>>>=0,I?postMessage({cmd:"cleanupThread",thread:c}):_n(c)},I:G,h:K,T:re,D:Ve,F:en,U:tn,R:A,J:ce,Q:ye,n:Dt,E:rn,B:ha,S:ma,C:ba,q:()=>!0,z:function(c,m){c>>>=0,c==m>>>0?setTimeout(()=>In()):I?postMessage({targetThread:c,cmd:"checkMailbox"}):(c=J.La[c])&&c.postMessage({cmd:"checkMailbox"})},L:function(){return-1},M:Bo,p:function(c){w&&J.La[c>>>0].ref()},t:function(c,m,y){c=m+2097152>>>0<4194305-!!c?(c>>>0)+4294967296*m:NaN,y>>>=0,c=new Date(1e3*c),r()[y>>2>>>0]=c.getUTCSeconds(),r()[y+4>>2>>>0]=c.getUTCMinutes(),r()[y+8>>2>>>0]=c.getUTCHours(),r()[y+12>>2>>>0]=c.getUTCDate(),r()[y+16>>2>>>0]=c.getUTCMonth(),r()[y+20>>2>>>0]=c.getUTCFullYear()-1900,r()[y+24>>2>>>0]=c.getUTCDay(),c=(c.getTime()-Date.UTC(c.getUTCFullYear(),0,1,0,0,0,0))/864e5|0,r()[y+28>>2>>>0]=c},u:function(c,m,y){c=m+2097152>>>0<4194305-!!c?(c>>>0)+4294967296*m:NaN,y>>>=0,c=new Date(1e3*c),r()[y>>2>>>0]=c.getSeconds(),r()[y+4>>2>>>0]=c.getMinutes(),r()[y+8>>2>>>0]=c.getHours(),r()[y+12>>2>>>0]=c.getDate(),r()[y+16>>2>>>0]=c.getMonth(),r()[y+20>>2>>>0]=c.getFullYear()-1900,r()[y+24>>2>>>0]=c.getDay(),m=(Sr(c.getFullYear())?ga:ya)[c.getMonth()]+c.getDate()-1|0,r()[y+28>>2>>>0]=m,r()[y+36>>2>>>0]=-(60*c.getTimezoneOffset()),m=new Date(c.getFullYear(),6,1).getTimezoneOffset();var S=new Date(c.getFullYear(),0,1).getTimezoneOffset();c=(m!=S&&c.getTimezoneOffset()==Math.min(S,m))|0,r()[y+32>>2>>>0]=c},v:function(c){c>>>=0;var m=new Date(r()[c+20>>2>>>0]+1900,r()[c+16>>2>>>0],r()[c+12>>2>>>0],r()[c+8>>2>>>0],r()[c+4>>2>>>0],r()[c>>2>>>0],0),y=r()[c+32>>2>>>0],S=m.getTimezoneOffset(),R=new Date(m.getFullYear(),6,1).getTimezoneOffset(),B=new Date(m.getFullYear(),0,1).getTimezoneOffset(),z=Math.min(B,R);return 0>y?r()[c+32>>2>>>0]=+(R!=B&&z==S):0>2>>>0]=m.getDay(),y=(Sr(m.getFullYear())?ga:ya)[m.getMonth()]+m.getDate()-1|0,r()[c+28>>2>>>0]=y,r()[c>>2>>>0]=m.getSeconds(),r()[c+4>>2>>>0]=m.getMinutes(),r()[c+8>>2>>>0]=m.getHours(),r()[c+12>>2>>>0]=m.getDate(),r()[c+16>>2>>>0]=m.getMonth(),r()[c+20>>2>>>0]=m.getYear(),c=m.getTime()/1e3,$a((Vt=c,1<=+Math.abs(Vt)?0>>0:~~+Math.ceil((Vt-+(~~Vt>>>0))/4294967296)>>>0:0)),c>>>0},r:Ta,s:xa,y:function(c,m,y){function S(Re){return(Re=Re.toTimeString().match(/\(([A-Za-z ]+)\)$/))?Re[1]:"GMT"}c>>>=0,m>>>=0,y>>>=0;var R=new Date().getFullYear(),B=new Date(R,0,1),z=new Date(R,6,1);R=B.getTimezoneOffset();var Ae=z.getTimezoneOffset(),Lt=Math.max(R,Ae);n()[c>>2>>>0]=60*Lt,r()[m>>2>>>0]=+(R!=Ae),c=S(B),m=S(z),c=wa(c),m=wa(m),Ae>2>>>0]=c,n()[y+4>>2>>>0]=m):(n()[y>>2>>>0]=m,n()[y+4>>2>>>0]=c)},c:()=>{lt("")},k:function(){},i:function(){return Date.now()},o:()=>{throw Ut+=1,"unwind"},A:function(){return 4294901760},e:()=>performance.timeOrigin+performance.now(),f:function(){return w?(Lp(),rr(Dp)).cpus().length:navigator.hardwareConcurrency},K:function(c,m,y,S){for(J.vb=m>>>0,$o.length=y,m=S>>>0>>3,S=0;S>>0];return xd[c].apply(null,$o)},x:function(c){c>>>=0;var m=e().length;if(c<=m||4294901760=y;y*=2){var S=m*(1+.2/y);S=Math.min(S,c+100663296);var R=Math;S=Math.max(c,S);e:{R=R.min.call(R,4294901760,S+(65536-S%65536)%65536)-Ie.buffer.byteLength+65535>>>16;try{Ie.grow(R),Qe();var B=1;break e}catch{}B=void 0}if(B)return!0}return!1},O:_a,P:Oa,H:Or,g:Ia,m:Sa,w:Aa,l:Ea,a:Ie||i.wasmMemory,G:La,d:function(c,m,y,S){return La(c>>>0,m>>>0,y>>>0,S>>>0)}};(function(){function c(y,S){return y=y.exports,Y=y=vd(y),J.Za.push(Y.ya),Jt=Y.za,ot.unshift(Y.V),te=S,wr(),y}var m={a:wd};if(zt(),i.instantiateWasm)try{return i.instantiateWasm(m,c)}catch(y){W("Module.instantiateWasm callback failed with error: "+y),l(y)}return Kr(m,function(y){c(y.instance,y.module)}).catch(l),{}})(),i._OrtInit=(c,m)=>(i._OrtInit=Y.W)(c,m),i._OrtGetLastError=(c,m)=>(i._OrtGetLastError=Y.X)(c,m),i._OrtCreateSessionOptions=(c,m,y,S,R,B,z,Ae,Lt,Re)=>(i._OrtCreateSessionOptions=Y.Y)(c,m,y,S,R,B,z,Ae,Lt,Re),i._OrtAppendExecutionProvider=(c,m)=>(i._OrtAppendExecutionProvider=Y.Z)(c,m),i._OrtAddFreeDimensionOverride=(c,m,y)=>(i._OrtAddFreeDimensionOverride=Y._)(c,m,y),i._OrtAddSessionConfigEntry=(c,m,y)=>(i._OrtAddSessionConfigEntry=Y.$)(c,m,y),i._OrtReleaseSessionOptions=c=>(i._OrtReleaseSessionOptions=Y.aa)(c),i._OrtCreateSession=(c,m,y)=>(i._OrtCreateSession=Y.ba)(c,m,y),i._OrtReleaseSession=c=>(i._OrtReleaseSession=Y.ca)(c),i._OrtGetInputOutputCount=(c,m,y)=>(i._OrtGetInputOutputCount=Y.da)(c,m,y),i._OrtGetInputName=(c,m)=>(i._OrtGetInputName=Y.ea)(c,m),i._OrtGetOutputName=(c,m)=>(i._OrtGetOutputName=Y.fa)(c,m),i._OrtFree=c=>(i._OrtFree=Y.ga)(c),i._OrtCreateTensor=(c,m,y,S,R,B)=>(i._OrtCreateTensor=Y.ha)(c,m,y,S,R,B),i._OrtGetTensorData=(c,m,y,S,R)=>(i._OrtGetTensorData=Y.ia)(c,m,y,S,R),i._OrtReleaseTensor=c=>(i._OrtReleaseTensor=Y.ja)(c),i._OrtCreateRunOptions=(c,m,y,S)=>(i._OrtCreateRunOptions=Y.ka)(c,m,y,S),i._OrtAddRunConfigEntry=(c,m,y)=>(i._OrtAddRunConfigEntry=Y.la)(c,m,y),i._OrtReleaseRunOptions=c=>(i._OrtReleaseRunOptions=Y.ma)(c),i._OrtCreateBinding=c=>(i._OrtCreateBinding=Y.na)(c),i._OrtBindInput=(c,m,y)=>(i._OrtBindInput=Y.oa)(c,m,y),i._OrtBindOutput=(c,m,y,S)=>(i._OrtBindOutput=Y.pa)(c,m,y,S),i._OrtClearBoundOutputs=c=>(i._OrtClearBoundOutputs=Y.qa)(c),i._OrtReleaseBinding=c=>(i._OrtReleaseBinding=Y.ra)(c),i._OrtRunWithBinding=(c,m,y,S,R)=>(i._OrtRunWithBinding=Y.sa)(c,m,y,S,R),i._OrtRun=(c,m,y,S,R,B,z,Ae)=>(i._OrtRun=Y.ta)(c,m,y,S,R,B,z,Ae),i._OrtEndProfiling=c=>(i._OrtEndProfiling=Y.ua)(c);var Sn=i._pthread_self=()=>(Sn=i._pthread_self=Y.va)(),Fa=i._malloc=c=>(Fa=i._malloc=Y.wa)(c);i._free=c=>(i._free=Y.xa)(c),i.__emscripten_tls_init=()=>(i.__emscripten_tls_init=Y.ya)();var Ca=i.__emscripten_thread_init=(c,m,y,S,R,B)=>(Ca=i.__emscripten_thread_init=Y.Aa)(c,m,y,S,R,B);i.__emscripten_thread_crashed=()=>(i.__emscripten_thread_crashed=Y.Ba)();var ka=(c,m,y,S)=>(ka=Y.Ca)(c,m,y,S),Mo=c=>(Mo=Y.Da)(c),Go=i.__emscripten_thread_exit=c=>(Go=i.__emscripten_thread_exit=Y.Ea)(c),Ba=i.__emscripten_check_mailbox=()=>(Ba=i.__emscripten_check_mailbox=Y.Fa)(),$a=c=>($a=Y.Ga)(c),Na=(c,m)=>(Na=Y.Ha)(c,m),Uo=()=>(Uo=Y.Ia)(),An=c=>(An=Y.Ja)(c),zo=c=>(zo=Y.Ka)(c);function vd(c){c=Object.assign({},c);var m=S=>()=>S()>>>0,y=S=>R=>S(R)>>>0;return c.__errno_location=m(c.__errno_location),c.pthread_self=m(c.pthread_self),c.malloc=y(c.malloc),c.stackSave=m(c.stackSave),c.stackAlloc=y(c.stackAlloc),c}i.keepRuntimeAlive=Ce,i.wasmMemory=Ie,i.stackAlloc=zo,i.stackSave=Uo,i.stackRestore=An,i.UTF8ToString=_r,i.stringToUTF8=ze,i.lengthBytesUTF8=$e,i.ExitStatus=Zt,i.PThread=J;var En;ut=function c(){En||Ra(),En||(ut=c)};function Ra(){function c(){if(!En&&(En=!0,i.calledRun=!0,!Ze)&&(I||Ir(ot),u(i),i.onRuntimeInitialized&&i.onRuntimeInitialized(),!I)){if(i.postRun)for(typeof i.postRun=="function"&&(i.postRun=[i.postRun]);i.postRun.length;){var m=i.postRun.shift();Pt.unshift(m)}Ir(Pt)}}if(!(0Fp)});var Bp=de((sO,sg)=>{sg.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");Object.assign(global,{self:global,require,Module,location:{href:__filename},Worker:nodeWorkerThreads.Worker,importScripts:e=>(0,eval)(fs.readFileSync(e,"utf8")+"//# sourceURL="+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&&Module.__emscripten_thread_crashed(),a}}self.onmessage=handleMessage;\n'});var Np,ug,oa,ia,Ao,$p,lg,fg,cg,Rp,Fe,zr=P(()=>{"use strict";Np=Ap();ug=kp(),ia=!1,Ao=!1,$p=!1,lg=a=>{if(a===1)return!1;if(typeof SharedArrayBuffer>"u")return typeof self<"u"&&!self.crossOriginIsolated&&console.warn("env.wasm.numThreads is set to "+a+", 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 "+a+", 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}},fg=()=>{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}},cg=(a,t)=>a?t?"ort-wasm-simd-threaded.wasm":"ort-wasm-simd.wasm":t?"ort-wasm-threaded.wasm":"ort-wasm.wasm",Rp=async a=>{if(ia)return Promise.resolve();if(Ao)throw new Error("multiple calls to 'initializeWebAssembly()' detected.");if($p)throw new Error("previous call to 'initializeWebAssembly()' failed.");Ao=!0;let t=a.initTimeout,o=a.numThreads,e=a.simd,r=lg(o),n=e&&fg(),s=a.wasmPaths,i=typeof s=="string"?s:void 0,u=cg(n,r),l=typeof s=="object"?s[u]:void 0,f=!1,p=[];if(t>0&&p.push(new Promise(d=>{setTimeout(()=>{f=!0,d()},t)})),p.push(new Promise((d,T)=>{let v=r?ug:Np,w={locateFile:(I,L)=>r&&I.endsWith(".worker.js")&&typeof Blob<"u"?URL.createObjectURL(new Blob([Bp()],{type:"text/javascript"})):I.endsWith(".wasm")?l||(i??L)+u:L+I};if(r)if(w.numThreads=o,typeof Blob>"u")w.mainScriptUrlOrBlob=(void 0)(__dirname,"ort-wasm-threaded.js");else{let I=`var ortWasmThreaded=${v.toString()};`;w.mainScriptUrlOrBlob=new Blob([I],{type:"text/javascript"})}v(w).then(I=>{Ao=!1,ia=!0,oa=I,d()},I=>{Ao=!1,$p=!0,T(I)})})),await Promise.race(p),f)throw new Error(`WebAssembly backend initializing failed due to timeout: ${t}ms`)},Fe=()=>{if(ia&&oa)return oa;throw new Error("WebAssembly is not initialized yet.")}});var ve,xn,_e,Eo=P(()=>{"use strict";zr();ve=(a,t)=>{let o=Fe(),e=o.lengthBytesUTF8(a)+1,r=o._malloc(e);return o.stringToUTF8(a,r,e),t.push(r),r},xn=(a,t,o,e)=>{if(typeof a=="object"&&a!==null){if(o.has(a))throw new Error("Circular reference in options");o.add(a)}Object.entries(a).forEach(([r,n])=>{let s=t?t+r:r;if(typeof n=="object")xn(n,s+".",o,e);else if(typeof n=="string"||typeof n=="number")e(s,n.toString());else if(typeof n=="boolean")e(s,n?"1":"0");else throw new Error(`Can't handle extra config type: ${typeof n}`)})},_e=a=>{let t=Fe(),o=t.stackSave();try{let e=t.stackAlloc(8);t._OrtGetLastError(e,e+4);let r=t.HEAP32[e/4],n=t.HEAPU32[e/4+1],s=n?t.UTF8ToString(n):"";throw new Error(`${a} ERROR_CODE: ${r}, ERROR_MESSAGE: ${s}`)}finally{t.stackRestore(o)}}});var Mp,Gp=P(()=>{"use strict";zr();Eo();Mp=a=>{let t=Fe(),o=0,e=[],r=a||{};try{if(a?.logSeverityLevel===void 0)r.logSeverityLevel=2;else if(typeof a.logSeverityLevel!="number"||!Number.isInteger(a.logSeverityLevel)||a.logSeverityLevel<0||a.logSeverityLevel>4)throw new Error(`log serverity level is not valid: ${a.logSeverityLevel}`);if(a?.logVerbosityLevel===void 0)r.logVerbosityLevel=0;else if(typeof a.logVerbosityLevel!="number"||!Number.isInteger(a.logVerbosityLevel))throw new Error(`log verbosity level is not valid: ${a.logVerbosityLevel}`);a?.terminate===void 0&&(r.terminate=!1);let n=0;return a?.tag!==void 0&&(n=ve(a.tag,e)),o=t._OrtCreateRunOptions(r.logSeverityLevel,r.logVerbosityLevel,!!r.terminate,n),o===0&&_e("Can't create run options."),a?.extra!==void 0&&xn(a.extra,"",new WeakSet,(s,i)=>{let u=ve(s,e),l=ve(i,e);t._OrtAddRunConfigEntry(o,u,l)!==0&&_e(`Can't set a run config entry: ${s} - ${i}.`)}),[o,e]}catch(n){throw o!==0&&t._OrtReleaseRunOptions(o),e.forEach(s=>t._free(s)),n}}});var pg,dg,hg,mg,Up,zp=P(()=>{"use strict";zr();Eo();pg=a=>{switch(a){case"disabled":return 0;case"basic":return 1;case"extended":return 2;case"all":return 99;default:throw new Error(`unsupported graph optimization level: ${a}`)}},dg=a=>{switch(a){case"sequential":return 0;case"parallel":return 1;default:throw new Error(`unsupported execution mode: ${a}`)}},hg=a=>{a.extra||(a.extra={}),a.extra.session||(a.extra.session={});let t=a.extra.session;t.use_ort_model_bytes_directly||(t.use_ort_model_bytes_directly="1"),a.executionProviders&&a.executionProviders.some(o=>(typeof o=="string"?o:o.name)==="webgpu")&&(a.enableMemPattern=!1)},mg=(a,t,o)=>{for(let e of t){let r=typeof e=="string"?e:e.name;switch(r){case"webnn":if(r="WEBNN",typeof e!="string"){let s=e;if(s?.deviceType){let i=ve("deviceType",o),u=ve(s.deviceType,o);Fe()._OrtAddSessionConfigEntry(a,i,u)!==0&&_e(`Can't set a session config entry: 'deviceType' - ${s.deviceType}.`)}if(s?.numThreads){let i=s.numThreads;(typeof i!="number"||!Number.isInteger(i)||i<0)&&(i=0);let u=ve("numThreads",o),l=ve(i.toString(),o);Fe()._OrtAddSessionConfigEntry(a,u,l)!==0&&_e(`Can't set a session config entry: 'numThreads' - ${s.numThreads}.`)}if(s?.powerPreference){let i=ve("powerPreference",o),u=ve(s.powerPreference,o);Fe()._OrtAddSessionConfigEntry(a,i,u)!==0&&_e(`Can't set a session config entry: 'powerPreference' - ${s.powerPreference}.`)}}break;case"webgpu":if(r="JS",typeof e!="string"){let s=e;if(s?.preferredLayout){if(s.preferredLayout!=="NCHW"&&s.preferredLayout!=="NHWC")throw new Error(`preferredLayout must be either 'NCHW' or 'NHWC': ${s.preferredLayout}`);let i=ve("preferredLayout",o),u=ve(s.preferredLayout,o);Fe()._OrtAddSessionConfigEntry(a,i,u)!==0&&_e(`Can't set a session config entry: 'preferredLayout' - ${s.preferredLayout}.`)}}break;case"wasm":case"cpu":continue;default:throw new Error(`not supported execution provider: ${r}`)}let n=ve(r,o);Fe()._OrtAppendExecutionProvider(a,n)!==0&&_e(`Can't append execution provider: ${r}.`)}},Up=a=>{let t=Fe(),o=0,e=[],r=a||{};hg(r);try{let n=pg(r.graphOptimizationLevel??"all"),s=dg(r.executionMode??"sequential"),i=typeof r.logId=="string"?ve(r.logId,e):0,u=r.logSeverityLevel??2;if(!Number.isInteger(u)||u<0||u>4)throw new Error(`log serverity level is not valid: ${u}`);let l=r.logVerbosityLevel??0;if(!Number.isInteger(l)||l<0||l>4)throw new Error(`log verbosity level is not valid: ${l}`);let f=typeof r.optimizedModelFilePath=="string"?ve(r.optimizedModelFilePath,e):0;if(o=t._OrtCreateSessionOptions(n,!!r.enableCpuMemArena,!!r.enableMemPattern,s,!!r.enableProfiling,0,i,u,l,f),o===0&&_e("Can't create session options."),r.executionProviders&&mg(o,r.executionProviders,e),r.enableGraphCapture!==void 0){if(typeof r.enableGraphCapture!="boolean")throw new Error(`enableGraphCapture must be a boolean value: ${r.enableGraphCapture}`);let p=ve("enableGraphCapture",e),d=ve(r.enableGraphCapture.toString(),e);t._OrtAddSessionConfigEntry(o,p,d)!==0&&_e(`Can't set a session config entry: 'enableGraphCapture' - ${r.enableGraphCapture}.`)}if(r.freeDimensionOverrides)for(let[p,d]of Object.entries(r.freeDimensionOverrides)){if(typeof p!="string")throw new Error(`free dimension override name must be a string: ${p}`);if(typeof d!="number"||!Number.isInteger(d)||d<0)throw new Error(`free dimension override value must be a non-negative integer: ${d}`);let T=ve(p,e);t._OrtAddFreeDimensionOverride(o,T,d)!==0&&_e(`Can't set a free dimension override: ${p} - ${d}.`)}return r.extra!==void 0&&xn(r.extra,"",new WeakSet,(p,d)=>{let T=ve(p,e),v=ve(d,e);t._OrtAddSessionConfigEntry(o,T,v)!==0&&_e(`Can't set a session config entry: ${p} - ${d}.`)}),[o,e]}catch(n){throw o!==0&&t._OrtReleaseSessionOptions(o),e.forEach(s=>t._free(s)),n}}});var aa,Vp,sa,Wp,Hp,Po,qp,ua=P(()=>{"use strict";aa=a=>{switch(a){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: ${a}`)}},Vp=a=>{switch(a){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: ${a}`)}},sa=a=>[void 0,4,1,1,2,2,4,8,void 0,1,2,8,4,8,void 0,void 0,void 0][a],Wp=a=>{switch(a){case"float16":return typeof Float16Array<"u"&&Float16Array.from?Float16Array: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: ${a}`)}},Hp=a=>{switch(a){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: ${a}`)}},Po=a=>a==="float32"||a==="float16"||a==="int32"||a==="int64"||a==="uint32"||a==="uint8"||a==="bool",qp=a=>{switch(a){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: ${a}`)}}});var wn,la=P(()=>{"use strict";wn=async a=>{if(typeof a=="string")if(typeof process<"u"&&process.versions&&process.versions.node)try{return new Uint8Array(await(void 0)(a))}catch(t){if(t.code==="ERR_FS_FILE_TOO_LARGE"){let o=(void 0)(a),e=[];for await(let r of o)e.push(r);return new Uint8Array(Buffer.concat(e))}throw t}else{let t=await fetch(a);if(!t.ok)throw new Error(`failed to load external data file: ${a}`);let o=t.headers.get("Content-Length"),e=o?parseInt(o,10):0;if(e<1073741824)return new Uint8Array(await t.arrayBuffer());{if(!t.body)throw new Error(`failed to load external data file: ${a}, no response body.`);let r=t.body.getReader(),n;try{n=new ArrayBuffer(e)}catch(i){if(i instanceof RangeError){let u=Math.ceil(e/65536);n=new WebAssembly.Memory({initial:u,maximum:u}).buffer}else throw i}let s=0;for(;;){let{done:i,value:u}=await r.read();if(i)break;let l=u.byteLength;new Uint8Array(n,s,l).set(u),s+=l}return new Uint8Array(n,0,e)}}else return a instanceof Blob?new Uint8Array(await a.arrayBuffer()):a instanceof Uint8Array?a:new Uint8Array(a)}});var bg,Yp,Xp,Vr,gg,fa,Kp,Jp,jp,Zp,Qp,ed,td=P(()=>{"use strict";Gp();zp();ua();zr();Eo();la();bg=(a,t)=>{Fe()._OrtInit(a,t)!==0&&_e("Can't initialize onnxruntime.")},Yp=async a=>{bg(a.wasm.numThreads,Hp(a.logLevel))},Xp=async(a,t)=>{},Vr=new Map,gg=a=>{let t=Fe(),o=t.stackSave();try{let e=t.stackAlloc(8);return t._OrtGetInputOutputCount(a,e,e+4)!==0&&_e("Can't get session input/output count."),[t.HEAP32[e/4],t.HEAP32[e/4+1]]}finally{t.stackRestore(o)}},fa=a=>{let t=Fe(),o=t._malloc(a.byteLength);if(o===0)throw new Error(`Can't create a session. failed to allocate a buffer of size ${a.byteLength}.`);return t.HEAPU8.set(a,o),[o,a.byteLength]},Kp=async(a,t)=>{let o,e,r=Fe();Array.isArray(a)?[o,e]=a:a.buffer===r.HEAPU8.buffer?[o,e]=[a.byteOffset,a.byteLength]:[o,e]=fa(a);let n=0,s=0,i=0,u=[],l=[],f=[];try{if([s,u]=Up(t),t?.externalData&&r.mountExternalData){let F=[];for(let C of t.externalData){let X=typeof C=="string"?C:C.path;F.push(wn(typeof C=="string"?C:C.data).then(N=>{r.mountExternalData(X,N)}))}await Promise.all(F)}n=await r._OrtCreateSession(o,e,s),n===0&&_e("Can't create a session.");let[p,d]=gg(n),T=!!t?.enableGraphCapture,v=[],w=[],I=[];for(let F=0;Fr._OrtFree(d)),f.forEach(d=>r._OrtFree(d)),i!==0&&r._OrtReleaseBinding(i),n!==0&&r._OrtReleaseSession(n),p}finally{r._free(o),s!==0&&r._OrtReleaseSessionOptions(s),u.forEach(p=>r._free(p)),r.unmountExternalData?.()}},Jp=a=>{let t=Fe(),o=Vr.get(a);if(!o)throw new Error(`cannot release session. invalid session id: ${a}`);let[e,r,n,s,i]=o;s&&(i&&t._OrtClearBoundOutputs(s.handle),t._OrtReleaseBinding(s.handle)),t.jsepOnReleaseSession?.(a),r.forEach(u=>t._OrtFree(u)),n.forEach(u=>t._OrtFree(u)),t._OrtReleaseSession(e),Vr.delete(a)},jp=(a,t,o,e,r,n=!1)=>{if(!a){t.push(0);return}let s=Fe(),i=a[0],u=a[1],l=a[3],f,p;if(i==="string"&&l==="gpu-buffer")throw new Error("String tensor is not supported on GPU.");if(n&&l!=="gpu-buffer")throw new Error(`External buffer must be provided for input/output index ${r} when enableGraphCapture is true.`);if(l==="gpu-buffer"){let v=a[2].gpuBuffer,w=sa(aa(i));p=u.reduce((L,F)=>L*F,1)*w;let I=s.jsepRegisterBuffer;if(!I)throw new Error('Tensor location "gpu-buffer" is not supported without using WebGPU.');f=I(e,r,v,p)}else{let v=a[2];if(Array.isArray(v)){p=4*v.length,f=s._malloc(p),o.push(f);let w=f/4;for(let I=0;Is.HEAP32[v++]=I);let w=s._OrtCreateTensor(aa(i),f,p,T,u.length,qp(l));w===0&&_e(`Can't create tensor for input/output. session=${e}, index=${r}.`),t.push(w)}finally{s.stackRestore(d)}},Zp=async(a,t,o,e,r,n)=>{let s=Fe(),i=Vr.get(a);if(!i)throw new Error(`cannot run inference. invalid session id: ${a}`);let u=i[0],l=i[1],f=i[2],p=i[3],d=i[4],T=i[5],v=t.length,w=e.length,I=0,L=[],F=[],C=[],X=[],N=s.stackSave(),ge=s.stackAlloc(v*4),Oe=s.stackAlloc(v*4),Ne=s.stackAlloc(w*4),V=s.stackAlloc(w*4);try{[I,L]=Mp(n);for(let te=0;teCe*Te,1);Se=Vp(Et);let Ut=p?.outputPreferredLocations[e[te]];if(Se==="string"){if(Ut==="gpu-buffer")throw new Error("String tensor is not supported on GPU.");let Ce=[],Te=je/4;for(let it=0;it0){let Ce=s.jsepGetBuffer;if(!Ce)throw new Error('preferredLocation "gpu-buffer" is not supported without using WebGPU.');let Te=Ce(je),it=sa(Et);if(it===void 0||!Po(Se))throw new Error(`Unsupported data type: ${Se}`);At=!0,Y.push([Se,ot,{gpuBuffer:Te,download:s.jsepCreateDownloader(Te,Pt*it,Se),dispose:()=>{s._OrtReleaseTensor(Ze)}},"gpu-buffer"])}else{let Ce=Wp(Se),Te=new Ce(Pt);new Uint8Array(Te.buffer,Te.byteOffset,Te.byteLength).set(s.HEAPU8.subarray(je,je+Te.byteLength)),Y.push([Se,ot,Te,"cpu"])}}finally{s.stackRestore(qe),Se==="string"&&je&&s._free(je),At||s._OrtReleaseTensor(Ze)}}return p&&!d&&(s._OrtClearBoundOutputs(p.handle),Vr.set(a,[u,l,f,p,d,!1])),Y}finally{s.stackRestore(N),F.forEach(se=>s._OrtReleaseTensor(se)),C.forEach(se=>s._OrtReleaseTensor(se)),X.forEach(se=>s._free(se)),I!==0&&s._OrtReleaseRunOptions(I),L.forEach(se=>s._free(se))}},Qp=a=>{let t=Fe(),o=Vr.get(a);if(!o)throw new Error("invalid session id");let e=o[0],r=t._OrtEndProfiling(e);r===0&&_e("Can't get an profile file name."),t._OrtFree(r)},ed=a=>{let t=[];for(let o of a){let e=o[2];!Array.isArray(e)&&"buffer"in e&&t.push(e.buffer)}return t}});var rd=de((SO,Tg)=>{Tg.exports='/*!\n * ONNX Runtime Web v1.18.0\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n"use strict";(()=>{var vt=Object.defineProperty;var Vr=Object.getOwnPropertyDescriptor;var Jr=Object.getOwnPropertyNames;var Xr=Object.prototype.hasOwnProperty;var _t=(s,c)=>()=>(s&&(c=s(s=0)),c);var nt=(s,c)=>()=>(c||s((c={exports:{}}).exports,c),c.exports),Et=(s,c)=>{for(var o in c)vt(s,o,{get:c[o],enumerable:!0})},Zr=(s,c,o,h)=>{if(c&&typeof c=="object"||typeof c=="function")for(let f of Jr(c))!Xr.call(s,f)&&f!==o&&vt(s,f,{get:()=>c[f],enumerable:!(h=Vr(c,f))||h.enumerable});return s};var ot=s=>Zr(vt({},"__esModule",{value:!0}),s);var St={};Et(St,{createReadStream:()=>fr,readFile:()=>Qr,readFileSync:()=>Kr});var Qr,Kr,fr,At=_t(()=>{Qr=void 0,Kr=void 0,fr=void 0});var Tt={};Et(Tt,{join:()=>en});var en,Mt=_t(()=>{en=void 0});var dr=nt((cr,Ct)=>{"use strict";var lr=(()=>{var s=typeof document<"u"&&document.currentScript?document.currentScript.src:void 0;return typeof __filename<"u"&&(s=s||__filename),function(c={}){var o=c,h,f;o.ready=new Promise((r,i)=>{h=r,f=i});var w=Object.assign({},o),g="./this.program",a=typeof window=="object",E=typeof importScripts=="function",x=typeof process=="object"&&typeof process.versions=="object"&&typeof process.versions.node=="string",P="",R,D,K;if(x){var I=(At(),ot(St)),L=(Mt(),ot(Tt));P=E?L.dirname(P)+"/":__dirname+"/",R=(r,i)=>(r=r.startsWith("file://")?new URL(r):L.normalize(r),I.readFileSync(r,i?void 0:"utf8")),K=r=>(r=R(r,!0),r.buffer||(r=new Uint8Array(r)),r),D=(r,i,u,m=!0)=>{r=r.startsWith("file://")?new URL(r):L.normalize(r),I.readFile(r,m?void 0:"utf8",(O,T)=>{O?u(O):i(m?T.buffer:T)})},!o.thisProgram&&1"[Emscripten Module object]"}else(a||E)&&(E?P=self.location.href:typeof document<"u"&&document.currentScript&&(P=document.currentScript.src),s&&(P=s),P.indexOf("blob:")!==0?P=P.substr(0,P.replace(/[?#].*/,"").lastIndexOf("/")+1):P="",R=r=>{var i=new XMLHttpRequest;return i.open("GET",r,!1),i.send(null),i.responseText},E&&(K=r=>{var i=new XMLHttpRequest;return i.open("GET",r,!1),i.responseType="arraybuffer",i.send(null),new Uint8Array(i.response)}),D=(r,i,u)=>{var m=new XMLHttpRequest;m.open("GET",r,!0),m.responseType="arraybuffer",m.onload=()=>{m.status==200||m.status==0&&m.response?i(m.response):u()},m.onerror=u,m.send(null)});var v=o.print||console.log.bind(console),k=o.printErr||console.error.bind(console);Object.assign(o,w),w=null,o.thisProgram&&(g=o.thisProgram);var W;o.wasmBinary&&(W=o.wasmBinary);var j=o.noExitRuntime||!0;typeof WebAssembly!="object"&&te("no native wasm support detected");var oe,C,ve=!1,Oe,ce,A,N;function ae(){var r=oe.buffer;o.HEAP8=Oe=new Int8Array(r),o.HEAP16=new Int16Array(r),o.HEAP32=A=new Int32Array(r),o.HEAPU8=ce=new Uint8Array(r),o.HEAPU16=new Uint16Array(r),o.HEAPU32=N=new Uint32Array(r),o.HEAPF32=new Float32Array(r),o.HEAPF64=new Float64Array(r)}var _e=[],xe=[],V=[];function S(){var r=o.preRun.shift();_e.unshift(r)}var F=0,de=null,ue=null;function te(r){throw o.onAbort&&o.onAbort(r),r="Aborted("+r+")",k(r),ve=!0,r=new WebAssembly.RuntimeError(r+". Build with -sASSERTIONS for more info."),f(r),r}function Ee(r){return r.startsWith("data:application/octet-stream;base64,")}var J;if(J="ort-wasm.wasm",!Ee(J)){var fe=J;J=o.locateFile?o.locateFile(fe,P):P+fe}function ke(r){if(r==J&&W)return new Uint8Array(W);if(K)return K(r);throw"both async and sync fetching of the wasm failed"}function pe(r){if(!W&&(a||E)){if(typeof fetch=="function"&&!r.startsWith("file://"))return fetch(r,{credentials:"same-origin"}).then(i=>{if(!i.ok)throw"failed to load wasm binary file at \'"+r+"\'";return i.arrayBuffer()}).catch(()=>ke(r));if(D)return new Promise((i,u)=>{D(r,m=>i(new Uint8Array(m)),u)})}return Promise.resolve().then(()=>ke(r))}function Se(r,i,u){return pe(r).then(m=>WebAssembly.instantiate(m,i)).then(m=>m).then(u,m=>{k("failed to asynchronously prepare wasm: "+m),te(m)})}function Pe(r,i){var u=J;return W||typeof WebAssembly.instantiateStreaming!="function"||Ee(u)||u.startsWith("file://")||x||typeof fetch!="function"?Se(u,r,i):fetch(u,{credentials:"same-origin"}).then(m=>WebAssembly.instantiateStreaming(m,r).then(i,function(O){return k("wasm streaming compile failed: "+O),k("falling back to ArrayBuffer instantiation"),Se(u,r,i)}))}var ye,ge=r=>{for(;0>2>>>0]=i},this.za=function(i){N[this.va+8>>2>>>0]=i},this.xa=function(i,u){this.ya(),this.Ea(i),this.za(u)},this.ya=function(){N[this.va+16>>2>>>0]=0}}var Re=0,ee=0,Y=typeof TextDecoder<"u"?new TextDecoder("utf8"):void 0,he=(r,i,u)=>{i>>>=0;var m=i+u;for(u=i;r[u]&&!(u>=m);)++u;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,i)=>(r>>>=0)?he(ce,r,i):"",De=r=>{for(var i=0,u=0;u=m?i++:2047>=m?i+=2:55296<=m&&57343>=m?(i+=4,++u):i+=3}return i},We=(r,i,u,m)=>{if(u>>>=0,!(0=U){var re=r.charCodeAt(++T);U=65536+((U&1023)<<10)|re&1023}if(127>=U){if(u>=m)break;i[u++>>>0]=U}else{if(2047>=U){if(u+1>=m)break;i[u++>>>0]=192|U>>6}else{if(65535>=U){if(u+2>=m)break;i[u++>>>0]=224|U>>12}else{if(u+3>=m)break;i[u++>>>0]=240|U>>18,i[u++>>>0]=128|U>>12&63}i[u++>>>0]=128|U>>6&63}i[u++>>>0]=128|U&63}}return i[u>>>0]=0,u-O},we=r=>r%4===0&&(r%100!==0||r%400===0),$e=[0,31,60,91,121,152,182,213,244,274,305,335],Ce=[0,31,59,90,120,151,181,212,243,273,304,334],qe=r=>{var i=De(r)+1,u=Qe(i);return u&&We(r,ce,u,i),u},Ve={},Je=()=>{if(!Xe){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"},i;for(i in Ve)Ve[i]===void 0?delete r[i]:r[i]=Ve[i];var u=[];for(i in r)u.push(`${i}=${r[i]}`);Xe=u}return Xe},Xe,Fe=[null,[],[]],Ie=[31,29,31,30,31,30,31,31,30,31,30,31],Ne=[31,28,31,30,31,30,31,31,30,31,30,31];function it(r){var i=Array(De(r)+1);return We(r,i,0,i.length),i}function Ze(r,i,u,m){function O(d,B,G){for(d=typeof d=="number"?d.toString():d||"";d.lengthrt?-1:0Te-d.getDate())B-=Te-d.getDate()+1,d.setDate(1),11>G?d.setMonth(G+1):(d.setMonth(0),d.setFullYear(d.getFullYear()+1));else{d.setDate(d.getDate()+B);break}}return G=new Date(d.getFullYear()+1,0,4),B=re(new Date(d.getFullYear(),0,4)),G=re(G),0>=U(B,d)?0>=U(G,d)?d.getFullYear()+1:d.getFullYear():d.getFullYear()-1}r>>>=0,i>>>=0,u>>>=0,m>>>=0;var ie=A[m+40>>2>>>0];m={Ca:A[m>>2>>>0],Ba:A[m+4>>2>>>0],ta:A[m+8>>2>>>0],wa:A[m+12>>2>>>0],ua:A[m+16>>2>>>0],sa:A[m+20>>2>>>0],ma:A[m+24>>2>>>0],ra:A[m+28>>2>>>0],Fa:A[m+32>>2>>>0],Aa:A[m+36>>2>>>0],Da:ie?be(ie):""},u=be(u),ie={"%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 ie)u=u.replace(new RegExp(se,"g"),ie[se]);var et="Sunday Monday Tuesday Wednesday Thursday Friday Saturday".split(" "),tt="January February March April May June July August September October November December".split(" ");ie={"%a":d=>et[d.ma].substring(0,3),"%A":d=>et[d.ma],"%b":d=>tt[d.ua].substring(0,3),"%B":d=>tt[d.ua],"%C":d=>T((d.sa+1900)/100|0,2),"%d":d=>T(d.wa,2),"%e":d=>O(d.wa,2," "),"%g":d=>le(d).toString().substring(2),"%G":d=>le(d),"%H":d=>T(d.ta,2),"%I":d=>(d=d.ta,d==0?d=12:12{for(var B=0,G=0;G<=d.ua-1;B+=(we(d.sa+1900)?Ie:Ne)[G++]);return T(d.wa+B,3)},"%m":d=>T(d.ua+1,2),"%M":d=>T(d.Ba,2),"%n":()=>`\n`,"%p":d=>0<=d.ta&&12>d.ta?"AM":"PM","%S":d=>T(d.Ca,2),"%t":()=>" ","%u":d=>d.ma||7,"%U":d=>T(Math.floor((d.ra+7-d.ma)/7),2),"%V":d=>{var B=Math.floor((d.ra+7-(d.ma+6)%7)/7);if(2>=(d.ma+371-d.ra-2)%7&&B++,B)B==53&&(G=(d.ma+371-d.ra)%7,G==4||G==3&&we(d.sa)||(B=1));else{B=52;var G=(d.ma+7-d.ra-1)%7;(G==4||G==5&&we(d.sa%400-1))&&B++}return T(B,2)},"%w":d=>d.ma,"%W":d=>T(Math.floor((d.ra+7-(d.ma+6)%7)/7),2),"%y":d=>(d.sa+1900).toString().substring(2),"%Y":d=>d.sa+1900,"%z":d=>{d=d.Aa;var B=0<=d;return d=Math.abs(d)/60,(B?"+":"-")+("0000"+(d/60*100+d%60)).slice(-4)},"%Z":d=>d.Da,"%%":()=>"%"},u=u.replace(/%%/g,"\\0\\0");for(se in ie)u.includes(se)&&(u=u.replace(new RegExp(se,"g"),ie[se](m)));return u=u.replace(/\\0\\0/g,"%"),se=it(u),se.length>i?0:(Oe.set(se,r>>>0),se.length-1)}var st={a:function(r,i,u){throw r>>>=0,new Ae(r).xa(i>>>0,u>>>0),Re=r,ee++,Re},e:function(){return 0},H:function(){},x:function(){},z:function(){},k:function(){return 0},F:function(){},B:function(){},E:function(){},g:function(){},y:function(){},v:function(){},G:function(){},w:function(){},l:()=>!0,o:function(r,i,u){r=i+2097152>>>0<4194305-!!r?(r>>>0)+4294967296*i:NaN,u>>>=0,r=new Date(1e3*r),A[u>>2>>>0]=r.getUTCSeconds(),A[u+4>>2>>>0]=r.getUTCMinutes(),A[u+8>>2>>>0]=r.getUTCHours(),A[u+12>>2>>>0]=r.getUTCDate(),A[u+16>>2>>>0]=r.getUTCMonth(),A[u+20>>2>>>0]=r.getUTCFullYear()-1900,A[u+24>>2>>>0]=r.getUTCDay(),A[u+28>>2>>>0]=(r.getTime()-Date.UTC(r.getUTCFullYear(),0,1,0,0,0,0))/864e5|0},p:function(r,i,u){r=i+2097152>>>0<4194305-!!r?(r>>>0)+4294967296*i:NaN,u>>>=0,r=new Date(1e3*r),A[u>>2>>>0]=r.getSeconds(),A[u+4>>2>>>0]=r.getMinutes(),A[u+8>>2>>>0]=r.getHours(),A[u+12>>2>>>0]=r.getDate(),A[u+16>>2>>>0]=r.getMonth(),A[u+20>>2>>>0]=r.getFullYear()-1900,A[u+24>>2>>>0]=r.getDay(),A[u+28>>2>>>0]=(we(r.getFullYear())?$e:Ce)[r.getMonth()]+r.getDate()-1|0,A[u+36>>2>>>0]=-(60*r.getTimezoneOffset()),i=new Date(r.getFullYear(),6,1).getTimezoneOffset();var m=new Date(r.getFullYear(),0,1).getTimezoneOffset();A[u+32>>2>>>0]=(i!=m&&r.getTimezoneOffset()==Math.min(m,i))|0},q:function(r){r>>>=0;var i=new Date(A[r+20>>2>>>0]+1900,A[r+16>>2>>>0],A[r+12>>2>>>0],A[r+8>>2>>>0],A[r+4>>2>>>0],A[r>>2>>>0],0),u=A[r+32>>2>>>0],m=i.getTimezoneOffset(),O=new Date(i.getFullYear(),6,1).getTimezoneOffset(),T=new Date(i.getFullYear(),0,1).getTimezoneOffset(),U=Math.min(T,O);return 0>u?A[r+32>>2>>>0]=+(O!=T&&U==m):0>2>>>0]=i.getDay(),A[r+28>>2>>>0]=(we(i.getFullYear())?$e:Ce)[i.getMonth()]+i.getDate()-1|0,A[r>>2>>>0]=i.getSeconds(),A[r+4>>2>>>0]=i.getMinutes(),A[r+8>>2>>>0]=i.getHours(),A[r+12>>2>>>0]=i.getDate(),A[r+16>>2>>>0]=i.getMonth(),A[r+20>>2>>>0]=i.getYear(),r=i.getTime()/1e3,He((ye=r,1<=+Math.abs(ye)?0>>0:~~+Math.ceil((ye-+(~~ye>>>0))/4294967296)>>>0:0)),r>>>0},m:function(){return-52},n:function(){},t:function(r,i,u){function m(le){return(le=le.toTimeString().match(/\\(([A-Za-z ]+)\\)$/))?le[1]:"GMT"}u>>>=0;var O=new Date().getFullYear(),T=new Date(O,0,1),U=new Date(O,6,1);O=T.getTimezoneOffset();var re=U.getTimezoneOffset();N[r>>>0>>2>>>0]=60*Math.max(O,re),A[i>>>0>>2>>>0]=+(O!=re),r=m(T),i=m(U),r=qe(r),i=qe(i),re>2>>>0]=r,N[u+4>>2>>>0]=i):(N[u>>2>>>0]=i,N[u+4>>2>>>0]=r)},d:()=>{te("")},h:function(){return Date.now()},u:function(){return 4294901760},b:()=>performance.now(),I:function(r,i,u){return i>>>=0,ce.copyWithin(r>>>0>>>0,i>>>0,i+(u>>>0)>>>0)},s:function(r){r>>>=0;var i=ce.length;if(4294901760=u;u*=2){var m=i*(1+.2/u);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)-oe.buffer.byteLength+65535>>>16;try{oe.grow(O),ae();var T=1;break e}catch{}T=void 0}if(T)return!0}return!1},C:function(r,i){r>>>=0,i>>>=0;var u=0;return Je().forEach(function(m,O){var T=i+u;for(O=N[r+4*O>>2>>>0]=T,T=0;T>0>>>0]=m.charCodeAt(T);Oe[O>>0>>>0]=0,u+=m.length+1}),0},D:function(r,i){r>>>=0,i>>>=0;var u=Je();N[r>>2>>>0]=u.length;var m=0;return u.forEach(function(O){m+=O.length+1}),N[i>>2>>>0]=m,0},f:()=>52,j:function(){return 52},r:function(){return 70},i:function(r,i,u,m){i>>>=0,u>>>=0,m>>>=0;for(var O=0,T=0;T>2>>>0],re=N[i+4>>2>>>0];i+=8;for(var le=0;le>>0],se=Fe[r];ie===0||ie===10?((r===1?v:k)(he(se,0)),se.length=0):se.push(ie)}O+=re}return N[m>>2>>>0]=O,0},A:Ze,c:function(r,i,u,m){return Ze(r>>>0,i>>>0,u>>>0,m>>>0)}};(function(){function r(u){if(u=u.exports,C=u=je(u),oe=C.J,ae(),xe.unshift(C.K),F--,o.monitorRunDependencies&&o.monitorRunDependencies(F),F==0&&(de!==null&&(clearInterval(de),de=null),ue)){var m=ue;ue=null,m()}return u}var i={a:st};if(F++,o.monitorRunDependencies&&o.monitorRunDependencies(F),o.instantiateWasm)try{return o.instantiateWasm(i,r)}catch(u){k("Module.instantiateWasm callback failed with error: "+u),f(u)}return Pe(i,function(u){r(u.instance)}).catch(f),{}})(),o._OrtInit=(r,i)=>(o._OrtInit=C.L)(r,i),o._OrtGetLastError=(r,i)=>(o._OrtGetLastError=C.M)(r,i),o._OrtCreateSessionOptions=(r,i,u,m,O,T,U,re,le,ie)=>(o._OrtCreateSessionOptions=C.N)(r,i,u,m,O,T,U,re,le,ie),o._OrtAppendExecutionProvider=(r,i)=>(o._OrtAppendExecutionProvider=C.O)(r,i),o._OrtAddFreeDimensionOverride=(r,i,u)=>(o._OrtAddFreeDimensionOverride=C.P)(r,i,u),o._OrtAddSessionConfigEntry=(r,i,u)=>(o._OrtAddSessionConfigEntry=C.Q)(r,i,u),o._OrtReleaseSessionOptions=r=>(o._OrtReleaseSessionOptions=C.R)(r),o._OrtCreateSession=(r,i,u)=>(o._OrtCreateSession=C.S)(r,i,u),o._OrtReleaseSession=r=>(o._OrtReleaseSession=C.T)(r),o._OrtGetInputOutputCount=(r,i,u)=>(o._OrtGetInputOutputCount=C.U)(r,i,u),o._OrtGetInputName=(r,i)=>(o._OrtGetInputName=C.V)(r,i),o._OrtGetOutputName=(r,i)=>(o._OrtGetOutputName=C.W)(r,i),o._OrtFree=r=>(o._OrtFree=C.X)(r),o._OrtCreateTensor=(r,i,u,m,O,T)=>(o._OrtCreateTensor=C.Y)(r,i,u,m,O,T),o._OrtGetTensorData=(r,i,u,m,O)=>(o._OrtGetTensorData=C.Z)(r,i,u,m,O),o._OrtReleaseTensor=r=>(o._OrtReleaseTensor=C._)(r),o._OrtCreateRunOptions=(r,i,u,m)=>(o._OrtCreateRunOptions=C.$)(r,i,u,m),o._OrtAddRunConfigEntry=(r,i,u)=>(o._OrtAddRunConfigEntry=C.aa)(r,i,u),o._OrtReleaseRunOptions=r=>(o._OrtReleaseRunOptions=C.ba)(r),o._OrtCreateBinding=r=>(o._OrtCreateBinding=C.ca)(r),o._OrtBindInput=(r,i,u)=>(o._OrtBindInput=C.da)(r,i,u),o._OrtBindOutput=(r,i,u,m)=>(o._OrtBindOutput=C.ea)(r,i,u,m),o._OrtClearBoundOutputs=r=>(o._OrtClearBoundOutputs=C.fa)(r),o._OrtReleaseBinding=r=>(o._OrtReleaseBinding=C.ga)(r),o._OrtRunWithBinding=(r,i,u,m,O)=>(o._OrtRunWithBinding=C.ha)(r,i,u,m,O),o._OrtRun=(r,i,u,m,O,T,U,re)=>(o._OrtRun=C.ia)(r,i,u,m,O,T,U,re),o._OrtEndProfiling=r=>(o._OrtEndProfiling=C.ja)(r);var Qe=o._malloc=r=>(Qe=o._malloc=C.ka)(r);o._free=r=>(o._free=C.la)(r);var He=r=>(He=C.na)(r),Ke=()=>(Ke=C.oa)(),Ge=r=>(Ge=C.pa)(r),M=r=>(M=C.qa)(r);function je(r){r=Object.assign({},r);var i=m=>()=>m()>>>0,u=m=>O=>m(O)>>>0;return r.__errno_location=i(r.__errno_location),r.malloc=u(r.malloc),r.stackSave=i(r.stackSave),r.stackAlloc=u(r.stackAlloc),r}o.stackAlloc=M,o.stackSave=Ke,o.stackRestore=Ge,o.UTF8ToString=be,o.stringToUTF8=(r,i,u)=>We(r,ce,i,u),o.lengthBytesUTF8=De;var Ue;ue=function r(){Ue||Le(),Ue||(ue=r)};function Le(){function r(){if(!Ue&&(Ue=!0,o.calledRun=!0,!ve)){if(ge(xe),h(o),o.onRuntimeInitialized&&o.onRuntimeInitialized(),o.postRun)for(typeof o.postRun=="function"&&(o.postRun=[o.postRun]);o.postRun.length;){var i=o.postRun.shift();V.unshift(i)}ge(V)}}if(!(0lr)});var pr=nt(()=>{});var mr=nt(()=>{});var gr={};Et(gr,{cpus:()=>tn});var tn,hr=_t(()=>{tn=void 0});var wr=nt((br,Rt)=>{"use strict";var yr=(()=>{var s=typeof document<"u"&&document.currentScript?document.currentScript.src:void 0;return typeof __filename<"u"&&(s=s||__filename),function(c={}){function o(){return V.buffer!=te.buffer&&pe(),te}function h(){return V.buffer!=te.buffer&&pe(),Ee}function f(){return V.buffer!=te.buffer&&pe(),J}function w(){return V.buffer!=te.buffer&&pe(),fe}function g(){return V.buffer!=te.buffer&&pe(),ke}var a=c,E,x;a.ready=new Promise((e,t)=>{E=e,x=t});var P=Object.assign({},a),R="./this.program",D=(e,t)=>{throw t},K=typeof window=="object",I=typeof importScripts=="function",L=typeof process=="object"&&typeof process.versions=="object"&&typeof process.versions.node=="string",v=a.ENVIRONMENT_IS_PTHREAD||!1,k="";function W(e){return a.locateFile?a.locateFile(e,k):k+e}var j,oe,C;if(L){var ve=(At(),ot(St)),Oe=(Mt(),ot(Tt));k=I?Oe.dirname(k)+"/":__dirname+"/",j=(t,n)=>(t=t.startsWith("file://")?new URL(t):Oe.normalize(t),ve.readFileSync(t,n?void 0:"utf8")),C=t=>(t=j(t,!0),t.buffer||(t=new Uint8Array(t)),t),oe=(t,n,l,b=!0)=>{t=t.startsWith("file://")?new URL(t):Oe.normalize(t),ve.readFile(t,b?void 0:"utf8",(y,_)=>{y?l(y):n(b?_.buffer:_)})},!a.thisProgram&&1{throw process.exitCode=t,n},a.inspect=()=>"[Emscripten Module object]";let e;try{e=pr()}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(K||I)&&(I?k=self.location.href:typeof document<"u"&&document.currentScript&&(k=document.currentScript.src),typeof s<"u"&&s&&(k=s),k.indexOf("blob:")!==0?k=k.substr(0,k.replace(/[?#].*/,"").lastIndexOf("/")+1):k="",L||(j=e=>{var t=new XMLHttpRequest;return t.open("GET",e,!1),t.send(null),t.responseText},I&&(C=e=>{var t=new XMLHttpRequest;return t.open("GET",e,!1),t.responseType="arraybuffer",t.send(null),new Uint8Array(t.response)}),oe=(e,t,n)=>{var l=new XMLHttpRequest;l.open("GET",e,!0),l.responseType="arraybuffer",l.onload=()=>{l.status==200||l.status==0&&l.response?t(l.response):n()},l.onerror=n,l.send(null)}));L&&typeof performance>"u"&&(global.performance=mr().performance);var ce=console.log.bind(console),A=console.error.bind(console);L&&(ce=(...e)=>ve.writeSync(1,e.join(" ")+`\n`),A=(...e)=>ve.writeSync(2,e.join(" ")+`\n`));var N=a.print||ce,ae=a.printErr||A;Object.assign(a,P),P=null,a.thisProgram&&(R=a.thisProgram),a.quit&&(D=a.quit);var _e;a.wasmBinary&&(_e=a.wasmBinary);var xe=a.noExitRuntime||!0;typeof WebAssembly!="object"&&we("no native wasm support detected");var V,S,F,de=!1,ue,te,Ee,J,fe,ke;function pe(){var e=V.buffer;a.HEAP8=te=new Int8Array(e),a.HEAP16=new Int16Array(e),a.HEAP32=J=new Int32Array(e),a.HEAPU8=Ee=new Uint8Array(e),a.HEAPU16=new Uint16Array(e),a.HEAPU32=fe=new Uint32Array(e),a.HEAPF32=new Float32Array(e),a.HEAPF64=ke=new Float64Array(e)}var Se=a.INITIAL_MEMORY||16777216;if(5242880<=Se||we("INITIAL_MEMORY should be larger than STACK_SIZE, was "+Se+"! (STACK_SIZE=5242880)"),v)V=a.wasmMemory;else if(a.wasmMemory)V=a.wasmMemory;else if(V=new WebAssembly.Memory({initial:Se/65536,maximum:65536,shared:!0}),!(V.buffer instanceof SharedArrayBuffer))throw ae("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&&ae("(on node you may need: --experimental-wasm-threads --experimental-wasm-bulk-memory and/or recent version)"),Error("bad memory");pe(),Se=V.buffer.byteLength;var Pe,ye=[],ge=[],Ae=[],Re=0;function ee(){return xe||0{if(!t.ok)throw"failed to load wasm binary file at \'"+e+"\'";return t.arrayBuffer()}).catch(()=>qe(e));if(oe)return new Promise((t,n)=>{oe(e,l=>t(new Uint8Array(l)),n)})}return Promise.resolve().then(()=>qe(e))}function Je(e,t,n){return Ve(e).then(l=>WebAssembly.instantiate(l,t)).then(l=>l).then(n,l=>{ae("failed to asynchronously prepare wasm: "+l),we(l)})}function Xe(e,t){var n=Ce;return _e||typeof WebAssembly.instantiateStreaming!="function"||$e(n)||n.startsWith("file://")||L||typeof fetch!="function"?Je(n,e,t):fetch(n,{credentials:"same-origin"}).then(l=>WebAssembly.instantiateStreaming(l,e).then(t,function(b){return ae("wasm streaming compile failed: "+b),ae("falling back to ArrayBuffer instantiation"),Je(n,e,t)}))}var Fe;function Ie(e){this.name="ExitStatus",this.message=`Program terminated with exit(${e})`,this.status=e}function Ne(e){e.terminate(),e.onmessage=()=>{}}function it(e){(e=M.La[e])||we(),M.lb(e)}function Ze(e){var t=M.fb();if(!t)return 6;M.Oa.push(t),M.La[e.Na]=t,t.Na=e.Na;var n={cmd:"run",start_routine:e.mb,arg:e.eb,pthread_ptr:e.Na};return L&&t.unref(),t.postMessage(n,e.sb),0}var st=typeof TextDecoder<"u"?new TextDecoder("utf8"):void 0,Qe=(e,t,n)=>{t>>>=0;var l=t+n;for(n=t;e[n]&&!(n>=l);)++n;if(16b?l+=String.fromCharCode(b):(b-=65536,l+=String.fromCharCode(55296|b>>10,56320|b&1023))}}else l+=String.fromCharCode(b)}return l},He=(e,t)=>(e>>>=0)?Qe(h(),e,t):"";function Ke(e){if(v)return z(1,1,e);ue=e,ee()||(M.nb(),a.onExit&&a.onExit(e),de=!0),D(e,new Ie(e))}var Ge=e=>{if(ue=e,v)throw Ue(e),"unwind";Ke(e)},M={Ra:[],Oa:[],Za:[],La:{},Va:function(){v?M.hb():M.gb()},gb:function(){ye.unshift(()=>{De(),M.ib(()=>We())})},hb:function(){M.receiveObjectTransfer=M.kb,M.threadInitTLS=M.Ya,M.setExitStatus=M.Xa,xe=!1},Xa:function(e){ue=e},xb:["$terminateWorker"],nb:function(){for(var e of M.Oa)Ne(e);for(e of M.Ra)Ne(e);M.Ra=[],M.Oa=[],M.La=[]},lb:function(e){var t=e.Na;delete M.La[t],M.Ra.push(e),M.Oa.splice(M.Oa.indexOf(e),1),e.Na=0,yt(t)},kb:function(){},Ya:function(){M.Za.forEach(e=>e())},jb:e=>new Promise(t=>{e.onmessage=y=>{y=y.data;var _=y.cmd;if(y.targetThread&&y.targetThread!=ft()){var X=M.La[y.wb];X?X.postMessage(y,y.transferList):ae(\'Internal error! Worker sent a message "\'+_+\'" to target pthread \'+y.targetThread+", but that thread no longer exists!")}else _==="checkMailbox"?ut():_==="spawnThread"?Ze(y):_==="cleanupThread"?it(y.thread):_==="killThread"?(y=y.thread,_=M.La[y],delete M.La[y],Ne(_),yt(y),M.Oa.splice(M.Oa.indexOf(_),1),_.Na=0):_==="cancelThread"?M.La[y.thread].postMessage({cmd:"cancel"}):_==="loaded"?(e.loaded=!0,t(e)):_==="alert"?alert("Thread "+y.threadId+": "+y.text):y.target==="setimmediate"?e.postMessage(y):_==="callHandler"?a[y.handler](...y.args):_&&ae("worker sent an unknown command "+_)},e.onerror=y=>{throw ae("worker sent an error! "+y.filename+":"+y.lineno+": "+y.message),y},L&&(e.on("message",function(y){e.onmessage({data:y})}),e.on("error",function(y){e.onerror(y)}));var n=[],l=["onExit","onAbort","print","printErr"],b;for(b of l)a.hasOwnProperty(b)&&n.push(b);e.postMessage({cmd:"load",handlers:n,urlOrBlob:a.mainScriptUrlOrBlob||s,wasmMemory:V,wasmModule:F})}),ib:function(e){e()},cb:function(){var e=W("ort-wasm-threaded.worker.js");e=new Worker(e),M.Ra.push(e)},fb:function(){return M.Ra.length==0&&(M.cb(),M.jb(M.Ra[0])),M.Ra.pop()}};a.PThread=M;var je=e=>{for(;0>2>>>0];e=f()[e+56>>2>>>0],or(t,t-e),lt(t)};function Ue(e){if(v)return z(2,0,e);Ge(e)}var Le=[];a.invokeEntryPoint=function(e,t){var n=Le[e];n||(e>=Le.length&&(Le.length=e+1),Le[e]=n=Pe.get(e)),e=n(t),ee()?M.Xa(e):bt(e)};function r(e){this.Ua=e-24,this.bb=function(t){w()[this.Ua+4>>2>>>0]=t},this.ab=function(t){w()[this.Ua+8>>2>>>0]=t},this.Va=function(t,n){this.$a(),this.bb(t),this.ab(n)},this.$a=function(){w()[this.Ua+16>>2>>>0]=0}}var i=0,u=0;function m(e,t,n,l){return v?z(3,1,e,t,n,l):O(e,t,n,l)}function O(e,t,n,l){if(e>>>=0,t>>>=0,n>>>=0,l>>>=0,typeof SharedArrayBuffer>"u")return ae("Current environment does not support SharedArrayBuffer, pthreads are not available!"),6;var b=[];return v&&b.length===0?m(e,t,n,l):(e={mb:n,Na:e,eb:l,sb:b},v?(e.ub="spawnThread",postMessage(e,b),0):Ze(e))}function T(e,t,n){return v?z(4,1,e,t,n):0}function U(e,t){if(v)return z(5,1,e,t)}var re=e=>{for(var t=0,n=0;n=l?t++:2047>=l?t+=2:55296<=l&&57343>=l?(t+=4,++n):t+=3}return t},le=(e,t,n,l)=>{if(n>>>=0,!(0=_){var X=e.charCodeAt(++y);_=65536+((_&1023)<<10)|X&1023}if(127>=_){if(n>=l)break;t[n++>>>0]=_}else{if(2047>=_){if(n+1>=l)break;t[n++>>>0]=192|_>>6}else{if(65535>=_){if(n+2>=l)break;t[n++>>>0]=224|_>>12}else{if(n+3>=l)break;t[n++>>>0]=240|_>>18,t[n++>>>0]=128|_>>12&63}t[n++>>>0]=128|_>>6&63}t[n++>>>0]=128|_&63}}return t[n>>>0]=0,n-b},ie=(e,t,n)=>le(e,h(),t,n);function se(e,t){if(v)return z(6,1,e,t)}function et(e,t,n){if(v)return z(7,1,e,t,n)}function tt(e,t,n){return v?z(8,1,e,t,n):0}function d(e,t){if(v)return z(9,1,e,t)}function B(e,t,n){if(v)return z(10,1,e,t,n)}function G(e,t,n,l){if(v)return z(11,1,e,t,n,l)}function Te(e,t,n,l){if(v)return z(12,1,e,t,n,l)}function rt(e,t,n,l){if(v)return z(13,1,e,t,n,l)}function Ut(e){if(v)return z(14,1,e)}function Lt(e,t){if(v)return z(15,1,e,t)}function Bt(e,t,n){if(v)return z(16,1,e,t,n)}var Nr=e=>{if(!de)try{if(e(),!ee())try{v?bt(ue):Ge(ue)}catch(t){t instanceof Ie||t=="unwind"||D(1,t)}}catch(t){t instanceof Ie||t=="unwind"||D(1,t)}};function pt(e){e>>>=0,typeof Atomics.tb=="function"&&(Atomics.tb(f(),e>>2,e).value.then(ut),e+=128,Atomics.store(f(),e>>2,1))}a.__emscripten_thread_mailbox_await=pt;function ut(){var e=ft();e&&(pt(e),Nr(()=>rr()))}a.checkMailbox=ut;var Ye=e=>e%4===0&&(e%100!==0||e%400===0),kt=[0,31,60,91,121,152,182,213,244,274,305,335],Wt=[0,31,59,90,120,151,181,212,243,273,304,334];function Nt(e,t,n,l,b,y,_,X){return v?z(17,1,e,t,n,l,b,y,_,X):-52}function Ht(e,t,n,l,b,y,_){if(v)return z(18,1,e,t,n,l,b,y,_)}var Gt=e=>{var t=re(e)+1,n=Kt(t);return n&&ie(e,n,t),n},Hr=e=>{var t=wt();return e=e(),lt(t),e};function z(e,t){var n=arguments.length-2,l=arguments;return Hr(()=>{for(var b=Ot(8*n),y=b>>3,_=0;_>>0]=X}return tr(e,n,b,t)})}var mt=[],gt={},jt=()=>{if(!ht){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",_:R||"./this.program"},t;for(t in gt)gt[t]===void 0?delete e[t]:e[t]=gt[t];var n=[];for(t in e)n.push(`${t}=${e[t]}`);ht=n}return ht},ht;function Yt(e,t){if(v)return z(19,1,e,t);e>>>=0,t>>>=0;var n=0;return jt().forEach(function(l,b){var y=t+n;for(b=w()[e+4*b>>2>>>0]=y,y=0;y>0>>>0]=l.charCodeAt(y);o()[b>>0>>>0]=0,n+=l.length+1}),0}function zt(e,t){if(v)return z(20,1,e,t);e>>>=0,t>>>=0;var n=jt();w()[e>>2>>>0]=n.length;var l=0;return n.forEach(function(b){l+=b.length+1}),w()[t>>2>>>0]=l,0}function $t(e){return v?z(21,1,e):52}function qt(e,t,n,l){return v?z(22,1,e,t,n,l):52}function Vt(e,t,n,l,b){return v?z(23,1,e,t,n,l,b):70}var Gr=[null,[],[]];function Jt(e,t,n,l){if(v)return z(24,1,e,t,n,l);t>>>=0,n>>>=0,l>>>=0;for(var b=0,y=0;y>2>>>0],X=w()[t+4>>2>>>0];t+=8;for(var Me=0;Me>>0],me=Gr[e];ne===0||ne===10?((e===1?N:ae)(Qe(me,0)),me.length=0):me.push(ne)}b+=X}return w()[l>>2>>>0]=b,0}var Xt=[31,29,31,30,31,30,31,31,30,31,30,31],Zt=[31,28,31,30,31,30,31,31,30,31,30,31];function jr(e){var t=Array(re(e)+1);return le(e,t,0,t.length),t}var Yr=(e,t)=>{o().set(e,t>>>0)};function Qt(e,t,n,l){function b(p,H,Z){for(p=typeof p=="number"?p.toString():p||"";p.lengthur?-1:0Be-p.getDate())H-=Be-p.getDate()+1,p.setDate(1),11>Z?p.setMonth(Z+1):(p.setMonth(0),p.setFullYear(p.getFullYear()+1));else{p.setDate(p.getDate()+H);break}}return Z=new Date(p.getFullYear()+1,0,4),H=X(new Date(p.getFullYear(),0,4)),Z=X(Z),0>=_(H,p)?0>=_(Z,p)?p.getFullYear()+1:p.getFullYear():p.getFullYear()-1}e>>>=0,t>>>=0,n>>>=0,l>>>=0;var ne=f()[l+40>>2>>>0];l={qb:f()[l>>2>>>0],pb:f()[l+4>>2>>>0],Sa:f()[l+8>>2>>>0],Wa:f()[l+12>>2>>>0],Ta:f()[l+16>>2>>>0],Qa:f()[l+20>>2>>>0],Ma:f()[l+24>>2>>>0],Pa:f()[l+28>>2>>>0],yb:f()[l+32>>2>>>0],ob:f()[l+36>>2>>>0],rb:ne?He(ne):""},n=He(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 ir="Sunday Monday Tuesday Wednesday Thursday Friday Saturday".split(" "),sr="January February March April May June July August September October November December".split(" ");ne={"%a":p=>ir[p.Ma].substring(0,3),"%A":p=>ir[p.Ma],"%b":p=>sr[p.Ta].substring(0,3),"%B":p=>sr[p.Ta],"%C":p=>y((p.Qa+1900)/100|0,2),"%d":p=>y(p.Wa,2),"%e":p=>b(p.Wa,2," "),"%g":p=>Me(p).toString().substring(2),"%G":p=>Me(p),"%H":p=>y(p.Sa,2),"%I":p=>(p=p.Sa,p==0?p=12:12{for(var H=0,Z=0;Z<=p.Ta-1;H+=(Ye(p.Qa+1900)?Xt:Zt)[Z++]);return y(p.Wa+H,3)},"%m":p=>y(p.Ta+1,2),"%M":p=>y(p.pb,2),"%n":()=>`\n`,"%p":p=>0<=p.Sa&&12>p.Sa?"AM":"PM","%S":p=>y(p.qb,2),"%t":()=>" ","%u":p=>p.Ma||7,"%U":p=>y(Math.floor((p.Pa+7-p.Ma)/7),2),"%V":p=>{var H=Math.floor((p.Pa+7-(p.Ma+6)%7)/7);if(2>=(p.Ma+371-p.Pa-2)%7&&H++,H)H==53&&(Z=(p.Ma+371-p.Pa)%7,Z==4||Z==3&&Ye(p.Qa)||(H=1));else{H=52;var Z=(p.Ma+7-p.Pa-1)%7;(Z==4||Z==5&&Ye(p.Qa%400-1))&&H++}return y(H,2)},"%w":p=>p.Ma,"%W":p=>y(Math.floor((p.Pa+7-(p.Ma+6)%7)/7),2),"%y":p=>(p.Qa+1900).toString().substring(2),"%Y":p=>p.Qa+1900,"%z":p=>{p=p.ob;var H=0<=p;return p=Math.abs(p)/60,(H?"+":"-")+("0000"+(p/60*100+p%60)).slice(-4)},"%Z":p=>p.rb,"%%":()=>"%"},n=n.replace(/%%/g,"\\0\\0");for(me in ne)n.includes(me)&&(n=n.replace(new RegExp(me,"g"),ne[me](l)));return n=n.replace(/\\0\\0/g,"%"),me=jr(n),me.length>t?0:(Yr(me,e),me.length-1)}M.Va();var zr=[null,Ke,Ue,m,T,U,se,et,tt,d,B,G,Te,rt,Ut,Lt,Bt,Nt,Ht,Yt,zt,$t,qt,Vt,Jt],$r={b:function(e,t,n){throw e>>>=0,new r(e).Va(t>>>0,n>>>0),i=e,u++,i},N:function(e){er(e>>>0,!I,1,!K,131072,!1),M.Ya()},j:function(e){e>>>=0,v?postMessage({cmd:"cleanupThread",thread:e}):it(e)},I:O,h:T,T:U,D:se,F:et,U:tt,R:d,J:B,Q:G,n:Te,E:rt,B:Ut,S:Lt,C:Bt,q:()=>!0,z:function(e,t){e>>>=0,e==t>>>0?setTimeout(()=>ut()):v?postMessage({targetThread:e,cmd:"checkMailbox"}):(e=M.La[e])&&e.postMessage({cmd:"checkMailbox"})},L:function(){return-1},M:pt,p:function(e){L&&M.La[e>>>0].ref()},t:function(e,t,n){e=t+2097152>>>0<4194305-!!e?(e>>>0)+4294967296*t:NaN,n>>>=0,e=new Date(1e3*e),f()[n>>2>>>0]=e.getUTCSeconds(),f()[n+4>>2>>>0]=e.getUTCMinutes(),f()[n+8>>2>>>0]=e.getUTCHours(),f()[n+12>>2>>>0]=e.getUTCDate(),f()[n+16>>2>>>0]=e.getUTCMonth(),f()[n+20>>2>>>0]=e.getUTCFullYear()-1900,f()[n+24>>2>>>0]=e.getUTCDay(),e=(e.getTime()-Date.UTC(e.getUTCFullYear(),0,1,0,0,0,0))/864e5|0,f()[n+28>>2>>>0]=e},u:function(e,t,n){e=t+2097152>>>0<4194305-!!e?(e>>>0)+4294967296*t:NaN,n>>>=0,e=new Date(1e3*e),f()[n>>2>>>0]=e.getSeconds(),f()[n+4>>2>>>0]=e.getMinutes(),f()[n+8>>2>>>0]=e.getHours(),f()[n+12>>2>>>0]=e.getDate(),f()[n+16>>2>>>0]=e.getMonth(),f()[n+20>>2>>>0]=e.getFullYear()-1900,f()[n+24>>2>>>0]=e.getDay(),t=(Ye(e.getFullYear())?kt:Wt)[e.getMonth()]+e.getDate()-1|0,f()[n+28>>2>>>0]=t,f()[n+36>>2>>>0]=-(60*e.getTimezoneOffset()),t=new Date(e.getFullYear(),6,1).getTimezoneOffset();var l=new Date(e.getFullYear(),0,1).getTimezoneOffset();e=(t!=l&&e.getTimezoneOffset()==Math.min(l,t))|0,f()[n+32>>2>>>0]=e},v:function(e){e>>>=0;var t=new Date(f()[e+20>>2>>>0]+1900,f()[e+16>>2>>>0],f()[e+12>>2>>>0],f()[e+8>>2>>>0],f()[e+4>>2>>>0],f()[e>>2>>>0],0),n=f()[e+32>>2>>>0],l=t.getTimezoneOffset(),b=new Date(t.getFullYear(),6,1).getTimezoneOffset(),y=new Date(t.getFullYear(),0,1).getTimezoneOffset(),_=Math.min(y,b);return 0>n?f()[e+32>>2>>>0]=+(b!=y&&_==l):0>2>>>0]=t.getDay(),n=(Ye(t.getFullYear())?kt:Wt)[t.getMonth()]+t.getDate()-1|0,f()[e+28>>2>>>0]=n,f()[e>>2>>>0]=t.getSeconds(),f()[e+4>>2>>>0]=t.getMinutes(),f()[e+8>>2>>>0]=t.getHours(),f()[e+12>>2>>>0]=t.getDate(),f()[e+16>>2>>>0]=t.getMonth(),f()[e+20>>2>>>0]=t.getYear(),e=t.getTime()/1e3,nr((Fe=e,1<=+Math.abs(Fe)?0>>0:~~+Math.ceil((Fe-+(~~Fe>>>0))/4294967296)>>>0:0)),e>>>0},r:Nt,s:Ht,y:function(e,t,n){function l(ne){return(ne=ne.toTimeString().match(/\\(([A-Za-z ]+)\\)$/))?ne[1]:"GMT"}e>>>=0,t>>>=0,n>>>=0;var b=new Date().getFullYear(),y=new Date(b,0,1),_=new Date(b,6,1);b=y.getTimezoneOffset();var X=_.getTimezoneOffset(),Me=Math.max(b,X);w()[e>>2>>>0]=60*Me,f()[t>>2>>>0]=+(b!=X),e=l(y),t=l(_),e=Gt(e),t=Gt(t),X>2>>>0]=e,w()[n+4>>2>>>0]=t):(w()[n>>2>>>0]=t,w()[n+4>>2>>>0]=e)},c:()=>{we("")},k:function(){},i:function(){return Date.now()},o:()=>{throw Re+=1,"unwind"},A:function(){return 4294901760},e:()=>performance.timeOrigin+performance.now(),f:function(){return L?(hr(),ot(gr)).cpus().length:navigator.hardwareConcurrency},K:function(e,t,n,l){for(M.vb=t>>>0,mt.length=n,t=l>>>0>>3,l=0;l>>0];return zr[e].apply(null,mt)},x:function(e){e>>>=0;var t=h().length;if(e<=t||4294901760=n;n*=2){var l=t*(1+.2/n);l=Math.min(l,e+100663296);var b=Math;l=Math.max(e,l);e:{b=b.min.call(b,4294901760,l+(65536-l%65536)%65536)-V.buffer.byteLength+65535>>>16;try{V.grow(b),pe();var y=1;break e}catch{}y=void 0}if(y)return!0}return!1},O:Yt,P:zt,H:Ge,g:$t,m:qt,w:Vt,l:Jt,a:V||a.wasmMemory,G:Qt,d:function(e,t,n,l){return Qt(e>>>0,t>>>0,n>>>0,l>>>0)}};(function(){function e(n,l){return n=n.exports,S=n=qr(n),M.Za.push(S.ya),Pe=S.za,ge.unshift(S.V),F=l,We(),n}var t={a:$r};if(De(),a.instantiateWasm)try{return a.instantiateWasm(t,e)}catch(n){ae("Module.instantiateWasm callback failed with error: "+n),x(n)}return Xe(t,function(n){e(n.instance,n.module)}).catch(x),{}})(),a._OrtInit=(e,t)=>(a._OrtInit=S.W)(e,t),a._OrtGetLastError=(e,t)=>(a._OrtGetLastError=S.X)(e,t),a._OrtCreateSessionOptions=(e,t,n,l,b,y,_,X,Me,ne)=>(a._OrtCreateSessionOptions=S.Y)(e,t,n,l,b,y,_,X,Me,ne),a._OrtAppendExecutionProvider=(e,t)=>(a._OrtAppendExecutionProvider=S.Z)(e,t),a._OrtAddFreeDimensionOverride=(e,t,n)=>(a._OrtAddFreeDimensionOverride=S._)(e,t,n),a._OrtAddSessionConfigEntry=(e,t,n)=>(a._OrtAddSessionConfigEntry=S.$)(e,t,n),a._OrtReleaseSessionOptions=e=>(a._OrtReleaseSessionOptions=S.aa)(e),a._OrtCreateSession=(e,t,n)=>(a._OrtCreateSession=S.ba)(e,t,n),a._OrtReleaseSession=e=>(a._OrtReleaseSession=S.ca)(e),a._OrtGetInputOutputCount=(e,t,n)=>(a._OrtGetInputOutputCount=S.da)(e,t,n),a._OrtGetInputName=(e,t)=>(a._OrtGetInputName=S.ea)(e,t),a._OrtGetOutputName=(e,t)=>(a._OrtGetOutputName=S.fa)(e,t),a._OrtFree=e=>(a._OrtFree=S.ga)(e),a._OrtCreateTensor=(e,t,n,l,b,y)=>(a._OrtCreateTensor=S.ha)(e,t,n,l,b,y),a._OrtGetTensorData=(e,t,n,l,b)=>(a._OrtGetTensorData=S.ia)(e,t,n,l,b),a._OrtReleaseTensor=e=>(a._OrtReleaseTensor=S.ja)(e),a._OrtCreateRunOptions=(e,t,n,l)=>(a._OrtCreateRunOptions=S.ka)(e,t,n,l),a._OrtAddRunConfigEntry=(e,t,n)=>(a._OrtAddRunConfigEntry=S.la)(e,t,n),a._OrtReleaseRunOptions=e=>(a._OrtReleaseRunOptions=S.ma)(e),a._OrtCreateBinding=e=>(a._OrtCreateBinding=S.na)(e),a._OrtBindInput=(e,t,n)=>(a._OrtBindInput=S.oa)(e,t,n),a._OrtBindOutput=(e,t,n,l)=>(a._OrtBindOutput=S.pa)(e,t,n,l),a._OrtClearBoundOutputs=e=>(a._OrtClearBoundOutputs=S.qa)(e),a._OrtReleaseBinding=e=>(a._OrtReleaseBinding=S.ra)(e),a._OrtRunWithBinding=(e,t,n,l,b)=>(a._OrtRunWithBinding=S.sa)(e,t,n,l,b),a._OrtRun=(e,t,n,l,b,y,_,X)=>(a._OrtRun=S.ta)(e,t,n,l,b,y,_,X),a._OrtEndProfiling=e=>(a._OrtEndProfiling=S.ua)(e);var ft=a._pthread_self=()=>(ft=a._pthread_self=S.va)(),Kt=a._malloc=e=>(Kt=a._malloc=S.wa)(e);a._free=e=>(a._free=S.xa)(e),a.__emscripten_tls_init=()=>(a.__emscripten_tls_init=S.ya)();var er=a.__emscripten_thread_init=(e,t,n,l,b,y)=>(er=a.__emscripten_thread_init=S.Aa)(e,t,n,l,b,y);a.__emscripten_thread_crashed=()=>(a.__emscripten_thread_crashed=S.Ba)();var tr=(e,t,n,l)=>(tr=S.Ca)(e,t,n,l),yt=e=>(yt=S.Da)(e),bt=a.__emscripten_thread_exit=e=>(bt=a.__emscripten_thread_exit=S.Ea)(e),rr=a.__emscripten_check_mailbox=()=>(rr=a.__emscripten_check_mailbox=S.Fa)(),nr=e=>(nr=S.Ga)(e),or=(e,t)=>(or=S.Ha)(e,t),wt=()=>(wt=S.Ia)(),lt=e=>(lt=S.Ja)(e),Ot=e=>(Ot=S.Ka)(e);function qr(e){e=Object.assign({},e);var t=l=>()=>l()>>>0,n=l=>b=>l(b)>>>0;return e.__errno_location=t(e.__errno_location),e.pthread_self=t(e.pthread_self),e.malloc=n(e.malloc),e.stackSave=t(e.stackSave),e.stackAlloc=n(e.stackAlloc),e}a.keepRuntimeAlive=ee,a.wasmMemory=V,a.stackAlloc=Ot,a.stackSave=wt,a.stackRestore=lt,a.UTF8ToString=He,a.stringToUTF8=ie,a.lengthBytesUTF8=re,a.ExitStatus=Ie,a.PThread=M;var ct;be=function e(){ct||ar(),ct||(be=e)};function ar(){function e(){if(!ct&&(ct=!0,a.calledRun=!0,!de)&&(v||je(ge),E(a),a.onRuntimeInitialized&&a.onRuntimeInitialized(),!v)){if(a.postRun)for(typeof a.postRun=="function"&&(a.postRun=[a.postRun]);a.postRun.length;){var t=a.postRun.shift();Ae.unshift(t)}je(Ae)}}if(!(0yr)});var Or=nt((wn,rn)=>{rn.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");Object.assign(global,{self:global,require,Module,location:{href:__filename},Worker:nodeWorkerThreads.Worker,importScripts:e=>(0,eval)(fs.readFileSync(e,"utf8")+"//# sourceURL="+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&&Module.__emscripten_thread_crashed(),a}}self.onmessage=handleMessage;\\n\'});var _r;_r=dr();var nn=wr(),Dt,Ft=!1,dt=!1,vr=!1,on=s=>{if(s===1)return!1;if(typeof SharedArrayBuffer>"u")return typeof self<"u"&&!self.crossOriginIsolated&&console.warn("env.wasm.numThreads is set to "+s+", 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 "+s+", 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}},an=()=>{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}},sn=(s,c)=>s?c?"ort-wasm-simd-threaded.wasm":"ort-wasm-simd.wasm":c?"ort-wasm-threaded.wasm":"ort-wasm.wasm",Er=async s=>{if(Ft)return Promise.resolve();if(dt)throw new Error("multiple calls to \'initializeWebAssembly()\' detected.");if(vr)throw new Error("previous call to \'initializeWebAssembly()\' failed.");dt=!0;let c=s.initTimeout,o=s.numThreads,h=s.simd,f=on(o),w=h&&an(),g=s.wasmPaths,a=typeof g=="string"?g:void 0,E=sn(w,f),x=typeof g=="object"?g[E]:void 0,P=!1,R=[];if(c>0&&R.push(new Promise(D=>{setTimeout(()=>{P=!0,D()},c)})),R.push(new Promise((D,K)=>{let I=f?nn:_r,L={locateFile:(v,k)=>f&&v.endsWith(".worker.js")&&typeof Blob<"u"?URL.createObjectURL(new Blob([Or()],{type:"text/javascript"})):v.endsWith(".wasm")?x||(a??k)+E:k+v};if(f)if(L.numThreads=o,typeof Blob>"u")L.mainScriptUrlOrBlob=(void 0)(__dirname,"ort-wasm-threaded.js");else{let v=`var ortWasmThreaded=${I.toString()};`;L.mainScriptUrlOrBlob=new Blob([v],{type:"text/javascript"})}I(L).then(v=>{dt=!1,Ft=!0,Dt=v,D()},v=>{dt=!1,vr=!0,K(v)})})),await Promise.race(R),P)throw new Error(`WebAssembly backend initializing failed due to timeout: ${c}ms`)},Q=()=>{if(Ft&&Dt)return Dt;throw new Error("WebAssembly is not initialized yet.")};var $=(s,c)=>{let o=Q(),h=o.lengthBytesUTF8(s)+1,f=o._malloc(h);return o.stringToUTF8(s,f,h),c.push(f),f},at=(s,c,o,h)=>{if(typeof s=="object"&&s!==null){if(o.has(s))throw new Error("Circular reference in options");o.add(s)}Object.entries(s).forEach(([f,w])=>{let g=c?c+f:f;if(typeof w=="object")at(w,g+".",o,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}`)})},q=s=>{let c=Q(),o=c.stackSave();try{let h=c.stackAlloc(8);c._OrtGetLastError(h,h+4);let f=c.HEAP32[h/4],w=c.HEAPU32[h/4+1],g=w?c.UTF8ToString(w):"";throw new Error(`${s} ERROR_CODE: ${f}, ERROR_MESSAGE: ${g}`)}finally{c.stackRestore(o)}};var Sr=s=>{let c=Q(),o=0,h=[],f=s||{};try{if(s?.logSeverityLevel===void 0)f.logSeverityLevel=2;else if(typeof s.logSeverityLevel!="number"||!Number.isInteger(s.logSeverityLevel)||s.logSeverityLevel<0||s.logSeverityLevel>4)throw new Error(`log serverity level is not valid: ${s.logSeverityLevel}`);if(s?.logVerbosityLevel===void 0)f.logVerbosityLevel=0;else if(typeof s.logVerbosityLevel!="number"||!Number.isInteger(s.logVerbosityLevel))throw new Error(`log verbosity level is not valid: ${s.logVerbosityLevel}`);s?.terminate===void 0&&(f.terminate=!1);let w=0;return s?.tag!==void 0&&(w=$(s.tag,h)),o=c._OrtCreateRunOptions(f.logSeverityLevel,f.logVerbosityLevel,!!f.terminate,w),o===0&&q("Can\'t create run options."),s?.extra!==void 0&&at(s.extra,"",new WeakSet,(g,a)=>{let E=$(g,h),x=$(a,h);c._OrtAddRunConfigEntry(o,E,x)!==0&&q(`Can\'t set a run config entry: ${g} - ${a}.`)}),[o,h]}catch(w){throw o!==0&&c._OrtReleaseRunOptions(o),h.forEach(g=>c._free(g)),w}};var un=s=>{switch(s){case"disabled":return 0;case"basic":return 1;case"extended":return 2;case"all":return 99;default:throw new Error(`unsupported graph optimization level: ${s}`)}},fn=s=>{switch(s){case"sequential":return 0;case"parallel":return 1;default:throw new Error(`unsupported execution mode: ${s}`)}},ln=s=>{s.extra||(s.extra={}),s.extra.session||(s.extra.session={});let c=s.extra.session;c.use_ort_model_bytes_directly||(c.use_ort_model_bytes_directly="1"),s.executionProviders&&s.executionProviders.some(o=>(typeof o=="string"?o:o.name)==="webgpu")&&(s.enableMemPattern=!1)},cn=(s,c,o)=>{for(let h of c){let f=typeof h=="string"?h:h.name;switch(f){case"webnn":if(f="WEBNN",typeof h!="string"){let g=h;if(g?.deviceType){let a=$("deviceType",o),E=$(g.deviceType,o);Q()._OrtAddSessionConfigEntry(s,a,E)!==0&&q(`Can\'t set a session config entry: \'deviceType\' - ${g.deviceType}.`)}if(g?.numThreads){let a=g.numThreads;(typeof a!="number"||!Number.isInteger(a)||a<0)&&(a=0);let E=$("numThreads",o),x=$(a.toString(),o);Q()._OrtAddSessionConfigEntry(s,E,x)!==0&&q(`Can\'t set a session config entry: \'numThreads\' - ${g.numThreads}.`)}if(g?.powerPreference){let a=$("powerPreference",o),E=$(g.powerPreference,o);Q()._OrtAddSessionConfigEntry(s,a,E)!==0&&q(`Can\'t set a session config entry: \'powerPreference\' - ${g.powerPreference}.`)}}break;case"webgpu":if(f="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 a=$("preferredLayout",o),E=$(g.preferredLayout,o);Q()._OrtAddSessionConfigEntry(s,a,E)!==0&&q(`Can\'t set a session config entry: \'preferredLayout\' - ${g.preferredLayout}.`)}}break;case"wasm":case"cpu":continue;default:throw new Error(`not supported execution provider: ${f}`)}let w=$(f,o);Q()._OrtAppendExecutionProvider(s,w)!==0&&q(`Can\'t append execution provider: ${f}.`)}},Ar=s=>{let c=Q(),o=0,h=[],f=s||{};ln(f);try{let w=un(f.graphOptimizationLevel??"all"),g=fn(f.executionMode??"sequential"),a=typeof f.logId=="string"?$(f.logId,h):0,E=f.logSeverityLevel??2;if(!Number.isInteger(E)||E<0||E>4)throw new Error(`log serverity level is not valid: ${E}`);let x=f.logVerbosityLevel??0;if(!Number.isInteger(x)||x<0||x>4)throw new Error(`log verbosity level is not valid: ${x}`);let P=typeof f.optimizedModelFilePath=="string"?$(f.optimizedModelFilePath,h):0;if(o=c._OrtCreateSessionOptions(w,!!f.enableCpuMemArena,!!f.enableMemPattern,g,!!f.enableProfiling,0,a,E,x,P),o===0&&q("Can\'t create session options."),f.executionProviders&&cn(o,f.executionProviders,h),f.enableGraphCapture!==void 0){if(typeof f.enableGraphCapture!="boolean")throw new Error(`enableGraphCapture must be a boolean value: ${f.enableGraphCapture}`);let R=$("enableGraphCapture",h),D=$(f.enableGraphCapture.toString(),h);c._OrtAddSessionConfigEntry(o,R,D)!==0&&q(`Can\'t set a session config entry: \'enableGraphCapture\' - ${f.enableGraphCapture}.`)}if(f.freeDimensionOverrides)for(let[R,D]of Object.entries(f.freeDimensionOverrides)){if(typeof R!="string")throw new Error(`free dimension override name must be a string: ${R}`);if(typeof D!="number"||!Number.isInteger(D)||D<0)throw new Error(`free dimension override value must be a non-negative integer: ${D}`);let K=$(R,h);c._OrtAddFreeDimensionOverride(o,K,D)!==0&&q(`Can\'t set a free dimension override: ${R} - ${D}.`)}return f.extra!==void 0&&at(f.extra,"",new WeakSet,(R,D)=>{let K=$(R,h),I=$(D,h);c._OrtAddSessionConfigEntry(o,K,I)!==0&&q(`Can\'t set a session config entry: ${R} - ${D}.`)}),[o,h]}catch(w){throw o!==0&&c._OrtReleaseSessionOptions(o),h.forEach(g=>c._free(g)),w}};var xt=s=>{switch(s){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: ${s}`)}},Tr=s=>{switch(s){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: ${s}`)}},Pt=s=>[void 0,4,1,1,2,2,4,8,void 0,1,2,8,4,8,void 0,void 0,void 0][s],Mr=s=>{switch(s){case"float16":return typeof Float16Array<"u"&&Float16Array.from?Float16Array: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: ${s}`)}},Cr=s=>{switch(s){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: ${s}`)}},Rr=s=>s==="float32"||s==="float16"||s==="int32"||s==="int64"||s==="uint32"||s==="uint8"||s==="bool",Dr=s=>{switch(s){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: ${s}`)}};var Fr=async s=>{if(typeof s=="string")if(typeof process<"u"&&process.versions&&process.versions.node)try{return new Uint8Array(await(void 0)(s))}catch(c){if(c.code==="ERR_FS_FILE_TOO_LARGE"){let o=(void 0)(s),h=[];for await(let f of o)h.push(f);return new Uint8Array(Buffer.concat(h))}throw c}else{let c=await fetch(s);if(!c.ok)throw new Error(`failed to load external data file: ${s}`);let o=c.headers.get("Content-Length"),h=o?parseInt(o,10):0;if(h<1073741824)return new Uint8Array(await c.arrayBuffer());{if(!c.body)throw new Error(`failed to load external data file: ${s}, no response body.`);let f=c.body.getReader(),w;try{w=new ArrayBuffer(h)}catch(a){if(a instanceof RangeError){let E=Math.ceil(h/65536);w=new WebAssembly.Memory({initial:E,maximum:E}).buffer}else throw a}let g=0;for(;;){let{done:a,value:E}=await f.read();if(a)break;let x=E.byteLength;new Uint8Array(w,g,x).set(E),g+=x}return new Uint8Array(w,0,h)}}else return s instanceof Blob?new Uint8Array(await s.arrayBuffer()):s instanceof Uint8Array?s:new Uint8Array(s)};var dn=(s,c)=>{Q()._OrtInit(s,c)!==0&&q("Can\'t initialize onnxruntime.")},Pr=async s=>{dn(s.wasm.numThreads,Cr(s.logLevel))},Ir=async(s,c)=>{},ze=new Map,pn=s=>{let c=Q(),o=c.stackSave();try{let h=c.stackAlloc(8);return c._OrtGetInputOutputCount(s,h,h+4)!==0&&q("Can\'t get session input/output count."),[c.HEAP32[h/4],c.HEAP32[h/4+1]]}finally{c.stackRestore(o)}},It=s=>{let c=Q(),o=c._malloc(s.byteLength);if(o===0)throw new Error(`Can\'t create a session. failed to allocate a buffer of size ${s.byteLength}.`);return c.HEAPU8.set(s,o),[o,s.byteLength]},Ur=async(s,c)=>{let o,h,f=Q();Array.isArray(s)?[o,h]=s:s.buffer===f.HEAPU8.buffer?[o,h]=[s.byteOffset,s.byteLength]:[o,h]=It(s);let w=0,g=0,a=0,E=[],x=[],P=[];try{if([g,E]=Ar(c),c?.externalData&&f.mountExternalData){let W=[];for(let j of c.externalData){let oe=typeof j=="string"?j:j.path;W.push(Fr(typeof j=="string"?j:j.data).then(C=>{f.mountExternalData(oe,C)}))}await Promise.all(W)}w=await f._OrtCreateSession(o,h,g),w===0&&q("Can\'t create a session.");let[R,D]=pn(w),K=!!c?.enableGraphCapture,I=[],L=[],v=[];for(let W=0;Wf._OrtFree(D)),P.forEach(D=>f._OrtFree(D)),a!==0&&f._OrtReleaseBinding(a),w!==0&&f._OrtReleaseSession(w),R}finally{f._free(o),g!==0&&f._OrtReleaseSessionOptions(g),E.forEach(R=>f._free(R)),f.unmountExternalData?.()}},Lr=s=>{let c=Q(),o=ze.get(s);if(!o)throw new Error(`cannot release session. invalid session id: ${s}`);let[h,f,w,g,a]=o;g&&(a&&c._OrtClearBoundOutputs(g.handle),c._OrtReleaseBinding(g.handle)),c.jsepOnReleaseSession?.(s),f.forEach(E=>c._OrtFree(E)),w.forEach(E=>c._OrtFree(E)),c._OrtReleaseSession(h),ze.delete(s)},xr=(s,c,o,h,f,w=!1)=>{if(!s){c.push(0);return}let g=Q(),a=s[0],E=s[1],x=s[3],P,R;if(a==="string"&&x==="gpu-buffer")throw new Error("String tensor is not supported on GPU.");if(w&&x!=="gpu-buffer")throw new Error(`External buffer must be provided for input/output index ${f} when enableGraphCapture is true.`);if(x==="gpu-buffer"){let I=s[2].gpuBuffer,L=Pt(xt(a));R=E.reduce((k,W)=>k*W,1)*L;let v=g.jsepRegisterBuffer;if(!v)throw new Error(\'Tensor location "gpu-buffer" is not supported without using WebGPU.\');P=v(h,f,I,R)}else{let I=s[2];if(Array.isArray(I)){R=4*I.length,P=g._malloc(R),o.push(P);let L=P/4;for(let v=0;vg.HEAP32[I++]=v);let L=g._OrtCreateTensor(xt(a),P,R,K,E.length,Dr(x));L===0&&q(`Can\'t create tensor for input/output. session=${h}, index=${f}.`),c.push(L)}finally{g.stackRestore(D)}},Br=async(s,c,o,h,f,w)=>{let g=Q(),a=ze.get(s);if(!a)throw new Error(`cannot run inference. invalid session id: ${s}`);let E=a[0],x=a[1],P=a[2],R=a[3],D=a[4],K=a[5],I=c.length,L=h.length,v=0,k=[],W=[],j=[],oe=[],C=g.stackSave(),ve=g.stackAlloc(I*4),Oe=g.stackAlloc(I*4),ce=g.stackAlloc(L*4),A=g.stackAlloc(L*4);try{[v,k]=Sr(w);for(let F=0;Fee*Y,1);J=Tr(Se);let Re=R?.outputPreferredLocations[h[F]];if(J==="string"){if(Re==="gpu-buffer")throw new Error("String tensor is not supported on GPU.");let ee=[],Y=fe/4;for(let he=0;he0){let ee=g.jsepGetBuffer;if(!ee)throw new Error(\'preferredLocation "gpu-buffer" is not supported without using WebGPU.\');let Y=ee(fe),he=Pt(Se);if(he===void 0||!Rr(J))throw new Error(`Unsupported data type: ${J}`);Ee=!0,S.push([J,ge,{gpuBuffer:Y,download:g.jsepCreateDownloader(Y,Ae*he,J),dispose:()=>{g._OrtReleaseTensor(de)}},"gpu-buffer"])}else{let ee=Mr(J),Y=new ee(Ae);new Uint8Array(Y.buffer,Y.byteOffset,Y.byteLength).set(g.HEAPU8.subarray(fe,fe+Y.byteLength)),S.push([J,ge,Y,"cpu"])}}finally{g.stackRestore(ue),J==="string"&&fe&&g._free(fe),Ee||g._OrtReleaseTensor(de)}}return R&&!D&&(g._OrtClearBoundOutputs(R.handle),ze.set(s,[E,x,P,R,D,!1])),S}finally{g.stackRestore(C),W.forEach(N=>g._OrtReleaseTensor(N)),j.forEach(N=>g._OrtReleaseTensor(N)),oe.forEach(N=>g._free(N)),v!==0&&g._OrtReleaseRunOptions(v),k.forEach(N=>g._free(N))}},kr=s=>{let c=Q(),o=ze.get(s);if(!o)throw new Error("invalid session id");let h=o[0],f=c._OrtEndProfiling(h);f===0&&q("Can\'t get an profile file name."),c._OrtFree(f)},Wr=s=>{let c=[];for(let o of s){let h=o[2];!Array.isArray(h)&&"buffer"in h&&c.push(h.buffer)}return c};self.onmessage=s=>{let{type:c,in:o}=s.data;try{switch(c){case"init-wasm":Er(o.wasm).then(()=>{Pr(o).then(()=>{postMessage({type:c})},h=>{postMessage({type:c,err:h})})},h=>{postMessage({type:c,err:h})});break;case"init-ep":{let{epName:h,env:f}=o;Ir(f,h).then(()=>{postMessage({type:c})},w=>{postMessage({type:c,err:w})});break}case"copy-from":{let{buffer:h}=o,f=It(h);postMessage({type:c,out:f});break}case"create":{let{model:h,options:f}=o;Ur(h,f).then(w=>{postMessage({type:c,out:w})},w=>{postMessage({type:c,err:w})});break}case"release":Lr(o),postMessage({type:c});break;case"run":{let{sessionId:h,inputIndices:f,inputs:w,outputIndices:g,options:a}=o;Br(h,f,w,g,new Array(g.length).fill(null),a).then(E=>{E.some(x=>x[3]!=="cpu")?postMessage({type:c,err:"Proxy does not support non-cpu tensor location."}):postMessage({type:c,out:E},Wr([...w,...E]))},E=>{postMessage({type:c,err:E})});break}case"end-profiling":kr(o),postMessage({type:c});break;default:}}catch(h){postMessage({type:c,err:h})}};})();\n'});var Tr,yt,vn,Lo,Fo,ca,pa,Wr,Hr,xg,Do,nd,od,id,ad,sd,ud,ld,da=P(()=>{"use strict";Tt();td();zr();Tr=()=>!!Z.wasm.proxy&&typeof document<"u",vn=!1,Lo=!1,Fo=!1,pa=new Map,Wr=(a,t)=>{let o=pa.get(a);o?o.push(t):pa.set(a,[t])},Hr=()=>{if(vn||!Lo||Fo||!yt)throw new Error("worker not ready")},xg=a=>{switch(a.data.type){case"init-wasm":vn=!1,a.data.err?(Fo=!0,ca[1](a.data.err)):(Lo=!0,ca[0]());break;case"init-ep":case"copy-from":case"create":case"release":case"run":case"end-profiling":{let t=pa.get(a.data.type);a.data.err?t.shift()[1](a.data.err):t.shift()[0](a.data.out);break}default:}},Do=typeof document<"u"?document?.currentScript?.src:void 0,nd=async()=>{if(!Lo){if(vn)throw new Error("multiple calls to 'initWasm()' detected.");if(Fo)throw new Error("previous call to 'initWasm()' failed.");if(vn=!0,Tr())return Z.wasm.wasmPaths===void 0&&Do&&Do.indexOf("blob:")!==0&&(Z.wasm.wasmPaths=Do.substr(0,+Do.lastIndexOf("/")+1)),new Promise((a,t)=>{yt?.terminate();let o=URL.createObjectURL(new Blob([rd()],{type:"text/javascript"}));yt=new Worker(o,{name:"ort-wasm-proxy-worker"}),yt.onerror=r=>t(r),yt.onmessage=xg,URL.revokeObjectURL(o),ca=[a,t];let e={type:"init-wasm",in:Z};yt.postMessage(e)});try{await Rp(Z.wasm),await Yp(Z),Lo=!0}catch(a){throw Fo=!0,a}finally{vn=!1}}},od=async a=>{if(Tr())return Hr(),new Promise((t,o)=>{Wr("init-ep",[t,o]);let e={type:"init-ep",in:{epName:a,env:Z}};yt.postMessage(e)});await Xp(Z,a)},id=async a=>Tr()?(Hr(),new Promise((t,o)=>{Wr("copy-from",[t,o]);let e={type:"copy-from",in:{buffer:a}};yt.postMessage(e,[a.buffer])})):fa(a),ad=async(a,t)=>{if(Tr()){if(t?.preferredOutputLocation)throw new Error('session option "preferredOutputLocation" is not supported for proxy.');return Hr(),new Promise((o,e)=>{Wr("create",[o,e]);let r={type:"create",in:{model:a,options:{...t}}},n=[];a instanceof Uint8Array&&n.push(a.buffer),yt.postMessage(r,n)})}else return Kp(a,t)},sd=async a=>{if(Tr())return Hr(),new Promise((t,o)=>{Wr("release",[t,o]);let e={type:"release",in:a};yt.postMessage(e)});Jp(a)},ud=async(a,t,o,e,r,n)=>{if(Tr()){if(o.some(s=>s[3]!=="cpu"))throw new Error("input tensor on GPU is not supported for proxy.");if(r.some(s=>s))throw new Error("pre-allocated output tensor is not supported for proxy.");return Hr(),new Promise((s,i)=>{Wr("run",[s,i]);let u=o,l={type:"run",in:{sessionId:a,inputIndices:t,inputs:u,outputIndices:e,options:n}};yt.postMessage(l,ed(u))})}else return Zp(a,t,o,e,r,n)},ld=async a=>{if(Tr())return Hr(),new Promise((t,o)=>{Wr("end-profiling",[t,o]);let e={type:"end-profiling",in:a};yt.postMessage(e)});Qp(a)}});var fd,wg,Co,cd=P(()=>{"use strict";Tt();da();ua();la();fd=(a,t)=>{switch(a.location){case"cpu":return[a.type,a.dims,a.data,"cpu"];case"gpu-buffer":return[a.type,a.dims,{gpuBuffer:a.gpuBuffer},"gpu-buffer"];default:throw new Error(`invalid data location: ${a.location} for ${t()}`)}},wg=a=>{switch(a[3]){case"cpu":return new Me(a[0],a[2],a[1]);case"gpu-buffer":{let t=a[0];if(!Po(t))throw new Error(`not supported data type: ${t} for deserializing GPU tensor`);let{gpuBuffer:o,download:e,dispose:r}=a[2];return Me.fromGpuBuffer(o,{dataType:t,dims:a[1],download:e,dispose:r})}default:throw new Error(`invalid data location: ${a[3]}`)}},Co=class{async fetchModelAndCopyToWasmMemory(t){return id(await wn(t))}async loadModel(t,o){ir();let e;typeof t=="string"?typeof process<"u"&&process.versions&&process.versions.node?e=await wn(t):e=await this.fetchModelAndCopyToWasmMemory(t):e=t,[this.sessionId,this.inputNames,this.outputNames]=await ad(e,o),ar()}async dispose(){return sd(this.sessionId)}async run(t,o,e){ir();let r=[],n=[];Object.entries(t).forEach(d=>{let T=d[0],v=d[1],w=this.inputNames.indexOf(T);if(w===-1)throw new Error(`invalid input '${T}'`);r.push(v),n.push(w)});let s=[],i=[];Object.entries(o).forEach(d=>{let T=d[0],v=d[1],w=this.outputNames.indexOf(T);if(w===-1)throw new Error(`invalid output '${T}'`);s.push(v),i.push(w)});let u=r.map((d,T)=>fd(d,()=>`input "${this.inputNames[n[T]]}"`)),l=s.map((d,T)=>d?fd(d,()=>`output "${this.outputNames[i[T]]}"`):null),f=await ud(this.sessionId,n,u,i,l,e),p={};for(let d=0;d{"use strict";Tt();da();cd();vg=()=>{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 a=typeof navigator>"u"?(void 0)().length:navigator.hardwareConcurrency;Z.wasm.numThreads=Math.min(4,Math.ceil((a||1)/2))}},ko=class{async init(t){vg(),await nd(),await od(t)}async createInferenceSessionHandler(t,o){let e=new Co;return await e.loadModel(t,o),Promise.resolve(e)}}});var dd={};Ar(dd,{wasmBackend:()=>_g});var _g,hd=P(()=>{"use strict";pd();_g=new ko});Tt();Tt();Tt();var ys="1.18.0";var YO=qo;{let a=(_p(),rr(vp)).onnxjsBackend;Pr("webgl",a,-10)}{let a=(hd(),rr(dd)).wasmBackend;Pr("cpu",a,10),Pr("wasm",a,10)}Object.defineProperty(Z.versions,"web",{value:ys,enumerable:!0});export{Pd as InferenceSession,us as TRACE,ir as TRACE_FUNC_BEGIN,ar as TRACE_FUNC_END,Me as Tensor,Ld as TrainingSession,YO as default,Z as env,Pr as registerBackend}; +/*! 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 + *) +*/ +//# sourceMappingURL=ort.min.js.map