@mocklane/core 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,41 @@
1
+ var C0=Object.defineProperty;var xf=e=>{throw TypeError(e)};var S0=(e,t,r)=>t in e?C0(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r;var k=(e,t,r)=>S0(e,typeof t!="symbol"?t+"":t,r),kf=(e,t,r)=>t.has(e)||xf("Cannot "+r);var at=(e,t,r)=>(kf(e,t,"read from private field"),r?r.call(e):t.get(e)),qs=(e,t,r)=>t.has(e)?xf("Cannot add the same private member more than once"):t instanceof WeakSet?t.add(e):t.set(e,r),Ws=(e,t,r,n)=>(kf(e,t,"write to private field"),n?n.call(e,r):t.set(e,r),r);/*!
2
+ * ONNX Runtime Web v1.26.0-dev.20260416-b7804b056c
3
+ * Copyright (c) Microsoft Corporation. All rights reserved.
4
+ * Licensed under the MIT License.
5
+ */var kl=Object.defineProperty,P0=Object.getOwnPropertyDescriptor,F0=Object.getOwnPropertyNames,L0=Object.prototype.hasOwnProperty,I0=(e=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(e,{get:(t,r)=>(typeof require<"u"?require:t)[r]}):e)(function(e){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+e+'" is not supported')}),we=(e,t)=>()=>(e&&(t=e(e=0)),t),bs=(e,t)=>{for(var r in t)kl(e,r,{get:t[r],enumerable:!0})},O0=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of F0(t))!L0.call(e,s)&&s!==r&&kl(e,s,{get:()=>t[s],enumerable:!(n=P0(t,s))||n.enumerable});return e},Aa=e=>O0(kl({},"__esModule",{value:!0}),e),Un,br,Ur,Tf,sp,ap=we(()=>{Un=new Map,br=[],Ur=(e,t,r)=>{if(t&&typeof t.init=="function"&&typeof t.createInferenceSessionHandler=="function"){let n=Un.get(e);if(n===void 0)Un.set(e,{backend:t,priority:r});else{if(n.priority>r)return;if(n.priority===r&&n.backend!==t)throw new Error(`cannot register backend "${e}" using priority ${r}`)}if(r>=0){let s=br.indexOf(e);s!==-1&&br.splice(s,1);for(let a=0;a<br.length;a++)if(Un.get(br[a]).priority<=r){br.splice(a,0,e);return}br.push(e)}return}throw new TypeError("not a valid backend")},Tf=async e=>{let t=Un.get(e);if(!t)return"backend not found.";if(t.initialized)return t.backend;if(t.aborted)return t.error;{let r=!!t.initPromise;try{return r||(t.initPromise=t.backend.init(e)),await t.initPromise,t.initialized=!0,t.backend}catch(n){return r||(t.error=`${n}`,t.aborted=!0),t.error}finally{delete t.initPromise}}},sp=async e=>{let t=e.executionProviders||[],r=t.map(l=>typeof l=="string"?l:l.name),n=r.length===0?br:r,s,a=[],o=new Set;for(let l of n){let c=await Tf(l);typeof c=="string"?a.push({name:l,err:c}):(s||(s=c),s===c&&o.add(l))}if(!s)throw new Error(`no available backend found. ERR: ${a.map(l=>`[${l.name}] ${l.err}`).join(", ")}`);for(let{name:l,err:c}of a)r.includes(l)&&console.warn(`removing requested execution provider "${l}" from session options because it is not available: ${c}`);let i=t.filter(l=>o.has(typeof l=="string"?l:l.name));return[s,new Proxy(e,{get:(l,c)=>c==="executionProviders"?i:Reflect.get(l,c)})]}}),N0=we(()=>{ap()}),op,D0=we(()=>{op="1.24.0-dev.20251116-b39e144322"}),qo,Je,ip=we(()=>{D0(),qo="warning",Je={wasm:{},webgl:{},webgpu:{},versions:{common:op},set logLevel(e){if(e!==void 0){if(typeof e!="string"||["verbose","info","warning","error","fatal"].indexOf(e)===-1)throw new Error(`Unsupported logging level: ${e}`);qo=e}},get logLevel(){return qo}},Object.defineProperty(Je,"logLevel",{enumerable:!0})}),ze,z0=we(()=>{ip(),ze=Je}),lp,cp,B0=we(()=>{lp=(e,t)=>{let r=typeof document<"u"?document.createElement("canvas"):new OffscreenCanvas(1,1);r.width=e.dims[3],r.height=e.dims[2];let n=r.getContext("2d");if(n!=null){let s,a;(t==null?void 0:t.tensorLayout)!==void 0&&t.tensorLayout==="NHWC"?(s=e.dims[2],a=e.dims[3]):(s=e.dims[3],a=e.dims[2]);let o=(t==null?void 0:t.format)!==void 0?t.format:"RGB",i=t==null?void 0:t.norm,l,c;i===void 0||i.mean===void 0?l=[255,255,255,255]:typeof i.mean=="number"?l=[i.mean,i.mean,i.mean,i.mean]:(l=[i.mean[0],i.mean[1],i.mean[2],0],i.mean[3]!==void 0&&(l[3]=i.mean[3])),i===void 0||i.bias===void 0?c=[0,0,0,0]:typeof i.bias=="number"?c=[i.bias,i.bias,i.bias,i.bias]:(c=[i.bias[0],i.bias[1],i.bias[2],0],i.bias[3]!==void 0&&(c[3]=i.bias[3]));let d=a*s,h=0,_=d,p=d*2,w=-1;o==="RGBA"?(h=0,_=d,p=d*2,w=d*3):o==="RGB"?(h=0,_=d,p=d*2):o==="RBG"&&(h=0,p=d,_=d*2);for(let v=0;v<a;v++)for(let y=0;y<s;y++){let M=(e.data[h++]-c[0])*l[0],T=(e.data[_++]-c[1])*l[1],A=(e.data[p++]-c[2])*l[2],S=w===-1?255:(e.data[w++]-c[3])*l[3];n.fillStyle="rgba("+M+","+T+","+A+","+S+")",n.fillRect(y,v,1,1)}if("toDataURL"in r)return r.toDataURL();throw new Error("toDataURL is not supported")}else throw new Error("Can not access image data")},cp=(e,t)=>{let r=typeof document<"u"?document.createElement("canvas").getContext("2d"):new OffscreenCanvas(1,1).getContext("2d"),n;if(r!=null){let s,a,o;(t==null?void 0:t.tensorLayout)!==void 0&&t.tensorLayout==="NHWC"?(s=e.dims[2],a=e.dims[1],o=e.dims[3]):(s=e.dims[3],a=e.dims[2],o=e.dims[1]);let i=t!==void 0&&t.format!==void 0?t.format:"RGB",l=t==null?void 0:t.norm,c,d;l===void 0||l.mean===void 0?c=[255,255,255,255]:typeof l.mean=="number"?c=[l.mean,l.mean,l.mean,l.mean]:(c=[l.mean[0],l.mean[1],l.mean[2],255],l.mean[3]!==void 0&&(c[3]=l.mean[3])),l===void 0||l.bias===void 0?d=[0,0,0,0]:typeof l.bias=="number"?d=[l.bias,l.bias,l.bias,l.bias]:(d=[l.bias[0],l.bias[1],l.bias[2],0],l.bias[3]!==void 0&&(d[3]=l.bias[3]));let h=a*s;if(t!==void 0&&(t.format!==void 0&&o===4&&t.format!=="RGBA"||o===3&&t.format!=="RGB"&&t.format!=="BGR"))throw new Error("Tensor format doesn't match input tensor dims");let _=4,p=0,w=1,v=2,y=3,M=0,T=h,A=h*2,S=-1;i==="RGBA"?(M=0,T=h,A=h*2,S=h*3):i==="RGB"?(M=0,T=h,A=h*2):i==="RBG"&&(M=0,A=h,T=h*2),n=r.createImageData(s,a);for(let C=0;C<a*s;p+=_,w+=_,v+=_,y+=_,C++)n.data[p]=(e.data[M++]-d[0])*c[0],n.data[w]=(e.data[T++]-d[1])*c[1],n.data[v]=(e.data[A++]-d[2])*c[2],n.data[y]=S===-1?255:(e.data[S++]-d[3])*c[3]}else throw new Error("Can not access image data");return n}}),Hs,up,dp,hp,fp,_p,R0=we(()=>{Tl(),Hs=(e,t)=>{if(e===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:r,width:n}=t,s=t.norm??{mean:255,bias:0},a,o;typeof s.mean=="number"?a=[s.mean,s.mean,s.mean,s.mean]:a=[s.mean[0],s.mean[1],s.mean[2],s.mean[3]??255],typeof s.bias=="number"?o=[s.bias,s.bias,s.bias,s.bias]:o=[s.bias[0],s.bias[1],s.bias[2],s.bias[3]??0];let i=t.format!==void 0?t.format:"RGBA",l=t.tensorFormat!==void 0&&t.tensorFormat!==void 0?t.tensorFormat:"RGB",c=r*n,d=l==="RGBA"?new Float32Array(c*4):new Float32Array(c*3),h=4,_=0,p=1,w=2,v=3,y=0,M=c,T=c*2,A=-1;i==="RGB"&&(h=3,_=0,p=1,w=2,v=-1),l==="RGBA"?A=c*3:l==="RBG"?(y=0,T=c,M=c*2):l==="BGR"&&(T=0,M=c,y=c*2);for(let S=0;S<c;S++,_+=h,w+=h,p+=h,v+=h)d[y++]=(e[_]+o[0])/a[0],d[M++]=(e[p]+o[1])/a[1],d[T++]=(e[w]+o[2])/a[2],A!==-1&&v!==-1&&(d[A++]=(e[v]+o[3])/a[3]);return l==="RGBA"?new Mt("float32",d,[1,4,r,n]):new Mt("float32",d,[1,3,r,n])},up=async(e,t)=>{let r=typeof HTMLImageElement<"u"&&e instanceof HTMLImageElement,n=typeof ImageData<"u"&&e instanceof ImageData,s=typeof ImageBitmap<"u"&&e instanceof ImageBitmap,a=typeof e=="string",o,i=t??{},l=()=>{if(typeof document<"u")return document.createElement("canvas");if(typeof OffscreenCanvas<"u")return new OffscreenCanvas(1,1);throw new Error("Canvas is not supported")},c=d=>typeof HTMLCanvasElement<"u"&&d instanceof HTMLCanvasElement||d instanceof OffscreenCanvas?d.getContext("2d"):null;if(r){let d=l();d.width=e.width,d.height=e.height;let h=c(d);if(h!=null){let _=e.height,p=e.width;if(t!==void 0&&t.resizedHeight!==void 0&&t.resizedWidth!==void 0&&(_=t.resizedHeight,p=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=_,i.width=p}else i.tensorFormat="RGBA",i.height=_,i.width=p;h.drawImage(e,0,0),o=h.getImageData(0,0,p,_).data}else throw new Error("Can not access image data")}else if(n){let d,h;if(t!==void 0&&t.resizedWidth!==void 0&&t.resizedHeight!==void 0?(d=t.resizedHeight,h=t.resizedWidth):(d=e.height,h=e.width),t!==void 0&&(i=t),i.format="RGBA",i.height=d,i.width=h,t!==void 0){let _=l();_.width=h,_.height=d;let p=c(_);if(p!=null)p.putImageData(e,0,0),o=p.getImageData(0,0,h,d).data;else throw new Error("Can not access image data")}else o=e.data}else if(s){if(t===void 0)throw new Error("Please provide image config with format for Imagebitmap");let d=l();d.width=e.width,d.height=e.height;let h=c(d);if(h!=null){let _=e.height,p=e.width;return h.drawImage(e,0,0,p,_),o=h.getImageData(0,0,p,_).data,i.height=_,i.width=p,Hs(o,i)}else throw new Error("Can not access image data")}else{if(a)return new Promise((d,h)=>{let _=l(),p=c(_);if(!e||!p)return h();let w=new Image;w.crossOrigin="Anonymous",w.src=e,w.onload=()=>{_.width=w.width,_.height=w.height,p.drawImage(w,0,0,_.width,_.height);let v=p.getImageData(0,0,_.width,_.height);i.height=_.height,i.width=_.width,d(Hs(v.data,i))}});throw new Error("Input data provided is not supported - aborted tensor creation")}if(o!==void 0)return Hs(o,i);throw new Error("Input data provided is not supported - aborted tensor creation")},dp=(e,t)=>{let{width:r,height:n,download:s,dispose:a}=t,o=[1,n,r,4];return new Mt({location:"texture",type:"float32",texture:e,dims:o,download:s,dispose:a})},hp=(e,t)=>{let{dataType:r,dims:n,download:s,dispose:a}=t;return new Mt({location:"gpu-buffer",type:r??"float32",gpuBuffer:e,dims:n,download:s,dispose:a})},fp=(e,t)=>{let{dataType:r,dims:n,download:s,dispose:a}=t;return new Mt({location:"ml-tensor",type:r??"float32",mlTensor:e,dims:n,download:s,dispose:a})},_p=(e,t,r)=>new Mt({location:"cpu-pinned",type:e,data:t,dims:r??[t.length]})}),$r,ls,Wo,pp,G0=we(()=>{$r=new Map([["float32",Float32Array],["uint8",Uint8Array],["int8",Int8Array],["uint16",Uint16Array],["int16",Int16Array],["int32",Int32Array],["bool",Uint8Array],["float64",Float64Array],["uint32",Uint32Array],["int4",Uint8Array],["uint4",Uint8Array]]),ls=new Map([[Float32Array,"float32"],[Uint8Array,"uint8"],[Int8Array,"int8"],[Uint16Array,"uint16"],[Int16Array,"int16"],[Int32Array,"int32"],[Float64Array,"float64"],[Uint32Array,"uint32"]]),Wo=!1,pp=()=>{if(!Wo){Wo=!0;let e=typeof BigInt64Array<"u"&&BigInt64Array.from,t=typeof BigUint64Array<"u"&&BigUint64Array.from,r=globalThis.Float16Array,n=typeof r<"u"&&r.from;e&&($r.set("int64",BigInt64Array),ls.set(BigInt64Array,"int64")),t&&($r.set("uint64",BigUint64Array),ls.set(BigUint64Array,"uint64")),n?($r.set("float16",r),ls.set(r,"float16")):$r.set("float16",Uint16Array)}}}),mp,gp,$0=we(()=>{Tl(),mp=e=>{let t=1;for(let r=0;r<e.length;r++){let n=e[r];if(typeof n!="number"||!Number.isSafeInteger(n))throw new TypeError(`dims[${r}] must be an integer, got: ${n}`);if(n<0)throw new RangeError(`dims[${r}] must be a non-negative integer, got: ${n}`);t*=n}return t},gp=(e,t)=>{switch(e.location){case"cpu":return new Mt(e.type,e.data,t);case"cpu-pinned":return new Mt({location:"cpu-pinned",data:e.data,type:e.type,dims:t});case"texture":return new Mt({location:"texture",texture:e.texture,type:e.type,dims:t});case"gpu-buffer":return new Mt({location:"gpu-buffer",gpuBuffer:e.gpuBuffer,type:e.type,dims:t});case"ml-tensor":return new Mt({location:"ml-tensor",mlTensor:e.mlTensor,type:e.type,dims:t});default:throw new Error(`tensorReshape: tensor location ${e.location} is not supported`)}}}),Mt,Tl=we(()=>{B0(),R0(),G0(),$0(),Mt=class{constructor(e,t,r){pp();let n,s;if(typeof e=="object"&&"location"in e)switch(this.dataLocation=e.location,n=e.type,s=e.dims,e.location){case"cpu-pinned":{let o=$r.get(n);if(!o)throw new TypeError(`unsupported type "${n}" to create tensor from pinned buffer`);if(!(e.data instanceof o))throw new TypeError(`buffer should be of type ${o.name}`);this.cpuData=e.data;break}case"texture":{if(n!=="float32")throw new TypeError(`unsupported type "${n}" to create tensor from texture`);this.gpuTextureData=e.texture,this.downloader=e.download,this.disposer=e.dispose;break}case"gpu-buffer":{if(n!=="float32"&&n!=="float16"&&n!=="int32"&&n!=="int64"&&n!=="uint32"&&n!=="uint8"&&n!=="bool"&&n!=="uint4"&&n!=="int4")throw new TypeError(`unsupported type "${n}" to create tensor from gpu buffer`);this.gpuBufferData=e.gpuBuffer,this.downloader=e.download,this.disposer=e.dispose;break}case"ml-tensor":{if(n!=="float32"&&n!=="float16"&&n!=="int32"&&n!=="int64"&&n!=="uint32"&&n!=="uint64"&&n!=="int8"&&n!=="uint8"&&n!=="bool"&&n!=="uint4"&&n!=="int4")throw new TypeError(`unsupported type "${n}" to create tensor from MLTensor`);this.mlTensorData=e.mlTensor,this.downloader=e.download,this.disposer=e.dispose;break}default:throw new Error(`Tensor constructor: unsupported location '${this.dataLocation}'`)}else{let o,i;if(typeof e=="string")if(n=e,i=r,e==="string"){if(!Array.isArray(t))throw new TypeError("A string tensor's data must be a string array.");o=t}else{let l=$r.get(e);if(l===void 0)throw new TypeError(`Unsupported tensor type: ${e}.`);if(Array.isArray(t)){if(e==="float16"&&l===Uint16Array||e==="uint4"||e==="int4")throw new TypeError(`Creating a ${e} tensor from number array is not supported. Please use ${l.name} as data.`);e==="uint64"||e==="int64"?o=l.from(t,BigInt):o=l.from(t)}else if(t instanceof l)o=t;else if(t instanceof Uint8ClampedArray)if(e==="uint8")o=Uint8Array.from(t);else throw new TypeError("A Uint8ClampedArray tensor's data must be type of uint8");else if(e==="float16"&&t instanceof Uint16Array&&l!==Uint16Array)o=new globalThis.Float16Array(t.buffer,t.byteOffset,t.length);else throw new TypeError(`A ${n} tensor's data must be type of ${l}`)}else if(i=t,Array.isArray(e)){if(e.length===0)throw new TypeError("Tensor type cannot be inferred from an empty array.");let l=typeof e[0];if(l==="string")n="string",o=e;else if(l==="boolean")n="bool",o=Uint8Array.from(e);else throw new TypeError(`Invalid element type of data array: ${l}.`)}else if(e instanceof Uint8ClampedArray)n="uint8",o=Uint8Array.from(e);else{let l=ls.get(e.constructor);if(l===void 0)throw new TypeError(`Unsupported type for tensor data: ${e.constructor}.`);n=l,o=e}if(i===void 0)i=[o.length];else if(!Array.isArray(i))throw new TypeError("A tensor's dims must be a number array");s=i,this.cpuData=o,this.dataLocation="cpu"}let a=mp(s);if(this.cpuData&&a!==this.cpuData.length&&!((n==="uint4"||n==="int4")&&Math.ceil(a/2)===this.cpuData.length))throw new Error(`Tensor's size(${a}) does not match data length(${this.cpuData.length}).`);this.type=n,this.dims=s,this.size=a}static async fromImage(e,t){return up(e,t)}static fromTexture(e,t){return dp(e,t)}static fromGpuBuffer(e,t){return hp(e,t)}static fromMLTensor(e,t){return fp(e,t)}static fromPinnedBuffer(e,t,r){return _p(e,t,r)}toDataURL(e){return lp(this,e)}toImageData(e){return cp(this,e)}get data(){if(this.ensureValid(),!this.cpuData)throw new Error("The data is not on CPU. Use `getData()` to download GPU data to CPU, or use `texture` or `gpuBuffer` property to access the GPU data directly.");return this.cpuData}get location(){return this.dataLocation}get texture(){if(this.ensureValid(),!this.gpuTextureData)throw new Error("The data is not stored as a WebGL texture.");return this.gpuTextureData}get gpuBuffer(){if(this.ensureValid(),!this.gpuBufferData)throw new Error("The data is not stored as a WebGPU buffer.");return this.gpuBufferData}get mlTensor(){if(this.ensureValid(),!this.mlTensorData)throw new Error("The data is not stored as a WebNN MLTensor.");return this.mlTensorData}async getData(e){switch(this.ensureValid(),this.dataLocation){case"cpu":case"cpu-pinned":return this.data;case"texture":case"gpu-buffer":case"ml-tensor":{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 t=await this.downloader();return this.downloader=void 0,this.dataLocation="cpu",this.cpuData=t,e&&this.disposer&&(this.disposer(),this.disposer=void 0),t}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.mlTensorData=void 0,this.downloader=void 0,this.isDownloading=void 0,this.dataLocation="none"}ensureValid(){if(this.dataLocation==="none")throw new Error("The tensor is disposed.")}reshape(e){if(this.ensureValid(),this.downloader||this.disposer)throw new Error("Cannot reshape a tensor that owns GPU resource.");return gp(this,e)}}}),Nt,wp=we(()=>{Tl(),Nt=Mt}),Ca,Ho,qr,Wr,Cr,Sr,vp=we(()=>{ip(),Ca=(e,t)=>{(typeof Je.trace>"u"?!Je.wasm.trace:!Je.trace)||console.timeStamp(`${e}::ORT::${t}`)},Ho=(e,t)=>{var s;let r=((s=new Error().stack)==null?void 0:s.split(/\r\n|\r|\n/g))||[],n=!1;for(let a=0;a<r.length;a++){if(n&&!r[a].includes("TRACE_FUNC")){let o=`FUNC_${e}::${r[a].trim().split(" ")[1]}`;t&&(o+=`::${t}`),Ca("CPU",o);return}r[a].includes("TRACE_FUNC")&&(n=!0)}},qr=e=>{(typeof Je.trace>"u"?!Je.wasm.trace:!Je.trace)||Ho("BEGIN",e)},Wr=e=>{(typeof Je.trace>"u"?!Je.wasm.trace:!Je.trace)||Ho("END",e)},Cr=e=>{(typeof Je.trace>"u"?!Je.wasm.trace:!Je.trace)||console.time(`ORT::${e}`)},Sr=e=>{(typeof Je.trace>"u"?!Je.wasm.trace:!Je.trace)||console.timeEnd(`ORT::${e}`)}}),yp,V0=we(()=>{ap(),wp(),vp(),yp=class bp{constructor(t){this.handler=t}async run(t,r,n){qr(),Cr("InferenceSession.run");let s={},a={};if(typeof t!="object"||t===null||t instanceof Nt||Array.isArray(t))throw new TypeError("'feeds' must be an object that use input names as keys and OnnxValue as corresponding values.");let o=!0;if(typeof r=="object"){if(r===null)throw new TypeError("Unexpected argument[1]: cannot be null.");if(r instanceof Nt)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.");o=!1;for(let c of r){if(typeof c!="string")throw new TypeError("'fetches' must be a string array or an object.");if(this.outputNames.indexOf(c)===-1)throw new RangeError(`'fetches' contains invalid output name: ${c}.`);s[c]=null}if(typeof n=="object"&&n!==null)a=n;else if(typeof n<"u")throw new TypeError("'options' must be an object.")}else{let c=!1,d=Object.getOwnPropertyNames(r);for(let h of this.outputNames)if(d.indexOf(h)!==-1){let _=r[h];(_===null||_ instanceof Nt)&&(c=!0,o=!1,s[h]=_)}if(c){if(typeof n=="object"&&n!==null)a=n;else if(typeof n<"u")throw new TypeError("'options' must be an object.")}else a=r}}else if(typeof r<"u")throw new TypeError("Unexpected argument[1]: must be 'fetches' or 'options'.");for(let c of this.inputNames)if(typeof t[c]>"u")throw new Error(`input '${c}' is missing in 'feeds'.`);if(o)for(let c of this.outputNames)s[c]=null;let i=await this.handler.run(t,s,a),l={};for(let c in i)if(Object.hasOwnProperty.call(i,c)){let d=i[c];d instanceof Nt?l[c]=d:l[c]=new Nt(d.type,d.data,d.dims)}return Sr("InferenceSession.run"),Wr(),l}async release(){return this.handler.dispose()}static async create(t,r,n,s){qr(),Cr("InferenceSession.create");let a,o={};if(typeof t=="string"){if(a=t,typeof r=="object"&&r!==null)o=r;else if(typeof r<"u")throw new TypeError("'options' must be an object.")}else if(t instanceof Uint8Array){if(a=t,typeof r=="object"&&r!==null)o=r;else if(typeof r<"u")throw new TypeError("'options' must be an object.")}else if(t instanceof ArrayBuffer||typeof SharedArrayBuffer<"u"&&t instanceof SharedArrayBuffer){let d=t,h=0,_=t.byteLength;if(typeof r=="object"&&r!==null)o=r;else if(typeof r=="number"){if(h=r,!Number.isSafeInteger(h))throw new RangeError("'byteOffset' must be an integer.");if(h<0||h>=d.byteLength)throw new RangeError(`'byteOffset' is out of range [0, ${d.byteLength}).`);if(_=t.byteLength-h,typeof n=="number"){if(_=n,!Number.isSafeInteger(_))throw new RangeError("'byteLength' must be an integer.");if(_<=0||h+_>d.byteLength)throw new RangeError(`'byteLength' is out of range (0, ${d.byteLength-h}].`);if(typeof s=="object"&&s!==null)o=s;else if(typeof s<"u")throw new TypeError("'options' must be an object.")}else if(typeof n<"u")throw new TypeError("'byteLength' must be a number.")}else if(typeof r<"u")throw new TypeError("'options' must be an object.");a=new Uint8Array(d,h,_)}else throw new TypeError("Unexpected argument[0]: must be 'path' or 'buffer'.");let[i,l]=await sp(o),c=await i.createInferenceSessionHandler(a,l);return Sr("InferenceSession.create"),Wr(),new bp(c)}startProfiling(){this.handler.startProfiling()}endProfiling(){this.handler.endProfiling()}get inputNames(){return this.handler.inputNames}get outputNames(){return this.handler.outputNames}get inputMetadata(){return this.handler.inputMetadata}get outputMetadata(){return this.handler.outputMetadata}}}),El,U0=we(()=>{V0(),El=yp}),j0=we(()=>{}),q0=we(()=>{}),W0=we(()=>{}),H0=we(()=>{}),Mp={};bs(Mp,{InferenceSession:()=>El,TRACE:()=>Ca,TRACE_EVENT_BEGIN:()=>Cr,TRACE_EVENT_END:()=>Sr,TRACE_FUNC_BEGIN:()=>qr,TRACE_FUNC_END:()=>Wr,Tensor:()=>Nt,env:()=>ze,registerBackend:()=>Ur});var Hr=we(()=>{N0(),z0(),U0(),wp(),j0(),q0(),vp(),W0(),H0()}),Al=we(()=>{}),xp={};bs(xp,{default:()=>kp});var Qo,Xo,kp,Q0=we(()=>{var e;Rp(),Qr(),Cl(),Qo="ort-wasm-proxy-worker",Xo=((e=globalThis.self)==null?void 0:e.name)===Qo,Xo&&(self.onmessage=t=>{let{type:r,in:n}=t.data;try{switch(r){case"init-wasm":Sl(n.wasm).then(()=>{Ol(n).then(()=>{postMessage({type:r})},s=>{postMessage({type:r,err:s})})},s=>{postMessage({type:r,err:s})});break;case"init-ep":{let{epName:s,env:a}=n;Nl(a,s).then(()=>{postMessage({type:r})},o=>{postMessage({type:r,err:o})});break}case"copy-from":{let{buffer:s}=n,a=Fa(s);postMessage({type:r,out:a});break}case"create":{let{model:s,options:a}=n;Dl(s,a).then(o=>{postMessage({type:r,out:o})},o=>{postMessage({type:r,err:o})});break}case"release":zl(n),postMessage({type:r});break;case"run":{let{sessionId:s,inputIndices:a,inputs:o,outputIndices:i,options:l}=n;Bl(s,a,o,i,new Array(i.length).fill(null),l).then(c=>{c.some(d=>d[3]!=="cpu")?postMessage({type:r,err:"Proxy does not support non-cpu tensor location."}):postMessage({type:r,out:c},Gl([...o,...c]))},c=>{postMessage({type:r,err:c})});break}case"end-profiling":Rl(n),postMessage({type:r});break;default:}}catch(s){postMessage({type:r,err:s})}}),kp=Xo?null:t=>new Worker(t??yt,{type:"module",name:Qo})}),Tp={};bs(Tp,{default:()=>Ep});async function Ef(e={}){var bf,Mf;var t=e,r=!!globalThis.window,n=!!globalThis.WorkerGlobalScope,s=n&&((bf=self.name)==null?void 0:bf.startsWith("em-pthread"));t.mountExternalData=(u,f)=>{u.startsWith("./")&&(u=u.substring(2)),(t.Uc||(t.Uc=new Map)).set(u,f)},t.unmountExternalData=()=>{delete t.Uc},globalThis.SharedArrayBuffer??new WebAssembly.Memory({initial:0,maximum:0,shared:!0}).buffer.constructor;let a=()=>{let u=f=>(...m)=>{let g=Qt;return m=f(...m),Qt!=g?new Promise((b,E)=>{To={resolve:b,reject:E}}):m};(()=>{for(let f of["_OrtAppendExecutionProvider","_OrtCreateSession","_OrtRun","_OrtRunWithBinding","_OrtBindInput"])t[f]=u(t[f])})(),typeof jsepRunAsync<"u"&&(t._OrtRun=jsepRunAsync(t._OrtRun),t._OrtRunWithBinding=jsepRunAsync(t._OrtRunWithBinding)),a=void 0};t.asyncInit=()=>{a==null||a()};var o,i,l=(u,f)=>{throw f},c=import.meta.url,d="";if(r||n){try{d=new URL(".",c).href}catch{}n&&(i=u=>{var f=new XMLHttpRequest;return f.open("GET",u,!1),f.responseType="arraybuffer",f.send(null),new Uint8Array(f.response)}),o=async u=>{if(I(u))return new Promise((m,g)=>{var b=new XMLHttpRequest;b.open("GET",u,!0),b.responseType="arraybuffer",b.onload=()=>{b.status==200||b.status==0&&b.response?m(b.response):g(b.status)},b.onerror=g,b.send(null)});var f=await fetch(u,{credentials:"same-origin"});if(f.ok)return f.arrayBuffer();throw Error(f.status+" : "+f.url)}}var h,_,p,w,v,y,M=console.log.bind(console),T=console.error.bind(console),A=M,S=T,C=!1,I=u=>u.startsWith("file://");function x(){vr.buffer!=z.buffer&&X()}if(s){let u=function(f){try{var m=f.data,g=m.Oc;if(g==="load"){let b=[];self.onmessage=E=>b.push(E),y=()=>{postMessage({Oc:"loaded"});for(let E of b)u(E);self.onmessage=u};for(let E of m.ce)t[E]&&!t[E].proxy||(t[E]=(...F)=>{postMessage({Oc:"callHandler",be:E,args:F})},E=="print"&&(A=t[E]),E=="printErr"&&(S=t[E]));vr=m.ie,X(),_=m.je,Fe(),js()}else if(g==="run"){(function(b){var E=(x(),O)[b+52>>>2>>>0];b=(x(),O)[b+56>>>2>>>0],Fh(E,E-b),se(E)})(m.Nc),zo(m.Nc,0,0,1,0,0),wd(),Mo(m.Nc),R||(fh(),R=!0);try{Fv(m.ge,m.Wc)}catch(b){if(b!="unwind")throw b}}else m.target!=="setimmediate"&&(g==="checkMailbox"?R&&Ds():g&&(S(`worker: received unknown command ${g}`),S(m)))}catch(b){throw Eh(),b}};var R=!1;self.onunhandledrejection=f=>{throw f.reason||f},self.onmessage=u}var z,$,Q,H,D,O,te,W,ee,G,L,V=!1;function X(){var u=vr.buffer;t.HEAP8=z=new Int8Array(u),Q=new Int16Array(u),t.HEAPU8=$=new Uint8Array(u),H=new Uint16Array(u),t.HEAP32=D=new Int32Array(u),t.HEAPU32=O=new Uint32Array(u),te=new Float32Array(u),W=new Float64Array(u),ee=new BigInt64Array(u),G=new BigUint64Array(u)}function J(){V=!0,s?y():ur._b()}function me(u){throw S(u="Aborted("+u+")"),C=!0,u=new WebAssembly.RuntimeError(u+". Build with -sASSERTIONS for more info."),v==null||v(u),u}function re(){return{a:{f:Lv,J:Iv,k:Ov,p:Nv,l:Dv,sa:zv,b:Bv,ca:Rv,Ja:kd,q:Gv,da:Cd,Za:Sd,Fa:Pd,Ha:Fd,_a:Ld,Xa:Id,Qa:Od,Wa:Nd,oa:Dd,Ga:zd,Xb:Bd,Ya:Rd,Yb:Gd,db:$v,Da:Vv,Sb:Uv,Qb:qv,Ca:Hv,M:Qv,I:Xv,Rb:Yv,ja:ny,Tb:sy,Ta:ay,Vb:iy,Ka:ly,Ob:cy,ka:uy,Sa:Mo,ab:dy,U:py,n:yy,c:yo,rb:by,w:My,L:xy,z:ky,j:Ty,o:Qd,sb:Ey,G:Ay,T:Cy,h:Sy,u:Py,m:Fy,i:Ly,Na:Iy,Oa:Oy,Pa:Ny,La:Kd,Ma:Zd,Pb:eh,eb:zy,cb:Ry,Y:Gy,qb:$y,la:Vy,bb:By,fb:Uy,$a:jy,Wb:qy,N:Dy,gb:Wy,X:Hy,Ub:Qy,nb,C:sb,ra:ab,qa:ob,pb:ib,W:lb,v:cb,mb:ub,lb:db,kb:hb,ob:fb,jb:_b,ib:pb,hb:mb,Ua:oh,Va:ih,Ia:Wt,V:lh,na:ch,Ra:uh,ma:dh,Cb:E0,xa:y0,Db:T0,ya:v0,F:l0,e:Xb,s:Hb,x:Wb,B:a0,Fb:m0,ba:p0,D:Kb,za:g0,$:b0,ga:_0,Gb:f0,Hb:h0,Ba:c0,Aa:d0,Ib:u0,wa:k0,aa:w0,d:Qb,A:Jb,r:Yb,Bb:A0,t:e0,y:o0,H:Zb,E:t0,K:i0,R:M0,ia:s0,_:x0,Jb:n0,Kb:r0,g:wb,a:vr,Nb:Se,Eb:vb,ha:yb,O:bb,pa:Mb,Lb:xb,ta:kb,Q:Tb,yb:Eb,zb:Ab,ua:Cb,ea:Sb,P:Pb,Ea:Fb,va:Lb,Z:Ib,wb:Ob,Zb:Nb,S:Db,Ab:zb,tb:Bb,ub:Gb,vb:$b,fa:Vb,xb:Ub,Mb:jb}}}async function Fe(){function u(g,b){var E=ur=g.exports;g={};for(let[F,N]of Object.entries(E))typeof N=="function"?(E=hy(N),g[F]=E):g[F]=N;return ur=g,ur=(function(){var F=ur,N=Y=>ve=>Y(ve)>>>0,U=Y=>()=>Y()>>>0;return(F=Object.assign({},F)).$b=N(F.$b),F.Cc=U(F.Cc),F.Ec=N(F.Ec),F.rd=(Y=>(ve,K)=>Y(ve,K)>>>0)(F.rd),F.wd=N(F.wd),F.xd=U(F.xd),F.Bd=N(F.Bd),F})(),md.push(ur.id),hh=(g=ur).$b,fh=g.ac,t._OrtInit=g.bc,t._OrtGetLastError=g.cc,t._OrtCreateSessionOptions=g.dc,t._OrtAppendExecutionProvider=g.ec,t._OrtAddFreeDimensionOverride=g.fc,t._OrtAddSessionConfigEntry=g.gc,t._OrtReleaseSessionOptions=g.hc,t._OrtCreateSession=g.ic,t._OrtReleaseSession=g.jc,t._OrtGetInputOutputCount=g.kc,t._OrtGetInputOutputMetadata=g.lc,t._OrtFree=g.mc,t._OrtCreateTensor=g.nc,t._OrtGetTensorData=g.oc,t._OrtReleaseTensor=g.pc,t._OrtCreateRunOptions=g.qc,t._OrtAddRunConfigEntry=g.rc,t._OrtReleaseRunOptions=g.sc,t._OrtCreateBinding=g.tc,t._OrtBindInput=g.uc,t._OrtBindOutput=g.vc,t._OrtClearBoundOutputs=g.wc,t._OrtReleaseBinding=g.xc,t._OrtRunWithBinding=g.yc,t._OrtRun=g.zc,t._OrtEndProfiling=g.Ac,Fo=t._OrtGetWebGpuDevice=g.Bc,Vs=g.Cc,Ot=t._free=g.Dc,tn=t._malloc=g.Ec,_h=t._wgpuBufferRelease=g.Fc,ph=t._wgpuCreateInstance=g.Gc,mh=g.Hc,gh=g.Ic,wh=g.Jc,vh=g.Kc,yh=g.Lc,bh=g.Pc,Mh=g.Zc,xh=g._c,kh=g.$c,Lo=g.bd,Io=g.cd,Oo=g.dd,No=g.ed,Gn=g.fd,Do=g.gd,Th=g.hd,zo=g.kd,Eh=g.ld,Ah=g.md,Ch=g.nd,Bo=g.od,Sh=g.pd,Ph=g.qd,Ro=g.rd,pe=g.sd,$n=g.td,Fh=g.ud,se=g.vd,Us=g.wd,ae=g.xd,Lh=g.yd,Go=g.zd,Ih=g.Ad,Oh=g.Bd,Nh=g.Cd,$o=g.Dd,Dh=g.Ed,zh=g.Fd,Bh=g.Gd,Rh=g.Hd,Gh=g.Id,$h=g.Jd,Vh=g.Kd,Uh=g.Ld,jh=g.Md,qh=g.Nd,Wh=g.Od,Hh=g.Pd,Qh=g.Qd,Xh=g.Rd,Yh=g.Td,Jh=g.Ud,Kh=g.Vd,Zh=g.Wd,ef=g.Yd,tf=g.Zd,rf=g._d,nf=g.$d,sf=g.ae,af=g.oe,of=g.pe,lf=g.qe,cf=g.re,uf=g.se,df=g.te,hf=g.ue,ff=g.ve,_f=g.we,pf=g.xe,mf=g.ye,gf=g.Ye,wf=g.Ze,vf=g._e,yf=g.$e,_=b,ur}var f,m=re();return t.instantiateWasm?new Promise(g=>{t.instantiateWasm(m,(b,E)=>{g(u(b,E))})}):s?u(new WebAssembly.Instance(_,re()),_):(L??(L=t.locateFile?t.locateFile?t.locateFile("ort-wasm-simd-threaded.asyncify.wasm",d):d+"ort-wasm-simd-threaded.asyncify.wasm":new URL("/assets/ort-wasm-simd-threaded.asyncify-DMmc6YqF.wasm",import.meta.url).href),f=await(async function(g){var b=L;if(!h&&!I(b))try{var E=fetch(b,{credentials:"same-origin"});return await WebAssembly.instantiateStreaming(E,g)}catch(F){S(`wasm streaming compile failed: ${F}`),S("falling back to ArrayBuffer instantiation")}return(async function(F,N){try{var U=await(async function(Y){if(!h)try{var ve=await o(Y);return new Uint8Array(ve)}catch{}if(Y==L&&h)Y=new Uint8Array(h);else{if(!i)throw"both async and sync fetching of the wasm failed";Y=i(Y)}return Y})(F);return await WebAssembly.instantiate(U,N)}catch(Y){S(`failed to asynchronously prepare wasm: ${Y}`),me(Y)}})(b,g)})(m),u(f.instance,f.module))}class Ve{constructor(f){k(this,"name","ExitStatus");this.message=`Program terminated with exit(${f})`,this.status=f}}var pt=u=>{u.terminate(),u.onmessage=()=>{}},Tt=[],Et=0,je=null,ht=u=>{At.length==0&&(yd(),vd(At[0]));var f=At.pop();if(!f)return 6;zn.push(f),Ir[u.Nc]=f,f.Nc=u.Nc;var m={Oc:"run",ge:u.fe,Wc:u.Wc,Nc:u.Nc};return f.postMessage(m,u.Yc),0},be=0,le=(u,f,...m)=>{var g,b=16*m.length,E=ae(),F=Us(b),N=F>>>3;for(g of m)typeof g=="bigint"?((x(),ee)[N++>>>0]=1n,(x(),ee)[N++>>>0]=g):((x(),ee)[N++>>>0]=0n,(x(),W)[N++>>>0]=g);return u=Ah(u,0,b,F,f),se(E),u};function Se(u){if(s)return le(0,1,u);if(p=u,!(0<be)){for(var f of zn)pt(f);for(f of At)pt(f);At=[],zn=[],Ir={},C=!0}l(0,new Ve(u))}function ft(u){if(s)return le(1,0,u);Wt(u)}var Wt=u=>{if(p=u,s)throw ft(u),"unwind";Se(u)},At=[],zn=[],md=[],Ir={},gd=u=>{var f=u.Nc;delete Ir[f],At.push(u),zn.splice(zn.indexOf(u),1),u.Nc=0,Ch(f)};function wd(){md.forEach(u=>u())}var vd=u=>new Promise(f=>{u.onmessage=b=>{var E=b.data;if(b=E.Oc,E.Vc&&E.Vc!=Vs()){var F=Ir[E.Vc];F?F.postMessage(E,E.Yc):S(`Internal error! Worker sent a message "${b}" to target pthread ${E.Vc}, but that thread no longer exists!`)}else b==="checkMailbox"?Ds():b==="spawnThread"?ht(E):b==="cleanupThread"?_t(()=>{gd(Ir[E.he])}):b==="loaded"?(u.loaded=!0,f(u)):E.target==="setimmediate"?u.postMessage(E):b==="uncaughtException"?u.onerror(E.error):b==="callHandler"?t[E.be](...E.args):b&&S(`worker sent an unknown command ${b}`)},u.onerror=b=>{throw S(`worker sent an error! ${b.filename}:${b.lineno}: ${b.message}`),b};var m,g=[];for(m of[])t.propertyIsEnumerable(m)&&g.push(m);u.postMessage({Oc:"load",ce:g,ie:vr,je:_})});function yd(){var u=new Worker((()=>{let f=URL;return import.meta.url>"file:"&&import.meta.url<"file;"?new f("ort.webgpu.bundle.min.mjs",import.meta.url):new URL(import.meta.url)})(),{type:"module",workerData:"em-pthread",name:"em-pthread"});At.push(u)}var vr,Fv=(u,f)=>{be=0,u=$o(u,f),0<be?p=u:Bo(u)},Os=[],Ns=0,et=u=>-9007199254740992>u||9007199254740992<u?NaN:Number(u);function Lv(u){var f=new mo(u>>>=0);return(x(),z)[f.Qc+12>>>0]==0&&(bd(f,!0),Ns--),Md(f,!1),Os.push(f),Oh(u)}var Jr=0,Iv=()=>{pe(0,0);var u=Os.pop();Lh(u.Xc),Jr=0};function bd(u,f){f=f?1:0,(x(),z)[u.Qc+12>>>0]=f}function Md(u,f){f=f?1:0,(x(),z)[u.Qc+13>>>0]=f}class mo{constructor(f){this.Xc=f,this.Qc=f-24}}var go=u=>{var f=Jr;if(!f)return $n(0),0;var m=new mo(f);(x(),O)[m.Qc+16>>>2>>>0]=f;var g=(x(),O)[m.Qc+4>>>2>>>0];if(!g)return $n(0),f;for(var b of u){if(b===0||b===g)break;if(Ih(b,g,m.Qc+16))return $n(b),f}return $n(g),f};function Ov(){return go([])}function Nv(u){return go([u>>>0])}function Dv(u,f,m,g){return go([u>>>0,f>>>0,m>>>0,g>>>0])}var zv=()=>{var u=Os.pop();u||me("no exception to throw");var f=u.Xc;throw(x(),z)[u.Qc+13>>>0]==0&&(Os.push(u),Md(u,!0),bd(u,!1),Ns++),Go(f),Jr=f};function Bv(u,f,m){var g=new mo(u>>>=0);throw f>>>=0,m>>>=0,(x(),O)[g.Qc+16>>>2>>>0]=0,(x(),O)[g.Qc+4>>>2>>>0]=f,(x(),O)[g.Qc+8>>>2>>>0]=m,Go(u),Ns++,Jr=u}var Rv=()=>Ns;function xd(u,f,m,g){return s?le(2,1,u,f,m,g):kd(u,f,m,g)}function kd(u,f,m,g){if(u>>>=0,f>>>=0,m>>>=0,g>>>=0,!globalThis.SharedArrayBuffer)return 6;var b=[];return s&&b.length===0?xd(u,f,m,g):(u={fe:m,Nc:u,Wc:g,Yc:b},s?(u.Oc="spawnThread",postMessage(u,b),0):ht(u))}function Gv(u){throw Jr||(Jr=u>>>0),Jr}var Td=globalThis.TextDecoder&&new TextDecoder,Ed=(u,f,m,g)=>{if(m=f+m,g)return m;for(;u[f]&&!(f>=m);)++f;return f},Ad=(u,f=0,m,g)=>{if(16<(m=Ed(u,f>>>=0,m,g))-f&&u.buffer&&Td)return Td.decode(u.buffer instanceof ArrayBuffer?u.subarray(f,m):u.slice(f,m));for(g="";f<m;){var b=u[f++];if(128&b){var E=63&u[f++];if((224&b)==192)g+=String.fromCharCode((31&b)<<6|E);else{var F=63&u[f++];65536>(b=(240&b)==224?(15&b)<<12|E<<6|F:(7&b)<<18|E<<12|F<<6|63&u[f++])?g+=String.fromCharCode(b):(b-=65536,g+=String.fromCharCode(55296|b>>10,56320|1023&b))}}else g+=String.fromCharCode(b)}return g},Kr=(u,f,m)=>(u>>>=0)?Ad((x(),$),u,f,m):"";function Cd(u,f,m){return s?le(3,1,u,f,m):0}function Sd(u,f){if(s)return le(4,1,u,f)}function Pd(u,f){if(s)return le(5,1,u,f)}function Fd(u,f,m){if(s)return le(6,1,u,f,m)}function Ld(u,f,m){return s?le(7,1,u,f,m):0}function Id(u,f){if(s)return le(8,1,u,f)}function Od(u,f,m){if(s)return le(9,1,u,f,m)}function Nd(u,f,m,g){if(s)return le(10,1,u,f,m,g)}function Dd(u,f,m,g){if(s)return le(11,1,u,f,m,g)}function zd(u,f,m,g){if(s)return le(12,1,u,f,m,g)}function Bd(u){if(s)return le(13,1,u)}function Rd(u,f){if(s)return le(14,1,u,f)}function Gd(u,f,m){if(s)return le(15,1,u,f,m)}var $v=()=>me(""),Ht=u=>{u>>>=0;for(var f="";;){var m=(x(),$)[u++>>>0];if(!m)return f;f+=String.fromCharCode(m)}},wo={},vo={},Zr=class extends Error{constructor(u){super(u),this.name="BindingError"}};function ar(u,f,m={}){return(function(g,b,E={}){var F=b.name;if(!g)throw new Zr(`type "${F}" must have a positive integer typeid pointer`);if(vo.hasOwnProperty(g)){if(E.de)return;throw new Zr(`Cannot register type '${F}' twice`)}vo[g]=b,wo.hasOwnProperty(g)&&(b=wo[g],delete wo[g],b.forEach(N=>N()))})(u,f,m)}var $d=(u,f,m)=>{switch(f){case 1:return m?g=>(x(),z)[g>>>0]:g=>(x(),$)[g>>>0];case 2:return m?g=>(x(),Q)[g>>>1>>>0]:g=>(x(),H)[g>>>1>>>0];case 4:return m?g=>(x(),D)[g>>>2>>>0]:g=>(x(),O)[g>>>2>>>0];case 8:return m?g=>(x(),ee)[g>>>3>>>0]:g=>(x(),G)[g>>>3>>>0];default:throw new TypeError(`invalid integer width (${f}): ${u}`)}};function Vv(u,f,m,g,b){u>>>=0,m>>>=0,f=Ht(f>>>0);let E=F=>F;if(g=g===0n){let F=8*m;E=N=>BigInt.asUintN(F,N),b=E(b)}ar(u,{name:f,Mc:E,Sc:(F,N)=>(typeof N=="number"&&(N=BigInt(N)),N),Rc:$d(f,m,!g),Tc:null})}function Uv(u,f,m,g){ar(u>>>=0,{name:f=Ht(f>>>0),Mc:function(b){return!!b},Sc:function(b,E){return E?m:g},Rc:function(b){return this.Mc((x(),$)[b>>>0])},Tc:null})}var Vd=[],Or=[0,1,,1,null,1,!0,1,!1,1];function yo(u){9<(u>>>=0)&&--Or[u+1]==0&&(Or[u]=void 0,Vd.push(u))}var Ct=u=>{if(!u)throw new Zr(`Cannot use deleted val. handle = ${u}`);return Or[u]},It=u=>{switch(u){case void 0:return 2;case null:return 4;case!0:return 6;case!1:return 8;default:let f=Vd.pop()||Or.length;return Or[f]=u,Or[f+1]=1,f}};function bo(u){return this.Mc((x(),O)[u>>>2>>>0])}var jv={name:"emscripten::val",Mc:u=>{var f=Ct(u);return yo(u),f},Sc:(u,f)=>It(f),Rc:bo,Tc:null};function qv(u){return ar(u>>>0,jv)}var Wv=(u,f)=>{switch(f){case 4:return function(m){return this.Mc((x(),te)[m>>>2>>>0])};case 8:return function(m){return this.Mc((x(),W)[m>>>3>>>0])};default:throw new TypeError(`invalid float width (${f}): ${u}`)}};function Hv(u,f,m){m>>>=0,ar(u>>>=0,{name:f=Ht(f>>>0),Mc:g=>g,Sc:(g,b)=>b,Rc:Wv(f,m),Tc:null})}function Qv(u,f,m,g,b){u>>>=0,m>>>=0,f=Ht(f>>>0);let E=N=>N;if(g===0){var F=32-8*m;E=N=>N<<F>>>F,b=E(b)}ar(u,{name:f,Mc:E,Sc:(N,U)=>U,Rc:$d(f,m,g!==0),Tc:null})}function Xv(u,f,m){function g(E){var F=(x(),O)[E>>>2>>>0];return E=(x(),O)[E+4>>>2>>>0],new b((x(),z).buffer,E,F)}var b=[Int8Array,Uint8Array,Int16Array,Uint16Array,Int32Array,Uint32Array,Float32Array,Float64Array,BigInt64Array,BigUint64Array][f];ar(u>>>=0,{name:m=Ht(m>>>0),Mc:g,Rc:g},{de:!0})}var or=(u,f,m)=>{var g=(x(),$);if(f>>>=0,0<m){var b=f;m=f+m-1;for(var E=0;E<u.length;++E){var F=u.codePointAt(E);if(127>=F){if(f>=m)break;g[f++>>>0]=F}else if(2047>=F){if(f+1>=m)break;g[f++>>>0]=192|F>>6,g[f++>>>0]=128|63&F}else if(65535>=F){if(f+2>=m)break;g[f++>>>0]=224|F>>12,g[f++>>>0]=128|F>>6&63,g[f++>>>0]=128|63&F}else{if(f+3>=m)break;g[f++>>>0]=240|F>>18,g[f++>>>0]=128|F>>12&63,g[f++>>>0]=128|F>>6&63,g[f++>>>0]=128|63&F,E++}}g[f>>>0]=0,u=f-b}else u=0;return u},ir=u=>{for(var f=0,m=0;m<u.length;++m){var g=u.charCodeAt(m);127>=g?f++:2047>=g?f+=2:55296<=g&&57343>=g?(f+=4,++m):f+=3}return f};function Yv(u,f){ar(u>>>=0,{name:f=Ht(f>>>0),Mc(m){var g=(x(),O)[m>>>2>>>0];return g=Kr(m+4,g,!0),Ot(m),g},Sc(m,g){g instanceof ArrayBuffer&&(g=new Uint8Array(g));var b=typeof g=="string";if(!(b||ArrayBuffer.isView(g)&&g.BYTES_PER_ELEMENT==1))throw new Zr("Cannot pass non-string to std::string");var E=b?ir(g):g.length,F=tn(4+E+1),N=F+4;return(x(),O)[F>>>2>>>0]=E,b?or(g,N,E+1):(x(),$).set(g,N>>>0),m!==null&&m.push(Ot,F),F},Rc:bo,Tc(m){Ot(m)}})}var Ud=globalThis.TextDecoder?new TextDecoder("utf-16le"):void 0,Jv=(u,f,m)=>{if(u>>>=1,16<(f=Ed((x(),H),u,f/2,m))-u&&Ud)return Ud.decode((x(),H).slice(u,f));for(m="";u<f;++u){var g=(x(),H)[u>>>0];m+=String.fromCharCode(g)}return m},Kv=(u,f,m)=>{if(m??(m=2147483647),2>m)return 0;var g=f;m=(m-=2)<2*u.length?m/2:u.length;for(var b=0;b<m;++b){var E=u.charCodeAt(b);(x(),Q)[f>>>1>>>0]=E,f+=2}return(x(),Q)[f>>>1>>>0]=0,f-g},Zv=u=>2*u.length,ey=(u,f,m)=>{var g="";u>>>=2;for(var b=0;!(b>=f/4);b++){var E=(x(),O)[u+b>>>0];if(!E&&!m)break;g+=String.fromCodePoint(E)}return g},ty=(u,f,m)=>{if(f>>>=0,m??(m=2147483647),4>m)return 0;var g=f;m=g+m-4;for(var b=0;b<u.length;++b){var E=u.codePointAt(b);if(65535<E&&b++,(x(),D)[f>>>2>>>0]=E,(f+=4)+4>m)break}return(x(),D)[f>>>2>>>0]=0,f-g},ry=u=>{for(var f=0,m=0;m<u.length;++m)65535<u.codePointAt(m)&&m++,f+=4;return f};function ny(u,f,m){if(u>>>=0,f>>>=0,m=Ht(m>>>=0),f===2)var g=Jv,b=Kv,E=Zv;else g=ey,b=ty,E=ry;ar(u,{name:m,Mc:F=>{var N=(x(),O)[F>>>2>>>0];return N=g(F+4,N*f,!0),Ot(F),N},Sc:(F,N)=>{if(typeof N!="string")throw new Zr(`Cannot pass non-string to C++ string type ${m}`);var U=E(N),Y=tn(4+U+f);return(x(),O)[Y>>>2>>>0]=U/f,b(N,Y+4,U+f),F!==null&&F.push(Ot,Y),Y},Rc:bo,Tc(F){Ot(F)}})}function sy(u,f){ar(u>>>=0,{ee:!0,name:f=Ht(f>>>0),Mc:()=>{},Sc:()=>{}})}function ay(u){zo(u>>>0,!n,1,!r,131072,!1),wd()}var _t=u=>{if(!C)try{if(u(),!(0<be))try{s?Vs()&&Bo(p):Wt(p)}catch(f){f instanceof Ve||f=="unwind"||l(0,f)}}catch(f){f instanceof Ve||f=="unwind"||l(0,f)}},oy=!Atomics.waitAsync||((Mf=globalThis.navigator)==null?void 0:Mf.userAgent)&&91>Number((navigator.userAgent.match(/Chrom(e|ium)\/([0-9]+)\./)||[])[2]);function Mo(u){u>>>=0,oy||(Atomics.waitAsync((x(),D),u>>>2,u).value.then(Ds),u+=128,Atomics.store((x(),D),u>>>2,1))}var Ds=()=>_t(()=>{var u=Vs();u&&(Mo(u),Ph())});function iy(u,f){(u>>>=0)==f>>>0?setTimeout(Ds):s?postMessage({Vc:u,Oc:"checkMailbox"}):(u=Ir[u])&&u.postMessage({Oc:"checkMailbox"})}var xo=[];function ly(u,f,m,g,b){for(f>>>=0,b>>>=0,xo.length=0,m=b>>>3,g=b+g>>>3;m<g;){var E;E=(x(),ee)[m++>>>0]?(x(),ee)[m++>>>0]:(x(),W)[m++>>>0],xo.push(E)}return(f?Vo[f]:qb[u])(...xo)}var cy=()=>{be=0};function uy(u){u>>>=0,s?postMessage({Oc:"cleanupThread",he:u}):gd(Ir[u])}function dy(u){}var zs=u=>{try{u()}catch(f){me(f)}};function hy(u){var f=(...m)=>{Bs.push(u);try{return u(...m)}finally{C||(Bs.pop(),Qt&&yr===1&&Bs.length===0&&(yr=0,be+=1,zs(wf),typeof Fibers<"u"&&Fibers.Be()))}};return Wd.set(u,f),f}var yr=0,Qt=null,jd=0,Bs=[],ko=new Map,qd=new Map,Wd=new Map,fy=0,To=null,_y=[],Hd=u=>(function(f){if(!C){if(yr===0){var m=!1,g=!1;f((b=0)=>{if(!C&&(jd=b,m=!0,g)){yr=2,zs(()=>vf(Qt)),typeof MainLoop<"u"&&MainLoop.Xd&&MainLoop.resume(),b=!1;try{var E=(function(){var U=(x(),D)[Qt+8>>>2>>>0];return U=qd.get(U),U=Wd.get(U),--be,U()})()}catch(U){E=U,b=!0}var F=!1;if(!Qt){var N=To;N&&(To=null,(b?N.reject:N.resolve)(E),F=!0)}if(b&&!F)throw E}}),g=!0,m||(yr=1,Qt=(function(){var b=tn(65548),E=b+12;if((x(),O)[b>>>2>>>0]=E,(x(),O)[b+4>>>2>>>0]=E+65536,E=Bs[0],!ko.has(E)){var F=fy++;ko.set(E,F),qd.set(F,E)}return E=ko.get(E),(x(),D)[b+8>>>2>>>0]=E,b})(),typeof MainLoop<"u"&&MainLoop.Xd&&MainLoop.pause(),zs(()=>gf(Qt)))}else yr===2?(yr=0,zs(yf),Ot(Qt),Qt=null,_y.forEach(_t)):me(`invalid state: ${yr}`);return jd}})(f=>{u().then(f)});function py(u){return u>>>=0,Hd(async()=>{var f=await Ct(u);return It(f)})}var Eo=[],my=u=>{var f=Eo.length;return Eo.push(u),f},gy=(u,f)=>{for(var m=Array(u),g=0;g<u;++g){var b=g,E=(x(),O)[f+4*g>>>2>>>0],F=vo[E];if(F===void 0)throw u=`parameter ${g}`,E=hh(E),f=Ht(E),Ot(E),new Zr(`${u} has unknown type ${f}`);m[b]=F}return m},wy=(u,f,m)=>{var g=[];return u=u(g,m),g.length&&((x(),O)[f>>>2>>>0]=It(g)),u},vy={},Rs=u=>{var f=vy[u];return f===void 0?Ht(u):f};function yy(u,f,m){var[g,...b]=gy(u,f>>>0);f=g.Sc.bind(g);var E=b.map(U=>U.Rc.bind(U));u--;var F={toValue:Ct};switch(u=E.map((U,Y)=>{var ve=`argFromPtr${Y}`;return F[ve]=U,`${ve}(args${Y?"+"+8*Y:""})`}),m){case 0:var N="toValue(handle)";break;case 2:N="new (toValue(handle))";break;case 3:N="";break;case 1:F.getStringOrSymbol=Rs,N="toValue(handle)[getStringOrSymbol(methodName)]"}return N+=`(${u})`,g.ee||(F.toReturnWire=f,F.emval_returnValue=wy,N=`return emval_returnValue(toReturnWire, destructorsRef, ${N})`),N=`return function (handle, methodName, destructorsRef, args) {
6
+ ${N}
7
+ }`,m=new Function(Object.keys(F),N)(...Object.values(F)),N=`methodCaller<(${b.map(U=>U.name)}) => ${g.name}>`,my(Object.defineProperty(m,"name",{value:N}))}function by(u,f){return f>>>=0,(u=Ct(u>>>0))==Ct(f)}function My(u){return(u>>>=0)?(u=Rs(u),It(globalThis[u])):It(globalThis)}function xy(u){return u=Rs(u>>>0),It(t[u])}function ky(u,f){return f>>>=0,u=Ct(u>>>0),f=Ct(f),It(u[f])}function Ty(u){9<(u>>>=0)&&(Or[u+1]+=1)}function Qd(u,f,m,g,b){return Eo[u>>>0](f>>>0,m>>>0,g>>>0,b>>>0)}function Ey(u,f,m,g,b){return Qd(u>>>0,f>>>0,m>>>0,g>>>0,b>>>0)}function Ay(){return It([])}function Cy(u){u=Ct(u>>>0);for(var f=Array(u.length),m=0;m<u.length;m++)f[m]=u[m];return It(f)}function Sy(u){return It(Rs(u>>>0))}function Py(){return It({})}function Fy(u){for(var f=Ct(u>>>=0);f.length;){var m=f.pop();f.pop()(m)}yo(u)}function Ly(u,f,m){f>>>=0,m>>>=0,u=Ct(u>>>0),f=Ct(f),m=Ct(m),u[f]=m}function Iy(u,f){u=et(u),f>>>=0,u=new Date(1e3*u),(x(),D)[f>>>2>>>0]=u.getUTCSeconds(),(x(),D)[f+4>>>2>>>0]=u.getUTCMinutes(),(x(),D)[f+8>>>2>>>0]=u.getUTCHours(),(x(),D)[f+12>>>2>>>0]=u.getUTCDate(),(x(),D)[f+16>>>2>>>0]=u.getUTCMonth(),(x(),D)[f+20>>>2>>>0]=u.getUTCFullYear()-1900,(x(),D)[f+24>>>2>>>0]=u.getUTCDay(),u=(u.getTime()-Date.UTC(u.getUTCFullYear(),0,1,0,0,0,0))/864e5|0,(x(),D)[f+28>>>2>>>0]=u}var Xd=u=>u%4==0&&(u%100!=0||u%400==0),Yd=[0,31,60,91,121,152,182,213,244,274,305,335],Jd=[0,31,59,90,120,151,181,212,243,273,304,334];function Oy(u,f){u=et(u),f>>>=0,u=new Date(1e3*u),(x(),D)[f>>>2>>>0]=u.getSeconds(),(x(),D)[f+4>>>2>>>0]=u.getMinutes(),(x(),D)[f+8>>>2>>>0]=u.getHours(),(x(),D)[f+12>>>2>>>0]=u.getDate(),(x(),D)[f+16>>>2>>>0]=u.getMonth(),(x(),D)[f+20>>>2>>>0]=u.getFullYear()-1900,(x(),D)[f+24>>>2>>>0]=u.getDay();var m=(Xd(u.getFullYear())?Yd:Jd)[u.getMonth()]+u.getDate()-1|0;(x(),D)[f+28>>>2>>>0]=m,(x(),D)[f+36>>>2>>>0]=-60*u.getTimezoneOffset(),m=new Date(u.getFullYear(),6,1).getTimezoneOffset();var g=new Date(u.getFullYear(),0,1).getTimezoneOffset();u=0|(m!=g&&u.getTimezoneOffset()==Math.min(g,m)),(x(),D)[f+32>>>2>>>0]=u}function Ny(u){u>>>=0;var f=new Date((x(),D)[u+20>>>2>>>0]+1900,(x(),D)[u+16>>>2>>>0],(x(),D)[u+12>>>2>>>0],(x(),D)[u+8>>>2>>>0],(x(),D)[u+4>>>2>>>0],(x(),D)[u>>>2>>>0],0),m=(x(),D)[u+32>>>2>>>0],g=f.getTimezoneOffset(),b=new Date(f.getFullYear(),6,1).getTimezoneOffset(),E=new Date(f.getFullYear(),0,1).getTimezoneOffset(),F=Math.min(E,b);return 0>m?(x(),D)[u+32>>>2>>>0]=+(b!=E&&F==g):0<m!=(F==g)&&(b=Math.max(E,b),f.setTime(f.getTime()+6e4*((0<m?F:b)-g))),(x(),D)[u+24>>>2>>>0]=f.getDay(),m=(Xd(f.getFullYear())?Yd:Jd)[f.getMonth()]+f.getDate()-1|0,(x(),D)[u+28>>>2>>>0]=m,(x(),D)[u>>>2>>>0]=f.getSeconds(),(x(),D)[u+4>>>2>>>0]=f.getMinutes(),(x(),D)[u+8>>>2>>>0]=f.getHours(),(x(),D)[u+12>>>2>>>0]=f.getDate(),(x(),D)[u+16>>>2>>>0]=f.getMonth(),(x(),D)[u+20>>>2>>>0]=f.getYear(),u=f.getTime(),BigInt(isNaN(u)?-1:u/1e3)}function Kd(u,f,m,g,b,E,F){return s?le(16,1,u,f,m,g,b,E,F):-52}function Zd(u,f,m,g,b,E){if(s)return le(17,1,u,f,m,g,b,E)}var Bn={},Dy=()=>performance.timeOrigin+performance.now();function eh(u,f){if(s)return le(18,1,u,f);if(Bn[u]&&(clearTimeout(Bn[u].id),delete Bn[u]),!f)return 0;var m=setTimeout(()=>{delete Bn[u],_t(()=>Sh(u,performance.timeOrigin+performance.now()))},f);return Bn[u]={id:m,Ae:f},0}function zy(u,f,m,g){u>>>=0,f>>>=0,m>>>=0,g>>>=0;var b=new Date().getFullYear(),E=new Date(b,0,1).getTimezoneOffset();b=new Date(b,6,1).getTimezoneOffset();var F=Math.max(E,b);(x(),O)[u>>>2>>>0]=60*F,(x(),D)[f>>>2>>>0]=+(E!=b),u=(f=N=>{var U=Math.abs(N);return`UTC${0<=N?"-":"+"}${String(Math.floor(U/60)).padStart(2,"0")}${String(U%60).padStart(2,"0")}`})(E),f=f(b),b<E?(or(u,m,17),or(f,g,17)):(or(u,g,17),or(f,m,17))}var By=()=>Date.now();function Ry(u,f,m){return m>>>=0,0<=u&&3>=u?(u===0?u=Date.now():u=performance.timeOrigin+performance.now(),u=Math.round(1e6*u),(x(),ee)[m>>>3>>>0]=BigInt(u),0):28}var Ao=[],th=(u,f)=>{Ao.length=0;for(var m;m=(x(),$)[u++>>>0];){var g=m!=105;f+=(g&=m!=112)&&f%8?4:0,Ao.push(m==112?(x(),O)[f>>>2>>>0]:m==106?(x(),ee)[f>>>3>>>0]:m==105?(x(),D)[f>>>2>>>0]:(x(),W)[f>>>3>>>0]),f+=g?8:4}return Ao};function Gy(u,f,m){return u>>>=0,f=th(f>>>0,m>>>0),Vo[u](...f)}function $y(u,f,m){return u>>>=0,f=th(f>>>0,m>>>0),Vo[u](...f)}var Vy=()=>{};function Uy(u,f){return S(Kr(u>>>0,f>>>0))}var jy=()=>{throw be+=1,"unwind"};function qy(){return 4294901760}var Wy=()=>1,Hy=()=>navigator.hardwareConcurrency;function Qy(u){u>>>=0;var f=(x(),$).length;if(u<=f||4294901760<u)return!1;for(var m=1;4>=m;m*=2){var g=f*(1+.2/m);g=Math.min(g,u+100663296);e:{g=(Math.min(4294901760,65536*Math.ceil(Math.max(u,g)/65536))-vr.buffer.byteLength+65535)/65536|0;try{vr.grow(g),X();var b=1;break e}catch{}b=void 0}if(b)return!0}return!1}var Xt=u=>{var f=ir(u)+1,m=Us(f);return or(u,m,f),m},Co=(u,f)=>{(x(),O)[u>>>2>>>0]=f;var m=(x(),O)[u>>>2>>>0];(x(),O)[u+4>>>2>>>0]=(f-m)/4294967296},Rn=u=>(x(),O)[u>>>2>>>0]+4294967296*(x(),D)[u+4>>>2>>>0],tt=[],Xy=(u,f)=>{tt[u>>>0]=f},lr=[],Gs=[],en=(u,f)=>{Gs[u]=new Promise(m=>f.finally(()=>m(u)))},ne=u=>{if(u)return tt[u>>>0]},Yy=(u,f)=>{for(u=(x(),O)[u>>>2>>>0];u;u=(x(),O)[u>>>2>>>0])f[(x(),D)[u+4>>>2>>>0]](u)},$s=(u,f,m)=>{(x(),O)[u>>>2>>>0]=f,(x(),O)[u+4>>>2>>>0]=m},rh=u=>{var f=(x(),O)[u>>>2>>>0];return u=(x(),O)[u+4>>>2>>>0],Kr(f,u)},cr=u=>{var f=(x(),O)[u>>>2>>>0];return u=(x(),O)[u+4>>>2>>>0],f?Kr(f,u):u===0?"":void 0},Jy=u=>{var f=cr(u+4),m=(m=(x(),O)[u+12>>>2>>>0])?ne(m):"auto";if(u+=16){var g=ne((x(),O)[u+4>>>2>>>0]),b=(x(),O)[u+16>>>2>>>0],E=(x(),O)[u+20>>>2>>>0];if(b){for(var F={},N=0;N<b;++N){var U=E+24*N;F[rh(U+4)]=(x(),W)[U+16>>>3>>>0]}b=F}else b=void 0;u={module:g,constants:b,entryPoint:cr(u+8)}}else u=void 0;return{label:f,layout:m,compute:u}},nh=(u,f)=>{function m(g,b){g=u[g],(x(),O)[f+b>>>2>>>0]=g}m("maxTextureDimension1D",4),m("maxTextureDimension2D",8),m("maxTextureDimension3D",12),m("maxTextureArrayLayers",16),m("maxBindGroups",20),m("maxBindGroupsPlusVertexBuffers",24),m("maxBindingsPerBindGroup",28),m("maxDynamicUniformBuffersPerPipelineLayout",32),m("maxDynamicStorageBuffersPerPipelineLayout",36),m("maxSampledTexturesPerShaderStage",40),m("maxSamplersPerShaderStage",44),m("maxStorageBuffersPerShaderStage",48),m("maxStorageTexturesPerShaderStage",52),m("maxUniformBuffersPerShaderStage",56),m("minUniformBufferOffsetAlignment",80),m("minStorageBufferOffsetAlignment",84),Co(f+64,u.maxUniformBufferBindingSize),Co(f+72,u.maxStorageBufferBindingSize),m("maxVertexBuffers",88),Co(f+96,u.maxBufferSize),m("maxVertexAttributes",104),m("maxVertexBufferArrayStride",108),m("maxInterStageShaderVariables",112),m("maxColorAttachments",116),m("maxColorAttachmentBytesPerSample",120),m("maxComputeWorkgroupStorageSize",124),m("maxComputeInvocationsPerWorkgroup",128),m("maxComputeWorkgroupSizeX",132),m("maxComputeWorkgroupSizeY",136),m("maxComputeWorkgroupSizeZ",140),m("maxComputeWorkgroupsPerDimension",144),u.ze!==void 0&&m("maxImmediateSize",148)},Ky=[,"validation","out-of-memory","internal"],Zy=[,"compatibility","core"],sh={1:"core-features-and-limits",2:"depth-clip-control",3:"depth32float-stencil8",4:"texture-compression-bc",5:"texture-compression-bc-sliced-3d",6:"texture-compression-etc2",7:"texture-compression-astc",8:"texture-compression-astc-sliced-3d",9:"timestamp-query",10:"indirect-first-instance",11:"shader-f16",12:"rg11b10ufloat-renderable",13:"bgra8unorm-storage",14:"float32-filterable",15:"float32-blendable",16:"clip-distances",17:"dual-source-blending",18:"subgroups",19:"texture-formats-tier1",20:"texture-formats-tier2",21:"primitive-index",22:"texture-component-swizzle",327692:"chromium-experimental-unorm16-texture-formats",327729:"chromium-experimental-multi-draw-indirect"},eb=[,"low-power","high-performance"],tb=[,"occlusion","timestamp"],rb={undefined:1,unknown:1,destroyed:2};function nb(u,f,m,g,b,E){f=et(f),m=et(m),g>>>=0,b>>>=0,E>>>=0;var F=ne(u>>>0);if(u={},E){var N=(x(),O)[E+12>>>2>>>0];if(N){var U=(x(),O)[E+16>>>2>>>0];u.requiredFeatures=Array.from((x(),O).subarray(U>>>2>>>0,U+4*N>>>2>>>0),K=>sh[K])}var Y=(x(),O)[E+20>>>2>>>0];if(Y){let K=function(Le,Ye,Vn=!1){Ye=Y+Ye,(Ye=(x(),O)[Ye>>>2>>>0])==4294967295||Vn&&Ye==0||(ve[Le]=Ye)},fe=function(Le,Ye){Ye=Y+Ye;var Vn=(x(),O)[Ye>>>2>>>0],Uo=(x(),O)[Ye+4>>>2>>>0];Vn==4294967295&&Uo==4294967295||(ve[Le]=Rn(Ye))};var ve={};K("maxTextureDimension1D",4),K("maxTextureDimension2D",8),K("maxTextureDimension3D",12),K("maxTextureArrayLayers",16),K("maxBindGroups",20),K("maxBindGroupsPlusVertexBuffers",24),K("maxDynamicUniformBuffersPerPipelineLayout",32),K("maxDynamicStorageBuffersPerPipelineLayout",36),K("maxSampledTexturesPerShaderStage",40),K("maxSamplersPerShaderStage",44),K("maxStorageBuffersPerShaderStage",48),K("maxStorageTexturesPerShaderStage",52),K("maxUniformBuffersPerShaderStage",56),K("minUniformBufferOffsetAlignment",80),K("minStorageBufferOffsetAlignment",84),fe("maxUniformBufferBindingSize",64),fe("maxStorageBufferBindingSize",72),K("maxVertexBuffers",88),fe("maxBufferSize",96),K("maxVertexAttributes",104),K("maxVertexBufferArrayStride",108),K("maxInterStageShaderVariables",112),K("maxColorAttachments",116),K("maxColorAttachmentBytesPerSample",120),K("maxComputeWorkgroupStorageSize",124),K("maxComputeInvocationsPerWorkgroup",128),K("maxComputeWorkgroupSizeX",132),K("maxComputeWorkgroupSizeY",136),K("maxComputeWorkgroupSizeZ",140),K("maxComputeWorkgroupsPerDimension",144),K("maxImmediateSize",148,!0),u.requiredLimits=ve}(N=(x(),O)[E+24>>>2>>>0])&&(N={label:cr(N+4)},u.defaultQueue=N),u.label=cr(E+4)}be+=1,en(f,F.requestDevice(u).then(K=>{--be,_t(()=>{tt[b>>>0]=K.queue,tt[g>>>0]=K,be+=1,en(m,K.lost.then(fe=>{_t(()=>{K.onuncapturederror=()=>{};var Le=ae(),Ye=Xt(fe.message);Io(m,rb[fe.reason],Ye),se(Le)}),--be})),K.onuncapturederror=fe=>{var Le=5;fe.error instanceof GPUValidationError?Le=2:fe.error instanceof GPUOutOfMemoryError?Le=3:fe.error instanceof GPUInternalError&&(Le=4);var Ye=ae();fe=Xt(fe.error.message),Th(g,Le,fe),se(Ye)},"adapterInfo"in K||(K.adapterInfo=F.info),Do(f,1,g,0)})},K=>{--be,_t(()=>{var fe=ae(),Le=Xt(K.message);Do(f,3,g,Le),m&&Io(m,4,Le),se(fe)})}))}function sb(u){var f=ne(u>>>=0),m=lr[u];if(m){for(var g=0;g<m.length;++g)m[g]();delete lr[u]}f.destroy()}function ab(u,f,m){m>>>=0;var g=ne(u>>>=0);m==4294967295&&(m=void 0);try{var b=g.getMappedRange(f>>>0,m)}catch{return 0}var E=Ro(16,b.byteLength);return(x(),$).set(new Uint8Array(b),E>>>0),lr[u].push(()=>Ot(E)),E}function ob(u,f,m){m>>>=0;var g=ne(u>>>=0);m==4294967295&&(m=void 0);try{var b=g.getMappedRange(f>>>0,m)}catch{return 0}var E=Ro(16,b.byteLength);return(x(),$).fill(0,E,b.byteLength),lr[u].push(()=>{new Uint8Array(b).set((x(),$).subarray(E>>>0,E+b.byteLength>>>0)),Ot(E)}),E}function ib(u,f,m,g,b){u>>>=0,f=et(f),m=et(m),b>>>=0;var E=ne(u);lr[u]=[],b==4294967295&&(b=void 0),be+=1,en(f,E.mapAsync(m,g>>>0,b).then(()=>{--be,_t(()=>{Oo(f,1,0)})},F=>{--be,_t(()=>{ae();var N=Xt(F.message);Oo(f,F.name==="AbortError"?4:F.name==="OperationError"?3:0,N),delete lr[u]})}))}function lb(u){var f=ne(u>>>=0),m=lr[u];if(m){for(var g=0;g<m.length;++g)m[g]();delete lr[u],f.unmap()}}function cb(u){delete tt[u>>>0]}function ub(u,f,m){u>>>=0,f>>>=0,m>>>=0;var g=!!(x(),O)[f+32>>>2>>>0];f={label:cr(f+4),usage:(x(),O)[f+16>>>2>>>0],size:Rn(f+24),mappedAtCreation:g},u=ne(u);try{var b=u.createBuffer(f)}catch{return!1}return tt[m>>>0]=b,g&&(lr[m]=[]),!0}function db(u,f,m,g){u>>>=0,f=et(f),g>>>=0,m=Jy(m>>>0),u=ne(u),be+=1,en(f,u.createComputePipelineAsync(m).then(b=>{--be,_t(()=>{tt[g>>>0]=b,Lo(f,1,g,0)})},b=>{--be,_t(()=>{var E=ae(),F=Xt(b.message);Lo(f,b.reason==="validation"?3:b.reason==="internal"?4:0,g,F),se(E)})}))}function hb(u,f,m){u>>>=0,f>>>=0,m>>>=0;var g=(x(),O)[f>>>2>>>0],b=(x(),D)[g+4>>>2>>>0];f={label:cr(f+4),code:""},b===2&&(f.code=rh(g+8)),u=ne(u).createShaderModule(f),tt[m>>>0]=u}var fb=u=>{(u=ne(u)).onuncapturederror=null,u.destroy()};function _b(u,f){f=et(f),u=ne(u>>>0),be+=1,en(f,u.popErrorScope().then(m=>{--be,_t(()=>{var g=5;m?m instanceof GPUValidationError?g=2:m instanceof GPUOutOfMemoryError?g=3:m instanceof GPUInternalError&&(g=4):g=1;var b=ae(),E=m?Xt(m.message):0;No(f,1,g,E),se(b)})},m=>{--be,_t(()=>{var g=ae(),b=Xt(m.message);No(f,1,5,b),se(g)})}))}function pb(u,f,m,g){if(f=et(f),g>>>=0,m>>>=0){var b={featureLevel:Zy[(x(),D)[m+4>>>2>>>0]],powerPreference:eb[(x(),D)[m+8>>>2>>>0]],forceFallbackAdapter:!!(x(),O)[m+12>>>2>>>0]};(u=(x(),O)[m>>>2>>>0])!==0&&(x(),b.De=!!(x(),O)[u+8>>>2>>>0])}"gpu"in navigator?(be+=1,en(f,navigator.gpu.requestAdapter(b).then(E=>{--be,_t(()=>{if(E)tt[g>>>0]=E,Gn(f,1,g,0);else{var F=ae(),N=Xt("WebGPU not available on this browser (requestAdapter returned null)");Gn(f,3,g,N),se(F)}})},E=>{--be,_t(()=>{var F=ae(),N=Xt(E.message);Gn(f,4,g,N),se(F)})}))):(b=ae(),u=Xt("WebGPU not available on this browser (navigator.gpu is not available)"),Gn(f,3,g,u),se(b))}function mb(u,f,m){return u>>>=0,f>>>=0,m>>>=0,Hd(async()=>{var g=[];if(m){var b=(x(),D)[m>>>2>>>0];g.length=f+1,g[f]=new Promise(N=>setTimeout(N,b,0))}else g.length=f;for(var E=0;E<f;++E){var F=Rn(u+8*E);if(!(F in Gs))return F;g[E]=Gs[F]}return g=await Promise.race(g),delete Gs[g],g})}var So,Po={},ah=()=>{var g;if(!So){var u,f={USER:"web_user",LOGNAME:"web_user",PATH:"/",PWD:"/",HOME:"/home/web_user",LANG:(((g=globalThis.navigator)==null?void 0:g.language)??"C").replace("-","_")+".UTF-8",_:"./this.program"};for(u in Po)Po[u]===void 0?delete f[u]:f[u]=Po[u];var m=[];for(u in f)m.push(`${u}=${f[u]}`);So=m}return So};function oh(u,f){if(s)return le(19,1,u,f);u>>>=0,f>>>=0;var m,g=0,b=0;for(m of ah()){var E=f+g;(x(),O)[u+b>>>2>>>0]=E,g+=or(m,E,1/0)+1,b+=4}return 0}function ih(u,f){if(s)return le(20,1,u,f);u>>>=0,f>>>=0;var m=ah();for(var g of((x(),O)[u>>>2>>>0]=m.length,u=0,m))u+=ir(g)+1;return(x(),O)[f>>>2>>>0]=u,0}function lh(u){return s?le(21,1,u):52}function ch(u,f,m,g){return s?le(22,1,u,f,m,g):52}function uh(u,f,m,g){return s?le(23,1,u,f,m,g):70}var gb=[null,[],[]];function dh(u,f,m,g){if(s)return le(24,1,u,f,m,g);f>>>=0,m>>>=0,g>>>=0;for(var b=0,E=0;E<m;E++){var F=(x(),O)[f>>>2>>>0],N=(x(),O)[f+4>>>2>>>0];f+=8;for(var U=0;U<N;U++){var Y=u,ve=(x(),$)[F+U>>>0],K=gb[Y];ve===0||ve===10?((Y===1?A:S)(Ad(K)),K.length=0):K.push(ve)}b+=N}return(x(),O)[g>>>2>>>0]=b,0}function wb(u){return u>>>0}function vb(u,f){return nh(ne(u>>>0).limits,f>>>0),1}function yb(u,f){return ne(u>>>0).features.has(sh[f])}function bb(u){return BigInt(ne(u>>>0).size)}function Mb(u){return BigInt(ne(u>>>0).usage)}function xb(u,f){if(u>>>=0,f>>>=0){var m=cr(f+4);m={label:m,timestampWrites:f=(f=(x(),O)[f+12>>>2>>>0])!==0?{querySet:ne((x(),O)[f+4>>>2>>>0]),beginningOfPassWriteIndex:(x(),O)[f+8>>>2>>>0],endOfPassWriteIndex:(x(),O)[f+12>>>2>>>0]}:void 0}}return f=ne(u),u=yh(0),m=f.beginComputePass(m),tt[u>>>0]=m,u}function kb(u,f,m,g){m=et(m),(g=et(g))==-1&&(g=void 0),(u=ne(u>>>0)).clearBuffer(ne(f>>>0),m,g)}function Tb(u,f,m,g,b,E){m=et(m),b=et(b),E=et(E),ne(u>>>0).copyBufferToBuffer(ne(f>>>0),m,ne(g>>>0),b,E)}function Eb(u){var f=ne(u>>>0);return u=wh(0),f=f.finish(),tt[u>>>0]=f,u}function Ab(u,f,m,g,b,E){E=et(E),ne(u>>>0).resolveQuerySet(ne(f>>>0),m,g,ne(b>>>0),E)}function Cb(u,f,m,g){ne(u>>>0).dispatchWorkgroups(f,m,g)}function Sb(u,f,m){m=et(m),ne(u>>>0).dispatchWorkgroupsIndirect(ne(f>>>0),m)}function Pb(u){ne(u>>>0).end()}function Fb(u,f,m,g,b){g>>>=0,b>>>=0,u=ne(u>>>0),m=ne(m>>>0),g==0?u.setBindGroup(f,m):u.setBindGroup(f,m,(x(),O),b>>>2,g)}function Lb(u,f){ne(u>>>0).setPipeline(ne(f>>>0))}function Ib(u,f,m){ne(u>>>0).Ce(ne(f>>>0),m)}function Ob(u,f){var m=ne(u>>>0);return u=gh(0),f=m.getBindGroupLayout(f),tt[u>>>0]=f,u}function Nb(u,f){function m(b){var E=(x(),O)[b+8>>>2>>>0],F=(x(),O)[b+32>>>2>>>0],N=(x(),O)[b+36>>>2>>>0],U=0;return Yy(b,{327681:Y=>{U=(x(),O)[Y+8>>>2>>>0]}}),E?((F=Rn(b+24))==-1&&(F=void 0),E={buffer:ne(E),offset:Rn(b+16),size:F}):E=ne(F||N||U),{binding:(x(),O)[b+4>>>2>>>0],resource:E}}u>>>=0,f={label:cr(4+(f>>>=0)),layout:ne((x(),O)[f+12>>>2>>>0]),entries:(function(b,E){for(var F=[],N=0;N<b;++N)F.push(m(E+40*N));return F})((x(),O)[f+16>>>2>>>0],(x(),O)[f+20>>>2>>>0])},u=ne(u);var g=mh(0);return Xy(g,u.createBindGroup(f)),g}function Db(u,f){var m;return u>>>=0,(f>>>=0)&&(m={label:cr(f+4)}),f=ne(u),u=vh(0),m=f.createCommandEncoder(m),tt[u>>>0]=m,u}function zb(u,f){u>>>=0,f>>>=0,f={type:tb[(x(),D)[f+12>>>2>>>0]],count:(x(),O)[f+16>>>2>>>0]};var m=ne(u);return u=bh(0),f=m.createQuerySet(f),tt[u>>>0]=f,u}function Bb(u,f){u=ne(u>>>0).adapterInfo,f>>>=0,(x(),O)[f+52>>>2>>>0]=u.subgroupMinSize,(x(),O)[f+56>>>2>>>0]=u.subgroupMaxSize;var m=u.vendor+u.architecture+u.device+u.description,g=ir(m)+1,b=tn(g);return b&&or(m,b,g),m=b,g=ir(u.vendor),$s(f+4,m,g),m+=g,g=ir(u.architecture),$s(f+12,m,g),m+=g,g=ir(u.device),$s(f+20,m,g),$s(f+28,m+g,ir(u.description)),(x(),D)[f+36>>>2>>>0]=2,u=u.isFallbackAdapter?3:4,(x(),D)[f+40>>>2>>>0]=u,(x(),O)[f+44>>>2>>>0]=0,(x(),O)[f+48>>>2>>>0]=0,1}var Rb={"core-features-and-limits":1,"depth-clip-control":2,"depth32float-stencil8":3,"texture-compression-bc":4,"texture-compression-bc-sliced-3d":5,"texture-compression-etc2":6,"texture-compression-astc":7,"texture-compression-astc-sliced-3d":8,"timestamp-query":9,"indirect-first-instance":10,"shader-f16":11,"rg11b10ufloat-renderable":12,"bgra8unorm-storage":13,"float32-filterable":14,"float32-blendable":15,"clip-distances":16,"dual-source-blending":17,subgroups:18,"texture-formats-tier1":19,"texture-formats-tier2":20,"primitive-index":21,"texture-component-swizzle":22,"chromium-experimental-unorm16-texture-formats":327692,"chromium-experimental-multi-draw-indirect":327729};function Gb(u,f){f>>>=0;var m=ne(u>>>0);u=tn(4*m.features.size);var g=0,b=0;for(let E of m.features)0<=(m=Rb[E])&&((x(),D)[u+g>>>2>>>0]=m,g+=4,b++);(x(),O)[f+4>>>2>>>0]=u,(x(),O)[f>>>2>>>0]=b}function $b(u,f){return nh(ne(u>>>0).limits,f>>>0),1}function Vb(u,f){ne(u>>>0).pushErrorScope(Ky[f])}function Ub(u,f,m){f>>>=0,m>>>=0,u=ne(u>>>0),f=Array.from((x(),D).subarray(m>>>2>>>0,m+4*f>>>2>>>0),g=>ne(g)),u.submit(f)}function jb(u,f,m,g,b){m=et(m),g>>>=0,b>>>=0,u=ne(u>>>0),f=ne(f>>>0),g=(x(),$).subarray(g>>>0,g+b>>>0),u.writeBuffer(f,m,g,0,b)}s||(function(){for(var u=t.numThreads-1;u--;)yd();Tt.push(async()=>{var f=(async function(){if(!s)return Promise.all(At.map(vd))})();Et++,await f,--Et==0&&je&&(f=je,je=null,f())})})(),s||(vr=new WebAssembly.Memory({initial:256,maximum:65536,shared:!0}),X()),t.wasmBinary&&(h=t.wasmBinary),t.stackSave=()=>ae(),t.stackRestore=u=>se(u),t.stackAlloc=u=>Us(u),t.setValue=function(u,f,m="i8"){switch(m.endsWith("*")&&(m="*"),m){case"i1":case"i8":(x(),z)[u>>>0]=f;break;case"i16":(x(),Q)[u>>>1>>>0]=f;break;case"i32":(x(),D)[u>>>2>>>0]=f;break;case"i64":(x(),ee)[u>>>3>>>0]=BigInt(f);break;case"float":(x(),te)[u>>>2>>>0]=f;break;case"double":(x(),W)[u>>>3>>>0]=f;break;case"*":(x(),O)[u>>>2>>>0]=f;break;default:me(`invalid type for setValue: ${m}`)}},t.getValue=function(u,f="i8"){switch(f.endsWith("*")&&(f="*"),f){case"i1":case"i8":return(x(),z)[u>>>0];case"i16":return(x(),Q)[u>>>1>>>0];case"i32":return(x(),D)[u>>>2>>>0];case"i64":return(x(),ee)[u>>>3>>>0];case"float":return(x(),te)[u>>>2>>>0];case"double":return(x(),W)[u>>>3>>>0];case"*":return(x(),O)[u>>>2>>>0];default:me(`invalid type for getValue: ${f}`)}},t.UTF8ToString=Kr,t.stringToUTF8=or,t.lengthBytesUTF8=ir;var hh,fh,Fo,Vs,Ot,tn,_h,ph,mh,gh,wh,vh,yh,bh,Mh,xh,kh,Lo,Io,Oo,No,Gn,Do,Th,zo,Eh,Ah,Ch,Bo,Sh,Ph,Ro,pe,$n,Fh,se,Us,ae,Lh,Go,Ih,Oh,Nh,$o,Dh,zh,Bh,Rh,Gh,$h,Vh,Uh,jh,qh,Wh,Hh,Qh,Xh,Yh,Jh,Kh,Zh,ef,tf,rf,nf,sf,af,of,lf,cf,uf,df,hf,ff,_f,pf,mf,gf,wf,vf,yf,ur,qb=[Se,ft,xd,Cd,Sd,Pd,Fd,Ld,Id,Od,Nd,Dd,zd,Bd,Rd,Gd,Kd,Zd,eh,oh,ih,lh,ch,uh,dh],Vo={970348:(u,f,m,g,b)=>{if(t===void 0||!t.Uc)return 1;if((u=Kr(Number(u>>>0))).startsWith("./")&&(u=u.substring(2)),!(u=t.Uc.get(u)))return 2;if(f=Number(f>>>0),m=Number(m>>>0),g=Number(g>>>0),f+m>u.byteLength)return 3;try{let E=u.subarray(f,f+m);switch(b){case 0:(x(),$).set(E,g>>>0);break;case 1:t.ad?t.ad(g,E):t.ne(g,E);break;default:return 4}return 0}catch{return 4}},971172:(u,f,m)=>{t.Sd(u,(x(),$).subarray(f>>>0,f+m>>>0))},971236:()=>t.le(),971278:u=>{t.jd(u)},971315:()=>typeof wasmOffsetConverter<"u"};function Wb(u,f,m,g){var b=ae();try{return Uh(u,f,m,g)}catch(E){if(se(b),E!==E+0)throw E;pe(1,0)}}function Hb(u,f,m){var g=ae();try{return Gh(u,f,m)}catch(b){if(se(g),b!==b+0)throw b;pe(1,0)}}function Qb(u){var f=ae();try{Dh(u)}catch(m){if(se(f),m!==m+0)throw m;pe(1,0)}}function Xb(u,f){var m=ae();try{return $o(u,f)}catch(g){if(se(m),g!==g+0)throw g;pe(1,0)}}function Yb(u,f,m){var g=ae();try{Nh(u,f,m)}catch(b){if(se(g),b!==b+0)throw b;pe(1,0)}}function Jb(u,f){var m=ae();try{jh(u,f)}catch(g){if(se(m),g!==g+0)throw g;pe(1,0)}}function Kb(u,f,m,g,b,E,F){var N=ae();try{return Rh(u,f,m,g,b,E,F)}catch(U){if(se(N),U!==U+0)throw U;pe(1,0)}}function Zb(u,f,m,g,b,E){var F=ae();try{zh(u,f,m,g,b,E)}catch(N){if(se(F),N!==N+0)throw N;pe(1,0)}}function e0(u,f,m,g){var b=ae();try{Vh(u,f,m,g)}catch(E){if(se(b),E!==E+0)throw E;pe(1,0)}}function t0(u,f,m,g,b,E,F){var N=ae();try{Wh(u,f,m,g,b,E,F)}catch(U){if(se(N),U!==U+0)throw U;pe(1,0)}}function r0(u,f,m,g,b,E,F){var N=ae();try{Hh(u,f,m,g,b,E,F)}catch(U){if(se(N),U!==U+0)throw U;pe(1,0)}}function n0(u,f,m,g,b,E,F,N){var U=ae();try{rf(u,f,m,g,b,E,F,N)}catch(Y){if(se(U),Y!==Y+0)throw Y;pe(1,0)}}function s0(u,f,m,g,b,E,F,N,U,Y,ve,K){var fe=ae();try{Qh(u,f,m,g,b,E,F,N,U,Y,ve,K)}catch(Le){if(se(fe),Le!==Le+0)throw Le;pe(1,0)}}function a0(u,f,m,g,b){var E=ae();try{return qh(u,f,m,g,b)}catch(F){if(se(E),F!==F+0)throw F;pe(1,0)}}function o0(u,f,m,g,b){var E=ae();try{Bh(u,f,m,g,b)}catch(F){if(se(E),F!==F+0)throw F;pe(1,0)}}function i0(u,f,m,g,b,E,F,N){var U=ae();try{$h(u,f,m,g,b,E,F,N)}catch(Y){if(se(U),Y!==Y+0)throw Y;pe(1,0)}}function l0(u){var f=ae();try{return nf(u)}catch(m){if(se(f),m!==m+0)throw m;pe(1,0)}}function c0(u,f,m){var g=ae();try{return sf(u,f,m)}catch(b){if(se(g),b!==b+0)throw b;pe(1,0)}}function u0(u,f){var m=ae();try{return mf(u,f)}catch(g){if(se(m),g!==g+0)throw g;return pe(1,0),0n}}function d0(u){var f=ae();try{return Xh(u)}catch(m){if(se(f),m!==m+0)throw m;return pe(1,0),0n}}function h0(u,f,m,g){var b=ae();try{return af(u,f,m,g)}catch(E){if(se(b),E!==E+0)throw E;pe(1,0)}}function f0(u,f,m,g,b){var E=ae();try{return of(u,f,m,g,b)}catch(F){if(se(E),F!==F+0)throw F;pe(1,0)}}function _0(u,f,m,g,b,E){var F=ae();try{return lf(u,f,m,g,b,E)}catch(N){if(se(F),N!==N+0)throw N;pe(1,0)}}function p0(u,f,m,g,b,E){var F=ae();try{return ef(u,f,m,g,b,E)}catch(N){if(se(F),N!==N+0)throw N;pe(1,0)}}function m0(u,f,m,g,b,E){var F=ae();try{return cf(u,f,m,g,b,E)}catch(N){if(se(F),N!==N+0)throw N;pe(1,0)}}function g0(u,f,m,g,b,E,F,N){var U=ae();try{return tf(u,f,m,g,b,E,F,N)}catch(Y){if(se(U),Y!==Y+0)throw Y;pe(1,0)}}function w0(u,f,m,g,b){var E=ae();try{return uf(u,f,m,g,b)}catch(F){if(se(E),F!==F+0)throw F;return pe(1,0),0n}}function v0(u,f,m,g){var b=ae();try{return df(u,f,m,g)}catch(E){if(se(b),E!==E+0)throw E;pe(1,0)}}function y0(u,f,m,g){var b=ae();try{return hf(u,f,m,g)}catch(E){if(se(b),E!==E+0)throw E;pe(1,0)}}function b0(u,f,m,g,b,E,F,N,U,Y,ve,K){var fe=ae();try{return ff(u,f,m,g,b,E,F,N,U,Y,ve,K)}catch(Le){if(se(fe),Le!==Le+0)throw Le;pe(1,0)}}function M0(u,f,m,g,b,E,F,N,U,Y,ve){var K=ae();try{_f(u,f,m,g,b,E,F,N,U,Y,ve)}catch(fe){if(se(K),fe!==fe+0)throw fe;pe(1,0)}}function x0(u,f,m,g,b,E,F,N,U,Y,ve,K,fe,Le,Ye,Vn){var Uo=ae();try{pf(u,f,m,g,b,E,F,N,U,Y,ve,K,fe,Le,Ye,Vn)}catch(jo){if(se(Uo),jo!==jo+0)throw jo;pe(1,0)}}function k0(u,f,m){var g=ae();try{return Jh(u,f,m)}catch(b){if(se(g),b!==b+0)throw b;return pe(1,0),0n}}function T0(u,f,m){var g=ae();try{return Yh(u,f,m)}catch(b){if(se(g),b!==b+0)throw b;pe(1,0)}}function E0(u,f,m){var g=ae();try{return Kh(u,f,m)}catch(b){if(se(g),b!==b+0)throw b;pe(1,0)}}function A0(u,f,m,g){var b=ae();try{Zh(u,f,m,g)}catch(E){if(se(b),E!==E+0)throw E;pe(1,0)}}function js(){if(0<Et)je=js;else if(s)w==null||w(t),J();else{for(var u=Tt;0<u.length;)u.shift()(t);0<Et?je=js:(t.calledRun=!0,C||(J(),w==null||w(t)))}}return s||(ur=await Fe(),js()),t.PTR_SIZE=4,t.webgpuInit=u=>{let f=new WeakMap,m,g,b=1;t.webgpuRegisterDevice=N=>{if(g!==void 0)throw Error("another WebGPU EP inference session is being created.");if(N){var U=f.get(N);if(!U){let Y=((ve,K=0)=>{var fe=kh(K);return K=xh(K,fe),tt[fe>>>0]=ve.queue,tt[K>>>0]=ve,K})(N,U=ph(0));U=[b++,U,Y],f.set(N,U)}return m=N,g=U[0],U}m=void 0,g=0};let E=new Map;t.webgpuOnCreateSession=N=>{if(g!==void 0){var U=g;if(g=void 0,N){let Y=Fo(U);E.set(N,Y),U===0&&u(m??ne(Y))}m=void 0}},t.webgpuOnReleaseSession=N=>{E.delete(N)};let F=Symbol("gpuBufferMetadata");t.webgpuRegisterBuffer=(N,U,Y)=>{if(Y)return N[F]=[Y,NaN],Y;if(Y=N[F])return Y[1]++,Y[0];if((U=E.get(U))===void 0)throw Error("Invalid session handle passed to webgpuRegisterBuffer");return U=((ve,K=0)=>(ve.mapState==="unmapped"||me(),K=Mh(K),tt[K>>>0]=ve,K))(N,U),N[F]=[U,1],U},t.webgpuUnregisterBuffer=N=>{let U=N[F];if(!U)throw Error("Buffer is not registered");U[1]--,U[1]===0&&(_h(U[0]),delete N[F])},t.webgpuGetBuffer=N=>ne(N),t.webgpuCreateDownloader=(N,U,Y)=>{if((Y=E.get(Y))===void 0)throw Error("Invalid session handle passed to webgpuRegisterBuffer");let ve=ne(Y),K=16*Math.ceil(Number(U)/16);return async()=>{let fe=ve.createBuffer({size:K,usage:9});try{let Le=ve.createCommandEncoder();return Le.copyBufferToBuffer(N,0,fe,0,K),ve.queue.submit([Le.finish()]),await fe.mapAsync(GPUMapMode.READ),fe.getMappedRange().slice(0,U)}finally{fe.destroy()}}},t.ad=(N,U)=>{var Y=U.buffer;let ve=U.byteOffset,K=U.byteLength;if(U=16*Math.ceil(Number(K)/16),N=ne(N),!m){var fe=Fo(g);m=ne(fe)}let Le=(fe=m.createBuffer({mappedAtCreation:!0,size:U,usage:6})).getMappedRange();new Uint8Array(Le).set(new Uint8Array(Y,ve,K)),fe.unmap(),(Y=m.createCommandEncoder()).copyBufferToBuffer(fe,0,N,0,U),m.queue.submit([Y.finish()]),fe.destroy()}},t.webnnInit=u=>{let f=u[0];[t.le,t.jd,t.webnnEnsureTensor,t.Sd,t.webnnDownloadTensor,t.ke,t.webnnEnableTraceEvent]=u.slice(1),t.webnnReleaseTensorId=t.jd,t.webnnUploadTensor=t.Sd,t.webnnRegisterMLContext=t.ke,t.webnnOnRunStart=m=>f.onRunStart(m),t.webnnOnRunEnd=f.onRunEnd.bind(f),t.webnnOnReleaseSession=m=>{f.onReleaseSession(m)},t.webnnCreateMLTensorDownloader=(m,g)=>f.createMLTensorDownloader(m,g),t.webnnRegisterMLTensor=(m,g,b,E)=>f.registerMLTensor(m,g,b,E),t.webnnCreateMLContext=m=>f.createMLContext(m),t.webnnRegisterMLConstant=(m,g,b,E,F,N)=>f.registerMLConstant(m,g,b,E,F,t.Uc,N),t.webnnRegisterGraphInput=f.registerGraphInput.bind(f),t.webnnIsGraphInput=f.isGraphInput.bind(f),t.webnnRegisterGraphOutput=f.registerGraphOutput.bind(f),t.webnnIsGraphOutput=f.isGraphOutput.bind(f),t.webnnCreateTemporaryTensor=f.createTemporaryTensor.bind(f),t.webnnIsGraphInputOutputTypeSupported=f.isGraphInputOutputTypeSupported.bind(f)},V?t:new Promise((u,f)=>{w=u,v=f})}var Ep,Af,X0=we(()=>{var e,t;Ep=Ef,Af=(t=(e=globalThis.self)==null?void 0:e.name)==null?void 0:t.startsWith("em-pthread"),Af&&Ef()}),Yo,al,Cf,yt,Ap,Qs,Sf,Pf,Jo,Ff,Ko,Cp,Zo,Sp,Cl=we(()=>{Al(),Yo=typeof location>"u"?void 0:location.origin,al=import.meta.url>"file:"&&import.meta.url<"file;",Cf=()=>{{if(al){let e=URL;return new URL(new e("ort.webgpu.bundle.min.mjs",import.meta.url).href,Yo).href}return import.meta.url}},yt=Cf(),Ap=()=>{if(yt&&!yt.startsWith("blob:"))return yt.substring(0,yt.lastIndexOf("/")+1)},Qs=(e,t)=>{try{let r=t??yt;return(r?new URL(e,r):new URL(e)).origin===Yo}catch{return!1}},Sf=(e,t)=>{let r=t??yt;try{return(r?new URL(e,r):new URL(e)).href}catch{return}},Pf=(e,t)=>`${t??"./"}${e}`,Jo=async e=>{let t=await(await fetch(e,{credentials:"same-origin"})).blob();return URL.createObjectURL(t)},Ff=async e=>(await import(e)).default,Ko=(Q0(),Aa(xp)).default,Cp=async()=>{if(!yt)throw new Error("Failed to load proxy worker: cannot determine the script source URL.");if(Qs(yt))return[void 0,Ko()];let e=await Jo(yt);return[e,Ko(e)]},Zo=(X0(),Aa(Tp)).default,Sp=async(e,t,r,n)=>{let s=Zo&&!(e||t);if(s)if(yt)s=Qs(yt)||n&&!r;else if(n&&!r)s=!0;else throw new Error("cannot determine the script source URL.");if(s)return[void 0,Zo];{let a="ort-wasm-simd-threaded.asyncify.mjs",o=e??Sf(a,t),i=r&&o&&!Qs(o,t),l=i?await Jo(o):o??Pf(a,t);return[i?l:void 0,await Ff(l)]}}}),ei,Xs,jn,ti,Lf,If,Of,Sl,Pe,Qr=we(()=>{Cl(),Xs=!1,jn=!1,ti=!1,Lf=()=>{if(typeof SharedArrayBuffer>"u")return!1;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}},If=()=>{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}},Of=()=>{try{return WebAssembly.validate(new Uint8Array([0,97,115,109,1,0,0,0,1,5,1,96,0,1,123,3,2,1,0,10,19,1,17,0,65,1,253,15,65,2,253,15,65,3,253,15,253,147,2,11]))}catch{return!1}},Sl=async e=>{if(Xs)return Promise.resolve();if(jn)throw new Error("multiple calls to 'initializeWebAssembly()' detected.");if(ti)throw new Error("previous call to 'initializeWebAssembly()' failed.");jn=!0;let t=e.initTimeout,r=e.numThreads;if(e.simd!==!1){if(e.simd==="relaxed"){if(!Of())throw new Error("Relaxed WebAssembly SIMD is not supported in the current environment.")}else if(!If())throw new Error("WebAssembly SIMD is not supported in the current environment.")}let n=Lf();r>1&&!n&&(typeof self<"u"&&!self.crossOriginIsolated&&console.warn("env.wasm.numThreads is set to "+r+", but this will not work unless you enable crossOriginIsolated mode. See https://web.dev/cross-origin-isolation-guide/ for more info."),console.warn("WebAssembly multi-threading is not supported in the current environment. Falling back to single-threading."),e.numThreads=r=1);let s=e.wasmPaths,a=typeof s=="string"?s:void 0,o=s==null?void 0:s.mjs,i=(o==null?void 0:o.href)??o,l=s==null?void 0:s.wasm,c=(l==null?void 0:l.href)??l,d=e.wasmBinary,[h,_]=await Sp(i,a,r>1,!!d||!!c),p=!1,w=[];if(t>0&&w.push(new Promise(v=>{setTimeout(()=>{p=!0,v()},t)})),w.push(new Promise((v,y)=>{let M={numThreads:r};if(d)M.wasmBinary=d,M.locateFile=T=>T;else if(c||a)M.locateFile=T=>c??a+T;else if(i&&i.indexOf("blob:")!==0)M.locateFile=T=>new URL(T,i).href;else if(h){let T=Ap();T&&(M.locateFile=A=>T+A)}_(M).then(T=>{jn=!1,Xs=!0,ei=T,v(),h&&URL.revokeObjectURL(h)},T=>{jn=!1,ti=!0,y(T)})})),await Promise.race(w),p)throw new Error(`WebAssembly backend initializing failed due to timeout: ${t}ms`)},Pe=()=>{if(Xs&&ei)return ei;throw new Error("WebAssembly is not initialized yet.")}}),bt,Sa,ke,Pl=we(()=>{Qr(),bt=(e,t)=>{let r=Pe(),n=r.lengthBytesUTF8(e)+1,s=r._malloc(n);return r.stringToUTF8(e,s,n),t.push(s),s},Sa=(e,t,r,n)=>{if(typeof e=="object"&&e!==null){if(r.has(e))throw new Error("Circular reference in options");r.add(e)}Object.entries(e).forEach(([s,a])=>{let o=t?t+s:s;if(typeof a=="object")Sa(a,o+".",r,n);else if(typeof a=="string"||typeof a=="number")n(o,a.toString());else if(typeof a=="boolean")n(o,a?"1":"0");else throw new Error(`Can't handle extra config type: ${typeof a}`)})},ke=e=>{let t=Pe(),r=t.stackSave();try{let n=t.PTR_SIZE,s=t.stackAlloc(2*n);t._OrtGetLastError(s,s+n);let a=Number(t.getValue(s,n===4?"i32":"i64")),o=t.getValue(s+n,"*"),i=o?t.UTF8ToString(o):"";throw new Error(`${e} ERROR_CODE: ${a}, ERROR_MESSAGE: ${i}`)}finally{t.stackRestore(r)}}}),Pp,Y0=we(()=>{Qr(),Pl(),Pp=e=>{let t=Pe(),r=0,n=[],s=e||{};try{if((e==null?void 0:e.logSeverityLevel)===void 0)s.logSeverityLevel=2;else if(typeof e.logSeverityLevel!="number"||!Number.isInteger(e.logSeverityLevel)||e.logSeverityLevel<0||e.logSeverityLevel>4)throw new Error(`log severity level is not valid: ${e.logSeverityLevel}`);if((e==null?void 0:e.logVerbosityLevel)===void 0)s.logVerbosityLevel=0;else if(typeof e.logVerbosityLevel!="number"||!Number.isInteger(e.logVerbosityLevel))throw new Error(`log verbosity level is not valid: ${e.logVerbosityLevel}`);(e==null?void 0:e.terminate)===void 0&&(s.terminate=!1);let a=0;return(e==null?void 0:e.tag)!==void 0&&(a=bt(e.tag,n)),r=t._OrtCreateRunOptions(s.logSeverityLevel,s.logVerbosityLevel,!!s.terminate,a),r===0&&ke("Can't create run options."),(e==null?void 0:e.extra)!==void 0&&Sa(e.extra,"",new WeakSet,(o,i)=>{let l=bt(o,n),c=bt(i,n);t._OrtAddRunConfigEntry(r,l,c)!==0&&ke(`Can't set a run config entry: ${o} - ${i}.`)}),[r,n]}catch(a){throw r!==0&&t._OrtReleaseRunOptions(r),n.forEach(o=>t._free(o)),a}}}),Nf,Df,zf,Ys,Mr,Bf,Fp,J0=we(()=>{Qr(),Pl(),Nf=e=>{switch(e){case"disabled":return 0;case"basic":return 1;case"extended":return 2;case"layout":return 3;case"all":return 99;default:throw new Error(`unsupported graph optimization level: ${e}`)}},Df=e=>{switch(e){case"sequential":return 0;case"parallel":return 1;default:throw new Error(`unsupported execution mode: ${e}`)}},zf=e=>{e.extra||(e.extra={}),e.extra.session||(e.extra.session={});let t=e.extra.session;t.use_ort_model_bytes_directly||(t.use_ort_model_bytes_directly="1"),e.executionProviders&&e.executionProviders.some(r=>(typeof r=="string"?r:r.name)==="webgpu")&&(e.enableMemPattern=!1)},Ys=(e,t,r,n)=>{let s=bt(t,n),a=bt(r,n);Pe()._OrtAddSessionConfigEntry(e,s,a)!==0&&ke(`Can't set a session config entry: ${t} - ${r}.`)},Mr=(e,t,r,n)=>{let s=bt(t,n),a=bt(r,n);e.push([s,a])},Bf=async(e,t,r)=>{let n=t.executionProviders;for(let s of n){let a=typeof s=="string"?s:s.name,o=[];switch(a){case"webnn":if(a="WEBNN",typeof s!="string"){let h=s==null?void 0:s.deviceType;h&&Ys(e,"deviceType",h,r)}break;case"webgpu":{a="WebGPU";let h;if(typeof s!="string"){let p=s;if(p.device)if(typeof GPUDevice<"u"&&p.device instanceof GPUDevice)h=p.device;else throw new Error("Invalid GPU device set in WebGPU EP options.");let{enableGraphCapture:w}=t;if(typeof w=="boolean"&&w&&Mr(o,"enableGraphCapture","1",r),typeof p.preferredLayout=="string"&&Mr(o,"preferredLayout",p.preferredLayout,r),p.forceCpuNodeNames){let v=Array.isArray(p.forceCpuNodeNames)?p.forceCpuNodeNames:[p.forceCpuNodeNames];Mr(o,"forceCpuNodeNames",v.join(`
8
+ `),r)}p.validationMode&&Mr(o,"validationMode",p.validationMode,r)}let _=Pe().webgpuRegisterDevice(h);if(_){let[p,w,v]=_;Mr(o,"deviceId",p.toString(),r),Mr(o,"webgpuInstance",w.toString(),r),Mr(o,"webgpuDevice",v.toString(),r)}}break;case"wasm":case"cpu":continue;default:throw new Error(`not supported execution provider: ${a}`)}let i=bt(a,r),l=o.length,c=0,d=0;if(l>0){c=Pe()._malloc(l*Pe().PTR_SIZE),r.push(c),d=Pe()._malloc(l*Pe().PTR_SIZE),r.push(d);for(let h=0;h<l;h++)Pe().setValue(c+h*Pe().PTR_SIZE,o[h][0],"*"),Pe().setValue(d+h*Pe().PTR_SIZE,o[h][1],"*")}await Pe()._OrtAppendExecutionProvider(e,i,c,d,l)!==0&&ke(`Can't append execution provider: ${a}.`)}},Fp=async e=>{let t=Pe(),r=0,n=[],s=e||{};zf(s);try{let a=Nf(s.graphOptimizationLevel??"all"),o=Df(s.executionMode??"sequential"),i=typeof s.logId=="string"?bt(s.logId,n):0,l=s.logSeverityLevel??2;if(!Number.isInteger(l)||l<0||l>4)throw new Error(`log severity level is not valid: ${l}`);let c=s.logVerbosityLevel??0;if(!Number.isInteger(c)||c<0||c>4)throw new Error(`log verbosity level is not valid: ${c}`);let d=typeof s.optimizedModelFilePath=="string"?bt(s.optimizedModelFilePath,n):0;if(r=t._OrtCreateSessionOptions(a,!!s.enableCpuMemArena,!!s.enableMemPattern,o,!!s.enableProfiling,0,i,l,c,d),r===0&&ke("Can't create session options."),s.executionProviders&&await Bf(r,s,n),s.enableGraphCapture!==void 0){if(typeof s.enableGraphCapture!="boolean")throw new Error(`enableGraphCapture must be a boolean value: ${s.enableGraphCapture}`);Ys(r,"enableGraphCapture",s.enableGraphCapture.toString(),n)}if(s.freeDimensionOverrides)for(let[h,_]of Object.entries(s.freeDimensionOverrides)){if(typeof h!="string")throw new Error(`free dimension override name must be a string: ${h}`);if(typeof _!="number"||!Number.isInteger(_)||_<0)throw new Error(`free dimension override value must be a non-negative integer: ${_}`);let p=bt(h,n);t._OrtAddFreeDimensionOverride(r,p,_)!==0&&ke(`Can't set a free dimension override: ${h} - ${_}.`)}return s.extra!==void 0&&Sa(s.extra,"",new WeakSet,(h,_)=>{Ys(r,h,_,n)}),[r,n]}catch(a){throw r!==0&&t._OrtReleaseSessionOptions(r)!==0&&ke("Can't release session options."),n.forEach(o=>t._free(o)),a}}}),Vr,xa,cn,_s,Pa,Fl,Ll,ol,wn=we(()=>{Vr=e=>{switch(e){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;case"int4":return 22;case"uint4":return 21;default:throw new Error(`unsupported data type: ${e}`)}},xa=e=>{switch(e){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";case 22:return"int4";case 21:return"uint4";default:throw new Error(`unsupported data type: ${e}`)}},cn=(e,t)=>{let r=[-1,4,1,1,2,2,4,8,-1,1,2,8,4,8,-1,-1,-1,-1,-1,-1,-1,.5,.5][e],n=typeof t=="number"?t:t.reduce((s,a)=>s*a,1);return r>0?Math.ceil(n*r):void 0},_s=e=>{switch(e){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: ${e}`)}},Pa=e=>{switch(e){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: ${e}`)}},Fl=e=>e==="float32"||e==="float16"||e==="int32"||e==="int64"||e==="uint32"||e==="uint8"||e==="bool"||e==="uint4"||e==="int4",Ll=e=>e==="float32"||e==="float16"||e==="int32"||e==="int64"||e==="uint32"||e==="uint64"||e==="int8"||e==="uint8"||e==="bool"||e==="uint4"||e==="int4",ol=e=>{switch(e){case"none":return 0;case"cpu":return 1;case"cpu-pinned":return 2;case"texture":return 3;case"gpu-buffer":return 4;case"ml-tensor":return 5;default:throw new Error(`unsupported data location: ${e}`)}}}),Il,Lp=we(()=>{Al(),Il=async e=>{if(typeof e=="string"){let t=await fetch(e);if(!t.ok)throw new Error(`failed to load external data file: ${e}`);let r=t.headers.get("Content-Length"),n=r?parseInt(r,10):0;if(n<1073741824)return new Uint8Array(await t.arrayBuffer());{if(!t.body)throw new Error(`failed to load external data file: ${e}, no response body.`);let s=t.body.getReader(),a;try{a=new ArrayBuffer(n)}catch(i){if(i instanceof RangeError){let l=Math.ceil(n/65536);a=new WebAssembly.Memory({initial:l,maximum:l}).buffer}else throw i}let o=0;for(;;){let{done:i,value:l}=await s.read();if(i)break;let c=l.byteLength;new Uint8Array(a,o,c).set(l),o+=c}return new Uint8Array(a,0,n)}}else return e instanceof Blob?new Uint8Array(await e.arrayBuffer()):e instanceof Uint8Array?e:new Uint8Array(e)}}),Ip,K0=we(()=>{wn(),Ip=(e,t)=>new(_s(t))(e)}),Rf,Gf,$f,Vf,Op,Uf,it,Np=we(()=>{wn(),Rf=["V","I","W","E","F"],Gf=(e,t)=>{console.log(`[${Rf[e]},${new Date().toISOString()}]${t}`)},Op=(e,t)=>{$f=e,Vf=t},Uf=(e,t)=>{let r=Pa(e),n=Pa($f);r>=n&&Gf(r,typeof t=="function"?t():t)},it=(...e)=>{Vf&&Uf(...e)}}),ri,il,ni,jf,si,qf,ai,oi,ii,Wf,Dp,Z0=we(()=>{wn(),Np(),ri=new Map([["float32",32],["float16",16],["int32",32],["uint32",32],["int64",64],["uint64",64],["int8",8],["uint8",8],["int4",4],["uint4",4]]),il=(e,t)=>{if(t==="int32")return e;let r=ri.get(t);if(!r)throw new Error(`WebNN backend does not support data type: ${t}`);let n=r/8;if(e.byteLength%n!==0)throw new Error(`Invalid Uint8Array length - must be a multiple of ${n}.`);let s=e.byteLength/n,a=new(_s(t))(e.buffer,e.byteOffset,s);switch(t){case"int64":case"uint64":{let o=new Int32Array(s);for(let i=0;i<s;i++){let l=a[i];if(l>2147483647n||l<-2147483648n)throw new Error("Can not convert int64 data to int32 - value out of range.");o[i]=Number(l)}return new Uint8Array(o.buffer)}case"int8":case"uint8":case"uint32":{if(t==="uint32"&&a.some(i=>i>2147483647))throw new Error("Can not convert uint32 data to int32 - value out of range.");let o=Int32Array.from(a,Number);return new Uint8Array(o.buffer)}default:throw new Error(`Unsupported data conversion from ${t} to 'int32'`)}},ni=(e,t)=>{if(t==="int32")return e;if(e.byteLength%4!==0)throw new Error("Invalid Uint8Array length - must be a multiple of 4 (int32).");let r=e.byteLength/4,n=new Int32Array(e.buffer,e.byteOffset,r);switch(t){case"int64":{let s=BigInt64Array.from(n,BigInt);return new Uint8Array(s.buffer)}case"uint64":{if(n.some(a=>a<0))throw new Error("Can not convert int32 data to uin64 - negative value found.");let s=BigUint64Array.from(n,BigInt);return new Uint8Array(s.buffer)}case"int8":{if(n.some(a=>a<-128||a>127))throw new Error("Can not convert int32 data to int8 - value out of range.");let s=Int8Array.from(n,Number);return new Uint8Array(s.buffer)}case"uint8":{if(n.some(s=>s<0||s>255))throw new Error("Can not convert int32 data to uint8 - value out of range.");return Uint8Array.from(n,Number)}case"uint32":{if(n.some(a=>a<0))throw new Error("Can not convert int32 data to uint32 - negative value found.");let s=Uint32Array.from(n,Number);return new Uint8Array(s.buffer)}default:throw new Error(`Unsupported data conversion from 'int32' to ${t}`)}},jf=1,si=()=>jf++,qf=new Map([["int8","int32"],["uint8","int32"],["uint32","int32"],["int64","int32"]]),ai=(e,t)=>{let r=ri.get(e);if(!r)throw new Error(`WebNN backend does not support data type: ${e}`);return t.length>0?Math.ceil(t.reduce((n,s)=>n*s)*r/8):0},oi=class{constructor(e){this.isDataConverted=!1;let{sessionId:t,context:r,tensor:n,dataType:s,shape:a,fallbackDataType:o}=e;this.sessionId=t,this.mlContext=r,this.mlTensor=n,this.dataType=s,this.tensorShape=a,this.fallbackDataType=o}get tensor(){return this.mlTensor}get type(){return this.dataType}get fallbackType(){return this.fallbackDataType}get shape(){return this.tensorShape}get byteLength(){return ai(this.dataType,this.tensorShape)}destroy(){it("verbose",()=>"[WebNN] TensorWrapper.destroy"),this.mlTensor.destroy()}write(e){this.mlContext.writeTensor(this.mlTensor,e)}async read(e){if(this.fallbackDataType){let t=await this.mlContext.readTensor(this.mlTensor),r=ni(new Uint8Array(t),this.dataType);if(e){(e instanceof ArrayBuffer?new Uint8Array(e):new Uint8Array(e.buffer,e.byteOffset,e.byteLength)).set(r);return}else return r.buffer}else return e?this.mlContext.readTensor(this.mlTensor,e):this.mlContext.readTensor(this.mlTensor)}canReuseTensor(e,t,r){return this.mlContext===e&&this.dataType===t&&this.tensorShape.length===r.length&&this.tensorShape.every((n,s)=>n===r[s])}setIsDataConverted(e){this.isDataConverted=e}},ii=class{constructor(e,t){this.tensorManager=e,this.wrapper=t}get tensorWrapper(){return this.wrapper}releaseTensor(){this.tensorWrapper&&(this.tensorManager.releaseTensor(this.tensorWrapper),this.wrapper=void 0)}async ensureTensor(e,t,r,n){let s=this.tensorManager.getMLContext(e),a=this.tensorManager.getMLOpSupportLimits(e),o;if(!(a!=null&&a.input.dataTypes.includes(t))){if(o=qf.get(t),!o||(a==null?void 0:a.input.dataTypes.includes(o)))throw new Error(`WebNN backend does not support data type: ${t}`);it("verbose",()=>`[WebNN] TensorIdTracker.ensureTensor: fallback dataType from ${t} to ${o}`)}if(this.wrapper){if(this.wrapper.canReuseTensor(s,t,r))return this.wrapper.tensor;if(n){if(this.wrapper.byteLength!==ai(t,r))throw new Error("Unable to copy data to tensor with different size.");this.activeUpload=new Uint8Array(await this.wrapper.read())}this.tensorManager.releaseTensor(this.wrapper)}let i=typeof MLTensorUsage>"u"?void 0:MLTensorUsage.READ|MLTensorUsage.WRITE;return this.wrapper=await this.tensorManager.getCachedTensor(e,t,r,i,!0,!0,o),n&&this.activeUpload&&(this.wrapper.write(this.activeUpload),this.activeUpload=void 0),this.wrapper.tensor}upload(e){let t=e;if(this.wrapper){if(this.wrapper.fallbackType)if(this.wrapper.fallbackType==="int32")t=il(e,this.wrapper.type),this.wrapper.setIsDataConverted(!0);else throw new Error(`Unsupported fallback data type: ${this.wrapper.fallbackType}`);if(e.byteLength===this.wrapper.byteLength){this.wrapper.write(t);return}else it("verbose",()=>"Data size does not match tensor size. Releasing tensor."),this.releaseTensor()}this.activeUpload?this.activeUpload.set(t):this.activeUpload=new Uint8Array(t)}async download(e){var t,r;if(this.activeUpload){let n=(t=this.wrapper)!=null&&t.isDataConverted?ni(this.activeUpload,(r=this.wrapper)==null?void 0:r.type):this.activeUpload;if(e){e instanceof ArrayBuffer?new Uint8Array(e).set(n):new Uint8Array(e.buffer,e.byteOffset,e.byteLength).set(n);return}else return n.buffer}if(!this.wrapper)throw new Error("Tensor has not been created.");return e?this.wrapper.read(e):this.wrapper.read()}},Wf=class{constructor(e){this.backend=e,this.tensorTrackersById=new Map,this.freeTensors=[],this.externalTensors=new Set}getMLContext(e){let t=this.backend.getMLContext(e);if(!t)throw new Error("MLContext not found for session.");return t}getMLOpSupportLimits(e){return this.backend.getMLOpSupportLimits(e)}reserveTensorId(){let e=si();return this.tensorTrackersById.set(e,new ii(this)),e}releaseTensorId(e){let t=this.tensorTrackersById.get(e);t&&(this.tensorTrackersById.delete(e),t.tensorWrapper&&this.releaseTensor(t.tensorWrapper))}async ensureTensor(e,t,r,n,s){it("verbose",()=>`[WebNN] TensorManager.ensureTensor {tensorId: ${t}, dataType: ${r}, shape: ${n}, copyOld: ${s}}`);let a=this.tensorTrackersById.get(t);if(!a)throw new Error("Tensor not found.");return a.ensureTensor(e,r,n,s)}upload(e,t){let r=this.tensorTrackersById.get(e);if(!r)throw new Error("Tensor not found.");r.upload(t)}async download(e,t){it("verbose",()=>`[WebNN] TensorManager.download {tensorId: ${e}, dstBuffer: ${t==null?void 0:t.byteLength}}`);let r=this.tensorTrackersById.get(e);if(!r)throw new Error("Tensor not found.");return r.download(t)}releaseTensorsForSession(e){for(let t of this.freeTensors)t.sessionId===e&&t.destroy();this.freeTensors=this.freeTensors.filter(t=>t.sessionId!==e)}registerTensor(e,t,r,n){let s=this.getMLContext(e),a=si(),o=new oi({sessionId:e,context:s,tensor:t,dataType:r,shape:n});return this.tensorTrackersById.set(a,new ii(this,o)),this.externalTensors.add(o),a}async getCachedTensor(e,t,r,n,s,a,o){let i=this.getMLContext(e);for(let[c,d]of this.freeTensors.entries())if(d.canReuseTensor(i,t,r)){it("verbose",()=>`[WebNN] Reusing tensor {dataType: ${t}, ${o?`fallbackDataType: ${o},`:""} shape: ${r}`);let h=this.freeTensors.splice(c,1)[0];return h.sessionId=e,h}it("verbose",()=>`[WebNN] MLContext.createTensor {dataType: ${t}, ${o?`fallbackDataType: ${o},`:""} shape: ${r}}`);let l=await i.createTensor({dataType:o??t,shape:r,dimensions:r,usage:n,writable:s,readable:a});return new oi({sessionId:e,context:i,tensor:l,dataType:t,shape:r,fallbackDataType:o})}releaseTensor(e){this.externalTensors.has(e)&&this.externalTensors.delete(e),this.freeTensors.push(e)}},Dp=(...e)=>new Wf(...e)}),zp={};bs(zp,{WebNNBackend:()=>Bp});var qn,Hf,Bp,eM=we(()=>{wn(),Qr(),K0(),Z0(),Np(),qn=new Map([[1,"float32"],[10,"float16"],[6,"int32"],[12,"uint32"],[7,"int64"],[13,"uint64"],[22,"int4"],[21,"uint4"],[3,"int8"],[2,"uint8"],[9,"uint8"]]),Hf=(e,t)=>{if(e===t)return!0;if(e===void 0||t===void 0)return!1;let r=Object.keys(e).sort(),n=Object.keys(t).sort();return r.length===n.length&&r.every((s,a)=>s===n[a]&&e[s]===t[s])},Bp=class{constructor(e){this.tensorManager=Dp(this),this.mlContextBySessionId=new Map,this.sessionIdsByMLContext=new Map,this.mlContextCache=[],this.sessionGraphInputs=new Map,this.sessionGraphOutputs=new Map,this.temporaryGraphInputs=[],this.temporaryGraphOutputs=[],this.temporarySessionTensorIds=new Map,this.mlOpSupportLimitsBySessionId=new Map,Op(e.logLevel,!!e.debug)}get currentSessionId(){if(this.activeSessionId===void 0)throw new Error("No active session");return this.activeSessionId}onRunStart(e){it("verbose",()=>`[WebNN] onRunStart {sessionId: ${e}}`),this.activeSessionId=e}onRunEnd(e){it("verbose",()=>`[WebNN] onRunEnd {sessionId: ${e}}`);let t=this.temporarySessionTensorIds.get(e);if(t){for(let r of t)it("verbose",()=>`[WebNN] releasing temporary tensor {tensorId: ${r}}`),this.tensorManager.releaseTensorId(r);this.temporarySessionTensorIds.delete(e),this.activeSessionId=void 0}}async createMLContext(e){if(e instanceof GPUDevice){let r=this.mlContextCache.findIndex(n=>n.gpuDevice===e);if(r!==-1)return this.mlContextCache[r].mlContext;{let n=await navigator.ml.createContext(e);return this.mlContextCache.push({gpuDevice:e,mlContext:n}),n}}else if(e===void 0){let r=this.mlContextCache.findIndex(n=>n.options===void 0&&n.gpuDevice===void 0);if(r!==-1)return this.mlContextCache[r].mlContext;{let n=await navigator.ml.createContext();return this.mlContextCache.push({mlContext:n}),n}}let t=this.mlContextCache.findIndex(r=>Hf(r.options,e));if(t!==-1)return this.mlContextCache[t].mlContext;{let r=await navigator.ml.createContext(e);return this.mlContextCache.push({options:e,mlContext:r}),r}}registerMLContext(e,t){this.mlContextBySessionId.set(e,t);let r=this.sessionIdsByMLContext.get(t);r||(r=new Set,this.sessionIdsByMLContext.set(t,r)),r.add(e),this.mlOpSupportLimitsBySessionId.has(e)||this.mlOpSupportLimitsBySessionId.set(e,t.opSupportLimits()),this.temporaryGraphInputs.length>0&&(this.sessionGraphInputs.set(e,this.temporaryGraphInputs),this.temporaryGraphInputs=[]),this.temporaryGraphOutputs.length>0&&(this.sessionGraphOutputs.set(e,this.temporaryGraphOutputs),this.temporaryGraphOutputs=[])}onReleaseSession(e){this.sessionGraphInputs.delete(e),this.sessionGraphOutputs.delete(e);let t=this.mlContextBySessionId.get(e);if(!t)return;this.tensorManager.releaseTensorsForSession(e),this.mlContextBySessionId.delete(e),this.mlOpSupportLimitsBySessionId.delete(e);let r=this.sessionIdsByMLContext.get(t);if(r.delete(e),r.size===0){this.sessionIdsByMLContext.delete(t);let n=this.mlContextCache.findIndex(s=>s.mlContext===t);n!==-1&&this.mlContextCache.splice(n,1)}}getMLContext(e){return this.mlContextBySessionId.get(e)}getMLOpSupportLimits(e){return this.mlOpSupportLimitsBySessionId.get(e)}reserveTensorId(){return this.tensorManager.reserveTensorId()}releaseTensorId(e){it("verbose",()=>`[WebNN] releaseTensorId {tensorId: ${e}}`),this.tensorManager.releaseTensorId(e)}async ensureTensor(e,t,r,n,s){let a=qn.get(r);if(!a)throw new Error(`Unsupported ONNX data type: ${r}`);return this.tensorManager.ensureTensor(e??this.currentSessionId,t,a,n,s)}async createTemporaryTensor(e,t,r){it("verbose",()=>`[WebNN] createTemporaryTensor {onnxDataType: ${t}, shape: ${r}}`);let n=qn.get(t);if(!n)throw new Error(`Unsupported ONNX data type: ${t}`);let s=this.tensorManager.reserveTensorId();await this.tensorManager.ensureTensor(e,s,n,r,!1);let a=this.temporarySessionTensorIds.get(e);return a?a.push(s):this.temporarySessionTensorIds.set(e,[s]),s}uploadTensor(e,t){if(!Pe().shouldTransferToMLTensor)throw new Error("Trying to upload to a MLTensor while shouldTransferToMLTensor is false");it("verbose",()=>`[WebNN] uploadTensor {tensorId: ${e}, data: ${t.byteLength}}`),this.tensorManager.upload(e,t)}async downloadTensor(e,t){return this.tensorManager.download(e,t)}createMLTensorDownloader(e,t){return async()=>{let r=await this.tensorManager.download(e);return Ip(r,t)}}registerMLTensor(e,t,r,n){let s=qn.get(r);if(!s)throw new Error(`Unsupported ONNX data type: ${r}`);let a=this.tensorManager.registerTensor(e,t,s,n);return it("verbose",()=>`[WebNN] registerMLTensor {tensor: ${t}, dataType: ${s}, dimensions: ${n}} -> {tensorId: ${a}}`),a}registerMLConstant(e,t,r,n,s,a,o=!1){if(!a)throw new Error("External mounted files are not available.");let i=e;e.startsWith("./")&&(i=e.substring(2));let l=a.get(i);if(!l)throw new Error(`File with name ${i} not found in preloaded files.`);if(t+r>l.byteLength)throw new Error("Out of bounds: data offset and length exceed the external file data size.");let c=l.slice(t,t+r).buffer,d;switch(s.dataType){case"float32":d=new Float32Array(c);break;case"float16":d=typeof Float16Array<"u"&&Float16Array.from?new Float16Array(c):new Uint16Array(c);break;case"int32":d=new Int32Array(c);break;case"uint32":d=new Uint32Array(c);break;case"int64":if(o){let h=il(new Uint8Array(c),"int64");d=new Int32Array(h.buffer),s.dataType="int32"}else d=new BigInt64Array(c);break;case"uint64":d=new BigUint64Array(c);break;case"int8":d=new Int8Array(c);break;case"int4":case"uint4":case"uint8":d=new Uint8Array(c);break;default:throw new Error(`Unsupported data type: ${s.dataType} in creating WebNN Constant from external data.`)}return it("verbose",()=>`[WebNN] registerMLConstant {dataType: ${s.dataType}, shape: ${s.shape}}} ${o?"(Note: it was int64 data type and registered to int32 as workaround)":""}`),n.constant(s,d)}registerGraphInput(e){this.temporaryGraphInputs.push(e)}registerGraphOutput(e){this.temporaryGraphOutputs.push(e)}isGraphInput(e,t){let r=this.sessionGraphInputs.get(e);return r?r.includes(t):!1}isGraphOutput(e,t){let r=this.sessionGraphOutputs.get(e);return r?r.includes(t):!1}isGraphInputOutputTypeSupported(e,t,r=!0){let n=qn.get(Vr(t)),s=this.mlOpSupportLimitsBySessionId.get(e);return typeof n>"u"?!1:r?!!(s!=null&&s.input.dataTypes.includes(n)):!!(s!=null&&s.output.dataTypes.includes(n))}flush(){}}}),Qf,Ol,Nl,xr,Xf,li,Fa,Dl,zl,ci,Bl,Rl,Gl,Rp=we(()=>{Hr(),Y0(),J0(),wn(),Qr(),Pl(),Lp(),Qf=(e,t)=>{Pe()._OrtInit(e,t)!==0&&ke("Can't initialize onnxruntime.")},Ol=async e=>{Qf(e.wasm.numThreads,Pa(e.logLevel))},Nl=async(e,t)=>{var n,s;(s=(n=Pe()).asyncInit)==null||s.call(n);let r=e.webgpu.adapter;if(t==="webgpu"){if(typeof navigator>"u"||!navigator.gpu)throw new Error("WebGPU is not supported in current environment");if(r){if(typeof r.limits!="object"||typeof r.features!="object"||typeof r.requestDevice!="function")throw new Error("Invalid GPU adapter set in `env.webgpu.adapter`. It must be a GPUAdapter object.")}else{let a=e.webgpu.powerPreference;if(a!==void 0&&a!=="low-power"&&a!=="high-performance")throw new Error(`Invalid powerPreference setting: "${a}"`);let o=e.webgpu.forceFallbackAdapter;if(o!==void 0&&typeof o!="boolean")throw new Error(`Invalid forceFallbackAdapter setting: "${o}"`);if(r=await navigator.gpu.requestAdapter({powerPreference:a,forceFallbackAdapter:o}),!r)throw new Error('Failed to get GPU adapter. You may need to enable flag "--enable-unsafe-webgpu" if you are using Chrome.')}}if(t==="webnn"&&(typeof navigator>"u"||!navigator.ml))throw new Error("WebNN is not supported in current environment");if(t==="webgpu"&&Pe().webgpuInit(a=>{e.webgpu.device=a}),t==="webnn"){let a=new(eM(),Aa(zp)).WebNNBackend(e);Pe().webnnInit([a,()=>a.reserveTensorId(),o=>a.releaseTensorId(o),async(o,i,l,c,d)=>a.ensureTensor(o,i,l,c,d),(o,i)=>{a.uploadTensor(o,i)},async(o,i)=>a.downloadTensor(o,i),(o,i)=>a.registerMLContext(o,i),!!e.trace])}},xr=new Map,Xf=e=>{let t=Pe(),r=t.stackSave();try{let n=t.PTR_SIZE,s=t.stackAlloc(2*n);t._OrtGetInputOutputCount(e,s,s+n)!==0&&ke("Can't get session input/output count.");let a=n===4?"i32":"i64";return[Number(t.getValue(s,a)),Number(t.getValue(s+n,a))]}finally{t.stackRestore(r)}},li=(e,t)=>{let r=Pe(),n=r.stackSave(),s=0;try{let a=r.PTR_SIZE,o=r.stackAlloc(2*a);r._OrtGetInputOutputMetadata(e,t,o,o+a)!==0&&ke("Can't get session input/output metadata.");let i=Number(r.getValue(o,"*"));s=Number(r.getValue(o+a,"*"));let l=r.HEAP32[s/4];if(l===0)return[i,0];let c=r.HEAPU32[s/4+1],d=[];for(let h=0;h<c;h++){let _=Number(r.getValue(s+8+h*a,"*"));d.push(_!==0?r.UTF8ToString(_):Number(r.getValue(s+8+(h+c)*a,"*")))}return[i,l,d]}finally{r.stackRestore(n),s!==0&&r._OrtFree(s)}},Fa=e=>{let t=Pe(),r=t._malloc(e.byteLength);if(r===0)throw new Error(`Can't create a session. failed to allocate a buffer of size ${e.byteLength}.`);return t.HEAPU8.set(e,r),[r,e.byteLength]},Dl=async(e,t)=>{var h,_,p,w;let r,n,s=Pe();Array.isArray(e)?[r,n]=e:e.buffer===s.HEAPU8.buffer?[r,n]=[e.byteOffset,e.byteLength]:[r,n]=Fa(e);let a=0,o=0,i=0,l=[],c=[],d=[];try{if([o,l]=await Fp(t),(t==null?void 0:t.externalData)&&s.mountExternalData){let R=[];for(let z of t.externalData){let $=typeof z=="string"?z:z.path;R.push(Il(typeof z=="string"?z:z.data).then(Q=>{s.mountExternalData($,Q)}))}await Promise.all(R)}for(let R of(t==null?void 0:t.executionProviders)??[])if((typeof R=="string"?R:R.name)==="webnn"){if(s.shouldTransferToMLTensor=!1,typeof R!="string"){let z=R,$=z==null?void 0:z.context,Q=z==null?void 0:z.gpuDevice,H=z==null?void 0:z.deviceType,D=z==null?void 0:z.powerPreference;$?s.currentContext=$:Q?s.currentContext=await s.webnnCreateMLContext(Q):s.currentContext=await s.webnnCreateMLContext({deviceType:H,powerPreference:D})}else s.currentContext=await s.webnnCreateMLContext();break}a=await s._OrtCreateSession(r,n,o),(h=s.webgpuOnCreateSession)==null||h.call(s,a),a===0&&ke("Can't create a session."),(_=s.jsepOnCreateSession)==null||_.call(s),s.currentContext&&(s.webnnRegisterMLContext(a,s.currentContext),s.currentContext=void 0,s.shouldTransferToMLTensor=!0);let[v,y]=Xf(a),M=!!(t!=null&&t.enableGraphCapture),T=[],A=[],S=[],C=[],I=[];for(let R=0;R<v;R++){let[z,$,Q]=li(a,R);z===0&&ke("Can't get an input name."),c.push(z);let H=s.UTF8ToString(z);T.push(H),S.push($===0?{name:H,isTensor:!1}:{name:H,isTensor:!0,type:xa($),shape:Q})}for(let R=0;R<y;R++){let[z,$,Q]=li(a,R+v);z===0&&ke("Can't get an output name."),d.push(z);let H=s.UTF8ToString(z);A.push(H),C.push($===0?{name:H,isTensor:!1}:{name:H,isTensor:!0,type:xa($),shape:Q});{if(M&&(t==null?void 0:t.preferredOutputLocation)===void 0){I.push("gpu-buffer");continue}let D=typeof(t==null?void 0:t.preferredOutputLocation)=="string"?t.preferredOutputLocation:((p=t==null?void 0:t.preferredOutputLocation)==null?void 0:p[H])??"cpu",O=s.webnnIsGraphOutput;if(D==="cpu"&&O&&O(a,H)){I.push("ml-tensor-cpu-output");continue}if(D!=="cpu"&&D!=="cpu-pinned"&&D!=="gpu-buffer"&&D!=="ml-tensor")throw new Error(`Not supported preferred output location: ${D}.`);if(M&&D!=="gpu-buffer")throw new Error(`Not supported preferred output location: ${D}. Only 'gpu-buffer' location is supported when enableGraphCapture is true.`);I.push(D)}}let x=null;return I.some(R=>R==="gpu-buffer"||R==="ml-tensor"||R==="ml-tensor-cpu-output")&&(i=s._OrtCreateBinding(a),i===0&&ke("Can't create IO binding."),x={handle:i,outputPreferredLocations:I,outputPreferredLocationsEncoded:I.map(R=>R==="ml-tensor-cpu-output"?"ml-tensor":R).map(R=>ol(R))}),xr.set(a,[a,c,d,x,M,!1]),[a,T,A,S,C]}catch(v){throw c.forEach(y=>s._OrtFree(y)),d.forEach(y=>s._OrtFree(y)),i!==0&&s._OrtReleaseBinding(i)!==0&&ke("Can't release IO binding."),a!==0&&s._OrtReleaseSession(a)!==0&&ke("Can't release session."),v}finally{s._free(r),o!==0&&s._OrtReleaseSessionOptions(o)!==0&&ke("Can't release session options."),l.forEach(v=>s._free(v)),(w=s.unmountExternalData)==null||w.call(s)}},zl=e=>{var l,c,d;let t=Pe(),r=xr.get(e);if(!r)throw new Error(`cannot release session. invalid session id: ${e}`);let[n,s,a,o,i]=r;o&&(i&&t._OrtClearBoundOutputs(o.handle)!==0&&ke("Can't clear bound outputs."),t._OrtReleaseBinding(o.handle)!==0&&ke("Can't release IO binding.")),(l=t.jsepOnReleaseSession)==null||l.call(t,e),(c=t.webnnOnReleaseSession)==null||c.call(t,e),(d=t.webgpuOnReleaseSession)==null||d.call(t,e),s.forEach(h=>t._OrtFree(h)),a.forEach(h=>t._OrtFree(h)),t._OrtReleaseSession(n)!==0&&ke("Can't release session."),xr.delete(e)},ci=async(e,t,r,n,s,a,o=!1)=>{if(!e){t.push(0);return}let i=Pe(),l=i.PTR_SIZE,c=e[0],d=e[1],h=e[3],_=h,p,w;if(c==="string"&&(h==="gpu-buffer"||h==="ml-tensor"))throw new Error("String tensor is not supported on GPU.");if(o&&h!=="gpu-buffer")throw new Error(`External buffer must be provided for input/output index ${a} when enableGraphCapture is true.`);if(h==="gpu-buffer"){let M=e[2].gpuBuffer;w=cn(Vr(c),d);{let T=i.webgpuRegisterBuffer;if(!T)throw new Error('Tensor location "gpu-buffer" is not supported without using WebGPU.');p=T(M,n)}}else if(h==="ml-tensor"){let M=e[2].mlTensor;w=cn(Vr(c),d);let T=i.webnnRegisterMLTensor;if(!T)throw new Error('Tensor location "ml-tensor" is not supported without using WebNN.');p=T(n,M,Vr(c),d)}else{let M=e[2];if(Array.isArray(M)){w=l*M.length,p=i._malloc(w),r.push(p);for(let T=0;T<M.length;T++){if(typeof M[T]!="string")throw new TypeError(`tensor data at index ${T} is not a string`);i.setValue(p+T*l,bt(M[T],r),"*")}}else{let T=i.webnnIsGraphInput,A=i.webnnIsGraphOutput;if(c!=="string"&&T&&A){let S=i.UTF8ToString(s);if(T(n,S)||A(n,S)){let C=Vr(c);w=cn(C,d),_="ml-tensor";let I=i.webnnCreateTemporaryTensor,x=i.webnnUploadTensor;if(!I||!x)throw new Error('Tensor location "ml-tensor" is not supported without using WebNN.');let R=await I(n,C,d);x(R,new Uint8Array(M.buffer,M.byteOffset,M.byteLength)),p=R}else w=M.byteLength,p=i._malloc(w),r.push(p),i.HEAPU8.set(new Uint8Array(M.buffer,M.byteOffset,w),p)}else w=M.byteLength,p=i._malloc(w),r.push(p),i.HEAPU8.set(new Uint8Array(M.buffer,M.byteOffset,w),p)}}let v=i.stackSave(),y=i.stackAlloc(4*d.length);try{d.forEach((T,A)=>i.setValue(y+A*l,T,l===4?"i32":"i64"));let M=i._OrtCreateTensor(Vr(c),p,w,y,d.length,ol(_));M===0&&ke(`Can't create tensor for input/output. session=${n}, index=${a}.`),t.push(M)}finally{i.stackRestore(v)}},Bl=async(e,t,r,n,s,a)=>{var H,D,O,te;let o=Pe(),i=o.PTR_SIZE,l=xr.get(e);if(!l)throw new Error(`cannot run inference. invalid session id: ${e}`);let c=l[0],d=l[1],h=l[2],_=l[3],p=l[4],w=l[5],v=t.length,y=n.length,M=0,T=[],A=[],S=[],C=[],I=[],x=o.stackSave(),R=o.stackAlloc(v*i),z=o.stackAlloc(v*i),$=o.stackAlloc(y*i),Q=o.stackAlloc(y*i);try{[M,T]=Pp(a),Cr("wasm prepareInputOutputTensor");for(let L=0;L<v;L++)await ci(r[L],A,C,e,d[t[L]],t[L],p);for(let L=0;L<y;L++)await ci(s[L],S,C,e,h[n[L]],v+n[L],p);Sr("wasm prepareInputOutputTensor");for(let L=0;L<v;L++)o.setValue(R+L*i,A[L],"*"),o.setValue(z+L*i,d[t[L]],"*");for(let L=0;L<y;L++)o.setValue($+L*i,S[L],"*"),o.setValue(Q+L*i,h[n[L]],"*");if(_&&!w){let{handle:L,outputPreferredLocations:V,outputPreferredLocationsEncoded:X}=_;if(d.length!==v)throw new Error(`input count from feeds (${v}) is expected to be always equal to model's input count (${d.length}).`);Cr("wasm bindInputsOutputs");for(let J=0;J<v;J++){let me=t[J];await o._OrtBindInput(L,d[me],A[J])!==0&&ke(`Can't bind input[${J}] for session=${e}.`)}for(let J=0;J<y;J++){let me=n[J];(H=s[J])!=null&&H[3]?(I.push(S[J]),o._OrtBindOutput(L,h[me],S[J],0)!==0&&ke(`Can't bind pre-allocated output[${J}] for session=${e}.`)):o._OrtBindOutput(L,h[me],0,X[me])!==0&&ke(`Can't bind output[${J}] to ${V[J]} for session=${e}.`)}Sr("wasm bindInputsOutputs"),xr.set(e,[c,d,h,_,p,!0])}(D=o.jsepOnRunStart)==null||D.call(o,c),(O=o.webnnOnRunStart)==null||O.call(o,c);let W;_?W=await o._OrtRunWithBinding(c,_.handle,y,$,M):W=await o._OrtRun(c,z,R,v,Q,y,$,M),W!==0&&ke("failed to call OrtRun().");let ee=[],G=[];Cr("wasm ProcessOutputTensor");for(let L=0;L<y;L++){let V=Number(o.getValue($+L*i,"*"));if(V===S[L]||I.includes(S[L])){ee.push(s[L]),V!==S[L]&&o._OrtReleaseTensor(V)!==0&&ke("Can't release tensor.");continue}let X=o.stackSave(),J=o.stackAlloc(4*i),me=!1,re,Fe=0;try{o._OrtGetTensorData(V,J,J+i,J+2*i,J+3*i)!==0&&ke(`Can't access output tensor data on index ${L}.`);let Ve=i===4?"i32":"i64",pt=Number(o.getValue(J,Ve));Fe=o.getValue(J+i,"*");let Tt=o.getValue(J+i*2,"*"),Et=Number(o.getValue(J+i*3,Ve)),je=[];for(let le=0;le<Et;le++)je.push(Number(o.getValue(Tt+le*i,Ve)));o._OrtFree(Tt)!==0&&ke("Can't free memory for tensor dims.");let ht=je.reduce((le,Se)=>le*Se,1);re=xa(pt);let be=_==null?void 0:_.outputPreferredLocations[n[L]];if(re==="string"){if(be==="gpu-buffer"||be==="ml-tensor")throw new Error("String tensor is not supported on GPU.");let le=[];for(let Se=0;Se<ht;Se++){let ft=o.getValue(Fe+Se*i,"*"),Wt=o.getValue(Fe+(Se+1)*i,"*"),At=Se===ht-1?void 0:Wt-ft;le.push(o.UTF8ToString(ft,At))}ee.push([re,je,le,"cpu"])}else if(be==="gpu-buffer"&&ht>0){let le=o.webgpuGetBuffer;if(!le)throw new Error('preferredLocation "gpu-buffer" is not supported without using WebGPU.');let Se=le(Fe),ft=cn(pt,ht);if(ft===void 0||!Fl(re))throw new Error(`Unsupported data type: ${re}`);me=!0;{o.webgpuRegisterBuffer(Se,e,Fe);let Wt=o.webgpuCreateDownloader(Se,ft,e);ee.push([re,je,{gpuBuffer:Se,download:async()=>{let At=await Wt();return new(_s(re))(At)},dispose:()=>{o._OrtReleaseTensor(V)!==0&&ke("Can't release tensor.")}},"gpu-buffer"])}}else if(be==="ml-tensor"&&ht>0){let le=o.webnnEnsureTensor,Se=o.webnnIsGraphInputOutputTypeSupported;if(!le||!Se)throw new Error('preferredLocation "ml-tensor" is not supported without using WebNN.');if(cn(pt,ht)===void 0||!Ll(re))throw new Error(`Unsupported data type: ${re}`);if(!Se(e,re,!1))throw new Error(`preferredLocation "ml-tensor" for ${re} output is not supported by current WebNN Context.`);let ft=await le(e,Fe,pt,je,!1);me=!0,ee.push([re,je,{mlTensor:ft,download:o.webnnCreateMLTensorDownloader(Fe,re),dispose:()=>{o.webnnReleaseTensorId(Fe),o._OrtReleaseTensor(V)}},"ml-tensor"])}else if(be==="ml-tensor-cpu-output"&&ht>0){let le=o.webnnCreateMLTensorDownloader(Fe,re)(),Se=ee.length;me=!0,G.push((async()=>{let ft=[Se,await le];return o.webnnReleaseTensorId(Fe),o._OrtReleaseTensor(V),ft})()),ee.push([re,je,[],"cpu"])}else{let le=_s(re),Se=new le(ht);new Uint8Array(Se.buffer,Se.byteOffset,Se.byteLength).set(o.HEAPU8.subarray(Fe,Fe+Se.byteLength)),ee.push([re,je,Se,"cpu"])}}finally{o.stackRestore(X),re==="string"&&Fe&&o._free(Fe),me||o._OrtReleaseTensor(V)}}_&&!p&&(o._OrtClearBoundOutputs(_.handle)!==0&&ke("Can't clear bound outputs."),xr.set(e,[c,d,h,_,p,!1]));for(let[L,V]of await Promise.all(G))ee[L][2]=V;return Sr("wasm ProcessOutputTensor"),ee}finally{(te=o.webnnOnRunEnd)==null||te.call(o,c),o.stackRestore(x),r.forEach(W=>{W&&W[3]==="gpu-buffer"&&o.webgpuUnregisterBuffer(W[2].gpuBuffer)}),s.forEach(W=>{W&&W[3]==="gpu-buffer"&&o.webgpuUnregisterBuffer(W[2].gpuBuffer)}),A.forEach(W=>o._OrtReleaseTensor(W)),S.forEach(W=>o._OrtReleaseTensor(W)),C.forEach(W=>o._free(W)),M!==0&&o._OrtReleaseRunOptions(M),T.forEach(W=>o._free(W))}},Rl=e=>{let t=Pe(),r=xr.get(e);if(!r)throw new Error("invalid session id");let n=r[0],s=t._OrtEndProfiling(n);s===0&&ke("Can't get an profile file name."),t._OrtFree(s)},Gl=e=>{let t=[];for(let r of e){let n=r[2];!Array.isArray(n)&&"buffer"in n&&t.push(n.buffer)}return t}}),kr,mt,rn,Wn,Hn,Js,ui,Ks,Nr,Dr,Yf,Gp,$p,Vp,Up,jp,qp,Wp,Hp=we(()=>{Hr(),Rp(),Qr(),Cl(),kr=()=>!!ze.wasm.proxy&&typeof document<"u",rn=!1,Wn=!1,Hn=!1,Ks=new Map,Nr=(e,t)=>{let r=Ks.get(e);r?r.push(t):Ks.set(e,[t])},Dr=()=>{if(rn||!Wn||Hn||!mt)throw new Error("worker not ready")},Yf=e=>{switch(e.data.type){case"init-wasm":rn=!1,e.data.err?(Hn=!0,ui[1](e.data.err)):(Wn=!0,ui[0]()),Js&&(URL.revokeObjectURL(Js),Js=void 0);break;case"init-ep":case"copy-from":case"create":case"release":case"run":case"end-profiling":{let t=Ks.get(e.data.type);e.data.err?t.shift()[1](e.data.err):t.shift()[0](e.data.out);break}}},Gp=async()=>{if(!Wn){if(rn)throw new Error("multiple calls to 'initWasm()' detected.");if(Hn)throw new Error("previous call to 'initWasm()' failed.");if(rn=!0,kr())return new Promise((e,t)=>{mt==null||mt.terminate(),Cp().then(([r,n])=>{try{mt=n,mt.onerror=a=>t(a),mt.onmessage=Yf,ui=[e,t];let s={type:"init-wasm",in:ze};!s.in.wasm.wasmPaths&&(r||al)&&(s.in.wasm.wasmPaths={wasm:new URL("/assets/ort-wasm-simd-threaded.asyncify-DMmc6YqF.wasm",import.meta.url).href}),mt.postMessage(s),Js=r}catch(s){t(s)}},t)});try{await Sl(ze.wasm),await Ol(ze),Wn=!0}catch(e){throw Hn=!0,e}finally{rn=!1}}},$p=async e=>{if(kr())return Dr(),new Promise((t,r)=>{Nr("init-ep",[t,r]);let n={type:"init-ep",in:{epName:e,env:ze}};mt.postMessage(n)});await Nl(ze,e)},Vp=async e=>kr()?(Dr(),new Promise((t,r)=>{Nr("copy-from",[t,r]);let n={type:"copy-from",in:{buffer:e}};mt.postMessage(n,[e.buffer])})):Fa(e),Up=async(e,t)=>{if(kr()){if(t!=null&&t.preferredOutputLocation)throw new Error('session option "preferredOutputLocation" is not supported for proxy.');return Dr(),new Promise((r,n)=>{Nr("create",[r,n]);let s={type:"create",in:{model:e,options:{...t}}},a=[];e instanceof Uint8Array&&a.push(e.buffer),mt.postMessage(s,a)})}else return Dl(e,t)},jp=async e=>{if(kr())return Dr(),new Promise((t,r)=>{Nr("release",[t,r]);let n={type:"release",in:e};mt.postMessage(n)});zl(e)},qp=async(e,t,r,n,s,a)=>{if(kr()){if(r.some(o=>o[3]!=="cpu"))throw new Error("input tensor on GPU is not supported for proxy.");if(s.some(o=>o))throw new Error("pre-allocated output tensor is not supported for proxy.");return Dr(),new Promise((o,i)=>{Nr("run",[o,i]);let l=r,c={type:"run",in:{sessionId:e,inputIndices:t,inputs:l,outputIndices:n,options:a}};mt.postMessage(c,Gl(l))})}else return Bl(e,t,r,n,s,a)},Wp=async e=>{if(kr())return Dr(),new Promise((t,r)=>{Nr("end-profiling",[t,r]);let n={type:"end-profiling",in:e};mt.postMessage(n)});Rl(e)}}),di,Jf,Qp,tM=we(()=>{Hr(),Hp(),wn(),Al(),Lp(),di=(e,t)=>{switch(e.location){case"cpu":return[e.type,e.dims,e.data,"cpu"];case"gpu-buffer":return[e.type,e.dims,{gpuBuffer:e.gpuBuffer},"gpu-buffer"];case"ml-tensor":return[e.type,e.dims,{mlTensor:e.mlTensor},"ml-tensor"];default:throw new Error(`invalid data location: ${e.location} for ${t()}`)}},Jf=e=>{switch(e[3]){case"cpu":return new Nt(e[0],e[2],e[1]);case"gpu-buffer":{let t=e[0];if(!Fl(t))throw new Error(`not supported data type: ${t} for deserializing GPU tensor`);let{gpuBuffer:r,download:n,dispose:s}=e[2];return Nt.fromGpuBuffer(r,{dataType:t,dims:e[1],download:n,dispose:s})}case"ml-tensor":{let t=e[0];if(!Ll(t))throw new Error(`not supported data type: ${t} for deserializing MLTensor tensor`);let{mlTensor:r,download:n,dispose:s}=e[2];return Nt.fromMLTensor(r,{dataType:t,dims:e[1],download:n,dispose:s})}default:throw new Error(`invalid data location: ${e[3]}`)}},Qp=class{async fetchModelAndCopyToWasmMemory(e){return Vp(await Il(e))}async loadModel(e,t){qr();let r;typeof e=="string"?r=await this.fetchModelAndCopyToWasmMemory(e):r=e,[this.sessionId,this.inputNames,this.outputNames,this.inputMetadata,this.outputMetadata]=await Up(r,t),Wr()}async dispose(){return jp(this.sessionId)}async run(e,t,r){qr();let n=[],s=[];Object.entries(e).forEach(h=>{let _=h[0],p=h[1],w=this.inputNames.indexOf(_);if(w===-1)throw new Error(`invalid input '${_}'`);n.push(p),s.push(w)});let a=[],o=[];Object.entries(t).forEach(h=>{let _=h[0],p=h[1],w=this.outputNames.indexOf(_);if(w===-1)throw new Error(`invalid output '${_}'`);a.push(p),o.push(w)});let i=n.map((h,_)=>di(h,()=>`input "${this.inputNames[s[_]]}"`)),l=a.map((h,_)=>h?di(h,()=>`output "${this.outputNames[o[_]]}"`):null),c=await qp(this.sessionId,s,i,o,l,r),d={};for(let h=0;h<c.length;h++)d[this.outputNames[o[h]]]=a[h]??Jf(c[h]);return Wr(),d}startProfiling(){}endProfiling(){Wp(this.sessionId)}}}),Xp={};bs(Xp,{OnnxruntimeWebAssemblyBackend:()=>cl,initializeFlags:()=>ll,wasmBackend:()=>Yp});var ll,cl,Yp,rM=we(()=>{Hr(),Hp(),tM(),ll=()=>{(typeof ze.wasm.initTimeout!="number"||ze.wasm.initTimeout<0)&&(ze.wasm.initTimeout=0);let e=ze.wasm.simd;if(typeof e!="boolean"&&e!==void 0&&e!=="fixed"&&e!=="relaxed"&&(console.warn(`Property "env.wasm.simd" is set to unknown value "${e}". Reset it to \`false\` and ignore SIMD feature checking.`),ze.wasm.simd=!1),typeof ze.wasm.proxy!="boolean"&&(ze.wasm.proxy=!1),typeof ze.wasm.trace!="boolean"&&(ze.wasm.trace=!1),typeof ze.wasm.numThreads!="number"||!Number.isInteger(ze.wasm.numThreads)||ze.wasm.numThreads<=0)if(typeof self<"u"&&!self.crossOriginIsolated)ze.wasm.numThreads=1;else{let t=typeof navigator>"u"?I0("node:os").cpus().length:navigator.hardwareConcurrency;ze.wasm.numThreads=Math.min(4,Math.ceil((t||1)/2))}},cl=class{async init(e){ll(),await Gp(),await $p(e)}async createInferenceSessionHandler(e,t){let r=new Qp;return await r.loadModel(e,t),r}},Yp=new cl});Hr();Hr();Hr();var nM="1.26.0-dev.20260416-b7804b056c",sM=Mp;{let e=(rM(),Aa(Xp)).wasmBackend;Ur("webgpu",e,5),Ur("webnn",e,5),Ur("cpu",e,10),Ur("wasm",e,10)}Object.defineProperty(ze.versions,"web",{value:nM,enumerable:!0});const aM=Object.freeze(Object.defineProperty({__proto__:null,get InferenceSession(){return El},get TRACE(){return Ca},get TRACE_EVENT_BEGIN(){return Cr},get TRACE_EVENT_END(){return Sr},get TRACE_FUNC_BEGIN(){return qr},get TRACE_FUNC_END(){return Wr},get Tensor(){return Nt},default:sM,get env(){return ze},get registerBackend(){return Ur}},Symbol.toStringTag,{value:"Module"})),oM=(e,t)=>{const r=typeof document<"u"?document.createElement("canvas"):new OffscreenCanvas(1,1);r.width=e.dims[3],r.height=e.dims[2];const n=r.getContext("2d");if(n!=null){let s,a;(t==null?void 0:t.tensorLayout)!==void 0&&t.tensorLayout==="NHWC"?(s=e.dims[2],a=e.dims[3]):(s=e.dims[3],a=e.dims[2]);const o=(t==null?void 0:t.format)!==void 0?t.format:"RGB",i=t==null?void 0:t.norm;let l,c;i===void 0||i.mean===void 0?l=[255,255,255,255]:typeof i.mean=="number"?l=[i.mean,i.mean,i.mean,i.mean]:(l=[i.mean[0],i.mean[1],i.mean[2],0],i.mean[3]!==void 0&&(l[3]=i.mean[3])),i===void 0||i.bias===void 0?c=[0,0,0,0]:typeof i.bias=="number"?c=[i.bias,i.bias,i.bias,i.bias]:(c=[i.bias[0],i.bias[1],i.bias[2],0],i.bias[3]!==void 0&&(c[3]=i.bias[3]));const d=a*s;let h=0,_=d,p=d*2,w=-1;o==="RGBA"?(h=0,_=d,p=d*2,w=d*3):o==="RGB"?(h=0,_=d,p=d*2):o==="RBG"&&(h=0,p=d,_=d*2);for(let v=0;v<a;v++)for(let y=0;y<s;y++){const M=(e.data[h++]-c[0])*l[0],T=(e.data[_++]-c[1])*l[1],A=(e.data[p++]-c[2])*l[2],S=w===-1?255:(e.data[w++]-c[3])*l[3];n.fillStyle="rgba("+M+","+T+","+A+","+S+")",n.fillRect(y,v,1,1)}if("toDataURL"in r)return r.toDataURL();throw new Error("toDataURL is not supported")}else throw new Error("Can not access image data")},iM=(e,t)=>{const r=typeof document<"u"?document.createElement("canvas").getContext("2d"):new OffscreenCanvas(1,1).getContext("2d");let n;if(r!=null){let s,a,o;(t==null?void 0:t.tensorLayout)!==void 0&&t.tensorLayout==="NHWC"?(s=e.dims[2],a=e.dims[1],o=e.dims[3]):(s=e.dims[3],a=e.dims[2],o=e.dims[1]);const i=t!==void 0&&t.format!==void 0?t.format:"RGB",l=t==null?void 0:t.norm;let c,d;l===void 0||l.mean===void 0?c=[255,255,255,255]:typeof l.mean=="number"?c=[l.mean,l.mean,l.mean,l.mean]:(c=[l.mean[0],l.mean[1],l.mean[2],255],l.mean[3]!==void 0&&(c[3]=l.mean[3])),l===void 0||l.bias===void 0?d=[0,0,0,0]:typeof l.bias=="number"?d=[l.bias,l.bias,l.bias,l.bias]:(d=[l.bias[0],l.bias[1],l.bias[2],0],l.bias[3]!==void 0&&(d[3]=l.bias[3]));const h=a*s;if(t!==void 0&&(t.format!==void 0&&o===4&&t.format!=="RGBA"||o===3&&t.format!=="RGB"&&t.format!=="BGR"))throw new Error("Tensor format doesn't match input tensor dims");const _=4;let p=0,w=1,v=2,y=3,M=0,T=h,A=h*2,S=-1;i==="RGBA"?(M=0,T=h,A=h*2,S=h*3):i==="RGB"?(M=0,T=h,A=h*2):i==="RBG"&&(M=0,A=h,T=h*2),n=r.createImageData(s,a);for(let C=0;C<a*s;p+=_,w+=_,v+=_,y+=_,C++)n.data[p]=(e.data[M++]-d[0])*c[0],n.data[w]=(e.data[T++]-d[1])*c[1],n.data[v]=(e.data[A++]-d[2])*c[2],n.data[y]=S===-1?255:(e.data[S++]-d[3])*c[3]}else throw new Error("Can not access image data");return n},hi=(e,t)=>{if(e===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");const{height:r,width:n}=t,s=t.norm??{mean:255,bias:0};let a,o;typeof s.mean=="number"?a=[s.mean,s.mean,s.mean,s.mean]:a=[s.mean[0],s.mean[1],s.mean[2],s.mean[3]??255],typeof s.bias=="number"?o=[s.bias,s.bias,s.bias,s.bias]:o=[s.bias[0],s.bias[1],s.bias[2],s.bias[3]??0];const i=t.format!==void 0?t.format:"RGBA",l=t.tensorFormat!==void 0&&t.tensorFormat!==void 0?t.tensorFormat:"RGB",c=r*n,d=l==="RGBA"?new Float32Array(c*4):new Float32Array(c*3);let h=4,_=0,p=1,w=2,v=3,y=0,M=c,T=c*2,A=-1;i==="RGB"&&(h=3,_=0,p=1,w=2,v=-1),l==="RGBA"?A=c*3:l==="RBG"?(y=0,T=c,M=c*2):l==="BGR"&&(T=0,M=c,y=c*2);for(let C=0;C<c;C++,_+=h,w+=h,p+=h,v+=h)d[y++]=(e[_]+o[0])/a[0],d[M++]=(e[p]+o[1])/a[1],d[T++]=(e[w]+o[2])/a[2],A!==-1&&v!==-1&&(d[A++]=(e[v]+o[3])/a[3]);return l==="RGBA"?new Ft("float32",d,[1,4,r,n]):new Ft("float32",d,[1,3,r,n])},lM=async(e,t)=>{const r=typeof HTMLImageElement<"u"&&e instanceof HTMLImageElement,n=typeof ImageData<"u"&&e instanceof ImageData,s=typeof ImageBitmap<"u"&&e instanceof ImageBitmap,a=typeof e=="string";let o,i=t??{};const l=()=>{if(typeof document<"u")return document.createElement("canvas");if(typeof OffscreenCanvas<"u")return new OffscreenCanvas(1,1);throw new Error("Canvas is not supported")},c=d=>typeof HTMLCanvasElement<"u"&&d instanceof HTMLCanvasElement||d instanceof OffscreenCanvas?d.getContext("2d"):null;if(r){const d=l();d.width=e.width,d.height=e.height;const h=c(d);if(h!=null){let _=e.height,p=e.width;if(t!==void 0&&t.resizedHeight!==void 0&&t.resizedWidth!==void 0&&(_=t.resizedHeight,p=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=_,i.width=p}else i.tensorFormat="RGBA",i.height=_,i.width=p;h.drawImage(e,0,0),o=h.getImageData(0,0,p,_).data}else throw new Error("Can not access image data")}else if(n){let d,h;if(t!==void 0&&t.resizedWidth!==void 0&&t.resizedHeight!==void 0?(d=t.resizedHeight,h=t.resizedWidth):(d=e.height,h=e.width),t!==void 0&&(i=t),i.format="RGBA",i.height=d,i.width=h,t!==void 0){const _=l();_.width=h,_.height=d;const p=c(_);if(p!=null)p.putImageData(e,0,0),o=p.getImageData(0,0,h,d).data;else throw new Error("Can not access image data")}else o=e.data}else if(s){if(t===void 0)throw new Error("Please provide image config with format for Imagebitmap");const d=l();d.width=e.width,d.height=e.height;const h=c(d);if(h!=null){const _=e.height,p=e.width;return h.drawImage(e,0,0,p,_),o=h.getImageData(0,0,p,_).data,i.height=_,i.width=p,hi(o,i)}else throw new Error("Can not access image data")}else{if(a)return new Promise((d,h)=>{const _=l(),p=c(_);if(!e||!p)return h();const w=new Image;w.crossOrigin="Anonymous",w.src=e,w.onload=()=>{_.width=w.width,_.height=w.height,p.drawImage(w,0,0,_.width,_.height);const v=p.getImageData(0,0,_.width,_.height);i.height=_.height,i.width=_.width,d(hi(v.data,i))}});throw new Error("Input data provided is not supported - aborted tensor creation")}if(o!==void 0)return hi(o,i);throw new Error("Input data provided is not supported - aborted tensor creation")},cM=(e,t)=>{const{width:r,height:n,download:s,dispose:a}=t,o=[1,n,r,4];return new Ft({location:"texture",type:"float32",texture:e,dims:o,download:s,dispose:a})},uM=(e,t)=>{const{dataType:r,dims:n,download:s,dispose:a}=t;return new Ft({location:"gpu-buffer",type:r??"float32",gpuBuffer:e,dims:n,download:s,dispose:a})},dM=(e,t)=>{const{dataType:r,dims:n,download:s,dispose:a}=t;return new Ft({location:"ml-tensor",type:r??"float32",mlTensor:e,dims:n,download:s,dispose:a})},hM=(e,t,r)=>new Ft({location:"cpu-pinned",type:e,data:t,dims:r??[t.length]}),dn=new Map([["float32",Float32Array],["uint8",Uint8Array],["int8",Int8Array],["uint16",Uint16Array],["int16",Int16Array],["int32",Int32Array],["bool",Uint8Array],["float64",Float64Array],["uint32",Uint32Array],["int4",Uint8Array],["uint4",Uint8Array]]),ka=new Map([[Float32Array,"float32"],[Uint8Array,"uint8"],[Int8Array,"int8"],[Uint16Array,"uint16"],[Int16Array,"int16"],[Int32Array,"int32"],[Float64Array,"float64"],[Uint32Array,"uint32"]]);let Kf=!1;const fM=()=>{if(!Kf){Kf=!0;const e=typeof BigInt64Array<"u"&&BigInt64Array.from,t=typeof BigUint64Array<"u"&&BigUint64Array.from,r=globalThis.Float16Array,n=typeof r<"u"&&r.from;e&&(dn.set("int64",BigInt64Array),ka.set(BigInt64Array,"int64")),t&&(dn.set("uint64",BigUint64Array),ka.set(BigUint64Array,"uint64")),n?(dn.set("float16",r),ka.set(r,"float16")):dn.set("float16",Uint16Array)}},_M=e=>{let t=1;for(let r=0;r<e.length;r++){const n=e[r];if(typeof n!="number"||!Number.isSafeInteger(n))throw new TypeError(`dims[${r}] must be an integer, got: ${n}`);if(n<0)throw new RangeError(`dims[${r}] must be a non-negative integer, got: ${n}`);t*=n}return t},pM=(e,t)=>{switch(e.location){case"cpu":return new Ft(e.type,e.data,t);case"cpu-pinned":return new Ft({location:"cpu-pinned",data:e.data,type:e.type,dims:t});case"texture":return new Ft({location:"texture",texture:e.texture,type:e.type,dims:t});case"gpu-buffer":return new Ft({location:"gpu-buffer",gpuBuffer:e.gpuBuffer,type:e.type,dims:t});case"ml-tensor":return new Ft({location:"ml-tensor",mlTensor:e.mlTensor,type:e.type,dims:t});default:throw new Error(`tensorReshape: tensor location ${e.location} is not supported`)}};let Ft=class{constructor(t,r,n){fM();let s,a;if(typeof t=="object"&&"location"in t)switch(this.dataLocation=t.location,s=t.type,a=t.dims,t.location){case"cpu-pinned":{const i=dn.get(s);if(!i)throw new TypeError(`unsupported type "${s}" 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(s!=="float32")throw new TypeError(`unsupported type "${s}" to create tensor from texture`);this.gpuTextureData=t.texture,this.downloader=t.download,this.disposer=t.dispose;break}case"gpu-buffer":{if(s!=="float32"&&s!=="float16"&&s!=="int32"&&s!=="int64"&&s!=="uint32"&&s!=="uint8"&&s!=="bool"&&s!=="uint4"&&s!=="int4")throw new TypeError(`unsupported type "${s}" to create tensor from gpu buffer`);this.gpuBufferData=t.gpuBuffer,this.downloader=t.download,this.disposer=t.dispose;break}case"ml-tensor":{if(s!=="float32"&&s!=="float16"&&s!=="int32"&&s!=="int64"&&s!=="uint32"&&s!=="uint64"&&s!=="int8"&&s!=="uint8"&&s!=="bool"&&s!=="uint4"&&s!=="int4")throw new TypeError(`unsupported type "${s}" to create tensor from MLTensor`);this.mlTensorData=t.mlTensor,this.downloader=t.download,this.disposer=t.dispose;break}default:throw new Error(`Tensor constructor: unsupported location '${this.dataLocation}'`)}else{let i,l;if(typeof t=="string")if(s=t,l=n,t==="string"){if(!Array.isArray(r))throw new TypeError("A string tensor's data must be a string array.");i=r}else{const c=dn.get(t);if(c===void 0)throw new TypeError(`Unsupported tensor type: ${t}.`);if(Array.isArray(r)){if(t==="float16"&&c===Uint16Array||t==="uint4"||t==="int4")throw new TypeError(`Creating a ${t} tensor from number array is not supported. Please use ${c.name} as data.`);t==="uint64"||t==="int64"?i=c.from(r,BigInt):i=c.from(r)}else if(r instanceof c)i=r;else if(r instanceof Uint8ClampedArray)if(t==="uint8")i=Uint8Array.from(r);else throw new TypeError("A Uint8ClampedArray tensor's data must be type of uint8");else if(t==="float16"&&r instanceof Uint16Array&&c!==Uint16Array)i=new globalThis.Float16Array(r.buffer,r.byteOffset,r.length);else throw new TypeError(`A ${s} tensor's data must be type of ${c}`)}else if(l=r,Array.isArray(t)){if(t.length===0)throw new TypeError("Tensor type cannot be inferred from an empty array.");const c=typeof t[0];if(c==="string")s="string",i=t;else if(c==="boolean")s="bool",i=Uint8Array.from(t);else throw new TypeError(`Invalid element type of data array: ${c}.`)}else if(t instanceof Uint8ClampedArray)s="uint8",i=Uint8Array.from(t);else{const c=ka.get(t.constructor);if(c===void 0)throw new TypeError(`Unsupported type for tensor data: ${t.constructor}.`);s=c,i=t}if(l===void 0)l=[i.length];else if(!Array.isArray(l))throw new TypeError("A tensor's dims must be a number array");a=l,this.cpuData=i,this.dataLocation="cpu"}const o=_M(a);if(this.cpuData&&o!==this.cpuData.length&&!((s==="uint4"||s==="int4")&&Math.ceil(o/2)===this.cpuData.length))throw new Error(`Tensor's size(${o}) does not match data length(${this.cpuData.length}).`);this.type=s,this.dims=a,this.size=o}static async fromImage(t,r){return lM(t,r)}static fromTexture(t,r){return cM(t,r)}static fromGpuBuffer(t,r){return uM(t,r)}static fromMLTensor(t,r){return dM(t,r)}static fromPinnedBuffer(t,r,n){return hM(t,r,n)}toDataURL(t){return oM(this,t)}toImageData(t){return iM(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}get mlTensor(){if(this.ensureValid(),!this.mlTensorData)throw new Error("The data is not stored as a WebNN MLTensor.");return this.mlTensorData}async getData(t){switch(this.ensureValid(),this.dataLocation){case"cpu":case"cpu-pinned":return this.data;case"texture":case"gpu-buffer":case"ml-tensor":{if(!this.downloader)throw new Error("The current tensor is not created with a specified data downloader.");if(this.isDownloading)throw new Error("The current tensor is being downloaded.");try{this.isDownloading=!0;const r=await this.downloader();return this.downloader=void 0,this.dataLocation="cpu",this.cpuData=r,t&&this.disposer&&(this.disposer(),this.disposer=void 0),r}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.mlTensorData=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 pM(this,t)}};const mM=Ft;var dr={},gM=Object.defineProperty,vn=(e,t)=>{for(var r in t)gM(e,r,{get:t[r],enumerable:!0})},xt={},Zt={},wM={},vM="4.2.0",$l=typeof self<"u",pn=!em(xt),Jp=!em(Zt),La=$l&&"caches"in self,yM=typeof globalThis.Deno<"u",$a=yM&&La&&!pn,Kp=typeof process<"u",ep,Zp=Kp&&((ep=process==null?void 0:process.release)==null?void 0:ep.name)==="node"&&!$a,Vl=typeof window<"u"&&typeof window.document<"u",tp,Ul=$l&&["DedicatedWorkerGlobalScope","ServiceWorkerGlobalScope","SharedWorkerGlobalScope"].includes((tp=self.constructor)==null?void 0:tp.name),bM=Vl||Ul||$a,MM=Zp||typeof navigator<"u"&&"gpu"in navigator,xM=typeof navigator<"u"&&"ml"in navigator,kM=typeof crypto<"u"&&typeof crypto.getRandomValues=="function",TM=typeof chrome<"u"&&typeof chrome.runtime<"u"&&typeof chrome.runtime.id=="string",EM=typeof ServiceWorkerGlobalScope<"u"&&$l&&self instanceof ServiceWorkerGlobalScope,AM=()=>{if(typeof navigator>"u")return!1;const e=navigator.userAgent,r=(navigator.vendor||"").indexOf("Apple")>-1,n=!e.match(/CriOS|FxiOS|EdgiOS|OPiOS|mercury|brave/i)&&!e.includes("Chrome")&&!e.includes("Android");return r&&n},CM=AM(),_e=Object.freeze({IS_BROWSER_ENV:Vl,IS_WEBWORKER_ENV:Ul,IS_WEB_ENV:bM,IS_SERVICE_WORKER_ENV:EM,IS_DENO_WEB_RUNTIME:$a,IS_WEB_CACHE_AVAILABLE:La,IS_WEBGPU_AVAILABLE:MM,IS_WEBNN_AVAILABLE:xM,IS_SAFARI:CM,IS_PROCESS_AVAILABLE:Kp,IS_NODE_ENV:Zp,IS_FS_AVAILABLE:pn,IS_PATH_AVAILABLE:Jp,IS_CRYPTO_AVAILABLE:kM,IS_CHROME_AVAILABLE:TM}),jl=pn&&Jp,Ia="./";if(jl){const e=Object(import.meta).url;e?Ia=Zt.dirname(Zt.dirname(wM.fileURLToPath(e))):typeof __dirname<"u"&&(Ia=Zt.dirname(__dirname))}var SM=jl?Zt.join(Ia,"/.cache/"):null,Zf="/models/",PM=jl?Zt.join(Ia,Zf):Zf,FM=typeof globalThis.fetch=="function"?globalThis.fetch.bind(globalThis):void 0,Dt=Object.freeze({DEBUG:10,INFO:20,WARNING:30,ERROR:40,NONE:50}),e_=Dt.WARNING,Me={version:vM,backends:{onnx:{}},get logLevel(){return e_},set logLevel(e){var t,r;e_=e,(r=(t=Me.backends.onnx)==null?void 0:t.setLogLevel)==null||r.call(t,e)},allowRemoteModels:!0,remoteHost:"https://huggingface.co/",remotePathTemplate:"{model}/resolve/{revision}/",allowLocalModels:!(Vl||Ul||$a),localModelPath:PM,useFS:pn,useBrowserCache:La,useFSCache:pn,cacheDir:SM,useCustomCache:!1,customCache:null,useWasmCache:La||pn,cacheKey:"transformers-cache",experimental_useCrossOriginStorage:!1,fetch:FM};function em(e){return Object.keys(e).length===0}var wt=class{constructor(){let e=function(...t){return e._call(...t)};return Object.setPrototypeOf(e,new.target.prototype)}_call(...e){throw Error("Must implement _call method in subclass")}};function Ar(e,t){e&&e(t)}var ul=class extends wt{constructor(e,t){super(),this.callback=e,this.files_loading=t}_call(e){if(e.status==="progress"){this.files_loading[e.file]={loaded:e.loaded,total:e.total};const t=Object.values(this.files_loading).reduce((s,a)=>s+a.loaded,0),r=Object.values(this.files_loading).reduce((s,a)=>s+a.total,0),n=r>0?t/r*100:0;this.callback({status:"progress_total",name:e.name,progress:n,loaded:t,total:r,files:structuredClone(this.files_loading)})}this.callback(e)}};function LM(e){return Number.isInteger(e)||typeof e=="bigint"}function t_(e){return e==null||e===-1}function r_(e){const t=[];let r=e;for(;Array.isArray(r);)t.push(r.length),r=r[0];return t}function er(...e){return Array.prototype.concat.apply([],e)}function IM(...e){return e.reduce((t,r)=>t.flatMap(n=>r.map(s=>[n,s])))}function Oa(e,t){return Math.abs((e+t)%(2*t)-t)}function Ze(e,t){return Object.assign({},...t.map(r=>{if(e[r]!==void 0)return{[r]:e[r]}}))}function OM(e,t){let r=0;for(const n of e)n===t&&++r;return r}var ue={error(...e){Me.logLevel<=Dt.ERROR&&console.error(...e)},warn(...e){Me.logLevel<=Dt.WARNING&&console.warn(...e)},info(...e){Me.logLevel<=Dt.INFO&&console.log(...e)},debug(...e){Me.logLevel<=Dt.DEBUG&&console.log(...e)},log(...e){this.info(...e)}},NM=class{constructor(e){this.trie=this._build_trie(e)}_build_trie(e){const t=Object.create(null);for(const r of e){let n=t;for(let s=0;s<r.length;++s){const a=r[s];n=n[a]??(n[a]=Object.create(null))}n.end=r}return t}split(e){const t=[],r=e.length;let n=0,s=0;for(;s<r;){let a=this.trie,o=null,i=s;for(;i<r&&(a=a[e[i]]);)a.end&&(o=a.end),++i;o?(s>n&&t.push(e.slice(n,s)),t.push(o),s+=o.length,n=s):++s}return n<r&&t.push(e.slice(n)),t}},n_=NM,DM=class{constructor(e){this.content=e.content,this.id=e.id,this.single_word=e.single_word??!1,this.lstrip=e.lstrip??!1,this.rstrip=e.rstrip??!1,this.special=e.special??!1,this.normalized=e.normalized??!this.special}},zM=DM,tm=(()=>{const e=[...Array.from({length:94},(s,a)=>a+33),...Array.from({length:12},(s,a)=>a+161),...Array.from({length:82},(s,a)=>a+174)],t=e.slice();let r=0;for(let s=0;s<256;++s)e.includes(s)||(e.push(s),t.push(256+r),r+=1);const n=t.map(s=>String.fromCharCode(s));return Object.fromEntries(e.map((s,a)=>[s,n[a]]))})(),BM=e=>Object.fromEntries(Object.entries(e).map(([t,r])=>[r,t])),RM=BM(tm),s_=".,!?…。,、।۔،",GM=new Map([["(?i:'s|'t|'re|'ve|'m|'ll|'d)","(?:'([sS]|[tT]|[rR][eE]|[vV][eE]|[mM]|[lL][lL]|[dD]))"],["(?i:[sdmt]|ll|ve|re)","(?:[sS]|[dD]|[mM]|[tT]|[lL][lL]|[vV][eE]|[rR][eE])"],["[^\\r\\n\\p{L}\\p{N}]?+","[^\\r\\n\\p{L}\\p{N}]?"],["[^\\s\\p{L}\\p{N}]++","[^\\s\\p{L}\\p{N}]+"],["(?>\\p{Nd}{510})","(?:\\p{Nd}{510})"],["\\p{Nd}{3}+","(?:\\p{Nd}{3})+"],["\\G",""],[` ?[^(\\s|[${s_}])]+`,` ?[^\\s${s_}]+`]]),Na="\\p{P}\\u0021-\\u002F\\u003A-\\u0040\\u005B-\\u0060\\u007B-\\u007E",ql=e=>e.replace(/ \./g,".").replace(/ \?/g,"?").replace(/ \!/g,"!").replace(/ ,/g,",").replace(/ \' /g,"'").replace(/ n't/g,"n't").replace(/ 'm/g,"'m").replace(/ 's/g,"'s").replace(/ 've/g,"'ve").replace(/ 're/g,"'re"),Va=(e,t=!0)=>{if(e.Regex!==void 0){let r=e.Regex.replace(/\\([#&~])/g,"$1");r=r.replace(/\\A/g,"^").replace(/\\z/g,"$").replace(/\\Z/g,"(?=\\r?\\n?$)");for(const[n,s]of GM)r=r.replaceAll(n,s);try{return new RegExp(r,"gu")}catch(n){if(!(n instanceof SyntaxError)||!n.message.toLowerCase().includes("invalid property name"))throw n;let s=!1;const a=r.replace(/(\\[pP])\{([^}=]+)\}/g,(o,i,l)=>{try{return new RegExp(`\\p{${l}}`,"u"),`${i}{${l}}`}catch{return s=!0,`${i}{Script=${l}}`}});if(!s)throw n;try{return new RegExp(a,"gu")}catch{throw n}}}else if(e.String!==void 0){const r=$M(e.String);return new RegExp(t?r:`(${r})`,"gu")}else return console.warn("Unknown pattern type:",e),null},$M=e=>e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"),VM=(e,t,r)=>{const n=[];let s=0;for(;s<e.length;){if(n.push(e[s]),(t.get(e[s])??r)!==r){++s;continue}for(;++s<e.length&&(t.get(e[s])??r)===r;)t.get(n.at(-1))!==r&&(n[n.length-1]+=e[s])}return n},UM=e=>e>=19968&&e<=40959||e>=13312&&e<=19903||e>=131072&&e<=173791||e>=173824&&e<=177983||e>=177984&&e<=178207||e>=178208&&e<=183983||e>=63744&&e<=64255||e>=194560&&e<=195103,jM=e=>Number.isInteger(e)||typeof e=="bigint",qM=e=>{let t=0;for(const r of e)++t;return t},WM=e=>rm(e.toLowerCase()),zt=(...e)=>Array.prototype.concat.apply([],e),Wl=e=>new Map(Object.entries(e)),HM=(e,t)=>{const r=[];let n=0;for(const s of e.matchAll(t)){const a=s[0];n<s.index&&r.push(e.slice(n,s.index)),a.length>0&&r.push(a),n=s.index+a.length}return n<e.length&&r.push(e.slice(n)),r},rm=e=>e.replace(new RegExp("\\p{M}","gu"),""),a_=(e,t,r=[])=>{if(!e||Array.isArray(e)||typeof e!="object")return`${t} must be a valid object`;for(const n of r)if(!(n in e))return`${t} must contain a "${n}" property`;return null},QM=e=>e.match(/\S+/g)||[],XM=class{constructor(){const e=function(...t){return e._call(...t)};return Object.setPrototypeOf(e,new.target.prototype)}},Ms=XM,YM=class extends Ms{constructor(e){super(),this.config=e}_call(e){return this.normalize(e)}},gr=YM,JM=class extends gr{tokenize_chinese_chars(e){const t=[];for(let r=0;r<e.length;++r){const n=e[r],s=n.charCodeAt(0);UM(s)?(t.push(" "),t.push(n),t.push(" ")):t.push(n)}return t.join("")}strip_accents(e){return e.normalize("NFD").replace(new RegExp("\\p{Mn}","gu"),"")}is_control(e){switch(e){case" ":case`
9
+ `:case"\r":return!1;default:return new RegExp("^\\p{Cc}|\\p{Cf}|\\p{Co}|\\p{Cs}$","u").test(e)}}clean_text(e){const t=[];for(const r of e){const n=r.charCodeAt(0);n===0||n===65533||this.is_control(r)||(/^\s$/.test(r)?t.push(" "):t.push(r))}return t.join("")}normalize(e){return this.config.clean_text&&(e=this.clean_text(e)),this.config.handle_chinese_chars&&(e=this.tokenize_chinese_chars(e)),this.config.lowercase?(e=e.toLowerCase(),this.config.strip_accents!==!1&&(e=this.strip_accents(e))):this.config.strip_accents&&(e=this.strip_accents(e)),e}},KM=JM,ZM=class extends gr{constructor(e){super(e),this.charsmap=e.precompiled_charsmap??null}normalize(e){return e=e.replace(/[\u0001-\u0008\u000B\u000E-\u001F\u007F\u008F\u009F]/gm,""),e=e.replace(/[\u0009\u000A\u000C\u000D\u00A0\u1680\u2000-\u200F\u2028\u2029\u202F\u205F\u2581\u3000\uFEFF\uFFFD]/gm," "),e.includes("~")?e=e.split("~").map(r=>r.normalize("NFKC")).join("~"):e=e.normalize("NFKC"),e}},ex=ZM,tx=class extends gr{constructor(e){super(e),this.normalizers=(e.normalizers??[]).map(t=>nm(t))}normalize(e){return this.normalizers.reduce((t,r)=>r?r.normalize(t):t,e)}},rx=tx,nx=class extends gr{normalize(e){const t=Va(this.config.pattern??{});return t===null?e:e.replaceAll(t,this.config.content??"")}},sx=nx,ax=class extends gr{constructor(){super(...arguments),this.form="NFC"}normalize(e){return e=e.normalize(this.form),e}},Ua=ax,ox=class extends Ua{constructor(){super(...arguments),this.form="NFC"}},ix=ox,lx=class extends Ua{constructor(){super(...arguments),this.form="NFD"}},cx=lx,ux=class extends Ua{constructor(){super(...arguments),this.form="NFKC"}},dx=ux,hx=class extends Ua{constructor(){super(...arguments),this.form="NFKD"}},fx=hx,_x=class extends gr{normalize(e){return this.config.strip_left&&this.config.strip_right?e=e.trim():(this.config.strip_left&&(e=e.trimStart()),this.config.strip_right&&(e=e.trimEnd())),e}},px=_x,mx=class extends gr{normalize(e){return rm(e)}},gx=mx,wx=class extends gr{normalize(e){return e.toLowerCase()}},vx=wx,yx=class extends gr{normalize(e){return e=this.config.prepend+e,e}},bx=yx;function Mx(e){if(e===null)return null;switch(e.type){case"BertNormalizer":return new KM(e);case"Precompiled":return new ex(e);case"Sequence":return new rx(e);case"Replace":return new sx(e);case"NFC":return new ix(e);case"NFD":return new cx(e);case"NFKC":return new dx(e);case"NFKD":return new fx(e);case"Strip":return new px(e);case"StripAccents":return new gx(e);case"Lowercase":return new vx(e);case"Prepend":return new bx(e);default:throw new Error(`Unknown Normalizer type: ${e.type}`)}}var nm=Mx,xx=class extends Ms{pre_tokenize(e,t){return(Array.isArray(e)?e.map(r=>this.pre_tokenize_text(r,t)):this.pre_tokenize_text(e,t)).flat()}_call(e,t){return this.pre_tokenize(e,t)}},$t=xx,kx=class extends $t{constructor(e){super(),this.config=e,this.add_prefix_space=this.config.add_prefix_space??!1,this.trim_offsets=this.config.trim_offsets??!1,this.use_regex=this.config.use_regex??!0,this.pattern=new RegExp("'s|'t|'re|'ve|'m|'ll|'d| ?\\p{L}+| ?\\p{N}+| ?[^\\s\\p{L}\\p{N}]+|\\s+(?!\\S)|\\s+","gu"),this.byte_encoder=tm,this.text_encoder=new TextEncoder}pre_tokenize_text(e,t){return this.add_prefix_space&&!e.startsWith(" ")&&(e=" "+e),(this.use_regex?e.match(this.pattern)||[]:[e]).map(n=>Array.from(this.text_encoder.encode(n),s=>this.byte_encoder[s]).join(""))}},Tx=kx,Ex=class extends $t{pre_tokenize_text(e,t){return e.match(/\w+|[^\w\s]+/g)||[]}},Ax=Ex,Cx=class extends $t{constructor(e){super(),this.replacement=e.replacement??"▁",this.str_rep=e.str_rep||this.replacement,this.prepend_scheme=e.prepend_scheme??"always"}pre_tokenize_text(e,t){const{section_index:r=void 0}=t??{};let n=e.replaceAll(" ",this.str_rep);return!n.startsWith(this.replacement)&&(this.prepend_scheme==="always"||this.prepend_scheme==="first"&&r===0)&&(n=this.str_rep+n),[n]}},Sx=Cx,Px=class extends $t{constructor(e){super(),this.config=e,this.pattern=Va(this.config.pattern??{},this.config.invert??!0)}pre_tokenize_text(e){var t;return this.pattern===null?[]:this.config.invert?e.match(this.pattern)||[]:((t=this.config.behavior)==null?void 0:t.toLowerCase())==="removed"?e.split(this.pattern).filter(r=>r):HM(e,this.pattern)}},Fx=Px,Lx=class extends $t{constructor(e){super(),this.config=e,this.pattern=new RegExp(`[^${Na}]+|[${Na}]+`,"gu")}pre_tokenize_text(e){return e.match(this.pattern)||[]}},Ix=Lx,Ox=class extends $t{constructor(e){super(),this.config=e;const t=`[^\\d]+|\\d${this.config.individual_digits?"":"+"}`;this.pattern=new RegExp(t,"gu")}pre_tokenize_text(e){return e.match(this.pattern)||[]}},Nx=Ox,Dx=class extends $t{constructor(){super(),this.pattern=new RegExp(`[^\\s${Na}]+|[${Na}]`,"gu")}pre_tokenize_text(e,t){return e.trim().match(this.pattern)||[]}},zx=Dx,Bx=class extends $t{constructor(e){super(),this.config=e,this.pattern=Va(this.config.pattern??{}),this.content=this.config.content??""}pre_tokenize_text(e){return this.pattern===null?[e]:[e.replaceAll(this.pattern,this.config.content??"")]}},Rx=Bx,Gx=class extends $t{constructor(e){super(),this.tokenizers=(e.pretokenizers??[]).map(t=>sm(t))}pre_tokenize_text(e,t){return this.tokenizers.reduce((r,n)=>n?n.pre_tokenize(r,t):r,[e])}},$x=Gx,Vx=class extends $t{pre_tokenize_text(e){return QM(e)}},Ux=Vx,jx=class extends $t{constructor(e){super(),this.config=e,this._length=e.length}pre_tokenize_text(e){const t=[];for(let r=0;r<e.length;r+=this._length)t.push(e.slice(r,r+this._length));return t}},qx=jx;function Wx(e){if(e===null)return null;switch(e.type){case"BertPreTokenizer":return new zx;case"Sequence":return new $x(e);case"Whitespace":return new Ax;case"WhitespaceSplit":return new Ux;case"Metaspace":return new Sx(e);case"ByteLevel":return new Tx(e);case"Split":return new Fx(e);case"Punctuation":return new Ix(e);case"Digits":return new Nx(e);case"Replace":return new Rx(e);case"FixedLength":return new qx(e);default:throw new Error(`Unknown PreTokenizer type: ${e.type}`)}}var sm=Wx,Hx=class extends Ms{constructor(e){super(),this.config=e,this.vocab=[],this.tokens_to_ids=new Map,this.unk_token_id=void 0,this.unk_token=void 0,this.end_of_word_suffix=void 0,this.fuse_unk=this.config.fuse_unk??!1}_call(e){let t=this.encode(e);return this.fuse_unk&&(t=VM(t,this.tokens_to_ids,this.unk_token_id)),t}},ja=Hx,Qx=class extends ja{constructor(e){super(e),this.max_input_chars_per_word=100,this.tokens_to_ids=Wl(e.vocab),this.unk_token_id=this.tokens_to_ids.get(e.unk_token),this.unk_token=e.unk_token,this.max_input_chars_per_word=e.max_input_chars_per_word??100,this.vocab=new Array(this.tokens_to_ids.size);for(const[t,r]of this.tokens_to_ids)this.vocab[r]=t}encode(e){const t=[];for(const r of e){const n=[...r];if(n.length>this.max_input_chars_per_word){t.push(this.unk_token);continue}let s=!1,a=0;const o=[];for(;a<n.length;){let i=n.length,l=null;for(;a<i;){let c=n.slice(a,i).join("");if(a>0&&(c=this.config.continuing_subword_prefix+c),this.tokens_to_ids.has(c)){l=c;break}--i}if(l===null){s=!0;break}o.push(l),a=i}s?t.push(this.unk_token):t.push(...o)}return t}},o_=Qx,i_=class am{constructor(t,r){this.is_leaf=t,this.children=r}static default(){return new am(!1,new Map)}},Xx=class{constructor(){this.root=i_.default()}extend(e){for(const t of e)this.push(t)}push(e){let t=this.root;for(const r of e){let n=t.children.get(r);n===void 0&&(n=i_.default(),t.children.set(r,n)),t=n}t.is_leaf=!0}*common_prefix_search(e){let t=this.root;if(t===void 0)return;let r="";for(const n of e){if(r+=n,t=t.children.get(n),t===void 0)return;t.is_leaf&&(yield r)}}},Yx=Xx,fi=class om{constructor(t,r,n,s,a){this.token_id=t,this.node_id=r,this.pos=n,this.length=s,this.score=a,this.prev=null,this.backtrace_score=0}clone(){const t=new om(this.token_id,this.node_id,this.pos,this.length,this.score);return t.prev=this.prev,t.backtrace_score=this.backtrace_score,t}},Jx=class{constructor(e,t,r){this.chars=Array.from(e),this.len=this.chars.length,this.bos_token_id=t,this.eos_token_id=r,this.nodes=[],this.begin_nodes=Array.from({length:this.len+1},()=>[]),this.end_nodes=Array.from({length:this.len+1},()=>[]);const n=new fi(this.bos_token_id??0,0,0,0,0),s=new fi(this.eos_token_id??0,1,this.len,0,0);this.nodes.push(n.clone()),this.nodes.push(s.clone()),this.begin_nodes[this.len].push(s),this.end_nodes[0].push(n)}insert(e,t,r,n){const s=this.nodes.length,a=new fi(n,s,e,t,r);this.begin_nodes[e].push(a),this.end_nodes[e+t].push(a),this.nodes.push(a)}viterbi(){const e=this.len;let t=0;for(;t<=e;){if(this.begin_nodes[t].length==0)return[];for(let o of this.begin_nodes[t]){o.prev=null;let i=0,l=null;for(let c of this.end_nodes[t]){const d=c.backtrace_score+o.score;(l===null||d>i)&&(l=c.clone(),i=d)}if(l!==null)o.prev=l,o.backtrace_score=i;else return[]}++t}const r=[],s=this.begin_nodes[e][0].prev;if(s===null)return[];let a=s.clone();for(;a.prev!==null;)r.push(a.clone()),a=a.clone().prev.clone();return r.reverse(),r}piece(e){return this.chars.slice(e.pos,e.pos+e.length).join("")}tokens(){return this.viterbi().map(t=>this.piece(t))}token_ids(){return this.viterbi().map(t=>t.token_id)}},Kx=Jx;function Zx(e){if(e.length===0)throw new Error("Array must not be empty");let t=e[0],r=0;for(let n=1;n<e.length;++n)e[n]<t&&(t=e[n],r=n);return[t,r]}var e1=class extends ja{constructor(e,t){super(e);const r=e.vocab.length;this.vocab=new Array(r),this.scores=new Array(r);for(let n=0;n<r;++n)[this.vocab[n],this.scores[n]]=e.vocab[n];this.unk_token_id=e.unk_id,this.unk_token=this.vocab[e.unk_id],this.tokens_to_ids=new Map(this.vocab.map((n,s)=>[n,s])),this.bos_token=" ",this.bos_token_id=this.tokens_to_ids.get(this.bos_token),this.eos_token=t,this.eos_token_id=this.tokens_to_ids.get(this.eos_token),this.unk_token=this.vocab[this.unk_token_id],this.min_score=Zx(this.scores)[0],this.unk_score=this.min_score-10,this.scores[this.unk_token_id]=this.unk_score,this.trie=new Yx,this.trie.extend(this.vocab),this.fuse_unk=!0}populate_nodes(e){const t=e.chars,r=1;let n=0;for(;n<t.length;){let s=!1;const a=t.slice(n).join(""),o=this.trie.common_prefix_search(a);for(const i of o){const l=this.tokens_to_ids.get(i),c=this.scores[l],d=qM(i);e.insert(n,d,c,l),!s&&d===r&&(s=!0)}s||e.insert(n,r,this.unk_score,this.unk_token_id),n+=r}}tokenize(e){const t=new Kx(e,this.bos_token_id,this.eos_token_id);return this.populate_nodes(t),t.tokens()}encode(e){const t=[];for(const r of e){const n=this.tokenize(r);t.push(...n)}return t}},l_=e1,t1=class{constructor(e=(r,n)=>r>n,t=1/0){this._heap=[],this._comparator=e,this._max_size=t}get size(){return this._heap.length}is_empty(){return this.size===0}peek(){return this._heap[0]}push(...e){return this.extend(e)}extend(e){for(const t of e)if(this.size<this._max_size)this._heap.push(t),this._sift_up();else{const r=this._smallest();this._comparator(t,this._heap[r])&&(this._heap[r]=t,this._sift_up_from(r))}return this.size}pop(){const e=this.peek(),t=this.size-1;return t>0&&this._swap(0,t),this._heap.pop(),this._sift_down(),e}replace(e){const t=this.peek();return this._heap[0]=e,this._sift_down(),t}_parent(e){return(e+1>>>1)-1}_left(e){return(e<<1)+1}_right(e){return e+1<<1}_greater(e,t){return this._comparator(this._heap[e],this._heap[t])}_swap(e,t){const r=this._heap[e];this._heap[e]=this._heap[t],this._heap[t]=r}_sift_up(){this._sift_up_from(this.size-1)}_sift_up_from(e){for(;e>0&&this._greater(e,this._parent(e));)this._swap(e,this._parent(e)),e=this._parent(e)}_sift_down(){let e=0;for(;this._left(e)<this.size&&this._greater(this._left(e),e)||this._right(e)<this.size&&this._greater(this._right(e),e);){const t=this._right(e)<this.size&&this._greater(this._right(e),this._left(e))?this._right(e):this._left(e);this._swap(e,t),e=t}}_smallest(){return 2**Math.floor(Math.log2(this.size))-1}},r1=t1,n1=class{constructor(e){this.capacity=e,this.cache=new Map}get(e){if(!this.cache.has(e))return;const t=this.cache.get(e);return this.cache.delete(e),this.cache.set(e,t),t}put(e,t){this.cache.has(e)&&this.cache.delete(e),this.cache.set(e,t),this.cache.size>this.capacity&&this.cache.delete(this.cache.keys().next().value)}clear(){this.cache.clear()}},s1=n1,a1=class extends ja{constructor(e){super(e),this.tokens_to_ids=Wl(e.vocab),this.unk_token_id=this.tokens_to_ids.get(e.unk_token),this.unk_token=e.unk_token,this.vocab=new Array(this.tokens_to_ids.size);for(const[r,n]of this.tokens_to_ids)this.vocab[n]=r;const t=Array.isArray(e.merges[0]);this.merges=t?e.merges:e.merges.map(r=>r.split(" ",2)),this.bpe_ranks=new Map(this.merges.map((r,n)=>[JSON.stringify(r),n])),this.end_of_word_suffix=e.end_of_word_suffix,this.continuing_subword_suffix=e.continuing_subword_suffix??null,this.byte_fallback=this.config.byte_fallback??!1,this.byte_fallback&&(this.text_encoder=new TextEncoder),this.ignore_merges=this.config.ignore_merges??!1,this.max_length_to_cache=256,this.cache_capacity=1e4,this.cache=new s1(this.cache_capacity)}clear_cache(){this.cache.clear()}bpe(e){if(e.length===0)return[];const t=this.cache.get(e);if(t!==void 0)return t;const r=Array.from(e);this.end_of_word_suffix&&(r[r.length-1]+=this.end_of_word_suffix);let n=[];if(r.length>1){const s=new r1((i,l)=>i.score<l.score);let a={token:r[0],bias:0,prev:null,next:null},o=a;for(let i=1;i<r.length;++i){const l={bias:i/r.length,token:r[i],prev:o,next:null};o.next=l,this.add_node(s,o),o=l}for(;!s.is_empty();){const i=s.pop();if(i.deleted||!i.next||i.next.deleted)continue;if(i.deleted=!0,i.next.deleted=!0,i.prev){const c={...i.prev};i.prev.deleted=!0,i.prev=c,c.prev?c.prev.next=c:a=c}const l={token:i.token+i.next.token,bias:i.bias,prev:i.prev,next:i.next.next};l.prev?(l.prev.next=l,this.add_node(s,l.prev)):a=l,l.next&&(l.next.prev=l,this.add_node(s,l))}for(let i=a;i!==null;i=i.next)n.push(i.token)}else n=r;if(this.continuing_subword_suffix)for(let s=0;s<n.length-1;++s)n[s]+=this.continuing_subword_suffix;return e.length<this.max_length_to_cache&&this.cache.put(e,n),n}add_node(e,t){const r=this.bpe_ranks.get(JSON.stringify([t.token,t.next.token]));r!==void 0&&(t.score=r+t.bias,e.push(t))}encode(e){const t=[];for(const r of e){if(this.ignore_merges&&this.tokens_to_ids.has(r)){t.push(r);continue}const n=this.bpe(r);for(const s of n)if(this.tokens_to_ids.has(s))t.push(s);else if(this.byte_fallback){const a=Array.from(this.text_encoder.encode(s)).map(o=>`<0x${o.toString(16).toUpperCase().padStart(2,"0")}>`);a.every(o=>this.tokens_to_ids.has(o))?t.push(...a):this.unk_token!=null&&t.push(this.unk_token)}else this.unk_token!=null&&t.push(this.unk_token)}return t}},c_=a1,o1=class extends ja{constructor(e,t){super(e);const r=e.vocab;this.tokens_to_ids=Wl(t.target_lang?r[t.target_lang]:r),this.bos_token=t.bos_token,this.bos_token_id=this.tokens_to_ids.get(this.bos_token),this.eos_token=t.eos_token,this.eos_token_id=this.tokens_to_ids.get(this.eos_token),this.pad_token=t.pad_token,this.pad_token_id=this.tokens_to_ids.get(this.pad_token),this.unk_token=t.unk_token,this.unk_token_id=this.tokens_to_ids.get(this.unk_token),this.vocab=new Array(this.tokens_to_ids.size);for(const[n,s]of this.tokens_to_ids)this.vocab[s]=n}encode(e){return e}},i1=o1;function l1(e,t){switch(e.type){case"WordPiece":return new o_(e);case"Unigram":return new l_(e,t.eos_token);case"BPE":return new c_(e);default:if(e.vocab)return Array.isArray(e.vocab)?new l_(e,t.eos_token):Object.hasOwn(e,"continuing_subword_prefix")&&Object.hasOwn(e,"unk_token")?Object.hasOwn(e,"merges")?new c_(e):new o_(e):new i1(e,{target_lang:t.target_lang,bos_token:t.bos_token,eos_token:t.eos_token,pad_token:t.pad_token,unk_token:t.unk_token});throw new Error(`Unknown TokenizerModel type: ${e==null?void 0:e.type}`)}}var c1=l1,u1=class extends Ms{constructor(e){super(),this.config=e}_call(e,...t){return this.post_process(e,...t)}},xs=u1,d1=class extends xs{post_process(e,t=null,r=!0){const n=t===null?this.config.single:this.config.pair;let s=[],a=[];for(const o of n)"SpecialToken"in o?r&&(s.push(o.SpecialToken.id),a.push(o.SpecialToken.type_id)):"Sequence"in o&&(o.Sequence.id==="A"?(s=zt(s,e),a=zt(a,new Array(e.length).fill(o.Sequence.type_id))):o.Sequence.id==="B"&&(s=zt(s,t),a=zt(a,new Array(t.length).fill(o.Sequence.type_id))));return{tokens:s,token_type_ids:a}}},h1=d1,f1=class extends xs{post_process(e,t=null){return{tokens:e,tokens_pair:t}}},_1=f1,p1=class extends xs{constructor(e){super(e),this.sep=e.sep,this.cls=e.cls}post_process(e,t=null,r=!0){r&&(e=zt([this.cls[0]],e,[this.sep[0]]));let n=new Array(e.length).fill(0);if(t){const s=[],a=r?[this.sep[0]]:[];e=zt(e,s,t,a),n=zt(n,new Array(t.length+s.length+a.length).fill(1))}return{tokens:e,token_type_ids:n}}},m1=p1,g1=class extends xs{constructor(e){super(e),this.sep=e.sep,this.cls=e.cls}post_process(e,t,r=!0){r&&(e=zt([this.cls[0]],e,[this.sep[0]]));let n=new Array(e.length).fill(0);if(t){const s=r?[this.sep[0]]:[],a=r?[this.sep[0]]:[];e=zt(e,s,t,a),n=zt(n,new Array(t.length+s.length+a.length).fill(1))}return{tokens:e,token_type_ids:n}}},w1=g1,v1=class extends xs{constructor(e){super(e),this.processors=(e.processors??[]).map(t=>im(t))}post_process(e,t=null,r=!0){let n={tokens:e,tokens_pair:t};for(const s of this.processors)n=s.post_process(n.tokens,n.tokens_pair,r);return n}},y1=v1;function b1(e){if(e===null)return null;switch(e.type){case"TemplateProcessing":return new h1(e);case"ByteLevel":return new _1(e);case"BertProcessing":return new m1(e);case"RobertaProcessing":return new w1(e);case"Sequence":return new y1(e);default:throw new Error(`Unknown PostProcessor type: ${e.type}`)}}var im=b1,M1=class extends Ms{constructor(e){super(),this.config=e,this.added_tokens=[],this.end_of_word_suffix=null,this.trim_offsets="trim_offsets"in e?e.trim_offsets:!1}_call(e){return this.decode(e)}decode(e){return this.decode_chain(e).join("")}},Vt=M1,x1=class extends Vt{constructor(e){super(e),this.byte_decoder=RM,this.text_decoder=new TextDecoder("utf-8",{fatal:!1,ignoreBOM:!0}),this.end_of_word_suffix=null}convert_tokens_to_string(e){const t=e.join(""),r=new Uint8Array([...t].map(n=>this.byte_decoder[n]));return this.text_decoder.decode(r)}decode_chain(e){const t=[];let r=[];for(const n of e)this.added_tokens.find(s=>s.content===n)!==void 0?(r.length>0&&(t.push(this.convert_tokens_to_string(r)),r=[]),t.push(n)):r.push(n);return r.length>0&&t.push(this.convert_tokens_to_string(r)),t}},k1=x1,T1=class extends Vt{constructor(e){super(e),this.cleanup=e.cleanup}decode_chain(e){return e.map((t,r)=>{if(r!==0){const n=this.config.prefix;n&&t.startsWith(n)?t=t.replace(n,""):t=" "+t}return this.cleanup&&(t=ql(t)),t})}},E1=T1,A1=class extends Vt{constructor(e){super(e),this.replacement=e.replacement??"▁"}decode_chain(e){const t=[];for(let r=0;r<e.length;++r){let n=e[r].replaceAll(this.replacement," ");r==0&&n.startsWith(" ")&&(n=n.substring(1)),t.push(n)}return t}},C1=A1,S1=class extends Vt{constructor(e){super(e),this.suffix=e.suffix??""}decode_chain(e){return e.map((t,r)=>t.replaceAll(this.suffix,r===e.length-1?"":" "))}},P1=S1,F1=class extends Vt{constructor(e){super(e),this.pad_token=e.pad_token??"",this.word_delimiter_token=e.word_delimiter_token??"",this.cleanup=e.cleanup}convert_tokens_to_string(e){if(e.length===0)return"";const t=[e[0]];for(let s=1;s<e.length;++s)e[s]!==t.at(-1)&&t.push(e[s]);let n=t.filter(s=>s!==this.pad_token).join("");return this.cleanup&&(n=ql(n).replaceAll(this.word_delimiter_token," ").trim()),n}decode_chain(e){return[this.convert_tokens_to_string(e)]}},L1=F1,I1=class extends Vt{constructor(e){super(e),this.decoders=(e.decoders??[]).map(t=>lm(t))}decode_chain(e){return this.decoders.reduce((t,r)=>r.decode_chain(t),e)}},O1=I1,N1=class extends Vt{decode_chain(e){const t=Va(this.config.pattern),r=this.config.content??"";return t===null?e:e.map(n=>n.replaceAll(t,r))}},D1=N1,z1=class extends Vt{decode_chain(e){return[e.join("")]}},B1=z1,R1=class extends Vt{constructor(e){super(e),this.content=e.content??"",this.start=e.start??0,this.stop=e.stop??0}decode_chain(e){return e.map(t=>{let r=0;for(let s=0;s<this.start&&t[s]===this.content;++s){r=s+1;continue}let n=t.length;for(let s=0;s<this.stop;++s){const a=t.length-s-1;if(t[a]===this.content){n=a;continue}else break}return t.slice(r,n)})}},G1=R1,$1=class extends Vt{constructor(e){super(e),this.text_decoder=new TextDecoder}decode_chain(e){const t=[];let r=[];for(const n of e){let s=null;if(n.length===6&&n.startsWith("<0x")&&n.endsWith(">")){const a=parseInt(n.slice(3,5),16);isNaN(a)||(s=a)}if(s!==null)r.push(s);else{if(r.length>0){const a=this.text_decoder.decode(Uint8Array.from(r));t.push(a),r=[]}t.push(n)}}if(r.length>0){const n=this.text_decoder.decode(Uint8Array.from(r));t.push(n),r=[]}return t}},V1=$1;function U1(e){if(e===null)return null;switch(e.type){case"ByteLevel":return new k1(e);case"WordPiece":return new E1(e);case"Metaspace":return new C1(e);case"BPEDecoder":return new P1(e);case"CTC":return new L1(e);case"Sequence":return new O1(e);case"Replace":return new D1(e);case"Fuse":return new B1(e);case"Strip":return new G1(e);case"ByteFallback":return new V1(e);default:throw new Error(`Unknown Decoder type: ${e.type}`)}}var lm=U1,j1=class{constructor(e,t){const r=a_(e,"Tokenizer",["model","decoder","post_processor","pre_tokenizer","normalizer"]);if(r)throw new Error(r);const n=a_(t,"Config");if(n)throw new Error(n);this.tokenizer=e,this.config=t,this.normalizer=nm(this.tokenizer.normalizer),this.pre_tokenizer=sm(this.tokenizer.pre_tokenizer),this.model=c1(this.tokenizer.model,this.config),this.post_processor=im(this.tokenizer.post_processor),this.decoder=lm(this.tokenizer.decoder),this.special_tokens=[],this.all_special_ids=[],this.added_tokens=[];const s=[],a=[];this.added_tokens_map=new Map;for(const o of this.tokenizer.added_tokens){const i=new zM(o);if(this.added_tokens.push(i),this.model.tokens_to_ids.set(i.content,i.id),this.model.vocab[i.id]=i.content,i.special&&(this.special_tokens.push(i.content),this.all_special_ids.push(i.id)),this.added_tokens_map.set(i.content,i),i.normalized&&this.normalizer!==null){const l=this.normalizer(i.content);a.push(l),this.added_tokens_map.set(l,i)}else s.push(i.content)}(this.config.additional_special_tokens??[]).forEach(o=>{this.special_tokens.includes(o)||this.special_tokens.push(o)}),this.decoder&&(this.decoder.added_tokens=this.added_tokens,this.decoder.end_of_word_suffix=this.model.end_of_word_suffix),this.splitter_unnormalized=new n_(s),this.splitter_normalized=new n_(a),this.remove_space=this.config.remove_space,this.clean_up_tokenization_spaces=this.config.clean_up_tokenization_spaces??!0,this.do_lowercase_and_remove_accent=this.config.do_lowercase_and_remove_accent??!1}encode(e,{text_pair:t=null,add_special_tokens:r=!0,return_token_type_ids:n=null}={}){const{tokens:s,token_type_ids:a}=this.tokenize_helper(e,{text_pair:t,add_special_tokens:r}),o=s.map(l=>{var c;return((c=this.added_tokens_map.get(l))==null?void 0:c.id)??this.model.tokens_to_ids.get(l)??this.model.unk_token_id}),i={ids:o,tokens:s,attention_mask:new Array(o.length).fill(1)};return n&&a&&(i.token_type_ids=a),i}decode(e,t={}){if(!Array.isArray(e)||e.length===0||!jM(e[0]))throw Error("token_ids must be a non-empty array of integers.");let r=e.map(s=>this.model.vocab[Number(s)]??this.model.unk_token);t.skip_special_tokens&&(r=r.filter(s=>!this.special_tokens.includes(s)));let n=this.decoder?this.decoder(r):r.join(" ");return this.decoder&&this.decoder.end_of_word_suffix&&(n=n.replaceAll(this.decoder.end_of_word_suffix," "),t.skip_special_tokens&&(n=n.trim())),(t.clean_up_tokenization_spaces??this.clean_up_tokenization_spaces)&&(n=ql(n)),n}tokenize(e,{text_pair:t=null,add_special_tokens:r=!1}={}){return this.tokenize_helper(e,{text_pair:t,add_special_tokens:r}).tokens}encode_text(e){if(e===null)return null;const t=this.splitter_unnormalized.split(e);return t.forEach((r,n)=>{const s=this.added_tokens_map.get(r);s&&(s.lstrip&&n>0&&(t[n-1]=t[n-1].trimEnd()),s.rstrip&&n<t.length-1&&(t[n+1]=t[n+1].trimStart()))}),t.flatMap((r,n)=>{if(r.length===0)return[];if(this.added_tokens_map.has(r))return[r];if(this.remove_space===!0&&(r=r.trim().split(/\s+/).join(" ")),this.do_lowercase_and_remove_accent&&(r=WM(r)),this.normalizer!==null&&(r=this.normalizer(r)),r.length===0)return[];const s=this.splitter_normalized.split(r);return s.forEach((a,o)=>{const i=this.added_tokens_map.get(a);i&&(i.lstrip&&o>0&&(s[o-1]=s[o-1].trimEnd()),i.rstrip&&o<s.length-1&&(s[o+1]=s[o+1].trimStart()))}),s.flatMap(a=>{if(a.length===0)return[];if(this.added_tokens_map.has(a))return[a];const o=this.pre_tokenizer!==null?this.pre_tokenizer(a,{section_index:n}):[a];return this.model(o)})})}tokenize_helper(e,{text_pair:t=null,add_special_tokens:r=!0}){const n=this.encode_text(e),s=this.encode_text(t||null);return this.post_processor?this.post_processor(n,s,r):{tokens:zt(n??[],s??[])}}token_to_id(e){return this.model.tokens_to_ids.get(e)}id_to_token(e){return this.model.vocab[e]}get_added_tokens_decoder(){const e=new Map;for(const t of this.added_tokens)e.set(t.id,t);return e}get_vocab(e=!0){const t=new Map;for(let r=0;r<this.model.vocab.length;++r){const n=this.model.vocab[r];(e||!this.added_tokens_map.has(n))&&t.set(n,r)}return t}},q1=j1,B=Object.freeze({Text:"Text",NumericLiteral:"NumericLiteral",StringLiteral:"StringLiteral",Identifier:"Identifier",Equals:"Equals",OpenParen:"OpenParen",CloseParen:"CloseParen",OpenStatement:"OpenStatement",CloseStatement:"CloseStatement",OpenExpression:"OpenExpression",CloseExpression:"CloseExpression",OpenSquareBracket:"OpenSquareBracket",CloseSquareBracket:"CloseSquareBracket",OpenCurlyBracket:"OpenCurlyBracket",CloseCurlyBracket:"CloseCurlyBracket",Comma:"Comma",Dot:"Dot",Colon:"Colon",Pipe:"Pipe",CallOperator:"CallOperator",AdditiveBinaryOperator:"AdditiveBinaryOperator",MultiplicativeBinaryOperator:"MultiplicativeBinaryOperator",ComparisonBinaryOperator:"ComparisonBinaryOperator",UnaryOperator:"UnaryOperator",Comment:"Comment"}),St=class{constructor(e,t){this.value=e,this.type=t}};function u_(e){return/\w/.test(e)}function Qn(e){return/[0-9]/.test(e)}function d_(e){return/\s/.test(e)}var W1=[["{%",B.OpenStatement],["%}",B.CloseStatement],["{{",B.OpenExpression],["}}",B.CloseExpression],["(",B.OpenParen],[")",B.CloseParen],["{",B.OpenCurlyBracket],["}",B.CloseCurlyBracket],["[",B.OpenSquareBracket],["]",B.CloseSquareBracket],[",",B.Comma],[".",B.Dot],[":",B.Colon],["|",B.Pipe],["<=",B.ComparisonBinaryOperator],[">=",B.ComparisonBinaryOperator],["==",B.ComparisonBinaryOperator],["!=",B.ComparisonBinaryOperator],["<",B.ComparisonBinaryOperator],[">",B.ComparisonBinaryOperator],["+",B.AdditiveBinaryOperator],["-",B.AdditiveBinaryOperator],["~",B.AdditiveBinaryOperator],["*",B.MultiplicativeBinaryOperator],["/",B.MultiplicativeBinaryOperator],["%",B.MultiplicativeBinaryOperator],["=",B.Equals]],H1=new Map([["n",`
10
+ `],["t"," "],["r","\r"],["b","\b"],["f","\f"],["v","\v"],["'","'"],['"','"'],["\\","\\"]]);function Q1(e,t={}){return e.endsWith(`
11
+ `)&&(e=e.slice(0,-1)),t.lstrip_blocks&&(e=e.replace(/^[ \t]*({[#%-])/gm,"$1")),t.trim_blocks&&(e=e.replace(/([#%-]})\n/g,"$1")),e.replace(/{%\s*(end)?generation\s*%}/gs,"")}function X1(e,t={}){var c,d;const r=[],n=Q1(e,t);let s=0,a=0;const o=h=>{let _="";for(;h(n[s]);){if(n[s]==="\\"){if(++s,s>=n.length)throw new SyntaxError("Unexpected end of input");const p=n[s++],w=H1.get(p);if(w===void 0)throw new SyntaxError(`Unexpected escaped character: ${p}`);_+=w;continue}if(_+=n[s++],s>=n.length)throw new SyntaxError("Unexpected end of input")}return _},i=()=>{const h=r.at(-1);h&&h.type===B.Text&&(h.value=h.value.trimEnd(),h.value===""&&r.pop())},l=()=>{for(;s<n.length&&d_(n[s]);)++s};e:for(;s<n.length;){const h=(c=r.at(-1))==null?void 0:c.type;if(h===void 0||h===B.CloseStatement||h===B.CloseExpression||h===B.Comment){let p="";for(;s<n.length&&!(n[s]==="{"&&(n[s+1]==="%"||n[s+1]==="{"||n[s+1]==="#"));)p+=n[s++];if(p.length>0){r.push(new St(p,B.Text));continue}}if(n[s]==="{"&&n[s+1]==="#"){s+=2;const p=n[s]==="-";p&&++s;let w="";for(;n[s]!=="#"||n[s+1]!=="}";){if(s+2>=n.length)throw new SyntaxError("Missing end of comment tag");w+=n[s++]}const v=w.endsWith("-");v&&(w=w.slice(0,-1)),p&&i(),r.push(new St(w,B.Comment)),s+=2,v&&l();continue}if(n.slice(s,s+3)==="{%-"){i(),r.push(new St("{%",B.OpenStatement)),s+=3;continue}if(n.slice(s,s+3)==="{{-"){i(),r.push(new St("{{",B.OpenExpression)),a=0,s+=3;continue}if(o(d_),n.slice(s,s+3)==="-%}"){r.push(new St("%}",B.CloseStatement)),s+=3,l();continue}if(n.slice(s,s+3)==="-}}"){r.push(new St("}}",B.CloseExpression)),s+=3,l();continue}const _=n[s];if(_==="-"||_==="+"){const p=(d=r.at(-1))==null?void 0:d.type;if(p===B.Text||p===void 0)throw new SyntaxError(`Unexpected character: ${_}`);switch(p){case B.Identifier:case B.NumericLiteral:case B.StringLiteral:case B.CloseParen:case B.CloseSquareBracket:break;default:{++s;const w=o(Qn);r.push(new St(`${_}${w}`,w.length>0?B.NumericLiteral:B.UnaryOperator));continue}}}for(const[p,w]of W1){if(p==="}}"&&a>0)continue;if(n.slice(s,s+p.length)===p){r.push(new St(p,w)),w===B.OpenExpression?a=0:w===B.OpenCurlyBracket?++a:w===B.CloseCurlyBracket&&--a,s+=p.length;continue e}}if(_==="'"||_==='"'){++s;const p=o(w=>w!==_);r.push(new St(p,B.StringLiteral)),++s;continue}if(Qn(_)){let p=o(Qn);if(n[s]==="."&&Qn(n[s+1])){++s;const w=o(Qn);p=`${p}.${w}`}r.push(new St(p,B.NumericLiteral));continue}if(u_(_)){const p=o(u_);r.push(new St(p,B.Identifier));continue}throw new SyntaxError(`Unexpected character: ${_}`)}return r}var Ut=class{constructor(){k(this,"type","Statement")}},Y1=class extends Ut{constructor(t){super();k(this,"type","Program");this.body=t}},J1=class extends Ut{constructor(t,r,n){super();k(this,"type","If");this.test=t,this.body=r,this.alternate=n}},K1=class extends Ut{constructor(t,r,n,s){super();k(this,"type","For");this.loopvar=t,this.iterable=r,this.body=n,this.defaultBlock=s}},Z1=class extends Ut{constructor(){super(...arguments);k(this,"type","Break")}},ek=class extends Ut{constructor(){super(...arguments);k(this,"type","Continue")}},tk=class extends Ut{constructor(t,r,n){super();k(this,"type","Set");this.assignee=t,this.value=r,this.body=n}},rk=class extends Ut{constructor(t,r,n){super();k(this,"type","Macro");this.name=t,this.args=r,this.body=n}},nk=class extends Ut{constructor(t){super();k(this,"type","Comment");this.value=t}},kt=class extends Ut{constructor(){super(...arguments);k(this,"type","Expression")}},sk=class extends kt{constructor(t,r,n){super();k(this,"type","MemberExpression");this.object=t,this.property=r,this.computed=n}},h_=class extends kt{constructor(t,r){super();k(this,"type","CallExpression");this.callee=t,this.args=r}},nn=class extends kt{constructor(t){super();k(this,"type","Identifier");this.value=t}},yn=class extends kt{constructor(t){super();k(this,"type","Literal");this.value=t}},ak=class extends yn{constructor(){super(...arguments);k(this,"type","IntegerLiteral")}},ok=class extends yn{constructor(){super(...arguments);k(this,"type","FloatLiteral")}},f_=class extends yn{constructor(){super(...arguments);k(this,"type","StringLiteral")}},ik=class extends yn{constructor(){super(...arguments);k(this,"type","ArrayLiteral")}},__=class extends yn{constructor(){super(...arguments);k(this,"type","TupleLiteral")}},lk=class extends yn{constructor(){super(...arguments);k(this,"type","ObjectLiteral")}},Xn=class extends kt{constructor(t,r,n){super();k(this,"type","BinaryExpression");this.operator=t,this.left=r,this.right=n}},ck=class extends kt{constructor(t,r){super();k(this,"type","FilterExpression");this.operand=t,this.filter=r}},uk=class extends Ut{constructor(t,r){super();k(this,"type","FilterStatement");this.filter=t,this.body=r}},dk=class extends kt{constructor(t,r){super();k(this,"type","SelectExpression");this.lhs=t,this.test=r}},hk=class extends kt{constructor(t,r,n){super();k(this,"type","TestExpression");this.operand=t,this.negate=r,this.test=n}},fk=class extends kt{constructor(t,r){super();k(this,"type","UnaryExpression");this.operator=t,this.argument=r}},_k=class extends kt{constructor(t=void 0,r=void 0,n=void 0){super();k(this,"type","SliceExpression");this.start=t,this.stop=r,this.step=n}},pk=class extends kt{constructor(t,r){super();k(this,"type","KeywordArgumentExpression");this.key=t,this.value=r}},mk=class extends kt{constructor(t){super();k(this,"type","SpreadExpression");this.argument=t}},gk=class extends Ut{constructor(t,r,n){super();k(this,"type","CallStatement");this.call=t,this.callerArgs=r,this.body=n}},wk=class extends kt{constructor(t,r,n){super();k(this,"type","Ternary");this.condition=t,this.trueExpr=r,this.falseExpr=n}};function vk(e){const t=new Y1([]);let r=0;function n(G,L){const V=e[r++];if(!V||V.type!==G)throw new Error(`Parser Error: ${L}. ${V.type} !== ${G}.`);return V}function s(G){if(!l(G))throw new SyntaxError(`Expected ${G}`);++r}function a(){switch(e[r].type){case B.Comment:return new nk(e[r++].value);case B.Text:return c();case B.OpenStatement:return d();case B.OpenExpression:return h();default:throw new SyntaxError(`Unexpected token type: ${e[r].type}`)}}function o(...G){return r+G.length<=e.length&&G.every((L,V)=>L===e[r+V].type)}function i(...G){var L,V,X;return((L=e[r])==null?void 0:L.type)===B.OpenStatement&&((V=e[r+1])==null?void 0:V.type)===B.Identifier&&G.includes((X=e[r+1])==null?void 0:X.value)}function l(...G){return r+G.length<=e.length&&G.every((L,V)=>e[r+V].type==="Identifier"&&L===e[r+V].value)}function c(){return new f_(n(B.Text,"Expected text token").value)}function d(){if(n(B.OpenStatement,"Expected opening statement token"),e[r].type!==B.Identifier)throw new SyntaxError(`Unknown statement, got ${e[r].type}`);const G=e[r].value;let L;switch(G){case"set":++r,L=_();break;case"if":++r,L=p(),n(B.OpenStatement,"Expected {% token"),s("endif"),n(B.CloseStatement,"Expected %} token");break;case"macro":++r,L=w(),n(B.OpenStatement,"Expected {% token"),s("endmacro"),n(B.CloseStatement,"Expected %} token");break;case"for":++r,L=y(),n(B.OpenStatement,"Expected {% token"),s("endfor"),n(B.CloseStatement,"Expected %} token");break;case"call":{++r;let V=null;o(B.OpenParen)&&(V=$());const X=ee();if(X.type!=="Identifier")throw new SyntaxError("Expected identifier following call statement");const J=$();n(B.CloseStatement,"Expected closing statement token");const me=[];for(;!i("endcall");)me.push(a());n(B.OpenStatement,"Expected '{%'"),s("endcall"),n(B.CloseStatement,"Expected closing statement token");const re=new h_(X,J);L=new gk(re,V,me);break}case"break":++r,n(B.CloseStatement,"Expected closing statement token"),L=new Z1;break;case"continue":++r,n(B.CloseStatement,"Expected closing statement token"),L=new ek;break;case"filter":{++r;let V=ee();V instanceof nn&&o(B.OpenParen)&&(V=z(V)),n(B.CloseStatement,"Expected closing statement token");const X=[];for(;!i("endfilter");)X.push(a());n(B.OpenStatement,"Expected '{%'"),s("endfilter"),n(B.CloseStatement,"Expected '%}'"),L=new uk(V,X);break}default:throw new SyntaxError(`Unknown statement type: ${G}`)}return L}function h(){n(B.OpenExpression,"Expected opening expression token");const G=M();return n(B.CloseExpression,"Expected closing expression token"),G}function _(){const G=v();let L=null;const V=[];if(o(B.Equals))++r,L=v();else{for(n(B.CloseStatement,"Expected %} token");!i("endset");)V.push(a());n(B.OpenStatement,"Expected {% token"),s("endset")}return n(B.CloseStatement,"Expected closing statement token"),new tk(G,L,V)}function p(){const G=M();n(B.CloseStatement,"Expected closing statement token");const L=[],V=[];for(;!i("elif","else","endif");)L.push(a());if(i("elif")){++r,++r;const X=p();V.push(X)}else if(i("else"))for(++r,++r,n(B.CloseStatement,"Expected closing statement token");!i("endif");)V.push(a());return new J1(G,L,V)}function w(){const G=ee();if(G.type!=="Identifier")throw new SyntaxError("Expected identifier following macro statement");const L=$();n(B.CloseStatement,"Expected closing statement token");const V=[];for(;!i("endmacro");)V.push(a());return new rk(G,L,V)}function v(G=!1){const L=G?ee:M,V=[L()],X=o(B.Comma);for(;X&&(++r,V.push(L()),!!o(B.Comma)););return X?new __(V):V[0]}function y(){const G=v(!0);if(!(G instanceof nn||G instanceof __))throw new SyntaxError(`Expected identifier/tuple for the loop variable, got ${G.type} instead`);if(!l("in"))throw new SyntaxError("Expected `in` keyword following loop variable");++r;const L=M();n(B.CloseStatement,"Expected closing statement token");const V=[];for(;!i("endfor","else");)V.push(a());const X=[];if(i("else"))for(++r,++r,n(B.CloseStatement,"Expected closing statement token");!i("endfor");)X.push(a());return new K1(G,L,V,X)}function M(){return T()}function T(){const G=A();if(l("if")){++r;const L=A();if(l("else")){++r;const V=T();return new wk(L,G,V)}else return new dk(G,L)}return G}function A(){let G=S();for(;l("or");){const L=e[r];++r;const V=S();G=new Xn(L,G,V)}return G}function S(){let G=C();for(;l("and");){const L=e[r];++r;const V=C();G=new Xn(L,G,V)}return G}function C(){let G;for(;l("not");){const L=e[r];++r;const V=C();G=new fk(L,V)}return G??I()}function I(){let G=x();for(;;){let L;if(l("not","in"))L=new St("not in",B.Identifier),r+=2;else if(l("in"))L=e[r++];else if(o(B.ComparisonBinaryOperator))L=e[r++];else break;const V=x();G=new Xn(L,G,V)}return G}function x(){let G=O();for(;o(B.AdditiveBinaryOperator);){const L=e[r];++r;const V=O();G=new Xn(L,G,V)}return G}function R(){const G=D(ee());return o(B.OpenParen)?z(G):G}function z(G){let L=new h_(G,$());return L=D(L),o(B.OpenParen)&&(L=z(L)),L}function $(){n(B.OpenParen,"Expected opening parenthesis for arguments list");const G=Q();return n(B.CloseParen,"Expected closing parenthesis for arguments list"),G}function Q(){const G=[];for(;!o(B.CloseParen);){let L;if(e[r].type===B.MultiplicativeBinaryOperator&&e[r].value==="*"){++r;const V=M();L=new mk(V)}else if(L=M(),o(B.Equals)){if(++r,!(L instanceof nn))throw new SyntaxError("Expected identifier for keyword argument");const V=M();L=new pk(L,V)}G.push(L),o(B.Comma)&&++r}return G}function H(){const G=[];let L=!1;for(;!o(B.CloseSquareBracket);)o(B.Colon)?(G.push(void 0),++r,L=!0):(G.push(M()),o(B.Colon)&&(++r,L=!0));if(G.length===0)throw new SyntaxError("Expected at least one argument for member/slice expression");if(L){if(G.length>3)throw new SyntaxError("Expected 0-3 arguments for slice expression");return new _k(...G)}return G[0]}function D(G){for(;o(B.Dot)||o(B.OpenSquareBracket);){const L=e[r];++r;let V;const X=L.type===B.OpenSquareBracket;if(X)V=H(),n(B.CloseSquareBracket,"Expected closing square bracket");else if(V=ee(),V.type!=="Identifier")throw new SyntaxError("Expected identifier following dot operator");G=new sk(G,V,X)}return G}function O(){let G=te();for(;o(B.MultiplicativeBinaryOperator);){const L=e[r++],V=te();G=new Xn(L,G,V)}return G}function te(){let G=W();for(;l("is");){++r;const L=l("not");L&&++r;const V=ee();if(!(V instanceof nn))throw new SyntaxError("Expected identifier for the test");G=new hk(G,L,V)}return G}function W(){let G=R();for(;o(B.Pipe);){++r;let L=ee();if(!(L instanceof nn))throw new SyntaxError("Expected identifier for the filter");o(B.OpenParen)&&(L=z(L)),G=new ck(G,L)}return G}function ee(){const G=e[r++];switch(G.type){case B.NumericLiteral:{const L=G.value;return L.includes(".")?new ok(Number(L)):new ak(Number(L))}case B.StringLiteral:{let L=G.value;for(;o(B.StringLiteral);)L+=e[r++].value;return new f_(L)}case B.Identifier:return new nn(G.value);case B.OpenParen:{const L=v();return n(B.CloseParen,"Expected closing parenthesis, got ${tokens[current].type} instead."),L}case B.OpenSquareBracket:{const L=[];for(;!o(B.CloseSquareBracket);)L.push(M()),o(B.Comma)&&++r;return++r,new ik(L)}case B.OpenCurlyBracket:{const L=new Map;for(;!o(B.CloseCurlyBracket);){const V=M();n(B.Colon,"Expected colon between key and value in object literal");const X=M();L.set(V,X),o(B.Comma)&&++r}return++r,new lk(L)}default:throw new SyntaxError(`Unexpected token: ${G.type}`)}}for(;r<e.length;)t.body.push(a());return t}function yk(e,t,r=1){if(t===void 0&&(t=e,e=0),r===0)throw new Error("range() step must not be zero");const n=[];if(r>0)for(let s=e;s<t;s+=r)n.push(s);else for(let s=e;s>t;s+=r)n.push(s);return n}function p_(e,t,r,n=1){const s=Math.sign(n);s>=0?(t=(t??(t=0))<0?Math.max(e.length+t,0):Math.min(t,e.length),r=(r??(r=e.length))<0?Math.max(e.length+r,0):Math.min(r,e.length)):(t=(t??(t=e.length-1))<0?Math.max(e.length+t,-1):Math.min(t,e.length-1),r=(r??(r=-1))<-1?Math.max(e.length+r,-1):Math.min(r,e.length-1));const a=[];for(let o=t;s*o<s*r;o+=n)a.push(e[o]);return a}function bk(e){return e.replace(/\b\w/g,t=>t.toUpperCase())}function Mk(e){return xk(new Date,e)}function xk(e,t){const r=new Intl.DateTimeFormat(void 0,{month:"long"}),n=new Intl.DateTimeFormat(void 0,{month:"short"}),s=a=>a<10?"0"+a:a.toString();return t.replace(/%[YmdbBHM%]/g,a=>{switch(a){case"%Y":return e.getFullYear().toString();case"%m":return s(e.getMonth()+1);case"%d":return s(e.getDate());case"%b":return n.format(e);case"%B":return r.format(e);case"%H":return s(e.getHours());case"%M":return s(e.getMinutes());case"%%":return"%";default:return a}})}function kk(e){return e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Tk(e,t,r,n){if(n===0)return e;let s=n==null||n<0?1/0:n;const a=t.length===0?new RegExp("(?=)","gu"):new RegExp(kk(t),"gu");return e.replaceAll(a,o=>s>0?(--s,r):o)}var m_=class extends Error{},g_=class extends Error{},rr=class{constructor(e=void 0){k(this,"type","RuntimeValue");k(this,"value");k(this,"builtins",new Map);this.value=e}__bool__(){return new ie(!!this.value)}toString(){return String(this.value)}},he=class extends rr{constructor(){super(...arguments);k(this,"type","IntegerValue")}},Ge=class extends rr{constructor(){super(...arguments);k(this,"type","FloatValue")}toString(){return this.value%1===0?this.value.toFixed(1):this.value.toString()}},Z=class extends rr{constructor(){super(...arguments);k(this,"type","StringValue");k(this,"builtins",new Map([["upper",new Ne(()=>new Z(this.value.toUpperCase()))],["lower",new Ne(()=>new Z(this.value.toLowerCase()))],["strip",new Ne(()=>new Z(this.value.trim()))],["title",new Ne(()=>new Z(bk(this.value)))],["capitalize",new Ne(()=>new Z(this.value.charAt(0).toUpperCase()+this.value.slice(1)))],["length",new he(this.value.length)],["rstrip",new Ne(()=>new Z(this.value.trimEnd()))],["lstrip",new Ne(()=>new Z(this.value.trimStart()))],["startswith",new Ne(t=>{if(t.length===0)throw new Error("startswith() requires at least one argument");const r=t[0];if(r instanceof Z)return new ie(this.value.startsWith(r.value));if(r instanceof ge){for(const n of r.value){if(!(n instanceof Z))throw new Error("startswith() tuple elements must be strings");if(this.value.startsWith(n.value))return new ie(!0)}return new ie(!1)}throw new Error("startswith() argument must be a string or tuple of strings")})],["endswith",new Ne(t=>{if(t.length===0)throw new Error("endswith() requires at least one argument");const r=t[0];if(r instanceof Z)return new ie(this.value.endsWith(r.value));if(r instanceof ge){for(const n of r.value){if(!(n instanceof Z))throw new Error("endswith() tuple elements must be strings");if(this.value.endsWith(n.value))return new ie(!0)}return new ie(!1)}throw new Error("endswith() argument must be a string or tuple of strings")})],["split",new Ne(t=>{const r=t[0]??new Be;if(!(r instanceof Z||r instanceof Be))throw new Error("sep argument must be a string or null");const n=t[1]??new he(-1);if(!(n instanceof he))throw new Error("maxsplit argument must be a number");let s=[];if(r instanceof Be){const a=this.value.trimStart();for(const{0:o,index:i}of a.matchAll(/\S+/g)){if(n.value!==-1&&s.length>=n.value&&i!==void 0){s.push(o+a.slice(i+o.length));break}s.push(o)}}else{if(r.value==="")throw new Error("empty separator");s=this.value.split(r.value),n.value!==-1&&s.length>n.value&&s.push(s.splice(n.value).join(r.value))}return new ge(s.map(a=>new Z(a)))})],["replace",new Ne(t=>{if(t.length<2)throw new Error("replace() requires at least two arguments");const r=t[0],n=t[1];if(!(r instanceof Z&&n instanceof Z))throw new Error("replace() arguments must be strings");let s;if(t.length>2?t[2].type==="KeywordArgumentsValue"?s=t[2].value.get("count")??new Be:s=t[2]:s=new Be,!(s instanceof he||s instanceof Be))throw new Error("replace() count argument must be a number or null");return new Z(Tk(this.value,r.value,n.value,s.value))})]]))}},ie=class extends rr{constructor(){super(...arguments);k(this,"type","BooleanValue")}},Ek=/[\x7f-\uffff]/g;function w_(e){return e.replace(Ek,t=>"\\u"+t.charCodeAt(0).toString(16).padStart(4,"0"))}function jr(e,t={},r=0,n=!0){const{indent:s=null,ensureAscii:a=!1,separators:o=null,sortKeys:i=!1}=t;let l,c;switch(o?[l,c]=o:s?(l=",",c=": "):(l=", ",c=": "),e.type){case"NullValue":return"null";case"UndefinedValue":return n?"null":"undefined";case"IntegerValue":case"FloatValue":case"BooleanValue":return JSON.stringify(e.value);case"StringValue":{let d=JSON.stringify(e.value);return a&&(d=w_(d)),d}case"ArrayValue":case"ObjectValue":{const d=s?" ".repeat(s):"",h=`
12
+ `+d.repeat(r),_=h+d;if(e.type==="ArrayValue"){const p=e.value.map(w=>jr(w,t,r+1,n));return s?`[${_}${p.join(`${l}${_}`)}${h}]`:`[${p.join(l)}]`}else{let p=Array.from(e.value.entries());i&&(p=p.sort(([v],[y])=>v.localeCompare(y)));const w=p.map(([v,y])=>{let M=JSON.stringify(v);a&&(M=w_(M));const T=`${M}${c}${jr(y,t,r+1,n)}`;return s?`${_}${T}`:T});return s?`{${w.join(l)}${h}}`:`{${w.join(l)}}`}}default:throw new Error(`Cannot convert to JSON: ${e.type}`)}}var Ke=class extends rr{constructor(){super(...arguments);k(this,"type","ObjectValue");k(this,"builtins",new Map([["get",new Ne(([t,r])=>{if(!(t instanceof Z))throw new Error(`Object key must be a string: got ${t.type}`);return this.value.get(t.value)??r??new Be})],["items",new Ne(()=>this.items())],["keys",new Ne(()=>this.keys())],["values",new Ne(()=>this.values())],["dictsort",new Ne(t=>{let r=new Map;const n=t.filter(l=>l instanceof cs?(r=l.value,!1):!0),s=n.at(0)??r.get("case_sensitive")??new ie(!1);if(!(s instanceof ie))throw new Error("case_sensitive must be a boolean");const a=n.at(1)??r.get("by")??new Z("key");if(!(a instanceof Z))throw new Error("by must be a string");if(!["key","value"].includes(a.value))throw new Error("by must be either 'key' or 'value'");const o=n.at(2)??r.get("reverse")??new ie(!1);if(!(o instanceof ie))throw new Error("reverse must be a boolean");const i=Array.from(this.value.entries()).map(([l,c])=>new ge([new Z(l),c])).sort((l,c)=>{const d=a.value==="key"?0:1,h=l.value[d],_=c.value[d],p=dl(h,_,s.value);return o.value?-p:p});return new ge(i)})]]))}__bool__(){return new ie(this.value.size>0)}items(){return new ge(Array.from(this.value.entries()).map(([t,r])=>new ge([new Z(t),r])))}keys(){return new ge(Array.from(this.value.keys()).map(t=>new Z(t)))}values(){return new ge(Array.from(this.value.values()))}toString(){return jr(this,{},0,!1)}},cs=class extends Ke{constructor(){super(...arguments);k(this,"type","KeywordArgumentsValue")}},ge=class extends rr{constructor(){super(...arguments);k(this,"type","ArrayValue");k(this,"builtins",new Map([["length",new he(this.value.length)]]))}__bool__(){return new ie(this.value.length>0)}toString(){return jr(this,{},0,!1)}},v_=class extends ge{constructor(){super(...arguments);k(this,"type","TupleValue")}},Ne=class extends rr{constructor(){super(...arguments);k(this,"type","FunctionValue")}},Be=class extends rr{constructor(){super(...arguments);k(this,"type","NullValue")}},Oe=class extends rr{constructor(){super(...arguments);k(this,"type","UndefinedValue")}},Rr=class{constructor(e){k(this,"variables",new Map([["namespace",new Ne(e=>{if(e.length===0)return new Ke(new Map);if(e.length!==1||!(e[0]instanceof Ke))throw new Error("`namespace` expects either zero arguments or a single object argument");return e[0]})]]));k(this,"tests",new Map([["boolean",e=>e.type==="BooleanValue"],["callable",e=>e instanceof Ne],["odd",e=>{if(!(e instanceof he))throw new Error(`cannot odd on ${e.type}`);return e.value%2!==0}],["even",e=>{if(!(e instanceof he))throw new Error(`cannot even on ${e.type}`);return e.value%2===0}],["false",e=>e.type==="BooleanValue"&&!e.value],["true",e=>e.type==="BooleanValue"&&e.value],["none",e=>e.type==="NullValue"],["string",e=>e.type==="StringValue"],["number",e=>e instanceof he||e instanceof Ge],["integer",e=>e instanceof he],["iterable",e=>e.type==="ArrayValue"||e.type==="StringValue"],["mapping",e=>e instanceof Ke],["sequence",e=>e instanceof ge||e instanceof Ke||e instanceof Z],["lower",e=>{const t=e.value;return e.type==="StringValue"&&t===t.toLowerCase()}],["upper",e=>{const t=e.value;return e.type==="StringValue"&&t===t.toUpperCase()}],["none",e=>e.type==="NullValue"],["defined",e=>e.type!=="UndefinedValue"],["undefined",e=>e.type==="UndefinedValue"],["equalto",(e,t)=>e.value===t.value],["eq",(e,t)=>e.value===t.value]]));this.parent=e}set(e,t){return this.declareVariable(e,Ta(t))}declareVariable(e,t){if(this.variables.has(e))throw new SyntaxError(`Variable already declared: ${e}`);return this.variables.set(e,t),t}setVariable(e,t){return this.variables.set(e,t),t}resolve(e){if(this.variables.has(e))return this;if(this.parent)return this.parent.resolve(e);throw new Error(`Unknown variable: ${e}`)}lookupVariable(e){try{return this.resolve(e).variables.get(e)??new Oe}catch{return new Oe}}};function Ak(e){e.set("false",!1),e.set("true",!0),e.set("none",null),e.set("raise_exception",t=>{throw new Error(t)}),e.set("range",yk),e.set("strftime_now",Mk),e.set("True",!0),e.set("False",!1),e.set("None",null)}function y_(e,t){const r=t.split(".");let n=e;for(const s of r)if(n instanceof Ke)n=n.value.get(s)??new Oe;else if(n instanceof ge){const a=parseInt(s,10);if(!isNaN(a)&&a>=0&&a<n.value.length)n=n.value[a];else return new Oe}else return new Oe;return n}function dl(e,t,r=!1){if(e instanceof Be&&t instanceof Be)return 0;if(e instanceof Be||t instanceof Be)throw new Error(`Cannot compare ${e.type} with ${t.type}`);if(e instanceof Oe&&t instanceof Oe)return 0;if(e instanceof Oe||t instanceof Oe)throw new Error(`Cannot compare ${e.type} with ${t.type}`);const n=a=>a instanceof he||a instanceof Ge||a instanceof ie,s=a=>a instanceof ie?a.value?1:0:a.value;if(n(e)&&n(t)){const a=s(e),o=s(t);return a<o?-1:a>o?1:0}if(e.type!==t.type)throw new Error(`Cannot compare different types: ${e.type} and ${t.type}`);switch(e.type){case"StringValue":{let a=e.value,o=t.value;return r||(a=a.toLowerCase(),o=o.toLowerCase()),a<o?-1:a>o?1:0}default:throw new Error(`Cannot compare type: ${e.type}`)}}var Ck=class{constructor(e){k(this,"global");this.global=e??new Rr}run(e){return this.evaluate(e,this.global)}evaluateBinaryExpression(e,t){const r=this.evaluate(e.left,t);switch(e.operator.value){case"and":return r.__bool__().value?this.evaluate(e.right,t):r;case"or":return r.__bool__().value?r:this.evaluate(e.right,t)}const n=this.evaluate(e.right,t);switch(e.operator.value){case"==":return new ie(r.value==n.value);case"!=":return new ie(r.value!=n.value)}if(r instanceof Oe||n instanceof Oe){if(n instanceof Oe&&["in","not in"].includes(e.operator.value))return new ie(e.operator.value==="not in");throw new Error(`Cannot perform operation ${e.operator.value} on undefined values`)}else{if(r instanceof Be||n instanceof Be)throw new Error("Cannot perform operation on null values");if(e.operator.value==="~")return new Z(r.value.toString()+n.value.toString());if((r instanceof he||r instanceof Ge)&&(n instanceof he||n instanceof Ge)){const s=r.value,a=n.value;switch(e.operator.value){case"+":case"-":case"*":{const o=e.operator.value==="+"?s+a:e.operator.value==="-"?s-a:s*a;return r instanceof Ge||n instanceof Ge?new Ge(o):new he(o)}case"/":return new Ge(s/a);case"%":{const o=s%a;return r instanceof Ge||n instanceof Ge?new Ge(o):new he(o)}case"<":return new ie(s<a);case">":return new ie(s>a);case">=":return new ie(s>=a);case"<=":return new ie(s<=a)}}else if(r instanceof ge&&n instanceof ge)switch(e.operator.value){case"+":return new ge(r.value.concat(n.value))}else if(n instanceof ge){const s=n.value.find(a=>a.value===r.value)!==void 0;switch(e.operator.value){case"in":return new ie(s);case"not in":return new ie(!s)}}}if(r instanceof Z||n instanceof Z)switch(e.operator.value){case"+":return new Z(r.value.toString()+n.value.toString())}if(r instanceof Z&&n instanceof Z)switch(e.operator.value){case"in":return new ie(n.value.includes(r.value));case"not in":return new ie(!n.value.includes(r.value))}if(r instanceof Z&&n instanceof Ke)switch(e.operator.value){case"in":return new ie(n.value.has(r.value));case"not in":return new ie(!n.value.has(r.value))}throw new SyntaxError(`Unknown operator "${e.operator.value}" between ${r.type} and ${n.type}`)}evaluateArguments(e,t){const r=[],n=new Map;for(const s of e)if(s.type==="SpreadExpression"){const a=s,o=this.evaluate(a.argument,t);if(!(o instanceof ge))throw new Error(`Cannot unpack non-iterable type: ${o.type}`);for(const i of o.value)r.push(i)}else if(s.type==="KeywordArgumentExpression"){const a=s;n.set(a.key.value,this.evaluate(a.value,t))}else{if(n.size>0)throw new Error("Positional arguments must come before keyword arguments");r.push(this.evaluate(s,t))}return[r,n]}applyFilter(e,t,r){if(t.type==="Identifier"){const n=t;if(n.value==="safe")return e;if(n.value==="tojson")return new Z(jr(e,{}));if(e instanceof ge)switch(n.value){case"list":return e;case"first":return e.value[0];case"last":return e.value[e.value.length-1];case"length":return new he(e.value.length);case"reverse":return new ge(e.value.slice().reverse());case"sort":return new ge(e.value.slice().sort((s,a)=>dl(s,a,!1)));case"join":return new Z(e.value.map(s=>s.value).join(""));case"string":return new Z(jr(e,{},0,!1));case"unique":{const s=new Set,a=[];for(const o of e.value)s.has(o.value)||(s.add(o.value),a.push(o));return new ge(a)}default:throw new Error(`Unknown ArrayValue filter: ${n.value}`)}else if(e instanceof Z)switch(n.value){case"length":case"upper":case"lower":case"title":case"capitalize":{const s=e.builtins.get(n.value);if(s instanceof Ne)return s.value([],r);if(s instanceof he)return s;throw new Error(`Unknown StringValue filter: ${n.value}`)}case"trim":return new Z(e.value.trim());case"indent":return new Z(e.value.split(`
13
+ `).map((s,a)=>a===0||s.length===0?s:" "+s).join(`
14
+ `));case"join":case"string":return e;case"int":{const s=parseInt(e.value,10);return new he(isNaN(s)?0:s)}case"float":{const s=parseFloat(e.value);return new Ge(isNaN(s)?0:s)}default:throw new Error(`Unknown StringValue filter: ${n.value}`)}else if(e instanceof he||e instanceof Ge)switch(n.value){case"abs":return e instanceof he?new he(Math.abs(e.value)):new Ge(Math.abs(e.value));case"int":return new he(Math.floor(e.value));case"float":return new Ge(e.value);case"string":return new Z(e.toString());default:throw new Error(`Unknown NumericValue filter: ${n.value}`)}else if(e instanceof Ke)switch(n.value){case"items":return new ge(Array.from(e.value.entries()).map(([s,a])=>new ge([new Z(s),a])));case"length":return new he(e.value.size);default:{const s=e.builtins.get(n.value);if(s)return s instanceof Ne?s.value([],r):s;throw new Error(`Unknown ObjectValue filter: ${n.value}`)}}else if(e instanceof ie)switch(n.value){case"bool":return new ie(e.value);case"int":return new he(e.value?1:0);case"float":return new Ge(e.value?1:0);case"string":return new Z(e.value?"true":"false");default:throw new Error(`Unknown BooleanValue filter: ${n.value}`)}throw new Error(`Cannot apply filter "${n.value}" to type: ${e.type}`)}else if(t.type==="CallExpression"){const n=t;if(n.callee.type!=="Identifier")throw new Error(`Unknown filter: ${n.callee.type}`);const s=n.callee.value;if(s==="tojson"){const[,a]=this.evaluateArguments(n.args,r),o=a.get("indent")??new Be;if(!(o instanceof he||o instanceof Be))throw new Error("If set, indent must be a number");const i=a.get("ensure_ascii")??new ie(!1);if(!(i instanceof ie))throw new Error("If set, ensure_ascii must be a boolean");const l=a.get("sort_keys")??new ie(!1);if(!(l instanceof ie))throw new Error("If set, sort_keys must be a boolean");const c=a.get("separators")??new Be;let d=null;if(c instanceof ge||c instanceof v_){if(c.value.length!==2)throw new Error("separators must be a tuple of two strings");const[h,_]=c.value;if(!(h instanceof Z)||!(_ instanceof Z))throw new Error("separators must be a tuple of two strings");d=[h.value,_.value]}else if(!(c instanceof Be))throw new Error("If set, separators must be a tuple of two strings");return new Z(jr(e,{indent:o.value,ensureAscii:i.value,sortKeys:l.value,separators:d}))}else if(s==="join"){let a;if(e instanceof Z)a=Array.from(e.value);else if(e instanceof ge)a=e.value.map(c=>c.value);else throw new Error(`Cannot apply filter "${s}" to type: ${e.type}`);const[o,i]=this.evaluateArguments(n.args,r),l=o.at(0)??i.get("separator")??new Z("");if(!(l instanceof Z))throw new Error("separator must be a string");return new Z(a.join(l.value))}else if(s==="int"||s==="float"){const[a,o]=this.evaluateArguments(n.args,r),i=a.at(0)??o.get("default")??(s==="int"?new he(0):new Ge(0));if(e instanceof Z){const l=s==="int"?parseInt(e.value,10):parseFloat(e.value);return isNaN(l)?i:s==="int"?new he(l):new Ge(l)}else{if(e instanceof he||e instanceof Ge)return e;if(e instanceof ie)return s==="int"?new he(e.value?1:0):new Ge(e.value?1:0);throw new Error(`Cannot apply filter "${s}" to type: ${e.type}`)}}else if(s==="default"){const[a,o]=this.evaluateArguments(n.args,r),i=a[0]??new Z(""),l=a[1]??o.get("boolean")??new ie(!1);if(!(l instanceof ie))throw new Error("`default` filter flag must be a boolean");return e instanceof Oe||l.value&&!e.__bool__().value?i:e}if(e instanceof ge){switch(s){case"sort":{const[a,o]=this.evaluateArguments(n.args,r),i=a.at(0)??o.get("reverse")??new ie(!1);if(!(i instanceof ie))throw new Error("reverse must be a boolean");const l=a.at(1)??o.get("case_sensitive")??new ie(!1);if(!(l instanceof ie))throw new Error("case_sensitive must be a boolean");const c=a.at(2)??o.get("attribute")??new Be;if(!(c instanceof Z||c instanceof he||c instanceof Be))throw new Error("attribute must be a string, integer, or null");const d=h=>{if(c instanceof Be)return h;const _=c instanceof he?String(c.value):c.value;return y_(h,_)};return new ge(e.value.slice().sort((h,_)=>{const p=d(h),w=d(_),v=dl(p,w,l.value);return i.value?-v:v}))}case"selectattr":case"rejectattr":{const a=s==="selectattr";if(e.value.some(h=>!(h instanceof Ke)))throw new Error(`\`${s}\` can only be applied to array of objects`);if(n.args.some(h=>h.type!=="StringLiteral"))throw new Error(`arguments of \`${s}\` must be strings`);const[o,i,l]=n.args.map(h=>this.evaluate(h,r));let c;if(i){const h=r.tests.get(i.value);if(!h)throw new Error(`Unknown test: ${i.value}`);c=h}else c=(...h)=>h[0].__bool__().value;const d=e.value.filter(h=>{const _=h.value.get(o.value),p=_?c(_,l):!1;return a?p:!p});return new ge(d)}case"map":{const[,a]=this.evaluateArguments(n.args,r);if(a.has("attribute")){const o=a.get("attribute");if(!(o instanceof Z))throw new Error("attribute must be a string");const i=a.get("default"),l=e.value.map(c=>{if(!(c instanceof Ke))throw new Error("items in map must be an object");const d=y_(c,o.value);return d instanceof Oe?i??new Oe:d});return new ge(l)}else throw new Error("`map` expressions without `attribute` set are not currently supported.")}}throw new Error(`Unknown ArrayValue filter: ${s}`)}else if(e instanceof Z){switch(s){case"indent":{const[a,o]=this.evaluateArguments(n.args,r),i=a.at(0)??o.get("width")??new he(4);if(!(i instanceof he))throw new Error("width must be a number");const l=a.at(1)??o.get("first")??new ie(!1),c=a.at(2)??o.get("blank")??new ie(!1),d=e.value.split(`
15
+ `),h=" ".repeat(i.value),_=d.map((p,w)=>!l.value&&w===0||!c.value&&p.length===0?p:h+p);return new Z(_.join(`
16
+ `))}case"replace":{const a=e.builtins.get("replace");if(!(a instanceof Ne))throw new Error("replace filter not available");const[o,i]=this.evaluateArguments(n.args,r);return a.value([...o,new cs(i)],r)}}throw new Error(`Unknown StringValue filter: ${s}`)}else if(e instanceof Ke){const a=e.builtins.get(s);if(a&&a instanceof Ne){const[o,i]=this.evaluateArguments(n.args,r);return i.size>0&&o.push(new cs(i)),a.value(o,r)}throw new Error(`Unknown ObjectValue filter: ${s}`)}else throw new Error(`Cannot apply filter "${s}" to type: ${e.type}`)}throw new Error(`Unknown filter: ${t.type}`)}evaluateFilterExpression(e,t){const r=this.evaluate(e.operand,t);return this.applyFilter(r,e.filter,t)}evaluateTestExpression(e,t){const r=this.evaluate(e.operand,t),n=t.tests.get(e.test.value);if(!n)throw new Error(`Unknown test: ${e.test.value}`);const s=n(r);return new ie(e.negate?!s:s)}evaluateSelectExpression(e,t){return this.evaluate(e.test,t).__bool__().value?this.evaluate(e.lhs,t):new Oe}evaluateUnaryExpression(e,t){const r=this.evaluate(e.argument,t);switch(e.operator.value){case"not":return new ie(!r.value);default:throw new SyntaxError(`Unknown operator: ${e.operator.value}`)}}evaluateTernaryExpression(e,t){return this.evaluate(e.condition,t).__bool__().value?this.evaluate(e.trueExpr,t):this.evaluate(e.falseExpr,t)}evalProgram(e,t){return this.evaluateBlock(e.body,t)}evaluateBlock(e,t){let r="";for(const n of e){const s=this.evaluate(n,t);s.type!=="NullValue"&&s.type!=="UndefinedValue"&&(r+=s.toString())}return new Z(r)}evaluateIdentifier(e,t){return t.lookupVariable(e.value)}evaluateCallExpression(e,t){const[r,n]=this.evaluateArguments(e.args,t);n.size>0&&r.push(new cs(n));const s=this.evaluate(e.callee,t);if(s.type!=="FunctionValue")throw new Error(`Cannot call something that is not a function: got ${s.type}`);return s.value(r,t)}evaluateSliceExpression(e,t,r){if(!(e instanceof ge||e instanceof Z))throw new Error("Slice object must be an array or string");const n=this.evaluate(t.start,r),s=this.evaluate(t.stop,r),a=this.evaluate(t.step,r);if(!(n instanceof he||n instanceof Oe))throw new Error("Slice start must be numeric or undefined");if(!(s instanceof he||s instanceof Oe))throw new Error("Slice stop must be numeric or undefined");if(!(a instanceof he||a instanceof Oe))throw new Error("Slice step must be numeric or undefined");return e instanceof ge?new ge(p_(e.value,n.value,s.value,a.value)):new Z(p_(Array.from(e.value),n.value,s.value,a.value).join(""))}evaluateMemberExpression(e,t){const r=this.evaluate(e.object,t);let n;if(e.computed){if(e.property.type==="SliceExpression")return this.evaluateSliceExpression(r,e.property,t);n=this.evaluate(e.property,t)}else n=new Z(e.property.value);let s;if(r instanceof Ke){if(!(n instanceof Z))throw new Error(`Cannot access property with non-string: got ${n.type}`);s=r.value.get(n.value)??r.builtins.get(n.value)}else if(r instanceof ge||r instanceof Z)if(n instanceof he)s=r.value.at(n.value),r instanceof Z&&(s=new Z(r.value.at(n.value)));else if(n instanceof Z)s=r.builtins.get(n.value);else throw new Error(`Cannot access property with non-string/non-number: got ${n.type}`);else{if(!(n instanceof Z))throw new Error(`Cannot access property with non-string: got ${n.type}`);s=r.builtins.get(n.value)}return s instanceof rr?s:new Oe}evaluateSet(e,t){const r=e.value?this.evaluate(e.value,t):this.evaluateBlock(e.body,t);if(e.assignee.type==="Identifier"){const n=e.assignee.value;t.setVariable(n,r)}else if(e.assignee.type==="TupleLiteral"){const n=e.assignee;if(!(r instanceof ge))throw new Error(`Cannot unpack non-iterable type in set: ${r.type}`);const s=r.value;if(s.length!==n.value.length)throw new Error(`Too ${n.value.length>s.length?"few":"many"} items to unpack in set`);for(let a=0;a<n.value.length;++a){const o=n.value[a];if(o.type!=="Identifier")throw new Error(`Cannot unpack to non-identifier in set: ${o.type}`);t.setVariable(o.value,s[a])}}else if(e.assignee.type==="MemberExpression"){const n=e.assignee,s=this.evaluate(n.object,t);if(!(s instanceof Ke))throw new Error("Cannot assign to member of non-object");if(n.property.type!=="Identifier")throw new Error("Cannot assign to member with non-identifier property");s.value.set(n.property.value,r)}else throw new Error(`Invalid LHS inside assignment expression: ${JSON.stringify(e.assignee)}`);return new Be}evaluateIf(e,t){const r=this.evaluate(e.test,t);return this.evaluateBlock(r.__bool__().value?e.body:e.alternate,t)}evaluateFor(e,t){const r=new Rr(t);let n,s;if(e.iterable.type==="SelectExpression"){const c=e.iterable;s=this.evaluate(c.lhs,r),n=c.test}else s=this.evaluate(e.iterable,r);if(!(s instanceof ge||s instanceof Ke))throw new Error(`Expected iterable or object type in for loop: got ${s.type}`);s instanceof Ke&&(s=s.keys());const a=[],o=[];for(let c=0;c<s.value.length;++c){const d=new Rr(r),h=s.value[c];let _;if(e.loopvar.type==="Identifier")_=p=>p.setVariable(e.loopvar.value,h);else if(e.loopvar.type==="TupleLiteral"){const p=e.loopvar;if(h.type!=="ArrayValue")throw new Error(`Cannot unpack non-iterable type: ${h.type}`);const w=h;if(p.value.length!==w.value.length)throw new Error(`Too ${p.value.length>w.value.length?"few":"many"} items to unpack`);_=v=>{for(let y=0;y<p.value.length;++y){if(p.value[y].type!=="Identifier")throw new Error(`Cannot unpack non-identifier type: ${p.value[y].type}`);v.setVariable(p.value[y].value,w.value[y])}}}else throw new Error(`Invalid loop variable(s): ${e.loopvar.type}`);n&&(_(d),!this.evaluate(n,d).__bool__().value)||(a.push(h),o.push(_))}let i="",l=!0;for(let c=0;c<a.length;++c){const d=new Map([["index",new he(c+1)],["index0",new he(c)],["revindex",new he(a.length-c)],["revindex0",new he(a.length-c-1)],["first",new ie(c===0)],["last",new ie(c===a.length-1)],["length",new he(a.length)],["previtem",c>0?a[c-1]:new Oe],["nextitem",c<a.length-1?a[c+1]:new Oe]]);r.setVariable("loop",new Ke(d)),o[c](r);try{const h=this.evaluateBlock(e.body,r);i+=h.value}catch(h){if(h instanceof g_)continue;if(h instanceof m_)break;throw h}l=!1}if(l){const c=this.evaluateBlock(e.defaultBlock,r);i+=c.value}return new Z(i)}evaluateMacro(e,t){return t.setVariable(e.name.value,new Ne((r,n)=>{var o;const s=new Rr(n);r=r.slice();let a;((o=r.at(-1))==null?void 0:o.type)==="KeywordArgumentsValue"&&(a=r.pop());for(let i=0;i<e.args.length;++i){const l=e.args[i],c=r[i];if(l.type==="Identifier"){const d=l;if(!c)throw new Error(`Missing positional argument: ${d.value}`);s.setVariable(d.value,c)}else if(l.type==="KeywordArgumentExpression"){const d=l,h=c??(a==null?void 0:a.value.get(d.key.value))??this.evaluate(d.value,s);s.setVariable(d.key.value,h)}else throw new Error(`Unknown argument type: ${l.type}`)}return this.evaluateBlock(e.body,s)})),new Be}evaluateCallStatement(e,t){const r=new Ne((i,l)=>{const c=new Rr(l);if(e.callerArgs)for(let d=0;d<e.callerArgs.length;++d){const h=e.callerArgs[d];if(h.type!=="Identifier")throw new Error(`Caller parameter must be an identifier, got ${h.type}`);c.setVariable(h.value,i[d]??new Oe)}return this.evaluateBlock(e.body,c)}),[n,s]=this.evaluateArguments(e.call.args,t);n.push(new cs(s));const a=this.evaluate(e.call.callee,t);if(a.type!=="FunctionValue")throw new Error(`Cannot call something that is not a function: got ${a.type}`);const o=new Rr(t);return o.setVariable("caller",r),a.value(n,o)}evaluateFilterStatement(e,t){const r=this.evaluateBlock(e.body,t);return this.applyFilter(r,e.filter,t)}evaluate(e,t){if(!e)return new Oe;switch(e.type){case"Program":return this.evalProgram(e,t);case"Set":return this.evaluateSet(e,t);case"If":return this.evaluateIf(e,t);case"For":return this.evaluateFor(e,t);case"Macro":return this.evaluateMacro(e,t);case"CallStatement":return this.evaluateCallStatement(e,t);case"Break":throw new m_;case"Continue":throw new g_;case"IntegerLiteral":return new he(e.value);case"FloatLiteral":return new Ge(e.value);case"StringLiteral":return new Z(e.value);case"ArrayLiteral":return new ge(e.value.map(r=>this.evaluate(r,t)));case"TupleLiteral":return new v_(e.value.map(r=>this.evaluate(r,t)));case"ObjectLiteral":{const r=new Map;for(const[n,s]of e.value){const a=this.evaluate(n,t);if(!(a instanceof Z))throw new Error(`Object keys must be strings: got ${a.type}`);r.set(a.value,this.evaluate(s,t))}return new Ke(r)}case"Identifier":return this.evaluateIdentifier(e,t);case"CallExpression":return this.evaluateCallExpression(e,t);case"MemberExpression":return this.evaluateMemberExpression(e,t);case"UnaryExpression":return this.evaluateUnaryExpression(e,t);case"BinaryExpression":return this.evaluateBinaryExpression(e,t);case"FilterExpression":return this.evaluateFilterExpression(e,t);case"FilterStatement":return this.evaluateFilterStatement(e,t);case"TestExpression":return this.evaluateTestExpression(e,t);case"SelectExpression":return this.evaluateSelectExpression(e,t);case"Ternary":return this.evaluateTernaryExpression(e,t);case"Comment":return new Be;default:throw new SyntaxError(`Unknown node type: ${e.type}`)}}};function Ta(e){switch(typeof e){case"number":return Number.isInteger(e)?new he(e):new Ge(e);case"string":return new Z(e);case"boolean":return new ie(e);case"undefined":return new Oe;case"object":return e===null?new Be:Array.isArray(e)?new ge(e.map(Ta)):new Ke(new Map(Object.entries(e).map(([t,r])=>[t,Ta(r)])));case"function":return new Ne((t,r)=>{const n=e(...t.map(s=>s.value))??null;return Ta(n)});default:throw new Error(`Cannot convert to runtime value: ${e}`)}}var He=`
17
+ `,Sk="{%- ",Pk=" -%}";function Fk(e){switch(e.operator.type){case"MultiplicativeBinaryOperator":return 4;case"AdditiveBinaryOperator":return 3;case"ComparisonBinaryOperator":return 2;case"Identifier":return e.operator.value==="and"?1:e.operator.value==="in"||e.operator.value==="not in"?2:0}return 0}function Lk(e,t=" "){const r=typeof t=="number"?" ".repeat(t):t;return Bt(e.body,0,r).replace(/\n$/,"")}function rt(...e){return Sk+e.join(" ")+Pk}function Bt(e,t,r){return e.map(n=>Ik(n,t,r)).join(He)}function Ik(e,t,r){const n=r.repeat(t);switch(e.type){case"Program":return Bt(e.body,t,r);case"If":return Ok(e,t,r);case"For":return Nk(e,t,r);case"Set":return Dk(e,t,r);case"Macro":return zk(e,t,r);case"Break":return n+rt("break");case"Continue":return n+rt("continue");case"CallStatement":return Bk(e,t,r);case"FilterStatement":return Rk(e,t,r);case"Comment":return n+"{# "+e.value+" #}";default:return n+"{{- "+ye(e)+" -}}"}}function Ok(e,t,r){const n=r.repeat(t),s=[];let a=e;for(;a&&(s.push({test:a.test,body:a.body}),a.alternate.length===1&&a.alternate[0].type==="If");)a=a.alternate[0];let o=n+rt("if",ye(s[0].test))+He+Bt(s[0].body,t+1,r);for(let i=1;i<s.length;++i)o+=He+n+rt("elif",ye(s[i].test))+He+Bt(s[i].body,t+1,r);return a&&a.alternate.length>0&&(o+=He+n+rt("else")+He+Bt(a.alternate,t+1,r)),o+=He+n+rt("endif"),o}function Nk(e,t,r){const n=r.repeat(t);let s="";if(e.iterable.type==="SelectExpression"){const o=e.iterable;s=`${ye(o.lhs)} if ${ye(o.test)}`}else s=ye(e.iterable);let a=n+rt("for",ye(e.loopvar),"in",s)+He+Bt(e.body,t+1,r);return e.defaultBlock.length>0&&(a+=He+n+rt("else")+He+Bt(e.defaultBlock,t+1,r)),a+=He+n+rt("endfor"),a}function Dk(e,t,r){const n=r.repeat(t),s=ye(e.assignee),a=e.value?ye(e.value):"",o=n+rt("set",`${s}${e.value?" = "+a:""}`);return e.body.length===0?o:o+He+Bt(e.body,t+1,r)+He+n+rt("endset")}function zk(e,t,r){const n=r.repeat(t),s=e.args.map(ye).join(", ");return n+rt("macro",`${e.name.value}(${s})`)+He+Bt(e.body,t+1,r)+He+n+rt("endmacro")}function Bk(e,t,r){const n=r.repeat(t),s=e.callerArgs&&e.callerArgs.length>0?`(${e.callerArgs.map(ye).join(", ")})`:"",a=ye(e.call);let o=n+rt(`call${s}`,a)+He;return o+=Bt(e.body,t+1,r)+He,o+=n+rt("endcall"),o}function Rk(e,t,r){const n=r.repeat(t),s=e.filter.type==="Identifier"?e.filter.value:ye(e.filter);let a=n+rt("filter",s)+He;return a+=Bt(e.body,t+1,r)+He,a+=n+rt("endfilter"),a}function ye(e,t=-1){switch(e.type){case"SpreadExpression":return`*${ye(e.argument)}`;case"Identifier":return e.value;case"IntegerLiteral":return`${e.value}`;case"FloatLiteral":return`${e.value}`;case"StringLiteral":return JSON.stringify(e.value);case"BinaryExpression":{const r=e,n=Fk(r),s=ye(r.left,n),a=ye(r.right,n+1),o=`${s} ${r.operator.value} ${a}`;return n<t?`(${o})`:o}case"UnaryExpression":{const r=e;return r.operator.value+(r.operator.value==="not"?" ":"")+ye(r.argument,1/0)}case"CallExpression":{const r=e,n=r.args.map(ye).join(", ");return`${ye(r.callee)}(${n})`}case"MemberExpression":{const r=e;let n=ye(r.object);["Identifier","MemberExpression","CallExpression","StringLiteral","IntegerLiteral","FloatLiteral","ArrayLiteral","TupleLiteral","ObjectLiteral"].includes(r.object.type)||(n=`(${n})`);let s=ye(r.property);return!r.computed&&r.property.type!=="Identifier"&&(s=`(${s})`),r.computed?`${n}[${s}]`:`${n}.${s}`}case"FilterExpression":{const r=e,n=ye(r.operand,1/0);return r.filter.type==="CallExpression"?`${n} | ${ye(r.filter)}`:`${n} | ${r.filter.value}`}case"SelectExpression":{const r=e;return`${ye(r.lhs)} if ${ye(r.test)}`}case"TestExpression":{const r=e;return`${ye(r.operand)} is${r.negate?" not":""} ${r.test.value}`}case"ArrayLiteral":case"TupleLiteral":{const r=e.value.map(ye),n=e.type==="ArrayLiteral"?"[]":"()";return`${n[0]}${r.join(", ")}${n[1]}`}case"ObjectLiteral":return`{${Array.from(e.value.entries()).map(([n,s])=>`${ye(n)}: ${ye(s)}`).join(", ")}}`;case"SliceExpression":{const r=e,n=r.start?ye(r.start):"",s=r.stop?ye(r.stop):"",a=r.step?`:${ye(r.step)}`:"";return`${n}:${s}${a}`}case"KeywordArgumentExpression":{const r=e;return`${r.key.value}=${ye(r.value)}`}case"Ternary":{const r=e,n=`${ye(r.trueExpr)} if ${ye(r.condition,0)} else ${ye(r.falseExpr)}`;return t>-1?`(${n})`:n}default:throw new Error(`Unknown expression type: ${e.type}`)}}var Gk=class{constructor(e){k(this,"parsed");const t=X1(e,{lstrip_blocks:!0,trim_blocks:!0});this.parsed=vk(t)}render(e){const t=new Rr;if(Ak(t),e)for(const[s,a]of Object.entries(e))t.set(s,a);return new Ck(t).run(this.parsed).value}format(e){return Lk(this.parsed,(e==null?void 0:e.indent)||" ")}},$k={txt:"text/plain",html:"text/html",css:"text/css",js:"text/javascript",json:"application/json",png:"image/png",jpg:"image/jpeg",jpeg:"image/jpeg",gif:"image/gif"},Da=class cm{constructor(t){if(this.filePath=t,this.headers=new Headers,this.exists=xt.existsSync(t),this.exists){this.status=200,this.statusText="OK";let r=xt.statSync(t);this.headers.set("content-length",r.size.toString()),this.updateContentType();const n=xt.createReadStream(t);this.body=new ReadableStream({start(s){n.on("data",a=>s.enqueue(a)),n.on("end",()=>s.close()),n.on("error",a=>s.error(a))},cancel(){n.destroy()}})}else this.status=404,this.statusText="Not Found",this.body=null}updateContentType(){const t=this.filePath.toString().split(".").pop().toLowerCase();this.headers.set("content-type",$k[t]??"application/octet-stream")}clone(){let t=new cm(this.filePath);return t.exists=this.exists,t.status=this.status,t.statusText=this.statusText,t.headers=new Headers(this.headers),t}async arrayBuffer(){return(await xt.promises.readFile(this.filePath)).buffer}async blob(){const t=await xt.promises.readFile(this.filePath);return new Blob([t],{type:this.headers.get("content-type")})}async text(){return await xt.promises.readFile(this.filePath,"utf8")}async json(){return JSON.parse(await this.text())}},qa=class{constructor(e){this._mt=new Uint32Array(624),this._idx=625,this._gauss_next=null,this._random_fn=this.random.bind(this),this.seed(e)}seed(e){if(e==null)if(_e.IS_CRYPTO_AVAILABLE){const o=new Uint32Array(1);crypto.getRandomValues(o),e=o[0]}else e=Date.now()>>>0;const t=this._mt,r=(o,i)=>Math.imul(o,i)>>>0,n=[];for(let o=e||0;o>0;o=Math.floor(o/4294967296))n.push(o&4294967295);n.length||n.push(0),t[0]=19650218;for(let o=1;o<624;++o)t[o]=r(1812433253,t[o-1]^t[o-1]>>>30)+o>>>0;let s=1,a=0;for(let o=Math.max(624,n.length);o>0;--o,++s,++a)s>=624&&(t[0]=t[623],s=1),a>=n.length&&(a=0),t[s]=(t[s]^r(t[s-1]^t[s-1]>>>30,1664525))+n[a]+a>>>0;for(let o=623;o>0;--o,++s)s>=624&&(t[0]=t[623],s=1),t[s]=(t[s]^r(t[s-1]^t[s-1]>>>30,1566083941))-s>>>0;t[0]=2147483648,this._idx=624,this._gauss_next=null}_int32(){const e=this._mt;if(this._idx>=624){for(let r=0;r<624;++r){const n=e[r]&2147483648|e[(r+1)%624]&2147483647;e[r]=(e[(r+397)%624]^n>>>1^(n&1?2567483615:0))>>>0}this._idx=0}let t=e[this._idx++];return t^=t>>>11,t^=t<<7&2636928640,t^=t<<15&4022730752,t^=t>>>18,t>>>0}random(){return((this._int32()>>>5)*67108864+(this._int32()>>>6))/9007199254740992}gauss(e=0,t=1){let r=this._gauss_next;if(this._gauss_next=null,r===null){const n=this.random()*2*Math.PI,s=Math.sqrt(-2*Math.log(1-this.random()));r=Math.cos(n)*s,this._gauss_next=Math.sin(n)*s}return e+r*t}shuffle(e){for(let t=e.length-1;t>0;--t){const r=32-Math.clz32(t+1);let n=this._int32()>>>32-r;for(;n>t;)n=this._int32()>>>32-r;const s=e[t];e[t]=e[n],e[n]=s}}choices(e,t){return e[um(this._random_fn,t)]}};function um(e,t){let r=0;for(let s=0;s<t.length;++s)r+=t[s];let n=e()*r;for(let s=0;s<t.length;++s)if(n-=t[s],n<0)return s;return t.length-1}var Yt=new qa,Hl=Object.freeze({Random:qa,seed:Yt.seed.bind(Yt),random:Yt.random.bind(Yt),gauss:Yt.gauss.bind(Yt),shuffle:Yt.shuffle.bind(Yt),choices:Yt.choices.bind(Yt)}),Vk=e=>um(Hl.random,e),Uk=new qa,dm=class{constructor(e){this.path=e}async match(e){let t=Zt.join(this.path,e),r=new Da(t);if(r.exists)return r}async put(e,t,r=void 0){const n=Zt.join(this.path,e),s=_e.IS_PROCESS_AVAILABLE?process.pid:Date.now(),a=Uk._int32().toString(36),o=n+`.tmp.${s}.${a}`;try{const i=t.headers.get("Content-Length"),l=parseInt(i??"0");let c=0;await xt.promises.mkdir(Zt.dirname(n),{recursive:!0});const d=xt.createWriteStream(o),h=t.body.getReader();for(;;){const{done:_,value:p}=await h.read();if(_)break;await new Promise((v,y)=>{d.write(p,M=>{if(M){y(M);return}v()})}),c+=p.length;const w=l?c/l*100:0;r==null||r({progress:w,loaded:c,total:l})}await new Promise((_,p)=>{d.close(w=>w?p(w):_())}),await xt.promises.rename(o,n)}catch(i){try{await xt.promises.unlink(o)}catch{}throw i}}async delete(e){let t=Zt.join(this.path,e);try{return await xt.promises.unlink(t),!0}catch{return!1}}},jk={400:"Bad request error occurred while trying to load file",401:"Unauthorized access to file",403:"Forbidden access to file",404:"Could not locate file",408:"Request timeout error occurred while trying to load file",500:"Internal server error error occurred while trying to load file",502:"Bad gateway error occurred while trying to load file",503:"Service unavailable error occurred while trying to load file",504:"Gateway timeout error occurred while trying to load file"},b_=100,qk=/^(\b[\w\-.]+\b\/)?\b[\w\-.]{1,96}\b$/;function Zs(...e){return e=e.map((t,r)=>(r&&(t=t.replace(new RegExp("^/"),"")),r!==e.length-1&&(t=t.replace(new RegExp("/$"),"")),t)),e.join("/")}function bn(e,t=null,r=null){let n;try{n=new URL(e)}catch{return!1}return!(t&&!t.includes(n.protocol)||r&&!r.includes(n.hostname))}function Wk(e){return!(!qk.test(e)||e.includes("..")||e.includes("--")||e.endsWith(".git")||e.endsWith(".ipynb"))}function Hk(e,t,r){if(!r)return null;const n=jk[e]??`Error (${e}) occurred while trying to load file`;throw Error(`${n}: "${t}".`)}async function Qk(e,t,r){const n=e.headers.get("Content-Length");let s=n?parseInt(n,10):r??0;n===null&&!r&&ue.warn("Unable to determine content-length from response headers. Will expand buffer when needed.");let a=new Uint8Array(s),o=0;const i=e.body.getReader();async function l(){const{done:c,value:d}=await i.read();if(c)return;const h=o+d.length;if(h>s){s=h;const p=new Uint8Array(s);p.set(a),a=p}a.set(d,o),o=h;const _=o/s*100;return t({progress:_,loaded:o,total:s}),l()}return await l(),a}function M_(e){return bn(e,["blob:"])}function x_(e){let t;if(typeof location<"u"&&location.href)t=location.href;else if(typeof import.meta<"u"&&import.meta.url)t=import.meta.url;else return e;return new URL(e,t).href}var hm="SHA-256",Xk="experimental_transformers-hash-cache",k_=e=>({algorithm:hm,value:e}),vs,ki,T_=(ki=class{constructor(){qs(this,vs,null);k(this,"_getHashCache",()=>(at(this,vs)??Ws(this,vs,caches.open(Xk)),at(this,vs)));k(this,"match",async e=>{const t=await this._getFileHash(e);if(t)try{const[r]=await navigator.crossOriginStorage.requestFileHandles([k_(t)]),n=await r.getFile();return new Response(n,{headers:{"Content-Length":String(n.size)}})}catch{return}});k(this,"put",async(e,t)=>{const r=await this._getFileHash(e);if(r){const n=await t.blob();await this._storeBlobInCOS(n,r)}else this._processAndStore(e,t.body)});k(this,"_storeBlobInCOS",async(e,t)=>{const[r]=await navigator.crossOriginStorage.requestFileHandles([k_(t)],{create:!0}),n=await r.createWritable();await n.write(e),await n.close()});k(this,"_processAndStore",async(e,t)=>{try{const r=[];for await(const a of t)r.push(a);const n=new Blob(r),s=await this._getBlobHash(n);await this._storeBlobInCOS(n,s);try{await(await this._getHashCache()).put(e,new Response(s))}catch{}}catch{}});k(this,"delete",async e=>{try{return await(await this._getHashCache()).delete(e)}catch{return!1}});k(this,"_getFileHash",async e=>{try{const t=await this._getHashCache(),r=await t.match(e);if(r)return r.text();const n=await this._getLfsFileHash(e);return n?(await t.put(e,new Response(n)),n):null}catch{return null}});k(this,"_getLfsFileHash",async e=>{if(!e.includes("/resolve/"))return null;const t=e.replace("/resolve/","/raw/");try{const n=(await fetch(t).then(s=>s.text())).match(/^oid sha256:([0-9a-f]+)$/m);return n?n[1]:null}catch{return null}});k(this,"_getBlobHash",async e=>{const t=await e.arrayBuffer(),r=await crypto.subtle.digest(hm,t);return Array.from(new Uint8Array(r)).map(s=>s.toString(16).padStart(2,"0")).join("")})}},vs=new WeakMap,k(ki,"isAvailable",()=>typeof navigator<"u"&&"crossOriginStorage"in navigator),ki);async function Ql(e=null){let t=null;if(Me.useCustomCache){if(!Me.customCache)throw Error("`env.useCustomCache=true`, but `env.customCache` is not defined.");if(!Me.customCache.match||!Me.customCache.put)throw new Error("`env.customCache` must be an object which implements the `match` and `put` functions of the Web Cache API. For more information, see https://developer.mozilla.org/en-US/docs/Web/API/Cache");t=Me.customCache}if(!t&&Me.experimental_useCrossOriginStorage&&T_.isAvailable()&&(t=new T_),!t&&Me.useBrowserCache){if(typeof caches>"u")throw Error("Browser cache is not available in this environment.");try{t=await caches.open(Me.cacheKey)}catch(r){ue.warn("An error occurred while opening the browser cache:",r)}}if(!t&&Me.useFSCache){if(!_e.IS_FS_AVAILABLE)throw Error("File System Cache is not available in this environment.");t=new dm(e??Me.cacheDir)}return t}async function Yk(e,...t){for(let r of t)try{let n=await e.match(r);if(n)return n}catch{continue}}var ys,ot,rp,Jk=(rp=class{constructor(e){qs(this,ys);qs(this,ot);Ws(this,ys,e),Ws(this,ot,new Map)}get(e){if(!at(this,ot).has(e))return;const t=at(this,ot).get(e);return at(this,ot).delete(e),at(this,ot).set(e,t),t}put(e,t){at(this,ot).has(e)&&at(this,ot).delete(e),at(this,ot).set(e,t),at(this,ot).size>at(this,ys)&&at(this,ot).delete(at(this,ot).keys().next().value)}delete(e){return at(this,ot).delete(e)}clear(){at(this,ot).clear()}},ys=new WeakMap,ot=new WeakMap,rp),Kk=100,_i=new Jk(Kk);function fm(e,t){const r=_i.get(e);if(r!==void 0)return r;const n=t().then(s=>s,s=>(_i.delete(e),Promise.reject(s)));return _i.put(e,n),n}async function Zk(e){if(!bn(e,["http:","https:"]))return null;const t=_m(e);return t.set("Range","bytes=0-0"),Me.fetch(e,{method:"GET",headers:t,cache:"no-store"})}function ks(e,t,r={}){const n=JSON.stringify([e,t,r==null?void 0:r.revision,r==null?void 0:r.cache_dir,r==null?void 0:r.local_files_only]);return fm(n,()=>eT(e,t,r))}async function eT(e,t,r){var c;const n=await Ql(r==null?void 0:r.cache_dir),{localPath:s,remoteURL:a,proposedCacheKey:o,validModelId:i}=pm(e,t,r,n),l=await mm(n,s,o);if(l!==void 0&&typeof l!="string"){const d=l.headers.get("content-length"),h=l.headers.get("content-type");return{exists:!0,size:d?parseInt(d,10):void 0,contentType:h||void 0,fromCache:!0}}if(Me.allowLocalModels&&!bn(s,["http:","https:"]))try{const h=await ps(s);if(typeof h!="string"&&h.status!==404){const _=h.headers.get("content-length"),p=h.headers.get("content-type");return{exists:!0,size:_?parseInt(_,10):void 0,contentType:p||void 0,fromCache:!1}}}catch{}if(Me.allowRemoteModels&&!r.local_files_only&&i)try{const d=await Zk(a);if(d&&d.status>=200&&d.status<300){let h;const _=d.headers.get("content-type");if(d.status===206){const p=d.headers.get("content-range");if(p){const w=p.match(/bytes \d+-\d+\/(\d+)/);w&&(h=parseInt(w[1],10))}}else if(d.status===200)try{await((c=d.body)==null?void 0:c.cancel())}catch{}if(h===void 0){const p=d.headers.get("content-length");h=p?parseInt(p,10):void 0}return{exists:!0,size:h,contentType:_||void 0,fromCache:!1}}}catch(d){ue.warn(`Unable to fetch file metadata for "${a}": ${d}`)}return{exists:!1,fromCache:!1}}async function ps(e){return Me.useFS&&!bn(e,["http:","https:","blob:"])?new Da(e instanceof URL?e.protocol==="file:"?e.pathname:e.toString():e):Me.fetch(e,{headers:_m(e)})}function _m(e){var n;const t=typeof process<"u"&&((n=process==null?void 0:process.release)==null?void 0:n.name)==="node",r=new Headers;if(t){const s=!!(dr!=null&&dr.TESTING_REMOTELY),a=Me.version;if(r.set("User-Agent",`transformers.js/${a}; is_ci/${s};`),bn(e,["http:","https:"],["huggingface.co","hf.co"])){const i=(dr==null?void 0:dr.HF_TOKEN)??(dr==null?void 0:dr.HF_ACCESS_TOKEN);i&&r.set("Authorization",`Bearer ${i}`)}}return r}function pm(e,t,r={},n=null){const s=r.revision??"main",a=Zs(e,t),o=Wk(e),i=o?Zs(Me.localModelPath,a):a,l=Zs(Me.remoteHost,Me.remotePathTemplate.replaceAll("{model}",e).replaceAll("{revision}",encodeURIComponent(s)),t),c=n instanceof dm?s==="main"?a:Zs(e,s,t):l;return{requestURL:a,localPath:i,remoteURL:l,proposedCacheKey:c,validModelId:o}}async function mm(e,t,r){if(e)return await Yk(e,t,r)}async function tT(e,t,r,n,s,a,o={}){if(await r.match(n)===void 0)if(a){if(typeof s!="string"){const i=new Headers(s.headers);i.set("content-length",a.byteLength.toString()),await r.put(n,new Response(a,{headers:i})).catch(l=>{ue.warn(`Unable to add response to browser cache: ${l}.`)})}}else{const i=o.progress_callback?l=>Ar(o.progress_callback,{status:"progress",name:e,file:t,...l}):void 0;await r.put(n,s,i)}}async function rT(e,t,r=!0,n={},s=!1,a=null){const{requestURL:o,localPath:i,remoteURL:l,proposedCacheKey:c,validModelId:d}=pm(e,t,n,a);let h,_=!1,p;p=await mm(a,i,c);const w=p!==void 0;if(w)h=c;else{if(Me.allowLocalModels)if(bn(o,["http:","https:"])){if(n.local_files_only)throw new Error(`\`local_files_only=true\`, but attempted to load a remote file from: ${o}.`);if(!Me.allowRemoteModels)throw new Error(`\`env.allowRemoteModels=false\`, but attempted to load a remote file from: ${o}.`)}else try{p=await ps(i),h=i}catch(T){ue.warn(`Unable to load from local path "${i}": "${T}"`)}if(p===void 0||typeof p!="string"&&p.status===404){if(n.local_files_only||!Me.allowRemoteModels){if(r)throw Error(`\`local_files_only=true\` or \`env.allowRemoteModels=false\` and file was not found locally at "${i}".`);return null}if(!d)throw Error(`Local file missing at "${i}" and download aborted due to invalid model ID "${e}".`);if(p=await ps(l),p.status!==200)return Hk(p.status,l,r);h=c}_=a&&typeof Response<"u"&&p instanceof Response&&p.status===200}Ar(n.progress_callback,{status:"download",name:e,file:t});let v;if(!(_e.IS_NODE_ENV&&s)){let M;if(typeof p!="string")if(!n.progress_callback)M=new Uint8Array(await p.arrayBuffer());else if(w&&typeof navigator<"u"&&/firefox/i.test(navigator.userAgent))M=new Uint8Array(await p.arrayBuffer()),Ar(n.progress_callback,{status:"progress",name:e,file:t,progress:100,loaded:M.length,total:M.length});else{let T;const A=p.headers.get("content-length");if(A)T=parseInt(A,10);else try{const S=await ks(e,t,n);S.size&&(T=S.size)}catch{}M=await Qk(p,S=>{Ar(n.progress_callback,{status:"progress",name:e,file:t,...S})},T)}v=M}if(_&&h&&typeof p!="string"&&await tT(e,t,a,h,p,v,n),_e.IS_NODE_ENV&&s&&n.progress_callback&&typeof p!="string"){const M=parseInt(p.headers.get("content-length"),10)||0;Ar(n.progress_callback,{status:"progress",name:e,file:t,progress:100,loaded:M,total:M})}if(Ar(n.progress_callback,{status:"done",name:e,file:t}),v){if(!_e.IS_NODE_ENV&&s)throw new Error("Cannot return path in a browser environment.");return v}if(p instanceof Da)return p.filePath;const y=await(a==null?void 0:a.match(h));if(y instanceof Da)return y.filePath;if(y instanceof Response)return new Uint8Array(await y.arrayBuffer());if(typeof y=="string")return y;throw new Error("Unable to get model file path or buffer.")}var ea=new Map;async function za(e,t,r=!0,n={},s=!1){if(!Me.allowLocalModels){if(n.local_files_only)throw Error("Invalid configuration detected: local models are disabled (`env.allowLocalModels=false`) but you have requested to only use local models (`local_files_only=true`).");if(!Me.allowRemoteModels)throw Error("Invalid configuration detected: both local and remote models are disabled. Fix by setting `env.allowLocalModels` or `env.allowRemoteModels` to `true`.")}Ar(n.progress_callback,{status:"initiate",name:e,file:t});const a=`${e}::${t}`;let o=ea.get(a);if(!o){const i=await Ql(n==null?void 0:n.cache_dir);o=rT(e,t,r,n,s,i).then(l=>(ea.delete(a),l),l=>{throw ea.delete(a),l}),ea.set(a,o)}return await o}async function Xl(e,t,r=!0,n={}){const s=await za(e,t,r,n,!1);return s===null?null:new TextDecoder("utf-8").decode(s)}async function nr(e,t,r=!0,n={}){const s=await Xl(e,t,r,n);return s===null?{}:JSON.parse(s)}function nT(e,[t,r,n],[s,a],o="bilinear",i=!1){const l=a/n,c=s/r,d=new e.constructor(s*a*t),h=r*n,_=s*a;for(let p=0;p<s;++p)for(let w=0;w<a;++w){const v=p*a+w,y=(w+.5)/l-.5,M=(p+.5)/c-.5;let T=Math.floor(y),A=Math.floor(M);const S=Math.min(T+1,n-1),C=Math.min(A+1,r-1);T=Math.max(T,0),A=Math.max(A,0);const I=y-T,x=M-A,R=(1-I)*(1-x),z=I*(1-x),$=(1-I)*x,Q=I*x,H=A*n,D=C*n,O=H+T,te=H+S,W=D+T,ee=D+S;for(let G=0;G<t;++G){const L=G*h;d[G*_+v]=R*e[L+O]+z*e[L+te]+$*e[L+W]+Q*e[L+ee]}}return d}function sT(e,t,r){const n=new Array(r.length),s=new Array(r.length);for(let i=r.length-1,l=1;i>=0;--i)s[i]=l,n[i]=t[r[i]],l*=n[i];const a=r.map((i,l)=>s[r.indexOf(l)]),o=new e.constructor(e.length);for(let i=0;i<e.length;++i){let l=0;for(let c=t.length-1,d=i;c>=0;--c)l+=d%t[c]*a[c],d=Math.floor(d/t[c]);o[l]=e[i]}return[o,n]}function nt(e){const t=Ue(e)[0],r=e.map(a=>Math.exp(a-t)),n=r.reduce((a,o)=>a+o,0);return r.map(a=>a/n)}function aT(e){const t=Ue(e)[0];let r=0;for(let a=0;a<e.length;++a)r+=Math.exp(e[a]-t);const n=Math.log(r);return e.map(a=>a-t-n)}function hl(e){if(e.length===0)throw Error("Array must not be empty");let t=e[0],r=0;for(let n=1;n<e.length;++n)e[n]<t&&(t=e[n],r=n);return[t,r]}function Ue(e){if(e.length===0)throw Error("Array must not be empty");let t=e[0],r=0;for(let n=1;n<e.length;++n)e[n]>t&&(t=e[n],r=n);return[t,r]}function gm(e){return e>0&&(e&e-1)===0}var wm=class{constructor(e){if(this.size=e|0,this.size<=1||!gm(this.size))throw new Error("FFT size must be a power of two larger than 1");this._csize=e<<1,this.table=new Float64Array(this.size*2);for(let r=0;r<this.table.length;r+=2){const n=Math.PI*r/this.size;this.table[r]=Math.cos(n),this.table[r+1]=-Math.sin(n)}let t=0;for(let r=1;this.size>r;r<<=1)++t;this._width=t%2===0?t-1:t,this._bitrev=new Int32Array(1<<this._width);for(let r=0;r<this._bitrev.length;++r){this._bitrev[r]=0;for(let n=0;n<this._width;n+=2){const s=this._width-n-2;this._bitrev[r]|=(r>>>n&3)<<s}}}createComplexArray(){return new Float64Array(this._csize)}fromComplexArray(e,t){const r=t||new Array(e.length>>>1);for(let n=0;n<e.length;n+=2)r[n>>>1]=e[n];return r}toComplexArray(e,t){const r=t||this.createComplexArray();for(let n=0;n<r.length;n+=2)r[n]=e[n>>>1],r[n+1]=0;return r}transform(e,t){if(e===t)throw new Error("Input and output buffers must be different");this._transform4(e,t,1)}realTransform(e,t){if(e===t)throw new Error("Input and output buffers must be different");this._realTransform4(e,t,1)}inverseTransform(e,t){if(e===t)throw new Error("Input and output buffers must be different");this._transform4(e,t,-1);for(let r=0;r<e.length;++r)e[r]/=this.size}_transform4(e,t,r){const n=this._csize;let a=1<<this._width,o=n/a<<1,i,l;const c=this._bitrev;if(o===4)for(i=0,l=0;i<n;i+=o,++l){const h=c[l];this._singleTransform2(t,e,i,h,a)}else for(i=0,l=0;i<n;i+=o,++l){const h=c[l];this._singleTransform4(t,e,i,h,a,r)}const d=this.table;for(a>>=2;a>=2;a>>=2){o=n/a<<1;const h=o>>>2;for(i=0;i<n;i+=o){const _=i+h-1;for(let p=i,w=0;p<_;p+=2,w+=a){const v=p,y=v+h,M=y+h,T=M+h,A=e[v],S=e[v+1],C=e[y],I=e[y+1],x=e[M],R=e[M+1],z=e[T],$=e[T+1],Q=d[w],H=r*d[w+1],D=C*Q-I*H,O=C*H+I*Q,te=d[2*w],W=r*d[2*w+1],ee=x*te-R*W,G=x*W+R*te,L=d[3*w],V=r*d[3*w+1],X=z*L-$*V,J=z*V+$*L,me=A+ee,re=S+G,Fe=A-ee,Ve=S-G,pt=D+X,Tt=O+J,Et=r*(D-X),je=r*(O-J);e[v]=me+pt,e[v+1]=re+Tt,e[y]=Fe+je,e[y+1]=Ve-Et,e[M]=me-pt,e[M+1]=re-Tt,e[T]=Fe-je,e[T+1]=Ve+Et}}}}_singleTransform2(e,t,r,n,s){const a=e[n],o=e[n+1],i=e[n+s],l=e[n+s+1];t[r]=a+i,t[r+1]=o+l,t[r+2]=a-i,t[r+3]=o-l}_singleTransform4(e,t,r,n,s,a){const o=s*2,i=s*3,l=e[n],c=e[n+1],d=e[n+s],h=e[n+s+1],_=e[n+o],p=e[n+o+1],w=e[n+i],v=e[n+i+1],y=l+_,M=c+p,T=l-_,A=c-p,S=d+w,C=h+v,I=a*(d-w),x=a*(h-v);t[r]=y+S,t[r+1]=M+C,t[r+2]=T+x,t[r+3]=A-I,t[r+4]=y-S,t[r+5]=M-C,t[r+6]=T-x,t[r+7]=A+I}_realTransform4(e,t,r){const n=this._csize;let a=1<<this._width,o=n/a<<1,i,l;const c=this._bitrev;if(o===4)for(i=0,l=0;i<n;i+=o,++l){const _=c[l];this._singleRealTransform2(t,e,i,_>>>1,a>>>1)}else for(i=0,l=0;i<n;i+=o,++l){const _=c[l];this._singleRealTransform4(t,e,i,_>>>1,a>>>1,r)}const d=this.table;for(a>>=2;a>=2;a>>=2){o=n/a<<1;const _=o>>>1,p=_>>>1,w=p>>>1;for(i=0;i<n;i+=o)for(let v=0,y=0;v<=w;v+=2,y+=a){const M=i+v,T=M+p,A=T+p,S=A+p,C=e[M],I=e[M+1],x=e[T],R=e[T+1],z=e[A],$=e[A+1],Q=e[S],H=e[S+1],D=C,O=I,te=d[y],W=r*d[y+1],ee=x*te-R*W,G=x*W+R*te,L=d[2*y],V=r*d[2*y+1],X=z*L-$*V,J=z*V+$*L,me=d[3*y],re=r*d[3*y+1],Fe=Q*me-H*re,Ve=Q*re+H*me,pt=D+X,Tt=O+J,Et=D-X,je=O-J,ht=ee+Fe,be=G+Ve,le=r*(ee-Fe),Se=r*(G-Ve);if(e[M]=pt+ht,e[M+1]=Tt+be,e[T]=Et+Se,e[T+1]=je-le,v===0){e[A]=pt-ht,e[A+1]=Tt-be;continue}if(v===w)continue;const ft=i+p-v,Wt=i+_-v;e[ft]=Et-r*Se,e[ft+1]=-je-r*le,e[Wt]=pt-r*ht,e[Wt+1]=-Tt+r*be}}const h=n>>>1;for(let _=2;_<h;_+=2)e[n-_]=e[_],e[n-_+1]=-e[_+1]}_singleRealTransform2(e,t,r,n,s){const a=e[n],o=e[n+s];t[r]=a+o,t[r+1]=0,t[r+2]=a-o,t[r+3]=0}_singleRealTransform4(e,t,r,n,s,a){const o=s*2,i=s*3,l=e[n],c=e[n+s],d=e[n+o],h=e[n+i],_=l+d,p=l-d,w=c+h,v=a*(c-h);t[r]=_+w,t[r+1]=0,t[r+2]=p,t[r+3]=-v,t[r+4]=_-w,t[r+5]=0,t[r+6]=p,t[r+7]=v}},oT=class{constructor(e){const t=2*(e-1),r=2*(2*e-1),n=2**Math.ceil(Math.log2(r));this.bufferSize=n,this._a=t;const s=new Float64Array(r),a=new Float64Array(n);this._chirpBuffer=new Float64Array(n),this._buffer1=new Float64Array(n),this._buffer2=new Float64Array(n),this._outBuffer1=new Float64Array(n),this._outBuffer2=new Float64Array(n);const o=-2*Math.PI/e,i=Math.cos(o),l=Math.sin(o);for(let c=0;c<r>>1;++c){const d=(c+1-e)**2/2,h=Math.sqrt(i**2+l**2)**d,_=d*Math.atan2(l,i),p=2*c;s[p]=h*Math.cos(_),s[p+1]=h*Math.sin(_),a[p]=s[p],a[p+1]=-s[p+1]}this._slicedChirpBuffer=s.subarray(t,r),this._f=new wm(n>>1),this._f.transform(this._chirpBuffer,a)}_transform(e,t,r){const n=this._buffer1,s=this._buffer2,a=this._outBuffer1,o=this._outBuffer2,i=this._chirpBuffer,l=this._slicedChirpBuffer,c=this._a;if(r)for(let d=0;d<l.length;d+=2){const h=d+1,_=d>>1,p=t[_];n[d]=p*l[d],n[h]=p*l[h]}else for(let d=0;d<l.length;d+=2){const h=d+1;n[d]=t[d]*l[d]-t[h]*l[h],n[h]=t[d]*l[h]+t[h]*l[d]}this._f.transform(a,n);for(let d=0;d<i.length;d+=2){const h=d+1;s[d]=a[d]*i[d]-a[h]*i[h],s[h]=a[d]*i[h]+a[h]*i[d]}this._f.inverseTransform(o,s);for(let d=0;d<o.length;d+=2){const h=o[d+c],_=o[d+c+1],p=l[d],w=l[d+1];e[d]=h*p-_*w,e[d+1]=h*w+_*p}}transform(e,t){this._transform(e,t,!1)}realTransform(e,t){this._transform(e,t,!0)}},iT=class{constructor(e){this.fft_length=e,this.isPowerOfTwo=gm(e),this.isPowerOfTwo?(this.fft=new wm(e),this.outputBufferSize=2*e):(this.fft=new oT(e),this.outputBufferSize=this.fft.bufferSize)}realTransform(e,t){this.fft.realTransform(e,t)}transform(e,t){this.fft.transform(e,t)}};function lT(e,t){if(t%2===0||t<=0)throw new Error("Window size must be a positive odd number");const r=new e.constructor(e.length),n=new e.constructor(t),s=Math.floor(t/2);for(let a=0;a<e.length;++a){let o=0;for(let i=-s;i<=s;++i){let l=a+i;l<0?l=Math.abs(l):l>=e.length&&(l=2*(e.length-1)-l),n[o++]=e[l]}n.sort(),r[a]=n[s]}return r}function us(e,t){const r=Math.pow(10,t);return Math.round(e*r)/r}function cT(e){const t=Math.round(e);return Math.abs(e)%1===.5?t%2===0?t:t-1:t}function uT(e){const t=e.length,r=e[0].length,n=[t+1,r+1],s=Array.from({length:n[0]},()=>Array(n[1]).fill(1/0));s[0][0]=0;const a=Array.from({length:n[0]},()=>Array(n[1]).fill(-1));for(let d=1;d<n[1];++d)for(let h=1;h<n[0];++h){const _=s[h-1][d-1],p=s[h-1][d],w=s[h][d-1];let v,y;_<p&&_<w?(v=_,y=0):p<_&&p<w?(v=p,y=1):(v=w,y=2),s[h][d]=e[h-1][d-1]+v,a[h][d]=y}for(let d=0;d<n[1];++d)a[0][d]=2;for(let d=0;d<n[0];++d)a[d][0]=1;let o=t,i=r,l=[],c=[];for(;o>0||i>0;)switch(l.push(o-1),c.push(i-1),a[o][i]){case 0:--o,--i;break;case 1:--o;break;case 2:--i;break;default:throw new Error(`Internal error in dynamic time warping. Unexpected trace[${o}, ${i}]. Please file a bug report.`)}return l.reverse(),c.reverse(),[l,c]}var dT=(function(){let e=null;return function(t){if(!e){e=new Float32Array(65536);const a=new ArrayBuffer(4),o=new Uint32Array(a),i=new Float32Array(a);for(let l=0;l<e.length;++l){let c=0;const d=(l&32768)<<16,h=(l&31744)>>10;let _=l&1023;if(h===31)c=d|2139095040|_<<13;else if(h===0)if(_===0)c=d;else{let p=113;for(;(_&1024)===0;)_<<=1,--p;_&=-1025,c=d|p<<23|_<<13}else c=d|h+112<<23|_<<13;o[0]=c,e[l]=i[0]}}const r=t.length,n=e,s=new Float32Array(r);for(let a=0;a<r;++a)s[a]=n[t[a]];return s}})(),vm={};vn(vm,{default:()=>hT});var hT={};async function ym(e){const t=e.split("/").pop();let r;try{if(r=await Ql(),r){const s=await r.match(e);if(s)return s}}catch(s){ue.warn(`Failed to load ${t} from cache:`,s)}const n=await Me.fetch(e);if(!n.ok)throw new Error(`Failed to fetch ${t}: ${n.status} ${n.statusText}`);if(r)try{await r.put(e,n.clone())}catch(s){ue.warn(`Failed to cache ${t}:`,s)}return n}async function fT(e){const t=await ym(e);if(!t||typeof t=="string")return null;try{return await t.arrayBuffer()}catch(r){return ue.warn("Failed to read WASM binary:",r),null}}async function _T(e){if(_e.IS_SERVICE_WORKER_ENV||_e.IS_CHROME_AVAILABLE)return e;const t=await ym(e);if(!t||typeof t=="string")return null;try{let r=await t.text();r=r.replaceAll("globalThis.process?.versions?.node","false");const n=new Blob([r],{type:"text/javascript"});return URL.createObjectURL(n)}catch(r){return ue.warn("Failed to read WASM factory:",r),null}}var pT=Object.freeze({auto:null,gpu:null,cpu:"cpu",wasm:"wasm",webgpu:"webgpu",cuda:"cuda",dml:"dml",coreml:"coreml",webnn:{name:"webnn",deviceType:"cpu"},"webnn-npu":{name:"webnn",deviceType:"npu"},"webnn-gpu":{name:"webnn",deviceType:"gpu"},"webnn-cpu":{name:"webnn",deviceType:"cpu"}});function bm(e){return e<=Dt.DEBUG?0:e<=Dt.INFO?2:e<=Dt.WARNING||e<=Dt.ERROR?3:4}var mT={0:"verbose",1:"info",2:"warning",3:"error",4:"fatal"},Pt=[],fl,Pr,E_=Symbol.for("onnxruntime");if(E_ in globalThis)Pr=globalThis[E_];else if(_e.IS_NODE_ENV){switch(Pr=vm,process.platform){case"win32":Pt.push("dml");break;case"linux":process.arch==="x64"&&Pt.push("cuda");break;case"darwin":Pt.push("coreml");break}Pt.push("webgpu"),Pt.push("cpu"),fl=["cpu"]}else Pr=aM,_e.IS_WEBNN_AVAILABLE&&Pt.push("webnn-npu","webnn-gpu","webnn-cpu","webnn"),_e.IS_WEBGPU_AVAILABLE&&Pt.push("webgpu"),Pt.push("wasm"),fl=["wasm"];var gT=Pr.InferenceSession;function wT(e=null){if(!e)return fl;switch(e){case"auto":return Pt;case"gpu":return Pt.filter(t=>["webgpu","cuda","dml","webnn-gpu"].includes(t))}if(Pt.includes(e))return[pT[e]??e];throw new Error(`Unsupported device: "${e}". Should be one of: ${Pt.join(", ")}.`)}var A_=Promise.resolve(),sn=null;async function vT(){var t,r,n,s,a;if(sn)return sn;if(!(Me.useWasmCache&&typeof((t=Ie==null?void 0:Ie.wasm)==null?void 0:t.wasmPaths)=="object"&&((n=(r=Ie==null?void 0:Ie.wasm)==null?void 0:r.wasmPaths)==null?void 0:n.wasm)&&((a=(s=Ie==null?void 0:Ie.wasm)==null?void 0:s.wasmPaths)==null?void 0:a.mjs))){if(_e.IS_DENO_WEB_RUNTIME)throw new Error("env.useWasmCache=false is not supported in Deno's web runtime. Remove the useWasmCache override.");return sn=Promise.resolve(),sn}return sn=(async()=>{const o=Ie.wasm.wasmPaths;let i=!1;await Promise.all([o.wasm&&!M_(o.wasm)?(async()=>{try{const l=await fT(x_(o.wasm));l&&(Ie.wasm.wasmBinary=l,i=!0)}catch(l){ue.warn("Failed to pre-load WASM binary:",l)}})():Promise.resolve(),o.mjs&&!M_(o.mjs)?(async()=>{try{const l=await _T(x_(o.mjs));l&&(Ie.wasm.wasmPaths.mjs=l)}catch(l){ue.warn("Failed to pre-load WASM factory:",l)}})():Promise.resolve()]),i||(Ie.wasm.wasmPaths.mjs=o.mjs)})(),sn}async function Mm(e,t,r){await vT();const n=bm(Me.logLevel??Dt.WARNING),s=()=>gT.create(e,{logSeverityLevel:n,...t}),a=await(_e.IS_WEB_ENV?A_=A_.then(s):s());return a.config=r,a}var C_=Promise.resolve();async function xm(e,t){const r=()=>e.run(t);return _e.IS_WEB_ENV?C_=C_.then(r):r()}function km(e){return e instanceof Pr.Tensor}var Ie=Pr==null?void 0:Pr.env;function Yl(){var e;return(e=Ie==null?void 0:Ie.wasm)==null?void 0:e.proxy}var np;if(Ie){let e=function(t){const r=bm(t);Ie.logLevel=mT[r]};if(Ie.wasm){if(!(typeof ServiceWorkerGlobalScope<"u"&&self instanceof ServiceWorkerGlobalScope)&&((np=Ie.versions)!=null&&np.web)&&!Ie.wasm.wasmPaths){const t=`https://cdn.jsdelivr.net/npm/onnxruntime-web@${Ie.versions.web}/dist/`;Ie.wasm.wasmPaths=_e.IS_SAFARI?{mjs:`${t}ort-wasm-simd-threaded.mjs`,wasm:`${t}ort-wasm-simd-threaded.wasm`}:{mjs:`${t}ort-wasm-simd-threaded.asyncify.mjs`,wasm:`${t}ort-wasm-simd-threaded.asyncify.wasm`}}Ie.wasm.proxy=!1}Ie.webgpu&&(Ie.webgpu.powerPreference="high-performance"),e(Me.logLevel??Dt.WARNING),Me.backends.onnx={...Ie,setLogLevel:e}}var Tr=async(e,t,r)=>{const n=await Mm(new Uint8Array(e),t);return(async s=>{const a=Yl(),o=Object.fromEntries(Object.entries(s).map(([l,c])=>[l,(a?c.clone():c).ort_tensor])),i=await xm(n,o);return Array.isArray(r)?r.map(l=>new j(i[l])):new j(i[r])})},Ti,mn=(Ti=class{static get nearest_interpolate_4d(){return this._nearest_interpolate_4d||(this._nearest_interpolate_4d=Tr([8,10,18,0,58,129,1,10,41,10,1,120,10,0,10,0,10,1,115,18,1,121,34,6,82,101,115,105,122,101,42,18,10,4,109,111,100,101,34,7,110,101,97,114,101,115,116,160,1,3,18,1,114,90,31,10,1,120,18,26,10,24,8,1,18,20,10,3,18,1,98,10,3,18,1,99,10,3,18,1,104,10,3,18,1,119,90,15,10,1,115,18,10,10,8,8,7,18,4,10,2,8,4,98,31,10,1,121,18,26,10,24,8,1,18,20,10,3,18,1,98,10,3,18,1,99,10,3,18,1,104,10,3,18,1,119,66,2,16,21],this.session_options,"y")),this._nearest_interpolate_4d}static get bilinear_interpolate_4d(){return this._bilinear_interpolate_4d||(this._bilinear_interpolate_4d=Tr([8,9,18,0,58,128,1,10,40,10,1,120,10,0,10,0,10,1,115,18,1,121,34,6,82,101,115,105,122,101,42,17,10,4,109,111,100,101,34,6,108,105,110,101,97,114,160,1,3,18,1,114,90,31,10,1,120,18,26,10,24,8,1,18,20,10,3,18,1,98,10,3,18,1,99,10,3,18,1,104,10,3,18,1,119,90,15,10,1,115,18,10,10,8,8,7,18,4,10,2,8,4,98,31,10,1,121,18,26,10,24,8,1,18,20,10,3,18,1,98,10,3,18,1,99,10,3,18,1,104,10,3,18,1,119,66,2,16,20],this.session_options,"y")),this._bilinear_interpolate_4d}static get bicubic_interpolate_4d(){return this._bicubic_interpolate_4d||(this._bicubic_interpolate_4d=Tr([8,9,18,0,58,127,10,39,10,1,120,10,0,10,0,10,1,115,18,1,121,34,6,82,101,115,105,122,101,42,16,10,4,109,111,100,101,34,5,99,117,98,105,99,160,1,3,18,1,114,90,31,10,1,120,18,26,10,24,8,1,18,20,10,3,18,1,98,10,3,18,1,99,10,3,18,1,104,10,3,18,1,119,90,15,10,1,115,18,10,10,8,8,7,18,4,10,2,8,4,98,31,10,1,121,18,26,10,24,8,1,18,20,10,3,18,1,98,10,3,18,1,99,10,3,18,1,104,10,3,18,1,119,66,2,16,20],this.session_options,"y")),this._bicubic_interpolate_4d}static get matmul(){return this._matmul||(this._matmul=Tr([8,9,18,0,58,55,10,17,10,1,97,10,1,98,18,1,99,34,6,77,97,116,77,117,108,18,1,114,90,9,10,1,97,18,4,10,2,8,1,90,9,10,1,98,18,4,10,2,8,1,98,9,10,1,99,18,4,10,2,8,1,66,2,16,20],this.session_options,"c")),this._matmul}static get stft(){return this._stft||(this._stft=Tr([8,7,18,0,58,148,1,10,38,10,1,115,10,1,106,10,1,119,10,1,108,18,1,111,34,4,83,84,70,84,42,15,10,8,111,110,101,115,105,100,101,100,24,1,160,1,2,18,1,115,90,26,10,1,115,18,21,10,19,8,1,18,15,10,3,18,1,98,10,3,18,1,115,10,3,18,1,99,90,11,10,1,106,18,6,10,4,8,7,18,0,90,16,10,1,119,18,11,10,9,8,1,18,5,10,3,18,1,119,90,11,10,1,108,18,6,10,4,8,7,18,0,98,31,10,1,111,18,26,10,24,8,1,18,20,10,3,18,1,98,10,3,18,1,102,10,3,18,1,100,10,3,18,1,99,66,2,16,17],this.session_options,"o")),this._stft}static get rfft(){return this._rfft||(this._rfft=Tr([8,9,18,0,58,97,10,33,10,1,120,10,0,10,1,97,18,1,121,34,3,68,70,84,42,15,10,8,111,110,101,115,105,100,101,100,24,1,160,1,2,18,1,100,90,21,10,1,120,18,16,10,14,8,1,18,10,10,3,18,1,115,10,3,18,1,99,90,11,10,1,97,18,6,10,4,8,7,18,0,98,21,10,1,121,18,16,10,14,8,1,18,10,10,3,18,1,115,10,3,18,1,99,66,2,16,20],this.session_options,"y")),this._rfft}static get top_k(){return this._top_k||(this._top_k=Tr([8,10,18,0,58,73,10,18,10,1,120,10,1,107,18,1,118,18,1,105,34,4,84,111,112,75,18,1,116,90,9,10,1,120,18,4,10,2,8,1,90,15,10,1,107,18,10,10,8,8,7,18,4,10,2,8,1,98,9,10,1,118,18,4,10,2,8,1,98,9,10,1,105,18,4,10,2,8,7,66,2,16,21],this.session_options,["v","i"])),this._top_k}static get slice(){return this._slice||(this._slice=Tr([8,7,18,0,58,96,10,25,10,1,120,10,1,115,10,1,101,10,1,97,10,1,116,18,1,121,34,5,83,108,105,99,101,18,1,114,90,9,10,1,120,18,4,10,2,8,1,90,9,10,1,115,18,4,10,2,8,7,90,9,10,1,101,18,4,10,2,8,7,90,9,10,1,97,18,4,10,2,8,7,90,9,10,1,116,18,4,10,2,8,7,98,9,10,1,121,18,4,10,2,8,1,66,2,16,13],this.session_options,"y")),this._slice}},k(Ti,"session_options",{}),Ti),yT=Object.freeze({auto:"auto",gpu:"gpu",cpu:"cpu",wasm:"wasm",webgpu:"webgpu",cuda:"cuda",dml:"dml",coreml:"coreml",webnn:"webnn","webnn-npu":"webnn-npu","webnn-gpu":"webnn-gpu","webnn-cpu":"webnn-cpu"}),pi=_e.IS_NODE_ENV?"cpu":"wasm";function Tm(e,t,{warn:r}={}){return e?typeof e=="string"?e:e.hasOwnProperty(t)?e[t]:(r&&r(`device not specified for "${t}". Using the default device (${pi}).`),pi):pi}var bT=(function(){let e;return async function(){if(e===void 0)if(!_e.IS_WEBGPU_AVAILABLE)e=!1;else try{e=(await navigator.gpu.requestAdapter()).features.has("shader-f16")}catch{e=!1}return e}})(),qe=Object.freeze({auto:"auto",fp32:"fp32",fp16:"fp16",q8:"q8",int8:"int8",uint8:"uint8",q4:"q4",bnb4:"bnb4",q4f16:"q4f16",q2:"q2",q2f16:"q2f16",q1:"q1",q1f16:"q1f16"}),S_=qe.fp32,P_=Object.freeze({[yT.wasm]:qe.q8}),_l=Object.freeze({[qe.fp32]:"",[qe.fp16]:"_fp16",[qe.int8]:"_int8",[qe.uint8]:"_uint8",[qe.q8]:"_quantized",[qe.q4]:"_q4",[qe.q2]:"_q2",[qe.q1]:"_q1",[qe.q4f16]:"_q4f16",[qe.q2f16]:"_q2f16",[qe.q1f16]:"_q1f16",[qe.bnb4]:"_bnb4"});function Em(e,t,r,{configDtype:n=null,warn:s}={}){let a,o=!1;e&&typeof e!="string"?e.hasOwnProperty(t)?a=e[t]:(a=null,o=!0):a=e;let i;if(a===qe.auto){if(n){const l=typeof n=="string"?n:n==null?void 0:n[t];if(l&&l!==qe.auto&&qe.hasOwnProperty(l))return l}i=P_[r]??S_}else a&&qe.hasOwnProperty(a)?i=a:i=P_[r]??S_;return o&&s&&s(`dtype not specified for "${t}". Using the default dtype (${i}) for this device (${r}).`),i}var ms=Object.freeze({float32:Float32Array,float16:typeof Float16Array<"u"?Float16Array:Uint16Array,float64:Float64Array,string:Array,int8:Int8Array,uint8:Uint8Array,int16:Int16Array,uint16:Uint16Array,int32:Int32Array,uint32:Uint32Array,int64:BigInt64Array,uint64:BigUint64Array,bool:Uint8Array,uint4:Uint8Array,int4:Int8Array}),j=class Re{constructor(...t){k(this,"ort_tensor");return km(t[0])?this.ort_tensor=t[0]:this.ort_tensor=new mM(t[0],t[1],t[2]),new Proxy(this,{get:(r,n)=>{if(typeof n=="string"){let s=Number(n);if(Number.isInteger(s))return r._getitem(s)}return r[n]},set:(r,n,s)=>r[n]=s})}get dims(){return this.ort_tensor.dims}set dims(t){this.ort_tensor.dims=t}get type(){return this.ort_tensor.type}get data(){return this.ort_tensor.data}get size(){return this.ort_tensor.size}get location(){return this.ort_tensor.location}dispose(){this.ort_tensor.dispose()}*[Symbol.iterator](){const[t,...r]=this.dims;if(r.length>0){const n=r.reduce((s,a)=>s*a);for(let s=0;s<t;++s)yield this._subarray(s,n,r)}else yield*this.data}_getitem(t){const[r,...n]=this.dims;if(t=Kt(t,r),n.length>0){const s=n.reduce((a,o)=>a*o);return this._subarray(t,s,n)}else return new Re(this.type,[this.data[t]],n)}indexOf(t){const r=this.data;for(let n=0;n<r.length;++n)if(r[n]==t)return n;return-1}_subarray(t,r,n){const s=t*r,a=(t+1)*r,o="subarray"in this.data?this.data.subarray(s,a):this.data.slice(s,a);return new Re(this.type,o,n)}item(){const t=this.data;if(t.length!==1)throw new Error(`a Tensor with ${t.length} elements cannot be converted to Scalar`);return t[0]}tolist(){return MT(this.data,this.dims)}sigmoid(){return this.clone().sigmoid_()}sigmoid_(){const t=this.data;for(let r=0;r<t.length;++r)t[r]=1/(1+Math.exp(-t[r]));return this}map(t){return this.clone().map_(t)}map_(t){const r=this.data;for(let n=0;n<r.length;++n)r[n]=t(r[n],n,r);return this}mul(t){return this.clone().mul_(t)}mul_(t){const r=this.data;for(let n=0;n<r.length;++n)r[n]*=t;return this}div(t){return this.clone().div_(t)}div_(t){const r=this.data;for(let n=0;n<r.length;++n)r[n]/=t;return this}add(t){return this.clone().add_(t)}add_(t){const r=this.data;for(let n=0;n<r.length;++n)r[n]+=t;return this}sub(t){return this.clone().sub_(t)}sub_(t){const r=this.data;for(let n=0;n<r.length;++n)r[n]-=t;return this}clone(){return new Re(this.type,this.data.slice(),this.dims.slice())}slice(...t){const r=[],n=[];for(let d=0;d<this.dims.length;++d){let h=t[d];if(h==null)n.push([0,this.dims[d]]),r.push(this.dims[d]);else if(typeof h=="number")h=Kt(h,this.dims[d],d),n.push([h,h+1]);else if(Array.isArray(h)&&h.length===2){let[_,p]=h;if(_=_===null?0:Kt(_,this.dims[d],d,!1),p=p===null?this.dims[d]:Kt(p,this.dims[d],d,!1),_>p)throw new Error(`Invalid slice: ${h}`);const w=[Math.max(_,0),Math.min(p,this.dims[d])];n.push(w),r.push(w[1]-w[0])}else throw new Error(`Invalid slice: ${h}`)}const s=n.map(([d,h])=>h-d),a=s.reduce((d,h)=>d*h),o=this.data,i=new o.constructor(a),l=this.stride();let c=!0;for(let d=1;d<s.length;++d)if(n[d][0]!==0||n[d][1]!==this.dims[d]){c=!1;break}if(c){const d=n[0][0]*l[0],h=n[0][1]*l[0];if(ArrayBuffer.isView(o))i.set(o.subarray(d,h));else if(Array.isArray(o)){const _=o.slice(d,h);for(let p=0;p<_.length;++p)i[p]=_[p]}else throw new Error("Unsupported data type for slicing")}else for(let d=0;d<a;++d){let h=0;for(let _=s.length-1,p=d;_>=0;--_){const w=s[_];h+=(p%w+n[_][0])*l[_],p=Math.floor(p/w)}i[d]=o[h]}return new Re(this.type,i,r)}permute(...t){return xT(this,t)}transpose(...t){return this.permute(...t)}sum(t=null,r=!1){return this.norm(1,t,r)}norm(t="fro",r=null,n=!1){if(t==="fro")t=2;else if(typeof t=="string")throw Error(`Unsupported norm: ${t}`);const s=this.data,a=s instanceof BigInt64Array||s instanceof BigUint64Array;if(a&&t!==1)throw Error(`Expected a floating point tensor as input. Got ${this.type}`);let o,i;if(a?(o=(h,_)=>h+_,i=0n):(o=(h,_)=>h+_**t,i=0),r===null){let h=s.reduce(o,i);return t!==1&&(h=h**(1/t)),new Re(this.type,[h],[])}const[l,c,d]=hs(o,this,r,n);if(t!==1)for(let h=0;h<c.length;++h)c[h]=c[h]**(1/t);return new Re(l,c,d)}normalize_(t=2,r=1){r=Kt(r,this.dims.length);const n=this.norm(t,r,!0),s=this.data,a=n.data;for(let o=0;o<s.length;++o){let i=0;for(let l=this.dims.length-1,c=o,d=1;l>=0;--l){const h=this.dims[l];if(l!==r){const _=c%h;i+=_*d,d*=this.dims[l]}c=Math.floor(c/h)}s[o]/=a[i]}return this}normalize(t=2,r=1){return this.clone().normalize_(t,r)}stride(){return mi(this.dims)}squeeze(t=null){return new Re(this.type,this.data,F_(this.dims,t))}squeeze_(t=null){return this.dims=F_(this.dims,t),this}unsqueeze(t){return new Re(this.type,this.data,L_(this.dims,t))}unsqueeze_(t){return this.dims=L_(this.dims,t),this}flatten_(t=0,r=-1){r=(r+this.dims.length)%this.dims.length;let n=this.dims.slice(0,t),s=this.dims.slice(t,r+1),a=this.dims.slice(r+1);return this.dims=[...n,s.reduce((o,i)=>o*i,1),...a],this}flatten(t=0,r=-1){return this.clone().flatten_(t,r)}view(...t){let r=-1;for(let s=0;s<t.length;++s)if(t[s]===-1){if(r!==-1)throw new Error("Only one dimension can be inferred");r=s}const n=this.data;if(r!==-1){const s=t.reduce((a,o,i)=>i!==r?a*o:a,1);t[r]=n.length/s}return new Re(this.type,n,t)}neg_(){const t=this.data;for(let r=0;r<t.length;++r)t[r]=-t[r];return this}neg(){return this.clone().neg_()}gt(t){const r=new Uint8Array(this.data.length),n=this.data;for(let s=0;s<n.length;++s)r[s]=n[s]>t?1:0;return new Re("bool",r,this.dims)}lt(t){const r=new Uint8Array(this.data.length),n=this.data;for(let s=0;s<n.length;++s)r[s]=n[s]<t?1:0;return new Re("bool",r,this.dims)}clamp_(t,r){const n=this.data;for(let s=0;s<n.length;++s)n[s]=Math.min(Math.max(n[s],t),r);return this}clamp(t,r){return this.clone().clamp_(t,r)}round_(){const t=this.data;for(let r=0;r<t.length;++r)t[r]=Math.round(t[r]);return this}round(){return this.clone().round_()}mean(t=null,r=!1){return Jl(this,t,r)}min(t=null,r=!1){if(t===null){const o=hl(this.data)[0];return new Re(this.type,[o],[])}const[n,s,a]=hs((o,i)=>Math.min(o,i),this,t,r,1/0);return new Re(n,s,a)}max(t=null,r=!1){if(t===null){const o=Ue(this.data)[0];return new Re(this.type,[o],[])}const[n,s,a]=hs((o,i)=>Math.max(o,i),this,t,r,-1/0);return new Re(n,s,a)}argmin(t=null,r=!1){if(t!==null)throw new Error("`dim !== null` not yet implemented.");const n=hl(this.data)[1];return new Re("int64",[BigInt(n)],[])}argmax(t=null,r=!1){if(t!==null)throw new Error("`dim !== null` not yet implemented.");const n=Ue(this.data)[1];return new Re("int64",[BigInt(n)],[])}repeat(...t){if(t.length<this.dims.length)throw new Error(`Number of dimensions of repeat dims (${t.length}) cannot be smaller than number of dimensions of tensor (${this.dims.length})`);if(t.every(d=>d===1)){if(t.length===this.dims.length)return this.clone();const d=t.length-this.dims.length,h=Array(d).fill(1).concat(this.dims);return new Re(this.type,this.data.slice(),h)}const r=t.length-this.dims.length,n=Array(r).fill(1).concat(this.dims),s=n.map((d,h)=>d*t[h]),a=s.reduce((d,h)=>d*h,1),o=this.data,i=new o.constructor(a),l=mi(n),c=mi(s);for(let d=0;d<a;++d){let h=d,_=0;for(let p=0;p<s.length;++p){const w=Math.floor(h/c[p]);h=h%c[p];const v=w%n[p];_+=v*l[p]}i[d]=o[_]}return new Re(this.type,i,s)}tile(...t){if(t.length<this.dims.length){const r=this.dims.length-t.length;t=Array(r).fill(1).concat(t)}return this.repeat(...t)}to(t){if(this.type===t)return this;if(!ms.hasOwnProperty(t))throw new Error(`Unsupported type: ${t}`);let r;const n=["int64","uint64"].includes(this.type),s=["int64","uint64"].includes(t);if(n&&!s)r=Number;else if(!n&&s)["float16","float32","float64"].includes(this.type)?r=a=>BigInt(Math.floor(a)):r=BigInt;else if(this.type==="float16"&&t=="float32"&&this.data instanceof Uint16Array)return new Re(t,dT(this.data),this.dims);return new Re(t,ms[t].from(this.data,r),this.dims)}};function MT(e,t){const r=e.length,n=t.reduce((a,o)=>a*o);if(r!==n)throw Error(`cannot reshape array of size ${r} into shape (${t})`);let s=e;for(let a=t.length-1;a>=0;a--)s=s.reduce((o,i)=>{let l=o[o.length-1];return l.length<t[a]?l.push(i):o.push([i]),o},[[]]);return s[0]}function xT(e,t){const[r,n]=sT(e.data,e.dims,t);return new j(e.type,r,n)}function Am(e,[t,r],n="bilinear",s=!1){const a=e.dims.at(-3)??1,o=e.dims.at(-2),i=e.dims.at(-1),l=nT(e.data,[a,o,i],[t,r],n,s);return new j(e.type,l,[a,t,r])}async function Rt(e,{size:t=null,mode:r="bilinear"}={}){if(e.dims.length!==4)throw new Error("`interpolate_4d` currently only supports 4D input.");if(!t)throw new Error("`interpolate_4d` requires a `size` argument.");let n;if(t.length===2)n=[...e.dims.slice(0,2),...t];else if(t.length===3)n=[e.dims[0],...t];else if(t.length===4)n=t;else throw new Error("`size` must be of length 2, 3, or 4.");let s;if(r==="nearest")s=await mn.nearest_interpolate_4d;else if(r==="bilinear")s=await mn.bilinear_interpolate_4d;else if(r==="bicubic")s=await mn.bicubic_interpolate_4d;else throw new Error(`Unsupported mode: ${r}`);const a=new j("int64",new BigInt64Array(n.map(BigInt)),[n.length]);return await s({x:e,s:a})}async function kT(e,t){return await(await mn.matmul)({a:e,b:t})}async function Mn(e,t){const r=await mn.top_k;return t==null?t=e.dims.at(-1):t=Math.min(t,e.dims.at(-1)),await r({x:e,k:new j("int64",[BigInt(t)],[1])})}var ta=e=>new j("int64",e,[e.length]);async function Cm(e,t,r,n,s){return await(await mn.slice)({x:e,s:ta(t),e:ta(r),a:ta(n),t:ta(new Array(n.length).fill(1))})}function TT(e,t){const r=e.data,n=t.data,s=[e.dims[0],e.dims[2]],a=new r.constructor(s[0]*s[1]),[o,i,l]=e.dims;let c=0;for(let d=0;d<o;++d){const h=d*l*i;for(let _=0;_<l;++_){let p=0,w=0;const v=d*i,y=h+_;for(let T=0;T<i;++T){const A=Number(n[v+T]);w+=A,p+=r[y+T*l]*A}const M=p/w;a[c++]=M}}return new j(e.type,a,s)}function F_(e,t){return e=e.slice(),t===null?e=e.filter(r=>r!==1):typeof t=="number"?e[t]===1&&e.splice(t,1):Array.isArray(t)&&(e=e.filter((r,n)=>r!==1||!t.includes(n))),e}function L_(e,t){return t=Kt(t,e.length+1),e=e.slice(),e.splice(t,0,1),e}function Kt(e,t,r=null,n=!0){if(e<-t||e>=t){if(n)throw new Error(`IndexError: index ${e} is out of bounds for dimension${r===null?"":" "+r} with size ${t}`);return e<-t?0:t}return e<0&&(e=(e%t+t)%t),e}function De(e,t=0){t=Kt(t,e[0].dims.length);const r=e[0].dims.slice();r[t]=e.reduce((o,i)=>o+i.dims[t],0);const n=r.reduce((o,i)=>o*i,1),s=new e[0].data.constructor(n),a=e[0].type;if(t===0){let o=0;for(const i of e){const l=i.data;s.set(l,o),o+=l.length}}else{let o=0;for(let i=0;i<e.length;++i){const{data:l,dims:c}=e[i];for(let d=0;d<l.length;++d){let h=0;for(let _=c.length-1,p=d,w=1;_>=0;--_){const v=c[_];let y=p%v;_===t&&(y+=o),h+=y*w,w*=r[_],p=Math.floor(p/v)}s[h]=l[d]}o+=c[t]}}return new j(a,s,r)}function _r(e,t=0){return De(e.map(r=>r.unsqueeze(t)),t)}function hs(e,t,r,n=!1,s=null){const a=t.data,o=t.dims;r=Kt(r,o.length);const i=o.slice();i[r]=1;const l=new a.constructor(a.length/o[r]);s!==null&&l.fill(s);for(let c=0;c<a.length;++c){let d=0;for(let h=o.length-1,_=c,p=1;h>=0;--h){const w=o[h];if(h!==r){const v=_%w;d+=v*p,p*=i[h]}_=Math.floor(_/w)}l[d]=e(l[d],a[c],c,d)}return n||i.splice(r,1),[t.type,l,i]}function ET(e,t=null,r=1,n=!1){const s=e.data,a=e.dims;if(t===null){const p=s.reduce((M,T)=>M+T,0)/s.length,w=Math.sqrt(s.reduce((M,T)=>M+(T-p)**2,0)/(s.length-r)),v=new j(e.type,[p],[]);return[new j(e.type,[w],[]),v]}t=Kt(t,a.length);const o=Jl(e,t,n),i=o.data,[l,c,d]=hs((_,p,w,v)=>_+(p-i[v])**2,e,t,n);for(let _=0;_<c.length;++_)c[_]=Math.sqrt(c[_]/(a[t]-r));return[new j(l,c,d),o]}function Jl(e,t=null,r=!1){const n=e.dims,s=e.data;if(t===null){const l=s.reduce((c,d)=>c+d,0);return new j(e.type,[l/s.length],[])}t=Kt(t,n.length);const[a,o,i]=hs((l,c)=>l+c,e,t,r);if(n[t]!==1)for(let l=0;l<o.length;++l)o[l]/=n[t];return new j(a,o,i)}function mi(e){const t=new Array(e.length);for(let r=e.length-1,n=1;r>=0;--r)t[r]=n,n*=e[r];return t}function Kl(e,t,r,n){const s=e.reduce((a,o)=>a*o,1);return new j(r,new n(s).fill(t),e)}function lt(e,t){let r,n;if(typeof t=="number")r="float32",n=Float32Array;else if(typeof t=="bigint")r="int64",n=BigInt64Array;else if(typeof t=="boolean")r="bool",n=Uint8Array;else throw new Error(`Unsupported data type: ${typeof t}`);return Kl(e,t,r,n)}function pl(e,t){return lt(e.dims,t)}function gt(e){return Kl(e,1n,"int64",BigInt64Array)}function Sm(e){return gt(e.dims)}function Pm(e){return Kl(e,0n,"int64",BigInt64Array)}function Fm(e){return Pm(e.dims)}function AT(e){const t=e.reduce((r,n)=>r*n,1);return new j("float32",Float32Array.from({length:t},()=>Hl.gauss()),e)}function CT(e,t){if(e.dims.length!==2)throw new Error("The tensor must have 2 dimensions");if(e.dims.at(-1)%8!==0)throw new Error("The last dimension of the tensor must be a multiple of 8");if(!["binary","ubinary"].includes(t))throw new Error("The precision must be either 'binary' or 'ubinary'");const r=t==="binary",n=r?"int8":"uint8",s=r?Int8Array:Uint8Array,a=e.data,o=new s(a.length/8);for(let i=0;i<a.length;++i){const l=a[i]>0?1:0,c=Math.floor(i/8),d=i%8;o[c]|=l<<7-d,r&&d===0&&(o[c]-=128)}return new j(n,o,[e.dims[0],e.dims[1]/8])}async function Lm(e){if(!e)throw new Error("modelId is required for get_tokenizer_files");return(await ks(e,"tokenizer_config.json",{})).exists?["tokenizer.json","tokenizer_config.json"]:[]}async function Im(e,t){const r=await Lm(e);return await Promise.all(r.map(n=>nr(e,n,!0,t)))}function Zl(e){const t=e.dims;switch(t.length){case 1:return e.tolist();case 2:if(t[0]!==1)throw new Error("Unable to decode tensor with `batch size !== 1`. Use `tokenizer.batch_decode(...)` for batched inputs.");return e.tolist()[0];default:throw new Error(`Expected tensor to have 1-2 dimensions, got ${t.length}.`)}}var ST=["bos_token","eos_token","unk_token","sep_token","pad_token","cls_token","mask_token"];function PT(e,t,r,n){for(const s of Object.keys(e)){const a=t-e[s].length,o=r(s),i=new Array(a).fill(o);e[s]=n==="right"?er(e[s],i):er(i,e[s])}}function FT(e,t){for(const r of Object.keys(e))e[r].length=t}function zr(e,...t){for(const r of t){if(!Object.hasOwn(e,r))continue;const n=e[r];if(n)if(typeof n=="object"){if(n.__type==="AddedToken")return n.content;throw Error(`Unknown token: ${n}`)}else return n}return null}function LT(e){const t=[];for(const r of e.get_added_tokens_decoder().values())r.special&&t.push(r);return t}var ce=class extends wt{constructor(t,r){super();k(this,"return_token_type_ids",!1);k(this,"padding_side","right");if(this._tokenizerJSON=t,this._tokenizerConfig=r,this._tokenizer=new q1(t,r),this.config=r,this.padding_side=r.padding_side??this.padding_side,this.mask_token=zr(r,"mask_token"),this.mask_token_id=this._tokenizer.token_to_id(this.mask_token),this.pad_token=zr(r,"pad_token","eos_token"),this.pad_token_id=this._tokenizer.token_to_id(this.pad_token),this.sep_token=zr(r,"sep_token"),this.sep_token_id=this._tokenizer.token_to_id(this.sep_token),this.unk_token=zr(r,"unk_token"),this.unk_token_id=this._tokenizer.token_to_id(this.unk_token),this.bos_token=zr(r,"bos_token"),this.bos_token_id=this._tokenizer.token_to_id(this.bos_token),this.eos_token=zr(r,"eos_token"),this.eos_token_id=this._tokenizer.token_to_id(this.eos_token),this.chat_template=r.chat_template??null,Array.isArray(this.chat_template)){const s=Object.create(null);for(const{name:a,template:o}of this.chat_template){if(typeof a!="string"||typeof o!="string")throw new Error('Chat template must be a list of objects with "name" and "template" properties');s[a]=o}this.chat_template=s}this._compiled_template_cache=new Map;const n=LT(this._tokenizer);this.all_special_ids=n.map(s=>s.id),this.all_special_tokens=n.map(s=>s.content)}static async from_pretrained(t,{progress_callback:r=null,config:n=null,cache_dir:s=null,local_files_only:a=!1,revision:o="main"}={}){const i=await Im(t,{progress_callback:r,config:n,cache_dir:s,local_files_only:a,revision:o});return new this(...i)}get_vocab(){return this._tokenizer.get_vocab()}get model_max_length(){return this._tokenizerConfig.model_max_length??1/0}get add_eos_token(){return this._tokenizerConfig.add_eos_token}get add_bos_token(){return this._tokenizerConfig.add_bos_token}convert_tokens_to_ids(t){return typeof t=="string"?this._tokenizer.token_to_id(t):t.map(r=>this._tokenizer.token_to_id(r))}_call(t,r={}){const{text_pair:n=null,add_special_tokens:s=!0,padding:a=!1,return_token_type_ids:o=null}=r;let{truncation:i=null,max_length:l=null}=r;const c=r.return_tensor??!0,d=Array.isArray(t);let h;if(d){if(t.length===0)throw Error("text array must be non-empty");if(n!==null){if(Array.isArray(n)){if(t.length!==n.length)throw Error("text and text_pair must have the same length")}else throw Error("text_pair must also be an array");h=t.map((p,w)=>this._encode_plus(p,{text_pair:n[w],add_special_tokens:s,return_token_type_ids:o}))}else h=t.map(p=>this._encode_plus(p,{add_special_tokens:s,return_token_type_ids:o}))}else{if(t==null)throw Error("text may not be null or undefined");if(Array.isArray(n))throw Error("When specifying `text_pair`, since `text` is a string, `text_pair` must also be a string (i.e., not an array).");h=[this._encode_plus(t,{text_pair:n,add_special_tokens:s,return_token_type_ids:o})]}if(l===null?l=this.model_max_length:i===null&&(a===!0?(ue.warn("`max_length` is ignored when `padding: true` and there is no truncation strategy. To pad to max length, use `padding: 'max_length'`."),l=this.model_max_length):a===!1&&(ue.warn("Truncation was not explicitly activated but `max_length` is provided a specific value, please use `truncation: true` to explicitly truncate examples to max length."),i=!0)),a===!0&&(l=Math.min(Ue(h.map(p=>p.input_ids.length))[0],l??1/0)),l=Math.min(l,this.model_max_length??1/0),a||i)for(let p=0;p<h.length;++p)h[p].input_ids.length!==l&&(h[p].input_ids.length>l?i&&FT(h[p],l):a&&PT(h[p],l,w=>w==="input_ids"?this.pad_token_id:0,this.padding_side));const _={};if(c){if(!(a&&i)&&h.some(w=>{var v;for(const y of Object.keys(w))if(w[y].length!==((v=h[0][y])==null?void 0:v.length))return!0;return!1}))throw Error("Unable to create tensor, you should probably activate truncation and/or padding with 'padding=true' and 'truncation=true' to have batched tensors with the same length.");const p=[h.length,h[0].input_ids.length];for(const w of Object.keys(h[0]))_[w]=new j("int64",BigInt64Array.from(h.flatMap(v=>v[w]).map(BigInt)),p)}else{for(const p of Object.keys(h[0]))_[p]=h.map(w=>w[p]);if(!d)for(const p of Object.keys(_))_[p]=_[p][0]}return _}_encode_text(t){return t===null?null:this._tokenizer.encode(t).tokens}_encode_plus(t,{text_pair:r=null,add_special_tokens:n=!0,return_token_type_ids:s=null}={}){const{ids:a,attention_mask:o,token_type_ids:i}=this._tokenizer.encode(t,{text_pair:r,add_special_tokens:n,return_token_type_ids:s??this.return_token_type_ids});return{input_ids:a,attention_mask:o,...i?{token_type_ids:i}:{}}}tokenize(t,{pair:r=null,add_special_tokens:n=!1}={}){return this._tokenizer.tokenize(t,{text_pair:r,add_special_tokens:n})}encode(t,{text_pair:r=null,add_special_tokens:n=!0,return_token_type_ids:s=null}={}){return this._tokenizer.encode(t,{text_pair:r,add_special_tokens:n,return_token_type_ids:s}).ids}batch_decode(t,r={}){return t instanceof j&&(t=t.tolist()),t.map(n=>this.decode(n,r))}decode(t,r={}){if(t instanceof j&&(t=Zl(t)),!Array.isArray(t)||t.length===0||!LM(t[0]))throw Error("token_ids must be a non-empty array of integers.");return this.decode_single(t,r)}decode_single(t,{skip_special_tokens:r=!1,clean_up_tokenization_spaces:n=null}){return this._tokenizer.decode(t,{skip_special_tokens:r,clean_up_tokenization_spaces:n})}get_chat_template({chat_template:t=null,tools:r=null}={}){if(this.chat_template&&typeof this.chat_template=="object"){const n=this.chat_template;if(t!==null&&Object.hasOwn(n,t))t=n[t];else if(t===null)if(r!==null&&"tool_use"in n)t=n.tool_use;else if("default"in n)t=n.default;else throw Error(`This model has multiple chat templates with no default specified! Please either pass a chat template or the name of the template you wish to use to the 'chat_template' argument. Available template names are ${Object.keys(n).sort()}.`)}else if(t===null)if(this.chat_template)t=this.chat_template;else throw Error("Cannot use apply_chat_template() because tokenizer.chat_template is not set and no template argument was passed! For information about writing templates and setting the tokenizer.chat_template attribute, please see the documentation at https://huggingface.co/docs/transformers/main/en/chat_templating");return t}apply_chat_template(t,r={}){let{tools:n=null,documents:s=null,chat_template:a=null,add_generation_prompt:o=!1,tokenize:i=!0,padding:l=!1,truncation:c=!1,max_length:d=null,return_tensor:h=!0,return_dict:_=!0,tokenizer_kwargs:p={},...w}=r;if(a=this.get_chat_template({chat_template:a,tools:n}),typeof a!="string")throw Error(`chat_template must be a string, but got ${typeof a}`);let v=this._compiled_template_cache.get(a);v===void 0&&(v=new Gk(a),this._compiled_template_cache.set(a,v));const y=Object.create(null);for(const T of ST){const A=zr(this.config,T);A&&(y[T]=A)}const M=v.render({messages:t,add_generation_prompt:o,tools:n,documents:s,...y,...w});if(i){const T=this._call(M,{add_special_tokens:!1,padding:l,truncation:c,max_length:d,return_tensor:h,...p});return _?T:T.input_ids}return M}};function ec(e,t,r,n){if(!("language_codes"in e)||!Array.isArray(e.language_codes))throw new Error("Tokenizer must have `language_codes` attribute set and it should be an array of language ids.");if(!("languageRegex"in e)||!(e.languageRegex instanceof RegExp))throw new Error("Tokenizer must have `languageRegex` attribute set and it should be a regular expression.");if(!("lang_to_token"in e)||typeof e.lang_to_token!="function")throw new Error("Tokenizer must have `lang_to_token` attribute set and it should be a function.");const s=n.src_lang,a=n.tgt_lang;if(!e.language_codes.includes(a))throw new Error(`Target language code "${a}" is not valid. Must be one of: {${e.language_codes.join(", ")}}`);if(s!==void 0){if(!e.language_codes.includes(s))throw new Error(`Source language code "${s}" is not valid. Must be one of: {${e.language_codes.join(", ")}}`);for(const o of e._tokenizer.post_processor.config.single)if("SpecialToken"in o&&e.languageRegex.test(o.SpecialToken.id)){o.SpecialToken.id=e.lang_to_token(s);break}}return n.forced_bos_token_id=e._tokenizer.token_to_id(e.lang_to_token(a)),e._call(t,r)}var Om={};vn(Om,{AlbertTokenizer:()=>IT,AutoTokenizer:()=>Te,BartTokenizer:()=>OT,BertTokenizer:()=>NT,BlenderbotSmallTokenizer:()=>DT,BlenderbotTokenizer:()=>zT,BloomTokenizer:()=>BT,CLIPTokenizer:()=>GT,CamembertTokenizer:()=>RT,CodeGenTokenizer:()=>VT,CodeLlamaTokenizer:()=>$T,CohereAsrTokenizer:()=>jT,CohereTokenizer:()=>UT,ConvBertTokenizer:()=>qT,DebertaTokenizer:()=>HT,DebertaV2Tokenizer:()=>WT,DistilBertTokenizer:()=>QT,ElectraTokenizer:()=>XT,EsmTokenizer:()=>YT,FalconTokenizer:()=>JT,GPT2Tokenizer:()=>eE,GPTNeoXTokenizer:()=>ZT,GemmaTokenizer:()=>KT,HerbertTokenizer:()=>tE,LlamaTokenizer:()=>rE,M2M100Tokenizer:()=>nE,MBart50Tokenizer:()=>aE,MBartTokenizer:()=>Nm,MPNetTokenizer:()=>lE,MarianTokenizer:()=>sE,MgpstrTokenizer:()=>oE,MobileBertTokenizer:()=>iE,NllbTokenizer:()=>cE,NougatTokenizer:()=>uE,PreTrainedTokenizer:()=>ce,Qwen2Tokenizer:()=>dE,RoFormerTokenizer:()=>fE,RobertaTokenizer:()=>hE,SiglipTokenizer:()=>_E,SpeechT5Tokenizer:()=>pE,SqueezeBertTokenizer:()=>mE,T5Tokenizer:()=>gE,TokenizersBackend:()=>ce,VitsTokenizer:()=>vE,Wav2Vec2CTCTokenizer:()=>yE,WhisperTokenizer:()=>TE,XLMRobertaTokenizer:()=>EE,XLMTokenizer:()=>AE});var IT=class extends ce{constructor(){super(...arguments);k(this,"return_token_type_ids",!0)}},OT=class extends ce{},NT=class extends ce{constructor(){super(...arguments);k(this,"return_token_type_ids",!0)}},DT=class extends ce{},zT=class extends ce{},BT=class extends ce{},RT=class extends ce{},GT=class extends ce{},$T=class extends ce{},VT=class extends ce{},UT=class extends ce{},jT=class extends ce{},qT=class extends ce{constructor(){super(...arguments);k(this,"return_token_type_ids",!0)}},WT=class extends ce{constructor(){super(...arguments);k(this,"return_token_type_ids",!0)}},HT=class extends ce{constructor(){super(...arguments);k(this,"return_token_type_ids",!0)}},QT=class extends ce{},XT=class extends ce{constructor(){super(...arguments);k(this,"return_token_type_ids",!0)}},YT=class extends ce{},JT=class extends ce{},KT=class extends ce{},ZT=class extends ce{},eE=class extends ce{},tE=class extends ce{constructor(){super(...arguments);k(this,"return_token_type_ids",!0)}},rE=class extends ce{constructor(){super(...arguments);k(this,"padding_side","left")}},nE=class extends ce{constructor(e,t){super(e,t),this.languageRegex=/^__[a-z]{2,3}__$/,this.language_codes=this.all_special_tokens.filter(r=>this.languageRegex.test(r)).map(r=>r.slice(2,-2)),this.lang_to_token=r=>`__${r}__`}_build_translation_inputs(e,t,r){return ec(this,e,t,r)}},sE=class extends ce{constructor(e,t){super(e,t),this.languageRegex=/^(>>\w+<<)\s*/g,this.supported_language_codes=Array.from(this.get_vocab().keys()).filter(r=>this.languageRegex.test(r)),ue.warn('WARNING: `MarianTokenizer` is not yet supported by Hugging Face\'s "fast" tokenizers library. Therefore, you may experience slightly inaccurate results.')}_encode_text(e){if(e===null)return null;const[t,...r]=e.trim().split(this.languageRegex);if(r.length===0)return super._encode_text(t);if(r.length===2){const[n,s]=r;return this.supported_language_codes.includes(n)||ue.warn(`Unsupported language code "${n}" detected, which may lead to unexpected behavior. Should be one of: ${JSON.stringify(this.supported_language_codes)}`),er([n],super._encode_text(s))}}},Nm=class extends ce{constructor(e,t){super(e,t),this.languageRegex=/^[a-z]{2}_[A-Z]{2}$/,this.language_codes=this.all_special_tokens.filter(r=>this.languageRegex.test(r)).map(r=>r),this.lang_to_token=r=>r}_build_translation_inputs(e,t,r){return ec(this,e,t,r)}},aE=class extends Nm{},oE=class extends ce{},iE=class extends ce{constructor(){super(...arguments);k(this,"return_token_type_ids",!0)}},lE=class extends ce{},cE=class extends ce{constructor(e,t){super(e,t),this.languageRegex=/^[a-z]{3}_[A-Z][a-z]{3}$/,this.language_codes=this.all_special_tokens.filter(r=>this.languageRegex.test(r)),this.lang_to_token=r=>r}_build_translation_inputs(e,t,r){return ec(this,e,t,r)}},uE=class extends ce{},dE=class extends ce{},hE=class extends ce{},fE=class extends ce{constructor(){super(...arguments);k(this,"return_token_type_ids",!0)}},_E=class extends ce{},pE=class extends ce{},mE=class extends ce{constructor(){super(...arguments);k(this,"return_token_type_ids",!0)}},gE=class extends ce{},wE=class extends Vt{decode_chain(e){let t="";for(let r=1;r<e.length;r+=2)t+=e[r];return[t]}},vE=class extends ce{constructor(e,t){super(e,t),this._tokenizer.decoder=new wE({type:"VitsDecoder"})}},yE=class extends ce{},Dm=[["en","english"],["zh","chinese"],["de","german"],["es","spanish"],["ru","russian"],["ko","korean"],["fr","french"],["ja","japanese"],["pt","portuguese"],["tr","turkish"],["pl","polish"],["ca","catalan"],["nl","dutch"],["ar","arabic"],["sv","swedish"],["it","italian"],["id","indonesian"],["hi","hindi"],["fi","finnish"],["vi","vietnamese"],["he","hebrew"],["uk","ukrainian"],["el","greek"],["ms","malay"],["cs","czech"],["ro","romanian"],["da","danish"],["hu","hungarian"],["ta","tamil"],["no","norwegian"],["th","thai"],["ur","urdu"],["hr","croatian"],["bg","bulgarian"],["lt","lithuanian"],["la","latin"],["mi","maori"],["ml","malayalam"],["cy","welsh"],["sk","slovak"],["te","telugu"],["fa","persian"],["lv","latvian"],["bn","bengali"],["sr","serbian"],["az","azerbaijani"],["sl","slovenian"],["kn","kannada"],["et","estonian"],["mk","macedonian"],["br","breton"],["eu","basque"],["is","icelandic"],["hy","armenian"],["ne","nepali"],["mn","mongolian"],["bs","bosnian"],["kk","kazakh"],["sq","albanian"],["sw","swahili"],["gl","galician"],["mr","marathi"],["pa","punjabi"],["si","sinhala"],["km","khmer"],["sn","shona"],["yo","yoruba"],["so","somali"],["af","afrikaans"],["oc","occitan"],["ka","georgian"],["be","belarusian"],["tg","tajik"],["sd","sindhi"],["gu","gujarati"],["am","amharic"],["yi","yiddish"],["lo","lao"],["uz","uzbek"],["fo","faroese"],["ht","haitian creole"],["ps","pashto"],["tk","turkmen"],["nn","nynorsk"],["mt","maltese"],["sa","sanskrit"],["lb","luxembourgish"],["my","myanmar"],["bo","tibetan"],["tl","tagalog"],["mg","malagasy"],["as","assamese"],["tt","tatar"],["haw","hawaiian"],["ln","lingala"],["ha","hausa"],["ba","bashkir"],["jw","javanese"],["su","sundanese"]],Ea=new Map(Dm),bE=new Map([...Dm.map(([e,t])=>[t,e]),["burmese","my"],["valencian","ca"],["flemish","nl"],["haitian","ht"],["letzeburgesch","lb"],["pushto","ps"],["panjabi","pa"],["moldavian","ro"],["moldovan","ro"],["sinhalese","si"],["castilian","es"]]);function ME(e){e=e.toLowerCase();let t=bE.get(e);if(t===void 0){const r=e.match(/^<\|([a-z]{2})\|>$/);if(r&&(e=r[1]),Ea.has(e))t=e;else{const s=e.length===2?Ea.keys():Ea.values();throw new Error(`Language "${e}" is not supported. Must be one of: ${JSON.stringify(Array.from(s))}`)}}return t}var xE="\\p{P}\\u0021-\\u002F\\u003A-\\u0040\\u005B-\\u0060\\u007B-\\u007E",I_=new RegExp(`^[${xE}]+$`,"gu"),kE=.1,TE=class extends ce{get timestamp_begin(){return this._tokenizer.token_to_id("<|notimestamps|>")+1}_decode_asr(e,{return_timestamps:t=!1,return_language:r=!1,time_precision:n=null,force_full_sequences:s=!0}={}){if(n===null)throw Error("Must specify time_precision");let a=null;const o=t==="word";function i(){return{language:a,timestamp:[null,null],text:""}}const l=[];let c=i(),d=0;const h=this.timestamp_begin,p=h+1500;let w=[],v=[],y=!1,M=null;const T=new Set(this.all_special_ids);for(const C of e){const I=C.tokens,x=o?C.token_timestamps:null;let R=null,z=h;if("stride"in C){const[H,D,O]=C.stride;if(d-=D,M=H-O,D&&(z=D/n+h),O)for(let te=I.length-1;te>=0;--te){const W=Number(I[te]);if(W>=h){if(R!==null&&(W-h)*n<M)break;R=W}}}let $=[],Q=[];for(let H=0;H<I.length;++H){const D=Number(I[H]);if(T.has(D)){const O=this.decode([D]),te=Ea.get(O.slice(2,-2));if(te!==void 0){if(a!==null&&te!==a&&!t){w.push($);const W=this.findLongestCommonSequence(w)[0],ee=this.decode(W);c.text=ee,l.push(c),w=[],$=[],c=i()}a=c.language=te}}else if(D>=h&&D<=p){const O=(D-h)*n+d,te=us(O,2);if(R!==null&&D>=R)y=!0;else if(y||w.length>0&&D<z)y=!1;else if(c.timestamp[0]===null)c.timestamp[0]=te;else if(te!==c.timestamp[0]){c.timestamp[1]=te,w.push($),o&&v.push(Q);const[W,ee]=this.findLongestCommonSequence(w,v),G=this.decode(W);if(c.text=G,o&&(c.words=this.collateWordTimestamps(W,ee,a),c.words.length>0&&c.timestamp[1]!==null))for(const L of c.words)L.timestamp[1]>c.timestamp[1]&&c.timestamp[1]>=L.timestamp[0]&&(L.timestamp[1]=c.timestamp[1]);l.push(c),w=[],$=[],v=[],Q=[],c=i()}}else if($.push(D),o){let O=us(x[H]+d,2),te;if(H+1<x.length){te=us(x[H+1]+d,2);const W=this.decode([D]);I_.test(W)&&(te=us(Math.min(O+n,te),2))}else te=null;Q.push([O,te])}}if("stride"in C){const[H,D,O]=C.stride;d+=H-O}$.length>0?(w.push($),o&&v.push(Q)):w.every(H=>H.length===0)&&(c=i(),w=[],$=[],v=[],Q=[])}if(w.length>0){if(s&&t)throw new Error("Whisper did not predict an ending timestamp, which can happen if audio is cut off in the middle of a word. Also make sure WhisperTimeStampLogitsProcessor was used during generation.");const[C,I]=this.findLongestCommonSequence(w,v),x=this.decode(C);c.text=x,o&&(c.words=this.collateWordTimestamps(C,I,a)),l.push(c)}let A=Object.create(null);const S=l.map(C=>C.text).join("");if(t||r){for(let C=0;C<l.length;++C){const I=l[C];t||delete I.timestamp,r||delete I.language}if(o){const C=[];for(const I of l)for(const x of I.words)C.push(x);A={chunks:C}}else A={chunks:l}}return[S,A]}findLongestCommonSequence(e,t=null){let r=e[0],n=r.length,s=[];const a=Array.isArray(t)&&t.length>0;let o=a?[]:null,i=a?t[0]:null;for(let l=1;l<e.length;++l){const c=e[l];let d=0,h=[n,n,0,0];const _=c.length;for(let A=1;A<n+_;++A){const S=Math.max(0,n-A),C=Math.min(n,n+_-A),I=r.slice(S,C),x=Math.max(0,A-n),R=Math.min(_,A),z=c.slice(x,R);if(I.length!==z.length)throw new Error("There is a bug within whisper `decode_asr` function, please report it. Dropping to prevent bad inference.");let $;a?$=I.filter((D,O)=>D===z[O]&&i[S+O][0]-kE<=t[l][x+O][0]).length:$=I.filter((D,O)=>D===z[O]).length;const Q=A/1e4,H=$/A+Q;$>1&&H>d&&(d=H,h=[S,C,x,R])}const[p,w,v,y]=h,M=Math.floor((w+p)/2);let T=Math.floor((y+v)/2);if(a&&d===0&&n>0){const A=i[n-1][0],S=t[l].findIndex(C=>C[0]>=A);T=S===-1?c.length:S}s.push(...r.slice(0,M)),r=c.slice(T),n=r.length,a&&(o.push(...i.slice(0,M)),i=t[l].slice(T))}return s.push(...r),a?(o.push(...i),[s,o]):[s,[]]}collateWordTimestamps(e,t,r){const[n,s,a]=this.combineTokensIntoWords(e,r),o=[];for(let i=0;i<n.length;++i){const l=a[i];o.push({text:n[i],timestamp:[t[l.at(0)][0],t[l.at(-1)][1]]})}return o}combineTokensIntoWords(e,t,r=`"'“¡¿([{-`,n=`"'.。,,!!??::”)]}、`){t=t??"english";let s,a,o;return["chinese","japanese","thai","lao","myanmar"].includes(t)?[s,a,o]=this.splitTokensOnUnicode(e):[s,a,o]=this.splitTokensOnSpaces(e),this.mergePunctuations(s,a,o,r,n)}decode(e,t){let r;return t!=null&&t.decode_with_timestamps?(e instanceof j&&(e=Zl(e)),r=this.decodeWithTimestamps(e,t)):r=super.decode(e,t),r}decodeWithTimestamps(e,t){const r=(t==null?void 0:t.time_precision)??.02,n=this.all_special_ids.at(-1)+1;let s=[[]];for(let a of e)if(a=Number(a),a>=n){const o=((a-n)*r).toFixed(2);s.push(`<|${o}|>`),s.push([])}else s[s.length-1].push(a);return s=s.map(a=>typeof a=="string"?a:super.decode(a,t)),s.join("")}splitTokensOnUnicode(e){const t=this.decode(e,{decode_with_timestamps:!0}),r="�",n=[],s=[],a=[];let o=[],i=[],l=0;for(let c=0;c<e.length;++c){const d=e[c];o.push(d),i.push(c);const h=this.decode(o,{decode_with_timestamps:!0});(!h.includes(r)||t[l+h.indexOf(r)]===r)&&(n.push(h),s.push(o),a.push(i),o=[],i=[],l+=h.length)}return[n,s,a]}splitTokensOnSpaces(e){const[t,r,n]=this.splitTokensOnUnicode(e),s=[],a=[],o=[];for(let i=0;i<t.length;++i){const l=t[i],c=r[i],d=n[i],h=c[0]>=this._tokenizer.token_to_id("<|endoftext|>"),_=l.startsWith(" "),p=l.trim(),w=I_.test(p);if(h||_||w||s.length===0)s.push(l),a.push(c),o.push(d);else{const v=s.length-1;s[v]+=l,a[v].push(...c),o[v].push(...d)}}return[s,a,o]}mergePunctuations(e,t,r,n,s){const a=structuredClone(e),o=structuredClone(t),i=structuredClone(r);let l=a.length-2,c=a.length-1;for(;l>=0;)a[l].startsWith(" ")&&n.includes(a[l].trim())?(a[c]=a[l]+a[c],o[c]=er(o[l],o[c]),i[c]=er(i[l],i[c]),a[l]="",o[l]=[],i[l]=[]):c=l,--l;for(l=0,c=1;c<a.length;)!a[l].endsWith(" ")&&s.includes(a[c])?(a[l]+=a[c],o[l]=er(o[l],o[c]),i[l]=er(i[l],i[c]),a[c]="",o[c]=[],i[c]=[]):l=c,++c;return[a.filter(d=>d),o.filter(d=>d.length>0),i.filter(d=>d.length>0)]}},EE=class extends ce{},AE=class extends ce{constructor(t,r){super(t,r);k(this,"return_token_type_ids",!0);ue.warn('WARNING: `XLMTokenizer` is not yet supported by Hugging Face\'s "fast" tokenizers library. Therefore, you may experience slightly inaccurate results.')}},Te=class{static async from_pretrained(e,{progress_callback:t=null,config:r=null,cache_dir:n=null,local_files_only:s=!1,revision:a="main"}={}){var d;const[o,i]=await Im(e,{progress_callback:t,config:r,cache_dir:n,local_files_only:s,revision:a}),l=((d=i.tokenizer_class)==null?void 0:d.replace(/Fast$/,""))??"PreTrainedTokenizer";let c=Om[l];return c||(ue.warn(`Unknown tokenizer class "${l}", attempting to construct from base class.`),c=ce),new c(o,i)}},Wa="https://github.com/huggingface/transformers.js/issues/new/choose",tc="preprocessor_config.json",gs=tc,zm="processor_config.json",Bm="chat_template.jinja",Yn,Ee=(Yn=class extends wt{constructor(e,t,r){super(),this.config=e,this.components=t,this.chat_template=r}get image_processor(){return this.components.image_processor}get tokenizer(){return this.components.tokenizer}get feature_extractor(){return this.components.feature_extractor}apply_chat_template(e,t={}){if(!this.tokenizer)throw new Error("Unable to apply chat template without a tokenizer.");return this.tokenizer.apply_chat_template(e,{tokenize:!1,chat_template:this.chat_template??void 0,...t})}batch_decode(...e){if(!this.tokenizer)throw new Error("Unable to decode without a tokenizer.");return this.tokenizer.batch_decode(...e)}decode(...e){if(!this.tokenizer)throw new Error("Unable to decode without a tokenizer.");return this.tokenizer.decode(...e)}async _call(e,...t){for(const r of[this.image_processor,this.feature_extractor,this.tokenizer])if(r)return r(e,...t);throw new Error("No image processor, feature extractor, or tokenizer found.")}static async from_pretrained(e,t={}){const[r,n,s]=await Promise.all([this.uses_processor_config?nr(e,zm,!0,t):{},Promise.all(this.classes.filter(a=>a in this).map(async a=>{const o=await this[a].from_pretrained(e,t);return[a.replace(/_class$/,""),o]})).then(Object.fromEntries),this.uses_chat_template_file?Xl(e,Bm,!0,t):null]);return new this(r,n,s)}},k(Yn,"classes",["image_processor_class","tokenizer_class","feature_extractor_class"]),k(Yn,"uses_processor_config",!1),k(Yn,"uses_chat_template_file",!1),Yn),ml={};vn(ml,{ChatterboxProcessor:()=>r2,CohereAsrProcessor:()=>s2,Florence2Processor:()=>aA,Gemma3Processor:()=>oA,Gemma3nProcessor:()=>iA,Gemma4Processor:()=>lA,Glm46VProcessor:()=>cA,GraniteSpeechProcessor:()=>uA,GroundingDinoProcessor:()=>hA,Idefics3Processor:()=>G_,JinaCLIPProcessor:()=>gA,Lfm2VlProcessor:()=>wA,LlavaProcessor:()=>vA,MgpstrProcessor:()=>yA,MoonshineProcessor:()=>bA,OwlViTProcessor:()=>MA,PaliGemmaProcessor:()=>kA,Phi3VProcessor:()=>EA,PixtralProcessor:()=>AA,Processor:()=>Ee,PyAnnoteProcessor:()=>CA,Qwen2VLProcessor:()=>ic,Qwen2_5_VLProcessor:()=>pg,Qwen3VLProcessor:()=>SA,Sam2Processor:()=>gg,Sam2VideoProcessor:()=>PA,SamProcessor:()=>mg,SmolVLMProcessor:()=>G_,SpeechT5Processor:()=>FA,UltravoxProcessor:()=>LA,VLChatProcessor:()=>mA,VoxtralProcessor:()=>DA,VoxtralRealtimeProcessor:()=>RA,Wav2Vec2Processor:()=>GA,Wav2Vec2ProcessorWithLM:()=>$A,WhisperProcessor:()=>VA});var ct=class extends wt{constructor(e){super(),this.config=e}static async from_pretrained(e,t={}){const r=await nr(e,tc,!0,t);return new this(r)}};function st(e,t){var r;if(!(e instanceof Float32Array||e instanceof Float64Array))throw new Error(`${t} expects input to be a Float32Array or a Float64Array, but got ${((r=e==null?void 0:e.constructor)==null?void 0:r.name)??typeof e} instead. If using the feature extractor directly, remember to use \`read_audio(url, sampling_rate)\` to obtain the raw audio data of the file/url.`)}var rc={};vn(rc,{ASTFeatureExtractor:()=>VE,ChatterboxFeatureExtractor:()=>UE,ClapFeatureExtractor:()=>jE,CohereAsrFeatureExtractor:()=>WE,DacFeatureExtractor:()=>jm,EncodecFeatureExtractor:()=>Vm,FeatureExtractor:()=>ct,Gemma3nAudioFeatureExtractor:()=>qm,Gemma4AudioFeatureExtractor:()=>Wm,GraniteSpeechFeatureExtractor:()=>HE,MoonshineFeatureExtractor:()=>QE,ParakeetFeatureExtractor:()=>Um,PyAnnoteFeatureExtractor:()=>Hm,SeamlessM4TFeatureExtractor:()=>XE,SnacFeatureExtractor:()=>YE,SpeechT5FeatureExtractor:()=>JE,VoxtralRealtimeFeatureExtractor:()=>e2,Wav2Vec2FeatureExtractor:()=>KE,WeSpeakerFeatureExtractor:()=>ZE,WhisperFeatureExtractor:()=>t2});var CE=()=>{},SE=CE;async function Rm(e,t){if(_e.IS_BROWSER_ENV){if(_e.IS_WEBWORKER_ENV)throw new Error("Unable to save a file from a Web Worker.");const r=URL.createObjectURL(t),n=document.createElement("a");n.href=r,n.download=e,n.click(),n.remove(),URL.revokeObjectURL(r)}else if(_e.IS_FS_AVAILABLE)t.stream(),xt.createWriteStream(e),await SE();else throw new Error("Unable to save because filesystem is disabled in this environment.")}async function PE(e,t){if(typeof AudioContext>"u")throw Error("Unable to load audio from path/URL since `AudioContext` is not available in your environment. Instead, audio data should be passed directly to the pipeline/processor. For more information and some example code, see https://huggingface.co/docs/transformers.js/guides/node-audio-processing.");const r=await(await ps(e)).arrayBuffer(),n=new AudioContext({sampleRate:t});typeof t>"u"&&ue.warn(`No sampling rate provided, using default of ${n.sampleRate}Hz.`);const s=await n.decodeAudioData(r);let a;if(s.numberOfChannels===2){const o=Math.sqrt(2),i=s.getChannelData(0),l=s.getChannelData(1);a=new Float32Array(i.length);for(let c=0;c<s.length;++c)a[c]=o*(i[c]+l[c])/2}else a=s.getChannelData(0);return a}var FE=PE;function Gm(e,t){if(e<1)return new Float64Array;if(e===1)return new Float64Array([1]);const r=1-t,n=2*Math.PI/(e-1),s=new Float64Array(e);for(let a=0;a<e;++a)s[a]=t-r*Math.cos(a*n);return s}function O_(e){return Gm(e,.5)}function LE(e){return Gm(e,.54)}var IE={htk:e=>2595*Math.log10(1+e/700),kaldi:e=>1127*Math.log(1+e/700),slaney:(e,t=1e3,r=15,n=27/Math.log(6.4))=>e>=t?r+Math.log(e/t)*n:3*e/200};function gi(e,t="htk"){const r=IE[t];if(!r)throw new Error('mel_scale should be one of "htk", "slaney" or "kaldi".');return typeof e=="number"?r(e):e.map(n=>r(n))}var OE={htk:e=>700*(10**(e/2595)-1),kaldi:e=>700*(Math.exp(e/1127)-1),slaney:(e,t=1e3,r=15,n=Math.log(6.4)/27)=>e>=r?t*Math.exp(n*(e-r)):200*e/3};function NE(e,t="htk"){const r=OE[t];if(!r)throw new Error('mel_scale should be one of "htk", "slaney" or "kaldi".');return typeof e=="number"?r(e):e.map(n=>r(n))}function DE(e,t){const r=Float64Array.from({length:t.length-1},(o,i)=>t[i+1]-t[i]),n=Array.from({length:e.length},()=>new Array(t.length));for(let o=0;o<e.length;++o){const i=n[o];for(let l=0;l<t.length;++l)i[l]=t[l]-e[o]}const s=t.length-2,a=Array.from({length:s},()=>new Array(e.length));for(let o=0;o<e.length;++o){const i=n[o];for(let l=0;l<s;++l){const c=-i[l]/r[l],d=i[l+2]/r[l+1];a[l][o]=Math.max(0,Math.min(c,d))}}return a}function N_(e,t,r){const n=(t-e)/(r-1);return Float64Array.from({length:r},(s,a)=>e+n*a)}function tr(e,t,r,n,s,a=null,o="htk",i=!1){if(a!==null&&a!=="slaney")throw new Error('norm must be one of null or "slaney"');if(e<2)throw new Error(`Require num_frequency_bins: ${e} >= 2`);if(r>n)throw new Error(`Require min_frequency: ${r} <= max_frequency: ${n}`);const l=gi(r,o),c=gi(n,o),d=N_(l,c,t+2);let h=NE(d,o),_;if(i){const w=s/((e-1)*2);_=gi(Float64Array.from({length:e},(v,y)=>y*w),o),h=d}else _=N_(0,Math.floor(s/2),e);const p=DE(_,h);if(a!==null&&a==="slaney")for(let w=0;w<t;++w){const v=p[w],y=2/(h[w+2]-h[w]);for(let M=0;M<e;++M)v[M]*=y}return p}function zE(e,t,r){const n=new e.constructor(e.length+t+r),s=e.length-1;for(let a=0;a<e.length;++a)n[t+a]=e[a];for(let a=1;a<=t;++a)n[t-a]=e[Oa(a,s)];for(let a=1;a<=r;++a)n[s+t+a]=e[Oa(s-a,s)];return n}function $m(e,t,r,n,s){if(r<=0)throw new Error("reference must be greater than zero");if(n<=0)throw new Error("min_value must be greater than zero");r=Math.max(n,r);const a=Math.log10(r);for(let o=0;o<e.length;++o)e[o]=t*Math.log10(Math.max(n,e[o])-a);if(s!==null){if(s<=0)throw new Error("db_range must be greater than zero");const o=Ue(e)[0]-s;for(let i=0;i<e.length;++i)e[i]=Math.max(e[i],o)}return e}function BE(e,t=1,r=1e-5,n=null){return $m(e,20,t,r,n)}function RE(e,t=1,r=1e-10,n=null){return $m(e,10,t,r,n)}async function sr(e,t,r,n,{fft_length:s=null,power:a=1,center:o=!0,pad_mode:i="reflect",onesided:l=!0,preemphasis:c=null,preemphasis_htk_flavor:d=!0,mel_filters:h=null,mel_floor:_=1e-10,log_mel:p=null,max_log_mel:w=null,reference:v=1,min_value:y=1e-10,db_range:M=null,remove_dc_offset:T=null,min_num_frames:A=null,max_num_frames:S=null,do_pad:C=!0,transpose:I=!1,mel_offset:x=0,mel_floor_mode:R="clamp"}={}){const z=t.length;if(s===null&&(s=r),r>s)throw Error(`frame_length (${r}) may not be larger than fft_length (${s})`);if(z!==r)throw new Error(`Length of the window (${z}) must equal frame_length (${r})`);if(n<=0)throw new Error("hop_length must be greater than zero");if(a===null&&h!==null)throw new Error("You have provided `mel_filters` but `power` is `None`. Mel spectrogram computation is not yet supported for complex-valued spectrogram. Specify `power` to fix this issue.");if(!d)throw new Error("`preemphasis_htk_flavor=false` is not currently supported.");if(o){const X=Math.floor(r/2);switch(i){case"reflect":{e=zE(e,X,X);break}case"constant":{const J=new e.constructor(e.length+2*X);J.set(e,X),e=J;break}case"semicausal":{const J=new e.constructor(e.length+X);J.set(e,X),e=J;break}default:throw new Error(`pad_mode="${i}" not implemented yet.`)}}let $=Math.floor(1+Math.floor((e.length-r)/n));A!==null&&$<A&&($=A);const Q=l?Math.floor(s/2)+1:s;let H=$,D=$;S!==null&&(S>$?C&&(D=S):D=H=S);const O=new iT(s),te=new Float64Array(s),W=new Float64Array(O.outputBufferSize),ee=new Float32Array(Q*D);for(let X=0;X<H;++X){const J=X*n,me=Math.min(e.length-J,r);me!==r&&te.fill(0,0,r);for(let re=0;re<me;++re)te[re]=e[J+re];if(T){let re=0;for(let Ve=0;Ve<me;++Ve)re+=te[Ve];const Fe=re/me;for(let Ve=0;Ve<me;++Ve)te[Ve]-=Fe}if(c!==null){for(let re=me-1;re>=1;--re)te[re]-=c*te[re-1];te[0]*=1-c}for(let re=0;re<t.length;++re)te[re]*=t[re];O.realTransform(W,te);for(let re=0;re<Q;++re){const Fe=re<<1;ee[re*D+X]=W[Fe]**2+W[Fe+1]**2}}if(a!==null&&a!==2){const X=a/2;for(let J=0;J<ee.length;++J)ee[J]**=X}const G=h.length;let L=await kT(new j("float32",h.flat(),[G,Q]),new j("float32",ee,[Q,D]));I&&(L=L.transpose(1,0));const V=L.data;if(R==="add")for(let X=0;X<V.length;++X)V[X]=x+V[X]+_;else for(let X=0;X<V.length;++X)V[X]=x+Math.max(_,V[X]);if(a!==null&&p!==null){const X=Math.min(V.length,H*G);switch(p){case"log":for(let J=0;J<X;++J)V[J]=Math.log(V[J]);break;case"log10":for(let J=0;J<X;++J)V[J]=Math.log10(V[J]);break;case"log10_max_norm":{for(let re=0;re<X;++re)V[re]=Math.log10(V[re]);const me=(w??Ue(V)[0])-8;for(let re=0;re<X;++re)V[re]=(Math.max(V[re],me)+4)/4;break}case"dB":if(a===1)BE(V,v,y,M);else if(a===2)RE(V,v,y,M);else throw new Error(`Cannot use log_mel option '${p}' with power ${a}`);break;default:throw new Error(`log_mel must be one of null, 'log', 'log10', 'log10_max_norm', or 'dB'. Got '${p}'`)}}return L}function wr(e,t,{periodic:r=!0,frame_length:n=null,center:s=!0}={}){const a=r?e+1:e;let o;switch(t){case"boxcar":o=new Float64Array(a).fill(1);break;case"hann":case"hann_window":o=O_(a);break;case"hamming":o=LE(a);break;case"povey":o=O_(a).map(c=>Math.pow(c,.85));break;default:throw new Error(`Unknown window type ${t}.`)}if(r&&(o=o.subarray(0,e)),n===null||e===n)return o;if(e>n)throw new Error(`Length of the window (${e}) may not be larger than frame_length (${n})`);const i=new Float64Array(n),l=s?Math.floor((n-e)/2):0;return i.set(o,l),i}function GE(e,t){const r=e.reduce((a,o)=>a+o.length,0),n=new ArrayBuffer(44),s=new DataView(n);return ra(s,0,"RIFF"),s.setUint32(4,36+r*4,!0),ra(s,8,"WAVE"),ra(s,12,"fmt "),s.setUint32(16,16,!0),s.setUint16(20,3,!0),s.setUint16(22,1,!0),s.setUint32(24,t,!0),s.setUint32(28,t*4,!0),s.setUint16(32,4,!0),s.setUint16(34,32,!0),ra(s,36,"data"),s.setUint32(40,r*4,!0),new Blob([n,...e.map(a=>a.buffer)],{type:"audio/wav"})}function ra(e,t,r){for(let n=0;n<r.length;++n)e.setUint8(t+n,r.charCodeAt(n))}var $E=class{constructor(e,t){this.audio=e,this.sampling_rate=t}get data(){if(Array.isArray(this.audio)){if(this.audio.length===0)return new Float32Array(0);if(this.audio.length===1)return this.audio[0];const e=this.audio.reduce((n,s)=>n+s.length,0),t=new Float32Array(e);let r=0;for(const n of this.audio)t.set(n,r),r+=n.length;return t}else return this.audio}toBlob(){let e=this.audio;return e instanceof Float32Array&&(e=[e]),GE(e,this.sampling_rate)}async save(e){return Rm(e,this.toBlob())}},VE=class extends ct{constructor(e){super(e);const t=this.config.sampling_rate,r=tr(257,this.config.num_mel_bins,20,Math.floor(t/2),t,null,"kaldi",!0);this.mel_filters=r,this.window=wr(400,"hann",{periodic:!1}),this.mean=this.config.mean,this.std=this.config.std}async _extract_fbank_features(e,t){return sr(e,this.window,400,160,{fft_length:512,power:2,center:!1,preemphasis:.97,mel_filters:this.mel_filters,log_mel:"log",mel_floor:1192092955078125e-22,remove_dc_offset:!0,max_num_frames:t,transpose:!0})}async _call(e){st(e,"ASTFeatureExtractor");const t=await this._extract_fbank_features(e,this.config.max_length);if(this.config.do_normalize){const r=this.std*2,n=t.data;for(let s=0;s<n.length;++s)n[s]=(n[s]-this.mean)/r}return{input_values:t.unsqueeze_(0)}}},Vm=class extends ct{async _call(e){st(e,"EncodecFeatureExtractor"),e instanceof Float64Array&&(e=new Float32Array(e));const t=this.config.feature_size;if(e.length%t!==0)throw new Error(`The length of the audio data must be a multiple of the number of channels (${t}).`);const r=[1,t,e.length/t];return{input_values:new j("float32",e,r)}}},UE=class extends ct{async _call(e){st(e,"ChatterboxFeatureExtractor"),e instanceof Float64Array&&(e=new Float32Array(e));const t=[1,e.length];return{input_values:new j("float32",e,t)}}},jE=class extends ct{constructor(e){super(e),this.mel_filters=tr(this.config.nb_frequency_bins,this.config.feature_size,this.config.frequency_min,this.config.frequency_max,this.config.sampling_rate,null,"htk"),this.mel_filters_slaney=tr(this.config.nb_frequency_bins,this.config.feature_size,this.config.frequency_min,this.config.frequency_max,this.config.sampling_rate,"slaney","slaney"),this.window=wr(this.config.fft_window_size,"hann")}async _get_input_mel(e,t,r,n){let s;const a=e.length-t;if(a>0)if(r==="rand_trunc"){const o=Math.floor(Hl.random()*(a+1));e=e.subarray(o,o+t),s=await this._extract_fbank_features(e,this.mel_filters_slaney,this.config.nb_max_samples)}else throw new Error(`Truncation strategy "${r}" not implemented`);else{if(a<0){let o=new Float64Array(t);if(o.set(e),n==="repeat")for(let i=e.length;i<t;i+=e.length)o.set(e.subarray(0,Math.min(e.length,t-i)),i);else if(n==="repeatpad")for(let i=e.length;i<-a;i+=e.length)o.set(e,i);e=o}if(r==="fusion")throw new Error(`Truncation strategy "${r}" not implemented`);s=await this._extract_fbank_features(e,this.mel_filters_slaney,this.config.nb_max_samples)}return s.unsqueeze_(0)}async _extract_fbank_features(e,t,r=null){return sr(e,this.window,this.config.fft_window_size,this.config.hop_length,{power:2,mel_filters:t,log_mel:"dB",max_num_frames:r,do_pad:!1,transpose:!0})}async _call(e,{max_length:t=null}={}){return st(e,"ClapFeatureExtractor"),{input_features:(await this._get_input_mel(e,t??this.config.nb_max_samples,this.config.truncation,this.config.padding)).unsqueeze_(0)}}},qE=1e-5,Um=class extends ct{constructor(e){var n;super(e),(n=this.config).mel_filters??(n.mel_filters=tr(Math.floor(1+this.config.n_fft/2),this.config.feature_size,0,this.config.sampling_rate/2,this.config.sampling_rate,"slaney","slaney"));const t=wr(this.config.win_length,"hann",{periodic:!1});this.window=new Float64Array(this.config.n_fft);const r=Math.floor((this.config.n_fft-this.config.win_length)/2);this.window.set(t,r)}async _extract_fbank_features(e){const t=this.config.preemphasis;e=new Float64Array(e);for(let n=e.length-1;n>=1;--n)e[n]-=t*e[n-1];return await sr(e,this.window,this.window.length,this.config.hop_length,{fft_length:this.config.n_fft,power:2,mel_filters:this.config.mel_filters,log_mel:"log",mel_floor:-1/0,pad_mode:"constant",center:!0,transpose:!0,mel_offset:2**-24})}async _call(e){st(e,"ParakeetFeatureExtractor");const t=await this._extract_fbank_features(e),r=Math.floor((e.length+Math.floor(this.config.n_fft/2)*2-this.config.n_fft)/this.config.hop_length),n=t.data;n.fill(0,r*t.dims[1]);const[s,a]=t.dims,o=new Float64Array(a),i=new Float64Array(a);for(let d=0;d<r;++d){const h=d*a;for(let _=0;_<a;++_){const p=n[h+_];o[_]+=p,i[_]+=p*p}}const l=r>1?r-1:1;for(let d=0;d<a;++d){const h=o[d]/r,_=(i[d]-r*h*h)/l,w=1/(Math.sqrt(_)+qE);for(let v=0;v<r;++v){const y=v*a+d;n[y]=(n[y]-h)*w}}const c=new BigInt64Array(s);return c.fill(1n,0,r),{input_features:t.unsqueeze_(0),attention_mask:new j("int64",c,[1,s])}}},WE=class extends Um{_apply_dither(e){const t=this.config.dither??0;if(t<=0)return e;const r=new qa(e.length);for(let n=0;n<e.length;++n)e[n]+=t*r.gauss();return e}split_audio(e){const t=this.config.max_audio_clip_s??35,r=this.config.overlap_chunk_second??5,n=this.config.min_energy_window_samples??1600,s=this.config.sampling_rate,a=Math.max(1,Math.round(t*s)),o=Math.max(1,Math.round(r*s));if(e.length<=a)return[e];const i=[];let l=0;const c=e.length;for(;l<c;){if(l+a>=c){i.push(e.slice(l,c));break}const d=Math.max(l,l+a-o),h=Math.min(l+a,c);let _;h<=d?_=l+a:_=this._find_split_point_energy(e,d,h,n),_=Math.max(l+1,Math.min(_,c)),i.push(e.slice(l,_)),l=_}return i}_find_split_point_energy(e,t,r,n){const s=r-t;if(s<=n)return Math.floor((t+r)/2);let a=1/0,o=t;const i=s-n;for(let l=0;l<=i;l+=n){let c=0;for(let d=0;d<n;++d){const h=e[t+l+d];c+=h*h}c=Math.sqrt(c/n),c<a&&(a=c,o=t+l)}return o}async _call(e){st(e,"CohereAsrFeatureExtractor");const t=new Float64Array(e);return this._apply_dither(t),super._call(t)}},jm=class extends Vm{},qm=class extends ct{constructor(e){super(e);const{fft_length:t,feature_size:r,min_frequency:n,max_frequency:s,sampling_rate:a,frame_length:o}=this.config,i=tr(Math.floor(1+t/2),r,n,s,a,null,"htk",!1);this.mel_filters=i,this.window=wr(o,"hann")}async _extract_fbank_features(e,t){return sr(e,this.window,this.config.frame_length,this.config.hop_length,{fft_length:this.config.fft_length,center:!1,onesided:!0,preemphasis:this.config.preemphasis,preemphasis_htk_flavor:this.config.preemphasis_htk_flavor,mel_filters:this.mel_filters,log_mel:"log",mel_floor:this.config.mel_floor,remove_dc_offset:!1,transpose:!0})}async _call(e,{max_length:t=48e4,truncation:r=!0,padding:n=!0,pad_to_multiple_of:s=128}={}){if(st(e,"Gemma3nAudioFeatureExtractor"),r&&e.length>t&&(e=e.slice(0,t)),n&&e.length%s!==0){const i=s-e.length%s,l=new Float64Array(e.length+i);l.set(e),this.config.padding_value!==0&&l.fill(this.config.padding_value,e.length),e=l}const a=await this._extract_fbank_features(e,this.config.max_length),o=lt([1,a.dims[0]],!0);return{input_features:a.unsqueeze_(0),input_features_mask:o}}},Wm=class extends qm{async _extract_fbank_features(e,t){const{frame_length:r,hop_length:n,fft_length:s}=this.config,a=Math.floor(r/2),o=Math.floor((e.length+a-(r+1))/n)+1;return sr(e,this.window,r,n,{fft_length:s,center:!0,pad_mode:"semicausal",onesided:!0,preemphasis:this.config.preemphasis,preemphasis_htk_flavor:this.config.preemphasis_htk_flavor,mel_filters:this.mel_filters,log_mel:"log",mel_floor:this.config.mel_floor,mel_floor_mode:"add",remove_dc_offset:!1,transpose:!0,max_num_frames:o})}async _call(e,t={}){st(e,"Gemma4AudioFeatureExtractor");const r=e.length,n=await super._call(e,t),{input_features:s}=n,[,a,o]=s.dims,{frame_length:i,hop_length:l}=this.config,c=Math.floor(i/2),d=i+1,h=new Uint8Array(r+c+(t.pad_to_multiple_of??128));h.fill(1,c,c+r);const _=new Uint8Array(a);for(let w=0;w<a;++w)_[w]=h[w*l+d-1]?1:0;const p=s.data;for(let w=0;w<a;++w)_[w]||p.fill(0,w*o,(w+1)*o);return n.input_features_mask=new j("bool",_,[1,a]),n}},HE=class extends ct{constructor(e){super(e);const{n_fft:t,win_length:r,n_mels:n,sample_rate:s}=e.melspec_kwargs;this.mel_filters=tr(Math.floor(1+t/2),n,0,s/2,s,null,"htk");const a=wr(r,"hann");this.window=new Float64Array(t);const o=Math.floor((t-r)/2);this.window.set(a,o)}async _call(e){st(e,"GraniteSpeechFeatureExtractor");const{n_fft:t,hop_length:r,n_mels:n}=this.config.melspec_kwargs,s=1+Math.floor((e.length-1)/r),a=s-s%2;return{input_features:(await sr(e,this.window,t,r,{power:2,mel_filters:this.mel_filters,log_mel:"log10_max_norm",transpose:!0,max_num_frames:a,do_pad:!1})).view(-1,2*n).unsqueeze_(0)}}},QE=class extends ct{async _call(e){st(e,"MoonshineFeatureExtractor"),e instanceof Float64Array&&(e=new Float32Array(e));const t=[1,e.length];return{input_values:new j("float32",e,t)}}},Hm=class extends ct{async _call(e){st(e,"PyAnnoteFeatureExtractor"),e instanceof Float64Array&&(e=new Float32Array(e));const t=[1,1,e.length];return{input_values:new j("float32",e,t)}}samples_to_frames(e){return(e-this.config.offset)/this.config.step}post_process_speaker_diarization(e,t){const r=t/this.samples_to_frames(t)/this.config.sampling_rate,n=[];for(const s of e.tolist()){const a=[];let o=-1;for(let i=0;i<s.length;++i){const l=nt(s[i]),[c,d]=Ue(l),[h,_]=[i,i+1];d!==o?(o=d,a.push({id:d,start:h,end:_,score:c})):(a.at(-1).end=_,a.at(-1).score+=c)}n.push(a.map(({id:i,start:l,end:c,score:d})=>({id:i,start:l*r,end:c*r,confidence:d/(c-l)})))}return n}},XE=class extends ct{constructor(e){super(e);const t=this.config.sampling_rate,r=tr(257,this.config.num_mel_bins,20,Math.floor(t/2),t,null,"kaldi",!0);this.mel_filters=r,this.window=wr(400,"povey",{periodic:!1})}async _extract_fbank_features(e,t){return e=e.map(r=>r*32768),sr(e,this.window,400,160,{fft_length:512,power:2,center:!1,preemphasis:.97,mel_filters:this.mel_filters,log_mel:"log",mel_floor:1192092955078125e-22,remove_dc_offset:!0,max_num_frames:t,transpose:!0})}async _call(e,{padding:t=!0,pad_to_multiple_of:r=2,do_normalize_per_mel_bins:n=!0,return_attention_mask:s=!0}={}){st(e,"SeamlessM4TFeatureExtractor");let a=await this._extract_fbank_features(e,this.config.max_length);if(n){const[p,w]=a.dims,v=a.data;for(let y=0;y<w;++y){let M=0;for(let C=0;C<p;++C)M+=v[C*w+y];const T=M/p;let A=0;for(let C=0;C<p;++C)A+=(v[C*w+y]-T)**2;A/=p-1;const S=Math.sqrt(A+1e-7);for(let C=0;C<p;++C){const I=C*w+y;v[I]=(v[I]-T)/S}}}let o;if(t){const[p,w]=a.dims,v=a.data,y=p%r;if(y>0){const M=new Float32Array(w*(p+y));M.set(v),M.fill(this.config.padding_value,v.length);const T=p+y;a=new j(a.type,M,[T,w]),s&&(o=new j("int64",new BigInt64Array(T),[1,T]),o.data.fill(1n,0,p))}}const[i,l]=a.dims,c=this.config.stride;if(i%c!==0)throw new Error(`The number of frames (${i}) must be a multiple of the stride (${c}).`);const h=a.view(1,Math.floor(i/c),l*c),_={input_features:h};if(s){const p=h.dims[1],w=new BigInt64Array(p);if(o){const v=o.data;for(let y=1,M=0;y<i;y+=c,++M)w[M]=v[y]}else w.fill(1n);_.attention_mask=new j("int64",w,[1,p])}return _}},YE=class extends jm{},JE=class extends ct{},KE=class extends ct{_zero_mean_unit_var_norm(e){const r=e.reduce((s,a)=>s+a,0)/e.length,n=e.reduce((s,a)=>s+(a-r)**2,0)/e.length;return e.map(s=>(s-r)/Math.sqrt(n+1e-7))}async _call(e){st(e,"Wav2Vec2FeatureExtractor"),e instanceof Float64Array&&(e=new Float32Array(e));let t=e;this.config.do_normalize&&(t=this._zero_mean_unit_var_norm(t));const r=[1,t.length];return{input_values:new j("float32",t,r),attention_mask:new j("int64",new BigInt64Array(t.length).fill(1n),r)}}},ZE=class extends ct{constructor(e){super(e);const t=this.config.sampling_rate,r=tr(257,this.config.num_mel_bins,20,Math.floor(t/2),t,null,"kaldi",!0);this.mel_filters=r,this.window=wr(400,"hamming",{periodic:!1}),this.min_num_frames=this.config.min_num_frames}async _extract_fbank_features(e){return e=e.map(t=>t*32768),sr(e,this.window,400,160,{fft_length:512,power:2,center:!1,preemphasis:.97,mel_filters:this.mel_filters,log_mel:"log",mel_floor:1192092955078125e-22,remove_dc_offset:!0,transpose:!0,min_num_frames:this.min_num_frames})}async _call(e){st(e,"WeSpeakerFeatureExtractor");const t=(await this._extract_fbank_features(e)).unsqueeze_(0);if(this.config.fbank_centering_span===null){const r=t.mean(1).data,n=t.data,[s,a,o]=t.dims;for(let i=0;i<s;++i){const l=i*a*o,c=i*o;for(let d=0;d<a;++d){const h=l+d*o;for(let _=0;_<o;++_)n[h+_]-=r[c+_]}}}return{input_features:t}}},e2=class extends ct{constructor(e){var t;super(e),(t=this.config).mel_filters??(t.mel_filters=tr(Math.floor(1+this.config.n_fft/2),this.config.feature_size,0,8e3,this.config.sampling_rate,"slaney","slaney")),this.window=wr(this.config.n_fft,"hann")}async _extract_fbank_features(e,{center:t=!0}={}){const{n_fft:r,hop_length:n,mel_filters:s,global_log_mel_max:a}=this.config,o=Math.floor(t?e.length/n:(e.length-r)/n);return await sr(e,this.window,r,n,{power:2,mel_filters:s,log_mel:"log10_max_norm",max_log_mel:a,center:t,max_num_frames:o,do_pad:!1})}async _call(e,{center:t=!0}={}){return st(e,"VoxtralRealtimeFeatureExtractor"),{input_features:(await this._extract_fbank_features(e,{center:t})).unsqueeze_(0)}}},t2=class extends ct{constructor(e){var t;super(e),(t=this.config).mel_filters??(t.mel_filters=tr(Math.floor(1+this.config.n_fft/2),this.config.feature_size,0,8e3,this.config.sampling_rate,"slaney","slaney")),this.window=wr(this.config.n_fft,"hann")}async _extract_fbank_features(e){return await sr(e,this.window,this.config.n_fft,this.config.hop_length,{power:2,mel_filters:this.config.mel_filters,log_mel:"log10_max_norm",max_num_frames:Math.min(Math.floor(e.length/this.config.hop_length),this.config.nb_max_frames)})}async _call(e,{max_length:t=null}={}){st(e,"WhisperFeatureExtractor");let r;const n=t??this.config.n_samples;return e.length>n?(e.length>this.config.n_samples&&ue.warn("Attempting to extract features for audio longer than 30 seconds. If using a pipeline to extract transcript from a long audio clip, remember to specify `chunk_length_s` and/or `stride_length_s`."),r=e.slice(0,n)):(r=new Float32Array(n),r.set(e)),{input_features:(await this._extract_fbank_features(r)).unsqueeze_(0)}}},Lt=class{static async from_pretrained(e,t={}){const r=await nr(e,tc,!0,t),n=r.feature_extractor_type,s=rc[n];if(!s)throw new Error(`Unknown feature_extractor_type: '${n}'. Please report this at ${Wa}.`);return new s(r)}},ia,r2=(ia=class extends Ee{async _call(e,t=null){const r=this.tokenizer(e),n=t?await this.feature_extractor(t):{};return{...r,...n}}},k(ia,"tokenizer_class",Te),k(ia,"feature_extractor_class",Lt),ia),n2=new Set(["ja","zh"]),Jn,s2=(Jn=class extends Ee{get_decoder_prompt_ids(e="en"){const t=["▁","<|startofcontext|>","<|startoftranscript|>","<|emo:undefined|>",`<|${e}|>`,`<|${e}|>`,"<|pnc|>","<|noitn|>","<|notimestamp|>","<|nodiarize|>"];return this.tokenizer.convert_tokens_to_ids(t)}static join_chunks(e,t="en"){const r=e.filter(a=>a&&a.trim());if(r.length===0)return"";const n=n2.has(t)?"":" ";return[r[0].trimEnd(),...r.slice(1).map(a=>a.trim())].join(n)}async _call(e){return await this.feature_extractor(e)}},k(Jn,"tokenizer_class",Te),k(Jn,"feature_extractor_class",Lt),k(Jn,"uses_processor_config",!0),Jn),gl={},Gr,Qm,Er;if(_e.IS_WEB_ENV)Gr=(e,t)=>{if(!self.OffscreenCanvas)throw new Error("OffscreenCanvas not supported by this environment.");return new self.OffscreenCanvas(e,t)},Er=self.createImageBitmap,Qm=self.ImageData;else if(gl)Er=async e=>{const r=(await e.metadata()).channels,{data:n,info:s}=await e.rotate().raw().toBuffer({resolveWithObject:!0}),a=new Gt(new Uint8ClampedArray(n),s.width,s.height,s.channels);return r!==void 0&&r!==s.channels&&a.convert(r),a};else throw new Error("Unable to load image processing library.");var a2={0:"nearest",1:"lanczos",2:"bilinear",3:"bicubic",4:"box",5:"hamming"},o2=new Map([["png","image/png"],["jpg","image/jpeg"],["jpeg","image/jpeg"],["gif","image/gif"]]),Gt=class Jt{constructor(t,r,n,s){this.data=t,this.width=r,this.height=n,this.channels=s}get size(){return[this.width,this.height]}static async read(t){if(t instanceof Jt)return t;if(typeof t=="string"||t instanceof URL)return await this.fromURL(t);if(t instanceof Blob)return await this.fromBlob(t);if(typeof HTMLCanvasElement<"u"&&t instanceof HTMLCanvasElement||typeof OffscreenCanvas<"u"&&t instanceof OffscreenCanvas)return this.fromCanvas(t);throw new Error(`Unsupported input type: ${typeof t}`)}static fromCanvas(t){if(!_e.IS_WEB_ENV)throw new Error("fromCanvas() is only supported in browser environments.");const n=t.getContext("2d").getImageData(0,0,t.width,t.height).data;return new Jt(n,t.width,t.height,4)}static async fromURL(t){const r=await ps(t);if(r.status!==200)throw new Error(`Unable to read image from "${t}" (${r.status} ${r.statusText})`);const n=await r.blob();return this.fromBlob(n)}static async fromBlob(t){if(_e.IS_WEB_ENV){const r=await Er(t),n=Gr(r.width,r.height).getContext("2d");return n.drawImage(r,0,0),new this(n.getImageData(0,0,r.width,r.height).data,r.width,r.height,4)}else{const r=gl(await t.arrayBuffer());return await Er(r)}}static fromTensor(t,r="CHW"){if(t.dims.length!==3)throw new Error(`Tensor should have 3 dimensions, but has ${t.dims.length} dimensions.`);if(r==="CHW")t=t.transpose(1,2,0);else if(r!=="HWC")throw new Error(`Unsupported channel format: ${r}`);if(!(t.data instanceof Uint8ClampedArray||t.data instanceof Uint8Array))throw new Error(`Unsupported tensor type: ${t.type}`);switch(t.dims[2]){case 1:case 2:case 3:case 4:return new Jt(t.data,t.dims[1],t.dims[0],t.dims[2]);default:throw new Error(`Unsupported number of channels: ${t.dims[2]}`)}}grayscale(){if(this.channels===1)return this;const t=new Uint8ClampedArray(this.width*this.height*1);switch(this.channels){case 3:case 4:for(let r=0,n=0;r<this.data.length;r+=this.channels){const s=this.data[r],a=this.data[r+1],o=this.data[r+2];t[n++]=Math.round(.2989*s+.587*a+.114*o)}break;default:throw new Error(`Conversion failed due to unsupported number of channels: ${this.channels}`)}return this._update(t,this.width,this.height,1)}rgb(){if(this.channels===3)return this;const t=new Uint8ClampedArray(this.width*this.height*3);switch(this.channels){case 1:for(let r=0,n=0;r<this.data.length;++r)t[n++]=this.data[r],t[n++]=this.data[r],t[n++]=this.data[r];break;case 4:for(let r=0,n=0;r<this.data.length;r+=4)t[n++]=this.data[r],t[n++]=this.data[r+1],t[n++]=this.data[r+2];break;default:throw new Error(`Conversion failed due to unsupported number of channels: ${this.channels}`)}return this._update(t,this.width,this.height,3)}rgba(){if(this.channels===4)return this;const t=new Uint8ClampedArray(this.width*this.height*4);switch(this.channels){case 1:for(let r=0,n=0;r<this.data.length;++r)t[n++]=this.data[r],t[n++]=this.data[r],t[n++]=this.data[r],t[n++]=255;break;case 3:for(let r=0,n=0;r<this.data.length;r+=3)t[n++]=this.data[r],t[n++]=this.data[r+1],t[n++]=this.data[r+2],t[n++]=255;break;default:throw new Error(`Conversion failed due to unsupported number of channels: ${this.channels}`)}return this._update(t,this.width,this.height,4)}putAlpha(t){if(t.width!==this.width||t.height!==this.height)throw new Error(`Expected mask size to be ${this.width}x${this.height}, but got ${t.width}x${t.height}`);if(t.channels!==1)throw new Error(`Expected mask to have 1 channel, but got ${t.channels}`);const r=this.data,n=t.data,s=this.width*this.height;if(this.channels===3){const a=new Uint8ClampedArray(s*4);for(let o=0,i=0,l=0;o<s;++o)a[l++]=r[i++],a[l++]=r[i++],a[l++]=r[i++],a[l++]=n[o];return this._update(a,this.width,this.height,4)}else if(this.channels===4){for(let a=0;a<s;++a)r[4*a+3]=n[a];return this}throw new Error(`Expected image to have 3 or 4 channels, but got ${this.channels}`)}async resize(t,r,{resample:n=2}={}){if(this.width===t&&this.height===r)return this;let s=a2[n]??n;const a=t_(t),o=t_(r);if(a&&o)return this;if(a?t=r/this.height*this.width:o&&(r=t/this.width*this.height),_e.IS_WEB_ENV){const i=this.channels,l=this.toCanvas(),c=Gr(t,r).getContext("2d");return c.drawImage(l,0,0,t,r),new Jt(c.getImageData(0,0,t,r).data,t,r,4).convert(i)}else{let i=this.toSharp();switch(s){case"box":case"hamming":(s==="box"||s==="hamming")&&(ue.warn(`Resampling method ${s} is not yet supported. Using bilinear instead.`),s="bilinear");case"nearest":case"bilinear":case"bicubic":i=i.affine([t/this.width,0,0,r/this.height],{interpolator:s});break;case"lanczos":i=i.resize({width:t,height:r,fit:"fill",kernel:"lanczos3"});break;default:throw new Error(`Resampling method ${s} is not supported.`)}return await Er(i)}}async pad([t,r,n,s]){if(t=Math.max(t,0),r=Math.max(r,0),n=Math.max(n,0),s=Math.max(s,0),t===0&&r===0&&n===0&&s===0)return this;if(_e.IS_WEB_ENV){const a=this.channels,o=this.toCanvas(),i=this.width+t+r,l=this.height+n+s,c=Gr(i,l).getContext("2d");return c.drawImage(o,0,0,this.width,this.height,t,n,this.width,this.height),new Jt(c.getImageData(0,0,i,l).data,i,l,4).convert(a)}else{const a=this.toSharp().extend({left:t,right:r,top:n,bottom:s});return await Er(a)}}async crop([t,r,n,s]){if(t=Math.max(t,0),r=Math.max(r,0),n=Math.min(n,this.width-1),s=Math.min(s,this.height-1),t===0&&r===0&&n===this.width-1&&s===this.height-1)return this;const a=n-t+1,o=s-r+1;if(_e.IS_WEB_ENV){const i=this.channels,l=this.toCanvas(),c=Gr(a,o).getContext("2d");return c.drawImage(l,t,r,a,o,0,0,a,o),new Jt(c.getImageData(0,0,a,o).data,a,o,4).convert(i)}else{const i=this.toSharp().extract({left:t,top:r,width:a,height:o});return await Er(i)}}async center_crop(t,r){if(this.width===t&&this.height===r)return this;const n=(this.width-t)/2,s=(this.height-r)/2;if(_e.IS_WEB_ENV){const a=this.channels,o=this.toCanvas(),i=Gr(t,r).getContext("2d");let l=0,c=0,d=0,h=0;return n>=0?l=n:d=-n,s>=0?c=s:h=-s,i.drawImage(o,l,c,t,r,d,h,t,r),new Jt(i.getImageData(0,0,t,r).data,t,r,4).convert(a)}else{let a=this.toSharp();if(n>=0&&s>=0)a=a.extract({left:Math.floor(n),top:Math.floor(s),width:t,height:r});else if(n<=0&&s<=0){const o=Math.floor(-s),i=Math.floor(-n);a=a.extend({top:o,left:i,right:t-this.width-i,bottom:r-this.height-o})}else{let o=[0,0],i=0;s<0?(o[0]=Math.floor(-s),o[1]=r-this.height-o[0]):i=Math.floor(s);let l=[0,0],c=0;n<0?(l[0]=Math.floor(-n),l[1]=t-this.width-l[0]):c=Math.floor(n),a=a.extend({top:o[0],bottom:o[1],left:l[0],right:l[1]}).extract({left:c,top:i,width:t,height:r})}return await Er(a)}}async toBlob(t="image/png",r=1){if(!_e.IS_WEB_ENV)throw new Error("toBlob() is only supported in browser environments.");return await this.toCanvas().convertToBlob({type:t,quality:r})}toTensor(t="CHW"){let r=new j("uint8",new Uint8Array(this.data),[this.height,this.width,this.channels]);if(t!=="HWC")if(t==="CHW")r=r.permute(2,0,1);else throw new Error(`Unsupported channel format: ${t}`);return r}toCanvas(){if(!_e.IS_WEB_ENV)throw new Error("toCanvas() is only supported in browser environments.");const t=this.clone().rgba(),r=Gr(t.width,t.height),n=new Qm(t.data,t.width,t.height);return r.getContext("2d").putImageData(n,0,0),r}split(){const{data:t,width:r,height:n,channels:s}=this,a=t.constructor,o=t.length/s,i=Array.from({length:s},()=>new a(o));for(let l=0;l<o;++l){const c=s*l;for(let d=0;d<s;++d)i[d][l]=t[c+d]}return i.map(l=>new Jt(l,r,n,1))}_update(t,r,n,s=null){return this.data=t,this.width=r,this.height=n,s!==null&&(this.channels=s),this}clone(){return new Jt(this.data.slice(),this.width,this.height,this.channels)}convert(t){if(this.channels===t)return this;switch(t){case 1:this.grayscale();break;case 3:this.rgb();break;case 4:this.rgba();break;default:throw new Error(`Conversion failed due to unsupported number of channels: ${this.channels}`)}return this}async save(t){if(_e.IS_WEB_ENV){if(_e.IS_WEBWORKER_ENV)throw new Error("Unable to save an image from a Web Worker.");const r=t.split(".").pop().toLowerCase(),n=o2.get(r)??"image/png",s=await this.toBlob(n);return Rm(t,s)}else if(_e.IS_FS_AVAILABLE)await this.toSharp().toFile(t);else throw new Error("Unable to save the image because filesystem is disabled in this environment.")}toSharp(){if(_e.IS_WEB_ENV)throw new Error("toSharp() is only supported in server-side environments.");return gl(this.data,{raw:{width:this.width,height:this.height,channels:this.channels}})}};Gt.read.bind(Gt);function D_(e,t,r=0,n=null){const s=e/t;let a=cT(s)*t;return n!==null&&a>n&&(a=Math.floor(s)*t),a<r&&(a=Math.ceil(s)*t),a}function z_([e,t],r){return[Math.max(Math.floor(e/r),1)*r,Math.max(Math.floor(t/r),1)*r]}function Xm([e,t,r,n]){return[e-r/2,t-n/2,e+r/2,t+n/2]}function Ha(e,t=.5,r=null,n=!1){const s=e.logits,a=e.pred_boxes,[o,i,l]=s.dims;if(r!==null&&r.length!==o)throw Error("Make sure that you pass in as many target sizes as the batch dimension of the logits");let c=[];for(let d=0;d<o;++d){let h=r!==null?r[d]:null,_={boxes:[],classes:[],scores:[]},p=s[d],w=a[d];for(let v=0;v<i;++v){let y=p[v],M=[],T;if(n){T=y.sigmoid().data;for(let A=0;A<T.length;++A)T[A]>t&&M.push(A)}else{let A=Ue(y.data)[1];if(A===l-1||(T=nt(y.data),T[A]<t))continue;M.push(A)}for(const A of M){let S=w[v].data;S=Xm(S),h!==null&&(S=S.map((C,I)=>C*h[(I+1)%2])),_.boxes.push(S),_.classes.push(A),_.scores.push(T[A])}}c.push(_)}return c}function Ym(e,t=null){const r=e.logits,n=r.dims[0];if(t!==null&&t.length!==n)throw Error("Make sure that you pass in as many target sizes as the batch dimension of the logits");const s=[];for(let a=0;a<n;++a){const o=t!==null?t[a]:null;let i=r[a];o!==null&&(i=Am(i,o,"bilinear",!1));const[l,c]=o??i.dims.slice(-2),d=new j("int32",new Int32Array(l*c),[l,c]),h=i[0].data,_=d.data;for(let v=1;v<i.dims[0];++v){const y=i[v].data;for(let M=0;M<y.length;++M)y[M]>h[M]&&(h[M]=y[M],_[M]=v)}const p=new Array(i.dims[0]);for(let v=0;v<_.length;++v){const y=_[v];p[y]=y}const w=p.filter(v=>v!==void 0);s.push({segmentation:d,labels:w})}return s}function i2(e,t,r,n){const s=[],a=[],o=[];for(let i=0;i<e.dims[0];++i){const l=e[i],c=t[i],d=Ue(l.data)[1];if(d===n)continue;const _=nt(l.data)[d];_>r&&(s.push(c),a.push(_),o.push(d))}return[s,a,o]}function l2(e,t,r,n=.5,s=.8){const a=[];let o=0,i=0;const l=t[r].data;for(let d=0;d<e.length;++d)e[d]===r&&(a.push(d),++o),l[d]>=n&&++i;let c=o>0&&i>0;return c&&(c=o/i>s),[c,a]}function c2(e,t,r,n,s,a=null,o=null){const[i,l]=o??e[0].dims,c=new j("int32",new Int32Array(i*l),[i,l]),d=[];if(o!==null)for(let v=0;v<e.length;++v)e[v]=Am(e[v],o,"bilinear",!1);const h=new Int32Array(e[0].data.length),_=new Float32Array(e[0].data.length);for(let v=0;v<e.length;++v){let y=t[v];const M=e[v].data;for(let T=0;T<M.length;++T)M[T]*=y,M[T]>_[T]&&(h[T]=v,_[T]=M[T])}let p=0;const w=c.data;for(let v=0;v<r.length;++v){const y=r[v],[M,T]=l2(h,e,v,n,s);if(M){++p;for(const A of T)w[A]=p;d.push({id:p,label_id:y,score:t[v]})}}return[c,d]}function nc(e,t,r=28,n=3136,s=784*1280,a=1){if(e<r||t<r){const l=Math.max(r/e,r/t);e=Math.round(e*l),t=Math.round(t*l)}if(Math.max(e,t)/Math.min(e,t)>200)throw new Error(`absolute aspect ratio must be smaller than 200, got ${Math.max(e,t)/Math.min(e,t)}`);let o=Math.round(e/r)*r,i=Math.round(t/r)*r;if(a*o*i>s){const l=Math.sqrt(a*e*t/s);o=Math.max(r,Math.floor(e/l/r)*r),i=Math.max(r,Math.floor(t/l/r)*r)}else if(a*o*i<n){const l=Math.sqrt(n/(a*e*t));o=Math.ceil(e*l/r)*r,i=Math.ceil(t*l/r)*r}return[i,o]}function Jm(e,t=.5,r=.5,n=.8,s=null,a=null){s===null&&(ue.warn("`label_ids_to_fuse` unset. No instance will be fused."),s=new Set);const o=e.class_queries_logits??e.logits,l=(e.masks_queries_logits??e.pred_masks).sigmoid();let[c,d,h]=o.dims;if(h-=1,a!==null&&a.length!==c)throw Error("Make sure that you pass in as many target sizes as the batch dimension of the logits");let _=[];for(let p=0;p<c;++p){let w=a!==null?a[p]:null,v=o[p],y=l[p],[M,T,A]=i2(v,y,t,h);if(A.length===0){let[I,x]=w??y.dims.slice(-2),R=new j("int32",new Int32Array(I*x).fill(-1),[I,x]);_.push({segmentation:R,segments_info:[]});continue}let[S,C]=c2(M,T,A,r,n,s,w);_.push({segmentation:S,segments_info:C})}return _}function Km(e,t=.5,r=null){throw new Error("`post_process_instance_segmentation` is not yet implemented.")}var de=class extends wt{constructor(e){super(),this.image_mean=e.image_mean??e.mean,this.image_std=e.image_std??e.std,this.resample=e.resample??2,this.do_rescale=e.do_rescale??!0,this.rescale_factor=e.rescale_factor??1/255,this.do_normalize=e.do_normalize,this.do_thumbnail=e.do_thumbnail,this.size=e.size??e.image_size,this.do_resize=e.do_resize??this.size!==void 0,this.size_divisibility=e.size_divisibility??e.size_divisor,this.do_center_crop=e.do_center_crop,this.crop_size=e.crop_size,this.do_convert_rgb=e.do_convert_rgb??!0,this.do_crop_margin=e.do_crop_margin,this.pad_size=e.pad_size,this.do_pad=e.do_pad,this.min_pixels=e.min_pixels,this.max_pixels=e.max_pixels,this.do_pad&&!this.pad_size&&!this.size_divisibility&&this.size&&this.size.width!==void 0&&this.size.height!==void 0&&(this.pad_size=this.size),this.do_flip_channel_order=e.do_flip_channel_order??!1,this.config=e}async thumbnail(e,t,r=2){const n=e.height,s=e.width,a=t.height,o=t.width;let i=Math.min(n,a),l=Math.min(s,o);return i===n&&l===s?e:(n>s?l=Math.floor(s*i/n):s>n&&(i=Math.floor(n*l/s)),await e.resize(l,i,{resample:r}))}async crop_margin(e,t=200){const r=e.clone().grayscale(),n=hl(r.data)[0],a=Ue(r.data)[0]-n;if(a===0)return e;const o=t/255;let i=r.width,l=r.height,c=0,d=0;const h=r.data;for(let _=0;_<r.height;++_){const p=_*r.width;for(let w=0;w<r.width;++w)(h[p+w]-n)/a<o&&(i=Math.min(i,w),l=Math.min(l,_),c=Math.max(c,w),d=Math.max(d,_))}return e=await e.crop([i,l,c,d]),e}pad_image(e,t,r,{mode:n="constant",center:s=!1,constant_values:a=0}={}){const[o,i,l]=t;let c,d;if(typeof r=="number"?(c=r,d=r):r==="square"?c=d=Math.max(o,i):(c=r.width,d=r.height),c!==i||d!==o){const h=new Float32Array(c*d*l);if(Array.isArray(a))for(let w=0;w<h.length;++w)h[w]=a[w%l];else a!==0&&h.fill(a);const[_,p]=s?[Math.floor((c-i)/2),Math.floor((d-o)/2)]:[0,0];for(let w=0;w<o;++w){const v=(w+p)*c,y=w*i;for(let M=0;M<i;++M){const T=(v+M+_)*l,A=(y+M)*l;for(let S=0;S<l;++S)h[T+S]=e[A+S]}}if(n==="symmetric"){if(s)throw new Error("`center` padding is not supported when `mode` is set to `symmetric`.");const w=o-1,v=i-1;for(let y=0;y<d;++y){const M=y*c,T=Oa(y,w)*i;for(let A=0;A<c;++A){if(y<o&&A<i)continue;const S=(M+A)*l,C=(T+Oa(A,v))*l;for(let I=0;I<l;++I)h[S+I]=e[C+I]}}}e=h,t=[d,c,l]}return[e,t]}rescale(e){for(let t=0;t<e.length;++t)e[t]=this.rescale_factor*e[t]}get_resize_output_image_size(e,t){const[r,n]=e.size;let s,a;if(this.do_thumbnail){const{height:o,width:i}=t;s=Math.min(o,i)}else Number.isInteger(t)?(s=t,a=this.config.max_size??s):t!==void 0&&(s=t.shortest_edge,a=t.longest_edge);if(s!==void 0||a!==void 0){const o=s===void 0?1:Math.max(s/r,s/n),i=r*o,l=n*o,c=a===void 0?1:Math.min(a/i,a/l);let d=Math.floor(Number((i*c).toFixed(2))),h=Math.floor(Number((l*c).toFixed(2)));return this.size_divisibility!==void 0&&([d,h]=z_([d,h],this.size_divisibility)),[d,h]}else if(t!==void 0&&t.width!==void 0&&t.height!==void 0){let o=t.width,i=t.height;if(this.config.keep_aspect_ratio&&this.config.ensure_multiple_of){let l=i/n,c=o/r;Math.abs(1-c)<Math.abs(1-l)?l=c:c=l,i=D_(l*n,this.config.ensure_multiple_of),o=D_(c*r,this.config.ensure_multiple_of)}return[o,i]}else{if(this.size_divisibility!==void 0)return z_([r,n],this.size_divisibility);throw new Error(`Could not resize image due to unsupported \`this.size\` option in config: ${JSON.stringify(t)}`)}}async resize(e){const[t,r]=this.get_resize_output_image_size(e,this.size);return await e.resize(t,r,{resample:this.resample})}async preprocess(e,{do_normalize:t=null,do_pad:r=null,do_convert_rgb:n=null,do_convert_grayscale:s=null,do_flip_channel_order:a=null}={}){this.do_crop_margin&&(e=await this.crop_margin(e));const[o,i]=e.size;if(n??this.do_convert_rgb?e=e.rgb():s&&(e=e.grayscale()),this.do_resize&&(e=await this.resize(e)),this.do_thumbnail&&(e=await this.thumbnail(e,this.size,this.resample)),this.do_center_crop){let _,p;Number.isInteger(this.crop_size)?(_=this.crop_size,p=this.crop_size):(_=this.crop_size.width,p=this.crop_size.height),e=await e.center_crop(_,p)}const l=[e.height,e.width];let c=Float32Array.from(e.data),d=[e.height,e.width,e.channels];if(this.do_rescale&&this.rescale(c),t??this.do_normalize){let _=this.image_mean;Array.isArray(this.image_mean)||(_=new Array(e.channels).fill(_));let p=this.image_std;if(Array.isArray(this.image_std)||(p=new Array(e.channels).fill(p)),_.length!==e.channels||p.length!==e.channels)throw new Error(`When set to arrays, the length of \`image_mean\` (${_.length}) and \`image_std\` (${p.length}) must match the number of channels in the image (${e.channels}).`);for(let w=0;w<c.length;w+=e.channels)for(let v=0;v<e.channels;++v)c[w+v]=(c[w+v]-_[v])/p[v]}if(r??this.do_pad){if(this.pad_size)[c,d]=this.pad_image(c,[e.height,e.width,e.channels],this.pad_size);else if(this.size_divisibility){const _=Math.ceil(d[1]/this.size_divisibility)*this.size_divisibility,p=Math.ceil(d[0]/this.size_divisibility)*this.size_divisibility;[c,d]=this.pad_image(c,d,{width:_,height:p})}}if(a??this.do_flip_channel_order){if(d[2]!==3)throw new Error("Flipping channel order is only supported for RGB images.");for(let _=0;_<c.length;_+=3){const p=c[_];c[_]=c[_+2],c[_+2]=p}}const h=new j("float32",c,d).permute(2,0,1);return{original_size:[i,o],reshaped_input_size:l,pixel_values:h}}async _call(e,...t){Array.isArray(e)||(e=[e]);const r=await Promise.all(e.map(s=>this.preprocess(s)));return{pixel_values:_r(r.map(s=>s.pixel_values),0),original_sizes:r.map(s=>s.original_size),reshaped_input_sizes:r.map(s=>s.reshaped_input_size)}}static async from_pretrained(e,t={}){const r=await nr(e,gs,!0,t);return new this(r)}},Ba={};vn(Ba,{BeitFeatureExtractor:()=>u2,BitImageProcessor:()=>d2,CHMv2ImageProcessor:()=>f2,CLIPFeatureExtractor:()=>_2,CLIPImageProcessor:()=>Zm,ChineseCLIPFeatureExtractor:()=>h2,ConvNextFeatureExtractor:()=>p2,ConvNextImageProcessor:()=>eg,DINOv3ViTImageProcessor:()=>w2,DPTFeatureExtractor:()=>y2,DPTImageProcessor:()=>ng,DeiTFeatureExtractor:()=>m2,DeiTImageProcessor:()=>tg,DetrFeatureExtractor:()=>g2,DetrImageProcessor:()=>rg,DonutFeatureExtractor:()=>v2,DonutImageProcessor:()=>sc,EfficientNetImageProcessor:()=>b2,GLPNFeatureExtractor:()=>E2,Gemma3ImageProcessor:()=>M2,Gemma4ImageProcessor:()=>sg,Glm46VImageProcessor:()=>T2,GroundingDinoImageProcessor:()=>A2,Idefics3ImageProcessor:()=>B_,ImageFeatureExtractor:()=>de,ImageProcessor:()=>de,JinaCLIPImageProcessor:()=>S2,Lfm2VlImageProcessor:()=>O2,LlavaOnevisionImageProcessor:()=>N2,Mask2FormerImageProcessor:()=>z2,MaskFormerFeatureExtractor:()=>D2,MaskFormerImageProcessor:()=>ac,MobileNetV1FeatureExtractor:()=>B2,MobileNetV1ImageProcessor:()=>og,MobileNetV2FeatureExtractor:()=>R2,MobileNetV2ImageProcessor:()=>ig,MobileNetV3FeatureExtractor:()=>G2,MobileNetV3ImageProcessor:()=>lg,MobileNetV4FeatureExtractor:()=>$2,MobileNetV4ImageProcessor:()=>cg,MobileViTFeatureExtractor:()=>V2,MobileViTImageProcessor:()=>ug,NougatImageProcessor:()=>U2,OwlViTFeatureExtractor:()=>j2,OwlViTImageProcessor:()=>oc,Owlv2ImageProcessor:()=>q2,Phi3VImageProcessor:()=>H2,PixtralImageProcessor:()=>Q2,PvtImageProcessor:()=>X2,Qwen2VLImageProcessor:()=>ag,RTDetrImageProcessor:()=>Y2,Sam2ImageProcessor:()=>yi,Sam3ImageProcessor:()=>yi,SamImageProcessor:()=>yi,SapiensFeatureExtractor:()=>J2,SapiensImageProcessor:()=>dg,SegformerFeatureExtractor:()=>K2,SegformerImageProcessor:()=>hg,SiglipImageProcessor:()=>Z2,SmolVLMImageProcessor:()=>B_,Swin2SRImageProcessor:()=>eA,VLMImageProcessor:()=>C2,ViTFeatureExtractor:()=>tA,ViTImageProcessor:()=>fg,VitMatteImageProcessor:()=>rA,VitPoseImageProcessor:()=>nA,YolosFeatureExtractor:()=>sA,YolosImageProcessor:()=>_g});var u2=class extends de{},d2=class extends de{},h2=class extends de{},f2=class extends de{},Zm=class extends de{},_2=class extends Zm{},eg=class extends de{constructor(e){super(e),this.crop_pct=this.config.crop_pct??224/256}async resize(e){var r;const t=(r=this.size)==null?void 0:r.shortest_edge;if(t===void 0)throw new Error("Size dictionary must contain 'shortest_edge' key.");if(t<384){const n=Math.floor(t/this.crop_pct),[s,a]=this.get_resize_output_image_size(e,{shortest_edge:n});e=await e.resize(s,a,{resample:this.resample}),e=await e.center_crop(t,t)}else e=await e.resize(t,t,{resample:this.resample});return e}},p2=class extends eg{},tg=class extends de{},m2=class extends tg{},rg=class extends de{async _call(e){const t=await super._call(e),r=[t.pixel_values.dims[0],64,64],n=lt(r,1n);return{...t,pixel_mask:n}}post_process_object_detection(...e){return Ha(...e)}post_process_panoptic_segmentation(...e){return Jm(...e)}post_process_instance_segmentation(...e){return Km(...e)}},g2=class extends rg{},w2=class extends de{},sc=class extends de{pad_image(e,t,r,n={}){const[s,a,o]=t;let i=this.image_mean;Array.isArray(this.image_mean)||(i=new Array(o).fill(i));let l=this.image_std;Array.isArray(l)||(l=new Array(o).fill(i));const c=i.map((d,h)=>-d/l[h]);return super.pad_image(e,t,r,{center:!0,constant_values:c,...n})}},v2=class extends sc{},ng=class extends de{},y2=class extends ng{},b2=class extends de{constructor(e){super(e),this.include_top=this.config.include_top??!0,this.include_top&&(this.image_std=this.image_std.map(t=>t*t))}},M2=class extends de{};function x2(e,t,r,n,s){const a=n*r**2,o=Math.sqrt(a/(e*t)),i=s*r;let l=Math.floor(o*e/i)*i,c=Math.floor(o*t/i)*i;if(l===0&&c===0)throw new Error(`Attempting to resize to a 0 x 0 image. Resized height should be divisible by \`pooling_kernel_size * patch_size\`=${i}.`);const d=Math.floor(n/s**2)*i;return l===0?(l=i,c=Math.min(Math.floor(t/e)*i,d)):c===0&&(c=i,l=Math.min(Math.floor(e/t)*i,d)),[l,c]}function k2(e,t,r,n,s,a,o){const i=Math.floor(t/s),l=Math.floor(r/s),c=i*l,d=s*s*n,h=new Float32Array(a*d);let _=0;for(let v=0;v<i;++v)for(let y=0;y<l;++y)for(let M=0;M<s;++M){const T=(v*s+M)*r*n+y*s*n;for(let A=0;A<s;++A){const S=T+A*n;for(let C=0;C<n;++C)h[_++]=e[S+C]}}const p=new BigInt64Array(a*2).fill(-1n);let w=0;for(let v=0;v<i;++v)for(let y=0;y<l;++y)p[w++]=BigInt(y),p[w++]=BigInt(v);return{patches:new j("float32",h,[a,d]),positions:new j("int64",p,[a,2]),num_soft_tokens:Math.floor(c/o**2)}}var sg=class extends wt{constructor(e){super(),this.config=e,this.patch_size=e.patch_size??16,this.max_soft_tokens=e.max_soft_tokens??280,this.pooling_kernel_size=e.pooling_kernel_size??3,this.resample=e.resample??3,this.rescale_factor=e.rescale_factor??1/255,this.do_rescale=e.do_rescale??!0,this.do_resize=e.do_resize??!0,this.do_convert_rgb=e.do_convert_rgb??!0}async _call(e){Array.isArray(e)||(e=[e]);const{patch_size:t,pooling_kernel_size:r}=this,n=this.max_soft_tokens*r**2,s=[],a=[],o=[];for(let i of e){if(this.do_convert_rgb&&(i=i.rgb()),this.do_resize){const[_,p]=x2(i.height,i.width,t,n,r);(_!==i.height||p!==i.width)&&(i=await i.resize(p,_,{resample:this.resample}))}const l=Float32Array.from(i.data);if(this.do_rescale)for(let _=0;_<l.length;++_)l[_]*=this.rescale_factor;const{patches:c,positions:d,num_soft_tokens:h}=k2(l,i.height,i.width,i.channels,t,n,r);s.push(c),a.push(d),o.push(h)}return{pixel_values:_r(s,0),image_position_ids:_r(a,0),num_soft_tokens_per_image:o}}},ag=class extends de{constructor(e){var t,r;super(e),this.min_pixels=e.min_pixels??((t=e.size)==null?void 0:t.shortest_edge),this.max_pixels=e.max_pixels??((r=e.size)==null?void 0:r.longest_edge),this.patch_size=e.patch_size,this.merge_size=e.merge_size}get_resize_output_image_size(e,t){const r=this.patch_size*this.merge_size;return nc(e.height,e.width,r,this.min_pixels,this.max_pixels)}async _call(e,...t){const{pixel_values:r,original_sizes:n,reshaped_input_sizes:s}=await super._call(e,...t);let a=r;const{temporal_patch_size:o,merge_size:i,patch_size:l}=this.config;a.dims[0]===1&&(a=De(Array.from({length:o},()=>a),0));const c=a.dims[0]/o,d=a.dims[1],h=Math.floor(a.dims[2]/l),_=Math.floor(a.dims[3]/l),p=a.view(c,o,d,Math.floor(h/i),i,l,Math.floor(_/i),i,l).permute(0,3,6,4,7,2,1,5,8).view(c*h*_,d*o*l*l),w=new j("int64",[c,h,_],[1,3]);return{pixel_values:p,image_grid_thw:w,original_sizes:n,reshaped_input_sizes:s}}},T2=class extends ag{get_resize_output_image_size(e,t){const r=this.patch_size*this.merge_size,n=this.config.temporal_patch_size??2;return nc(e.height,e.width,r,this.min_pixels,this.max_pixels,n)}},E2=class extends de{},A2=class extends de{async _call(e){const t=await super._call(e),r=t.pixel_values.dims,n=gt([r[0],r[2],r[3]]);return{...t,pixel_mask:n}}},B_=class extends de{constructor(e){super(e),this.do_image_splitting=e.do_image_splitting??!0,this.max_image_size=e.max_image_size}get_resize_for_vision_encoder(e,t){let[r,n]=e.dims.slice(-2);const s=n/r;return n>=r?(n=Math.ceil(n/t)*t,r=Math.floor(n/s),r=Math.ceil(r/t)*t):(r=Math.ceil(r/t)*t,n=Math.floor(r*s),n=Math.ceil(n/t)*t),{height:r,width:n}}async _call(e,{do_image_splitting:t=null,return_row_col_info:r=!1}={}){let n;if(!Array.isArray(e))n=[[e]];else{if(e.length===0||!e[0])throw new Error("No images provided.");Array.isArray(e[0])?n=e:n=[e]}let s=[],a=[],o=[];const i=[],l=[];for(const y of n){let M=await Promise.all(y.map(S=>this.preprocess(S)));i.push(...M.map(S=>S.original_size)),l.push(...M.map(S=>S.reshaped_input_size)),M.forEach(S=>S.pixel_values.unsqueeze_(0));const{longest_edge:T}=this.max_image_size;let A;if(t??this.do_image_splitting){let S=new Array(M.length),C=new Array(M.length);A=await Promise.all(M.map(async(I,x)=>{const R=this.get_resize_for_vision_encoder(I.pixel_values,T),z=await Rt(I.pixel_values,{size:[R.height,R.width]}),{frames:$,num_splits_h:Q,num_splits_w:H}=await this.split_image(z,this.max_image_size);return S[x]=Q,C[x]=H,De($,0)})),a.push(S),o.push(C)}else{const S=[T,T];A=await Promise.all(M.map(C=>Rt(C.pixel_values,{size:S}))),a.push(new Array(M.length).fill(0)),o.push(new Array(M.length).fill(0))}s.push(De(A,0))}const c=s.length,[d,h,_,p]=s[0].dims;let w,v;if(c===1)w=s[0].unsqueeze_(0),v=lt([c,d,_,p],!0);else{const y=Math.max(...s.map(A=>A.dims.at(0)));v=lt([c,y,_,p],!0);const M=v.data,T=y*_*p;for(let A=0;A<c;++A){const S=s[A].dims[0];if(S<y){s[A]=De([s[A],lt([y-S,h,_,p],0)],0);const C=A*T+S*_*p,I=(A+1)*T;M.fill(!1,C,I)}}w=_r(s,0)}return{pixel_values:w,pixel_attention_mask:v,original_sizes:i,reshaped_input_sizes:l,...r?{rows:a,cols:o}:{}}}async split_image(e,{longest_edge:t}){const r=t,n=t,s=[],[a,o]=e.dims.slice(-2);let i=0,l=0;if(a>r||o>n){i=Math.ceil(a/r),l=Math.ceil(o/n);const c=Math.ceil(a/i),d=Math.ceil(o/l);for(let p=0;p<i;++p)for(let w=0;w<l;++w){let v,y,M,T;p===i-1?(y=a-c,T=a):(y=p*c,T=(p+1)*c),w===l-1?(v=o-d,M=o):(v=w*d,M=(w+1)*d);const C=await Cm(e,[y,v],[T,M],[2,3]);s.push(C)}const h=r,_=n;(a!==h||o!==_)&&(e=await Rt(e,{size:[h,_]}))}return s.push(e),{frames:s,num_splits_h:i,num_splits_w:l}}},C2=class extends de{constructor(e){super({do_pad:!0,pad_size:{width:e.image_size,height:e.image_size},...e}),this.constant_values=this.config.background_color.map(t=>t*this.rescale_factor)}pad_image(e,t,r,n){return super.pad_image(e,t,r,{constant_values:this.constant_values,center:!0,...n})}},S2=class extends de{constructor(e){const{resize_mode:t,fill_color:r,interpolation:n,size:s,...a}=e,o=t==="squash"?{width:s,height:s}:t==="shortest"?{shortest_edge:s}:{longest_edge:s},i=n==="bicubic"?3:2;super({...a,size:o,resample:i,do_center_crop:!0,crop_size:s,do_normalize:!0})}};function R_(e,t){return Math.round(e/t)*t}function P2(e,t,r,n,s){let a=1/0,o=[1,1];const i=r*n;for(const l of t){const c=Math.abs(e-l[0]/l[1]);c<a?(a=c,o=l):c===a&&i>.5*s*s*l[0]*l[1]&&(o=l)}return o}function F2(e,t){const r=[],n=new Set;for(let s=e;s<=t;++s)for(let a=1;a<=s;++a)for(let o=1;o<=s;++o){const i=a*o;if(i>=e&&i<=t){const l=a<<16|o;n.has(l)||(n.add(l),r.push([a,o]))}}return r.sort((s,a)=>s[0]*s[1]-a[0]*a[1])}function L2(e,t){const[r,n,s,a]=e.dims,o=Math.floor(s/t),i=Math.floor(a/t),l=t*t*n,c=e.data,d=new Float32Array(r*o*i*l),h=s*a;for(let _=0;_<r;++_){const p=_*n*h,w=_*o*i*l;for(let v=0;v<o;++v)for(let y=0;y<i;++y){let M=w+(v*i+y)*l;for(let T=0;T<t;++T){const A=(v*t+T)*a+y*t;for(let S=0;S<t;++S){const C=A+S;for(let I=0;I<n;++I)d[M++]=c[p+I*h+C]}}}}return new j("float32",d,[r,o*i,l])}function I2(e,t){const[,r,n]=e.dims,s=new BigInt64Array(t);s.fill(1n,0,r);let a=e;if(r<t){const o=new Float32Array(t*n);o.set(e.data),a=new j("float32",o,[1,t,n])}return{padded:a,mask:new j("int64",s,[t])}}var O2=class extends de{constructor(e){super(e),this.downsample_factor=e.downsample_factor??2,this.do_image_splitting=e.do_image_splitting??!0,this.min_tiles=e.min_tiles??2,this.max_tiles=e.max_tiles??10,this.use_thumbnail=e.use_thumbnail??!0,this.min_image_tokens=e.min_image_tokens??64,this.max_image_tokens=e.max_image_tokens??256,this.encoder_patch_size=e.encoder_patch_size??e.patch_size??16,this.tile_size=e.tile_size??512,this.max_pixels_tolerance=e.max_pixels_tolerance??2,this.return_row_col_info=e.return_row_col_info??!1;const t=this.max_image_tokens*this.downsample_factor**2,r=this.do_image_splitting?(this.tile_size/this.encoder_patch_size)**2:0;this.max_num_patches=Math.max(t,r)}_is_image_too_large(e,t){const r=this.encoder_patch_size*this.downsample_factor,n=Math.max(this.encoder_patch_size,R_(e,r)),s=Math.max(this.encoder_patch_size,R_(t,r));return n*s>this.max_image_tokens*(this.encoder_patch_size*this.downsample_factor)**2*this.max_pixels_tolerance}_get_grid_layout(e,t){const r=F2(this.min_tiles,this.max_tiles),[n,s]=P2(t/e,r,t,e,this.tile_size);return{grid_width:n,grid_height:s,target_width:this.tile_size*n,target_height:this.tile_size*s}}async _call(e,{return_row_col_info:t=null}={}){let r;Array.isArray(e)?Array.isArray(e[0])?r=e:r=[e]:r=[[e]];const n=[],s=[],a=[],o=[],i=[],l=[];for(const d of r){const h=await Promise.all(d.map(_=>this.preprocess(_,{do_pad:!1})));for(const{pixel_values:_}of h){const[,p,w]=_.dims,v=_.unsqueeze_(0),y=this.encoder_patch_size*this.downsample_factor,M=y**2,[T,A]=nc(Math.max(y,p),Math.max(y,w),y,this.min_image_tokens*M,this.max_image_tokens*M).map(z=>Math.max(y,z));let S,C=1,I=1;const x=this._is_image_too_large(p,w),R=this.do_image_splitting&&!(this.min_tiles===1&&this.max_tiles===1);if(x&&R){const{grid_width:z,grid_height:$,target_width:Q,target_height:H}=this._get_grid_layout(p,w);C=$,I=z;const D=await Rt(v,{size:[H,Q]});S=[];for(let O=0;O<$;++O)for(let te=0;te<z;++te){const W=O*this.tile_size,ee=te*this.tile_size;S.push(D.slice(null,null,[W,W+this.tile_size],[ee,ee+this.tile_size]))}this.use_thumbnail&&z*$!==1&&S.push(await Rt(v,{size:[A,T]}))}else S=[await Rt(v,{size:[A,T]})];for(const z of S){const[,,$,Q]=z.dims,H=L2(z,this.encoder_patch_size),{padded:D,mask:O}=I2(H,this.max_num_patches);n.push(D),s.push(O),a.push([Math.floor($/this.encoder_patch_size),Math.floor(Q/this.encoder_patch_size)])}o.push(C),i.push(I),l.push([A,T])}}const c={pixel_values:De(n,0),pixel_attention_mask:_r(s,0),spatial_shapes:new j("int64",BigInt64Array.from(a.flat(),BigInt),[a.length,2])};return(t??this.return_row_col_info)&&(c.image_rows=o,c.image_cols=i,c.image_sizes=l),c}},N2=class extends de{},ac=class extends de{post_process_panoptic_segmentation(...e){return Jm(...e)}post_process_instance_segmentation(...e){return Km(...e)}},D2=class extends ac{},z2=class extends ac{},og=class extends de{},B2=class extends og{},ig=class extends de{},R2=class extends ig{},lg=class extends de{},G2=class extends lg{},cg=class extends de{},$2=class extends cg{},ug=class extends de{},V2=class extends ug{},U2=class extends sc{},oc=class extends de{post_process_object_detection(...e){return Ha(...e)}},j2=class extends oc{},q2=class extends oc{},vt=336,W2=[2,3],{ceil:wi,floor:an,sqrt:vi}=Math,H2=class extends de{constructor(e){super({...e,do_normalize:!0,do_pad:!0,pad_size:"custom",do_convert_rgb:!0,do_resize:!0}),this._num_crops=e.num_crops}calc_num_image_tokens_from_image_size(e,t){const{num_img_tokens:r}=this.config;return an((an(t/vt)*an(e/vt)+1)*r+1+(an(t/vt)+1)*vi(r))}get_resize_output_image_size(e,t){const r=this._num_crops,[n,s]=e.size;let a=n/s,o=1;for(;o*Math.ceil(o/a)<=r;)o+=1;o-=1;const i=Math.floor(o*336),l=Math.floor(i/a);return[i,l]}pad_image(e,t,r,n={}){const[s,a]=t,o=vt*wi(s/vt),i=vt*wi(a/vt),l=[1,1,1].map((c,d)=>(c-this.image_mean[d])/this.image_std[d]);return super.pad_image(e,t,{width:i,height:o},{center:!0,constant_values:l,...n})}async _call(e,{num_crops:t=null}={}){if(this._num_crops=t??(t=this.config.num_crops),t<4||vi(t)%1!==0)throw new Error("num_crops must be a square number >= 4");Array.isArray(e)||(e=[e]);const r=e.length,n=await Promise.all(e.map(h=>this.preprocess(h))),s=n.map(h=>h.original_size),a=n.map(h=>h.reshaped_input_size),o=[];for(const{pixel_values:h}of n){h.unsqueeze_(0);const[_,p]=h.dims.slice(-2),w=await Rt(h,{size:[vt,vt],mode:"bicubic"});if(t>0){const v=[],y=vi(t),M=an(p/y),T=an(_/y);for(let S=0;S<y;++S)for(let C=0;C<y;++C){let I,x,R,z;S===y-1?(x=_-T,z=_):(x=S*T,z=(S+1)*T),C===y-1?(I=p-M,R=p):(I=C*M,R=(C+1)*M);const H=await Cm(h,[x,I],[z,R],W2);v.push(H)}const A=await Rt(De(v,0),{size:[vt,vt],mode:"bicubic"});o.push(De([w,A],0))}else o.push(w)}const i=_r(o,0),l=a.map(h=>h.map(_=>vt*wi(_/vt))),c=new j("int64",l.flat(),[r,2]),d=l.map(([h,_])=>this.calc_num_image_tokens_from_image_size(_,h));return{pixel_values:i,original_sizes:s,reshaped_input_sizes:a,image_sizes:c,num_img_tokens:d}}},Q2=class extends de{get_resize_output_image_size(e,t){const{longest_edge:r}=t;if(r===void 0)throw new Error("size must contain 'longest_edge'");const[n,s]=e.size,a=Math.max(n,s)/r;let o=n,i=s;a>1&&(o=Math.floor(n/a),i=Math.floor(s/a));const{patch_size:l,spatial_merge_size:c}=this.config;if(!c)throw new Error("config must contain 'spatial_merge_size'");const d=l*c,h=Math.floor((o-1)/d)+1,_=Math.floor((i-1)/d)+1;return[h*d,_*d]}},X2=class extends de{},Y2=class extends de{post_process_object_detection(...e){return Ha(...e)}},yi=class extends de{reshape_input_points(e,t,r,n=!1){e=structuredClone(e);let s=r_(e);if(s.length===3)n||(s=[1,...s]),e=[e];else if(s.length!==4)throw Error("The input_points must be a 4D tensor of shape `batch_size`, `point_batch_size`, `nb_points_per_image`, `2`.");for(let a=0;a<e.length;++a){const[o,i]=t[a],[l,c]=r[a],d=[c/i,l/o];for(let h=0;h<e[a].length;++h)for(let _=0;_<e[a][h].length;++_)for(let p=0;p<e[a][h][_].length;++p)e[a][h][_][p]*=d[p%2]}return new j("float32",Float32Array.from(e.flat(1/0)),s)}add_input_labels(e,t){let r=r_(e);if(r.length===2)r=[1,...r],e=[e];else if(r.length!==3)throw Error("The input_points must be a 4D tensor of shape `batch_size`, `point_batch_size`, `nb_points_per_image`, `2`.");if(r.some((n,s)=>n!==t.dims[s]))throw Error(`The first ${r.length} dimensions of 'input_points' and 'input_labels' must be the same.`);return new j("int64",e.flat(1/0).map(BigInt),r)}async _call(e,{input_points:t=null,input_labels:r=null,input_boxes:n=null}={}){const s=await super._call(e);if(t&&(s.input_points=this.reshape_input_points(t,s.original_sizes,s.reshaped_input_sizes)),r){if(!s.input_points)throw Error("`input_points` must be provided if `input_labels` are provided.");s.input_labels=this.add_input_labels(r,s.input_points)}return n&&(s.input_boxes=this.reshape_input_points(n,s.original_sizes,s.reshaped_input_sizes,!0)),s}async post_process_masks(e,t,r,{mask_threshold:n=0,binarize:s=!0,pad_size:a=null}={}){const o=[];a=a??this.pad_size??this.size;const i=[a.height,a.width];for(let l=0;l<t.length;++l){const c=t[l],d=r[l];let h=await Rt(e[l],{mode:"bilinear",size:i});if(h=h.slice(null,null,[0,d[0]],[0,d[1]]),h=await Rt(h,{mode:"bilinear",size:c}),s){const _=h.data,p=new Uint8Array(_.length);for(let w=0;w<_.length;++w)_[w]>n&&(p[w]=1);h=new j("bool",p,h.dims)}o.push(h)}return o}generate_crop_boxes(e,t,{crop_n_layers:r=0,overlap_ratio:n=512/1500,points_per_crop:s=32,crop_n_points_downscale_factor:a=1}={}){}},dg=class extends de{post_process_semantic_segmentation(...e){return Ym(...e)}},J2=class extends dg{},hg=class extends de{post_process_semantic_segmentation(...e){return Ym(...e)}},K2=class extends hg{},Z2=class extends de{},eA=class extends de{pad_image(e,t,r,n={}){const[s,a,o]=t;return super.pad_image(e,t,{width:a+(r-a%r)%r,height:s+(r-s%r)%r},{mode:"symmetric",center:!1,constant_values:-1,...n})}},fg=class extends de{},tA=class extends fg{},rA=class extends de{async _call(e,t){Array.isArray(e)||(e=[e]),Array.isArray(t)||(t=[t]);const r=await Promise.all(e.map(a=>this.preprocess(a))),n=await Promise.all(t.map(a=>this.preprocess(a,{do_normalize:!1,do_convert_rgb:!1,do_convert_grayscale:!0})));return{pixel_values:_r(r.map((a,o)=>De([a.pixel_values,n[o].pixel_values],0)),0),original_sizes:r.map(a=>a.original_size),reshaped_input_sizes:r.map(a=>a.reshaped_input_size)}}},nA=class extends de{post_process_pose_estimation(e,t,{threshold:r=null}={}){const n=e.tolist(),[s,a,o,i]=e.dims,l=[];for(let c=0;c<s;++c){const d=n[c],h=t[c],_=[];for(let p=0;p<h.length;++p){const w=h[p],v=[],y=[],M=[],T=w.at(-2)/i,A=w.at(-1)/o;for(let S=0;S<d.length;++S){let[C,I]=[0,0],x=0,R=-1/0;const z=d[S];for(let Q=0;Q<z.length;++Q){const H=z[Q];for(let D=0;D<H.length;++D){const O=H[D];x+=O,R=Math.max(R,O),C+=(D+.5)*O,I+=Q*O}}if(r!=null&&R<r)continue;const $=[T*C/x,A*I/x];v.push($),M.push(S),y.push(R)}_.push({bbox:w,scores:y,labels:M,keypoints:v})}l.push(_)}return l}},_g=class extends de{post_process_object_detection(...e){return Ha(...e)}},sA=class extends _g{},ut=class{static async from_pretrained(e,t={}){const r=await nr(e,gs,!0,t),n=r.image_processor_type??r.feature_extractor_type;let s=Ba[n==null?void 0:n.replace(/Fast$/,"")];return s||(n!==void 0&&ue.warn(`Image processor type '${n}' not found, assuming base ImageProcessor. Please report this at ${Wa}.`),s=de),new s(r)}},la,aA=(la=class extends Ee{constructor(e,t,r){super(e,t,r);const{tasks_answer_post_processing_type:n,task_prompts_without_inputs:s,task_prompts_with_input:a}=this.image_processor.config;this.tasks_answer_post_processing_type=new Map(Object.entries(n??{})),this.task_prompts_without_inputs=new Map(Object.entries(s??{})),this.task_prompts_with_input=new Map(Object.entries(a??{})),this.regexes={quad_boxes:/(.+?)<loc_(\d+)><loc_(\d+)><loc_(\d+)><loc_(\d+)><loc_(\d+)><loc_(\d+)><loc_(\d+)><loc_(\d+)>/gm,bboxes:/([^<]+)?<loc_(\d+)><loc_(\d+)><loc_(\d+)><loc_(\d+)>/gm},this.size_per_bin=1e3}construct_prompts(e){typeof e=="string"&&(e=[e]);const t=[];for(const r of e)if(this.task_prompts_without_inputs.has(r))t.push(this.task_prompts_without_inputs.get(r));else{for(const[n,s]of this.task_prompts_with_input)if(r.includes(n)){t.push(s.replaceAll("{input}",r).replaceAll(n,""));break}t.length!==e.length&&t.push(r)}return t}post_process_generation(e,t,r){const n=this.tasks_answer_post_processing_type.get(t)??"pure_text";e=e.replaceAll("<s>","").replaceAll("</s>","");let s;switch(n){case"pure_text":s=e;break;case"description_with_bboxes":case"bboxes":case"phrase_grounding":case"ocr":const a=n==="ocr"?"quad_boxes":"bboxes",o=e.matchAll(this.regexes[a]),i=[],l=[];for(const[c,d,...h]of o)i.push(d?d.trim():i.at(-1)??""),l.push(h.map((_,p)=>(Number(_)+.5)/this.size_per_bin*r[p%2]));s={labels:i,[a]:l};break;default:throw new Error(`Task "${t}" (of type "${n}") not yet implemented.`)}return{[t]:s}}async _call(e,t=null,r={}){if(!e&&!t)throw new Error("Either text or images must be provided");const n=await this.image_processor(e,r),s=t?this.tokenizer(this.construct_prompts(t),r):{};return{...n,...s}}},k(la,"tokenizer_class",Te),k(la,"image_processor_class",ut),la),ln,oA=(ln=class extends Ee{constructor(e,t,r){super(e,t,r),this.image_seq_length=this.config.image_seq_length;const{boi_token:n,image_token:s,eoi_token:a}=this.tokenizer.config;this.boi_token=n,this.image_token=s,this.eoi_token=a;const o=s.repeat(this.image_seq_length);this.full_image_sequence=`
18
+
19
+ ${n}${o}${a}
20
+
21
+ `}async _call(e,t=null,r={}){typeof e=="string"&&(e=[e]);let n;return t&&(n=await this.image_processor(t,r),e=e.map(a=>a.replaceAll(this.boi_token,this.full_image_sequence))),{...this.tokenizer(e,r),...n}}},k(ln,"tokenizer_class",Te),k(ln,"image_processor_class",ut),k(ln,"uses_processor_config",!0),k(ln,"uses_chat_template_file",!0),ln),Br,iA=(Br=class extends Ee{constructor(e,t,r){super(e,t,r),this.audio_seq_length=this.config.audio_seq_length,this.image_seq_length=this.config.image_seq_length;const{audio_token_id:n,boa_token:s,audio_token:a,eoa_token:o,image_token_id:i,boi_token:l,image_token:c,eoi_token:d}=this.tokenizer.config;this.audio_token_id=n,this.boa_token=s,this.audio_token=a;const h=a.repeat(this.audio_seq_length);this.full_audio_sequence=`
22
+
23
+ ${s}${h}${o}
24
+
25
+ `,this.image_token_id=i,this.boi_token=l,this.image_token=c;const _=c.repeat(this.image_seq_length);this.full_image_sequence=`
26
+
27
+ ${l}${_}${d}
28
+
29
+ `}async _call(e,t=null,r=null,n={}){typeof e=="string"&&(e=[e]);let s;r&&(s=await this.feature_extractor(r,n),e=e.map(i=>i.replaceAll(this.audio_token,this.full_audio_sequence)));let a;return t&&(a=await this.image_processor(t,n),e=e.map(i=>i.replaceAll(this.image_token,this.full_image_sequence))),{...this.tokenizer(e,n),...a,...s}}},k(Br,"image_processor_class",ut),k(Br,"feature_extractor_class",Lt),k(Br,"tokenizer_class",Te),k(Br,"uses_processor_config",!0),k(Br,"uses_chat_template_file",!0),Br),ca,lA=(ca=class extends Ee{constructor(e,t,r){super(e,t,r),this.audio_ms_per_token=this.config.audio_ms_per_token??40,this.audio_seq_length=this.config.audio_seq_length??750,this.image_seq_length=this.config.image_seq_length??280;const{audio_token:n,boa_token:s,eoa_token:a,image_token:o,boi_token:i,eoi_token:l}=this.tokenizer.config;this.audio_token=n,this.boa_token=s,this.eoa_token=a,this.image_token=o,this.boi_token=i,this.eoi_token=l}static async from_pretrained(e,t={}){const[r,n,s]=await Promise.all([nr(e,zm,!0,t),Te.from_pretrained(e,t),Xl(e,Bm,!1,t)]),a={tokenizer:n};return r.image_processor&&(a.image_processor=new sg(r.image_processor)),r.feature_extractor&&(a.feature_extractor=new Wm(r.feature_extractor)),new this(r,a,s)}_compute_audio_num_tokens(e,t){const r=Math.round(t*20/1e3),n=Math.round(t*10/1e3),s=Math.floor(r/2);let a=Math.floor((e+s-r-1)/n)+1;if(a<=0)return 0;for(let o=0;o<2;++o)a=Math.floor((a-1)/2)+1;return Math.min(a,this.audio_seq_length)}async _call(e,t=null,r=null,n={}){typeof e=="string"&&(e=[e]);let s;if(t){s=await this.image_processor(t,n);const o=s.num_soft_tokens_per_image;let i=0;e=e.map(l=>l.replaceAll(this.image_token,()=>`
30
+
31
+ ${this.boi_token}${this.image_token.repeat(o[i++])}${this.eoi_token}
32
+
33
+ `))}let a;if(r){const o=Array.isArray(r)?r:[r];a=await this.feature_extractor(o[0],n);const i=this.feature_extractor.config.sampling_rate??16e3;let l=0;e=e.map(c=>c.replaceAll(this.audio_token,()=>`
34
+
35
+ ${this.boa_token}${this.audio_token.repeat(this._compute_audio_num_tokens(o[l++].length,i))}${this.eoa_token}
36
+
37
+ `))}return{...this.tokenizer(e,n),...s,...a}}},k(ca,"uses_processor_config",!0),k(ca,"uses_chat_template_file",!0),ca),Kn,ic=(Kn=class extends Ee{async _call(e,t=null,...r){Array.isArray(e)||(e=[e]);let n,s;if(t&&(n=await this.image_processor(t),s=n.image_grid_thw),s){let o=this.image_processor.config.merge_size**2,i=0;const l=this.constructor.image_token,c=s.tolist();e=e.map(d=>{for(;d.includes(l);){const h=Number(c[i++].reduce((_,p)=>_*p,1n));d=d.replace(l,"<|placeholder|>".repeat(Math.floor(h/o)))}return d.replaceAll("<|placeholder|>",l)})}return{...this.tokenizer(e),...n}}},k(Kn,"image_processor_class",ut),k(Kn,"tokenizer_class",Te),k(Kn,"image_token","<|image_pad|>"),Kn),Ei,cA=(Ei=class extends ic{},k(Ei,"image_token","<|image|>"),Ei),Zn,uA=(Zn=class extends Ee{_get_num_audio_features(e){const{hop_length:t}=this.feature_extractor.config.melspec_kwargs,{projector_window_size:r,projector_downsample_rate:n}=this.feature_extractor.config,s=Math.floor(r/n),a=Math.floor(e/t)+1,o=Math.floor(a/2);return Math.ceil(o/r)*s}async _call(e,t=null,r={}){if(Array.isArray(e))throw new Error("Batched inputs are not supported yet.");let n={};if(t){const{input_features:a}=await this.feature_extractor(t);n.input_features=a;const o=this._get_num_audio_features(t.length),i=new Uint8Array(o).fill(1);n.input_features_mask=new j("bool",i,[1,o]);const l=this.config.audio_token??"<|audio|>";if(!e.includes(l))throw new Error(`The input text does not contain the audio token ${l}.`);e=e.replaceAll(l,l.repeat(o))}return{...this.tokenizer(e,{add_special_tokens:!1,...r}),...n}}},k(Zn,"tokenizer_class",Te),k(Zn,"feature_extractor_class",Lt),k(Zn,"uses_processor_config",!0),Zn);function dA(e,t){const n=e.dims.at(-1)-1,s=e.tolist();s.fill(!1,0,1),s.fill(!1,n);const a=t.tolist();return s.map((o,i)=>o?i:null).filter(o=>o!==null).map(o=>a[o])}var ua,hA=(ua=class extends Ee{async _call(e,t,r={}){const n=e?await this.image_processor(e,r):{};return{...t?this.tokenizer(t,r):{},...n}}post_process_grounded_object_detection(e,t,{box_threshold:r=.25,text_threshold:n=.25,target_sizes:s=null}={}){const{logits:a,pred_boxes:o}=e,i=a.dims[0];if(s!==null&&s.length!==i)throw Error("Make sure that you pass in as many target sizes as the batch dimension of the logits");const l=a.dims.at(1),c=a.sigmoid(),d=c.max(-1).tolist(),h=o.tolist().map(p=>p.map(w=>Xm(w))),_=[];for(let p=0;p<i;++p){const w=s!==null?s[p]:null;w!==null&&(h[p]=h[p].map(A=>A.map((S,C)=>S*w[(C+1)%2])));const v=d[p],y=[],M=[],T=[];for(let A=0;A<l;++A){const S=v[A];if(S<=r)continue;const C=h[p][A],I=c[p][A];y.push(S),T.push(C);const x=dA(I.gt(n),t[p]);M.push(x)}_.push({scores:y,boxes:T,labels:this.batch_decode(M)})}return _}},k(ua,"tokenizer_class",Te),k(ua,"image_processor_class",ut),ua);function fA(e,t,r,n,s,a){let o="";for(let i=0;i<t;++i){for(let l=0;l<r;++l)o+=n+`<row_${i+1}_col_${l+1}>`+s.repeat(e);o+=`
38
+ `}return o+=`
39
+ ${n}${a}`+s.repeat(e)+`${n}`,o}function _A(e,t,r,n){return`${t}${n}`+r.repeat(e)+`${t}`}function pA(e,t,r,n,s,a){return e===0&&t===0?_A(r,n,s,a):fA(r,e,t,n,s,a)}var es,G_=(es=class extends Ee{constructor(){super(...arguments);k(this,"fake_image_token","<fake_token_around_image>");k(this,"image_token","<image>");k(this,"global_img_token","<global-img>")}async _call(t,r=null,n={}){n.return_row_col_info??(n.return_row_col_info=!0);let s;r&&(s=await this.image_processor(r,n)),Array.isArray(t)||(t=[t]);const a=s.rows??[new Array(t.length).fill(0)],o=s.cols??[new Array(t.length).fill(0)],i=this.config.image_seq_len,l=[],c=[];for(let h=0;h<t.length;++h){const _=t[h],p=a[h],w=o[h];l.push(OM(_,this.image_token));const v=p.map((T,A)=>pA(T,w[A],i,this.fake_image_token,this.image_token,this.global_img_token)),y=_.split(this.image_token);if(y.length===0)throw new Error("The image token should be present in the text.");let M=y[0];for(let T=0;T<v.length;++T)M+=v[T]+y[T+1];c.push(M)}return{...this.tokenizer(c),...s}}},k(es,"image_processor_class",ut),k(es,"tokenizer_class",Te),k(es,"uses_processor_config",!0),es),ts,mA=(ts=class extends Ee{constructor(e,t,r){super(e,t,r),this.image_tag=this.config.image_tag,this.image_start_tag=this.config.image_start_tag,this.image_end_tag=this.config.image_end_tag,this.num_image_tokens=this.config.num_image_tokens}async _call(e,{images:t=null,chat_template:r="default"}={}){t?Array.isArray(t)||(t=[t]):t=await Promise.all(e.filter(v=>v.images).flatMap(v=>v.images).map(v=>Gt.read(v)));const n=this.tokenizer,s=n.apply_chat_template(e,{tokenize:!1,add_generation_prompt:!0,chat_template:r}),a=v=>n.encode(v,{add_special_tokens:!1}),o=s.split(this.image_tag),i=o.length-1;if(t.length!==i)throw new Error(`Number of images provided (${t.length}) does not match number of "${this.image_tag}" image tags (${i})`);const[l,c,d]=n.convert_tokens_to_ids([this.image_tag,this.image_start_tag,this.image_end_tag]);let h=a(o[0]),_=new Array(h.length).fill(!1);for(let v=1;v<o.length;++v){const y=new Array(this.num_image_tokens).fill(l),M=a(o[v]);h=er(h,[c],y,[d],M);const T=new Array(this.num_image_tokens).fill(!0);_=er(_,[!1],T,[!1],new Array(M.length).fill(!1))}const p=[1,h.length],w={input_ids:new j("int64",h,p),attention_mask:new j("int64",new Array(h.length).fill(1),p),images_seq_mask:new j("bool",_,p),images_emb_mask:new j("bool",new Array(i*this.num_image_tokens).fill(!0),[1,i,this.num_image_tokens])};if(t&&t.length>0){const v=await this.image_processor(t);return v.pixel_values.unsqueeze_(0),{...w,...v}}return w}},k(ts,"image_processor_class",ut),k(ts,"tokenizer_class",Te),k(ts,"uses_processor_config",!0),ts),da,gA=(da=class extends Ee{async _call(e=null,t=null,r={}){if(!e&&!t)throw new Error("Either text or images must be provided");const n=e?this.tokenizer(e,r):{},s=t?await this.image_processor(t,r):{};return{...n,...s}}},k(da,"tokenizer_class",Te),k(da,"image_processor_class",ut),da),ha,wA=(ha=class extends Ee{async _call(e,t=null,r={}){const{image_rows:n,image_cols:s,image_sizes:a,...o}=await this.image_processor(e,{...r,return_row_col_info:!0});if(t){const i=this.config.image_token??"<image>",{tile_size:l=512,downsample_factor:c=2,encoder_patch_size:d=16,use_thumbnail:h=!0}=this.image_processor.config,_=T=>Math.ceil(Math.floor(T/d)/c),p=_(l)**2,w=this.config.image_start_token??"<|image_start|>",v=this.config.image_end_token??"<|image_end|>",y=this.config.image_thumbnail??"<|img_thumbnail|>";Array.isArray(t)||(t=[t]);let M=0;t=t.map(T=>{const A=T.split(i);return A[0]+A.slice(1).map(S=>{const C=M++,[I,x]=a[C],R=n[C],z=s[C],$=_(I)*_(x);let Q=w;if(R>1||z>1){const H=i.repeat(p);for(let D=0;D<R;++D)for(let O=0;O<z;++O)Q+=`<|img_row_${D+1}_col_${O+1}|>`+H;h&&(Q+=y+i.repeat($))}else Q+=i.repeat($);return Q+v+S}).join("")})}return{...o,...t?this.tokenizer(t,r):{}}}},k(ha,"tokenizer_class",Te),k(ha,"image_processor_class",ut),ha),rs,vA=(rs=class extends Ee{async _call(e,t=null,r={}){const n=await this.image_processor(e,r);if(t){const[a,o]=n.pixel_values.dims.slice(-2),{image_token:i,patch_size:l,num_additional_image_tokens:c}=this.config,d=Math.floor(a/l)*Math.floor(o/l)+c;t=structuredClone(t),Array.isArray(t)||(t=[t]);for(let h=0;h<t.length;++h)t[h]=t[h].replace(i,i.repeat(d))}const s=t?this.tokenizer(t,r):{};return{...n,...s}}},k(rs,"tokenizer_class",Te),k(rs,"image_processor_class",ut),k(rs,"uses_processor_config",!0),rs),$_={char:["char_decode",1],bpe:["bpe_decode",2],wp:["wp_decode",102]},fa,yA=(fa=class extends Ee{get char_tokenizer(){return this.components.char_tokenizer}get bpe_tokenizer(){return this.components.bpe_tokenizer}get wp_tokenizer(){return this.components.wp_tokenizer}_decode_helper(e,t){if(!$_.hasOwnProperty(t))throw new Error(`Format ${t} is not supported.`);const[r,n]=$_[t],s=this[r].bind(this),[a,o]=e.dims,i=[],l=[],c=e.tolist();for(let h=0;h<a;++h){const _=c[h],p=[],w=[];for(let y=1;y<o;++y){const[M,T]=Ue(nt(_[y]));if(w.push(M),T==n)break;p.push(T)}const v=w.length>0?w.reduce((y,M)=>y*M,1):0;l.push(p),i.push(v)}return[s(l),i]}char_decode(e){return this.char_tokenizer.batch_decode(e).map(t=>t.replaceAll(" ",""))}bpe_decode(e){return this.bpe_tokenizer.batch_decode(e)}wp_decode(e){return this.wp_tokenizer.batch_decode(e).map(t=>t.replaceAll(" ",""))}batch_decode([e,t,r]){const[n,s]=this._decode_helper(e,"char"),[a,o]=this._decode_helper(t,"bpe"),[i,l]=this._decode_helper(r,"wp"),c=[],d=[];for(let h=0;h<n.length;++h){const[_,p]=Ue([s[h],o[h],l[h]]);c.push([n[h],a[h],i[h]][p]),d.push(_)}return{generated_text:c,scores:d,char_preds:n,bpe_preds:a,wp_preds:i}}static async from_pretrained(...e){const t=await super.from_pretrained(...e),r=await Te.from_pretrained("Xenova/gpt2"),n=await Te.from_pretrained("Xenova/bert-base-uncased");return t.components={image_processor:t.image_processor,char_tokenizer:t.tokenizer,bpe_tokenizer:r,wp_tokenizer:n},t}async _call(e,t=null){const r=await this.image_processor(e);return t&&(r.labels=this.tokenizer(t).input_ids),r}},k(fa,"tokenizer_class",Te),k(fa,"image_processor_class",ut),fa),_a,bA=(_a=class extends Ee{async _call(e){return await this.feature_extractor(e)}},k(_a,"tokenizer_class",Te),k(_a,"feature_extractor_class",Lt),_a),pa,MA=(pa=class extends Ee{},k(pa,"tokenizer_class",Te),k(pa,"image_processor_class",ut),pa),on="<image>";function xA(e,t,r,n,s){return`${n.repeat(r*s)}${t}${e}
40
+ `}var ns,kA=(ns=class extends Ee{async _call(e,t=null,r={}){t||(ue.warn("You are using PaliGemma without a text prefix. It will perform as a picture-captioning model."),t=""),Array.isArray(e)||(e=[e]),Array.isArray(t)||(t=[t]);const n=this.tokenizer.bos_token,s=this.image_processor.config.image_seq_length;let a;t.some(l=>l.includes(on))?a=t.map(l=>{const c=l.replaceAll(on,on.repeat(s)),d=c.lastIndexOf(on),h=d===-1?0:d+on.length;return c.slice(0,h)+n+c.slice(h)+`
41
+ `}):(ue.warn("You are passing both `text` and `images` to `PaliGemmaProcessor`. The processor expects special image tokens in the text, as many tokens as there are images per each text. It is recommended to add `<image>` tokens in the very beginning of your text. For this call, we will infer how many images each text has and add special tokens."),a=t.map(l=>xA(l,n,s,on,e.length)));const o=this.tokenizer(a,r);return{...await this.image_processor(e,r),...o}}},k(ns,"tokenizer_class",Te),k(ns,"image_processor_class",ut),k(ns,"uses_processor_config",!1),ns),V_="<|image|>",TA=/<\|image_\d+\|>/g,ma,EA=(ma=class extends Ee{async _call(e,t=null,{padding:r=!0,truncation:n=!0,num_crops:s=null}={}){Array.isArray(e)||(e=[e]);let a,o;if(t){o=await this.image_processor(t,{num_crops:s});const{num_img_tokens:i}=o,l=e.map((d,h)=>d.split(TA).join(V_.repeat(i[h])));a=this.tokenizer(l,{padding:r,truncation:n});const c=this.tokenizer._tokenizer.token_to_id(V_);a.input_ids.map_(d=>d==c?-d:d)}else a=this.tokenizer(e);return{...a,...o}}},k(ma,"image_processor_class",ut),k(ma,"tokenizer_class",Te),ma),ss,AA=(ss=class extends Ee{async _call(e,t=null,r={}){const n=await this.image_processor(e,r);if(t){const[a,o]=n.pixel_values.dims.slice(-2),{image_token:i,image_break_token:l,image_end_token:c,patch_size:d,spatial_merge_size:h}=this.config,_=d*h,p=Math.floor(a/_),w=Math.floor(o/_);t=structuredClone(t),Array.isArray(t)||(t=[t]);for(let v=0;v<t.length;++v){const y=i.repeat(w),M=y+l,T=y+c,A=M.repeat(p-1)+T;t[v]=t[v].replace(i,A)}}const s=t?this.tokenizer(t,r):{};return{...n,...s}}},k(ss,"tokenizer_class",Te),k(ss,"image_processor_class",ut),k(ss,"uses_processor_config",!0),ss),Ai,CA=(Ai=class extends Ee{async _call(e){return await this.feature_extractor(e)}post_process_speaker_diarization(...e){return this.feature_extractor.post_process_speaker_diarization(...e)}get sampling_rate(){return this.feature_extractor.config.sampling_rate}},k(Ai,"feature_extractor_class",Hm),Ai),pg=class extends ic{},SA=class extends pg{},Ci,mg=(Ci=class extends Ee{async _call(...e){return await this.image_processor(...e)}post_process_masks(...e){return this.image_processor.post_process_masks(...e)}reshape_input_points(...e){return this.image_processor.reshape_input_points(...e)}},k(Ci,"image_processor_class",ut),Ci),gg=class extends mg{},PA=class extends gg{},ga,FA=(ga=class extends Ee{async _call(e){return await this.feature_extractor(e)}},k(ga,"tokenizer_class",Te),k(ga,"feature_extractor_class",Lt),ga),as,LA=(as=class extends Ee{async _call(e,t=null,r={}){if(Array.isArray(e))throw new Error("Batched inputs are not supported yet.");let n={};if(t){const a=t.length,{input_features:o}=await this.feature_extractor(t,{...r,max_length:a}),i=Math.round(a/this.config.encoder_ds_factor+1e-4),l=1+Math.ceil(i/this.config.stack_factor);n.audio_token_len=[l],n.audio_values=o;const c=this.config.audio_placeholder;if(!e.includes(c))throw new Error(`The input text does not contain the image token ${c}.`);e=e.replaceAll(c,c.repeat(l))}return{...this.tokenizer(e,{add_special_tokens:!1,...r}),...n}}},k(as,"tokenizer_class",Te),k(as,"feature_extractor_class",Lt),k(as,"uses_processor_config",!0),as),na="[AUDIO]",IA="[BEGIN_AUDIO]",OA=375;function NA(e,t){const r=[];for(let n=0;n<e.length;n+=t)r.push(e.subarray(n,Math.min(n+t,e.length)));return r}var os,DA=(os=class extends Ee{async _call(e,t=null,r={}){if(Array.isArray(e))throw new Error("Batched inputs are not supported yet.");const n={};if(t){if(!e.includes(na))throw new Error(`The input text does not contain the audio token ${na}.`);Array.isArray(t)||(t=[t]);const a=e.split(na),o=a.length-1;if(o!==t.length)throw new Error(`The number of audio inputs (${t.length}) does not match the number of audio tokens in the text (${o}).`);const i=this.feature_extractor.config.n_samples,l=t.map(p=>NA(p,i)),c=l.map(p=>p.length),d=l.flat(),h=(await Promise.all(d.map(p=>this.feature_extractor(p,r)))).map(p=>p.input_features);n.audio_values=h.length>1?De(h,0):h[0];let _=a[0];for(let p=0;p<c.length;++p){_+=IA;for(let w=0;w<c[p];++w)_+=na.repeat(OA);_+=a[p+1]}e=_}return{...this.tokenizer(e,{add_special_tokens:!1,...r}),...n}}},k(os,"tokenizer_class",Te),k(os,"feature_extractor_class",Lt),k(os,"uses_processor_config",!1),os),U_=32,bi=6,sa=8,zA=10,BA=32,is,RA=(is=class extends Ee{get num_mel_frames_first_audio_chunk(){return(bi+1)*sa}get num_samples_first_audio_chunk(){const{hop_length:e,n_fft:t}=this.feature_extractor.config;return(this.num_mel_frames_first_audio_chunk-1)*e+Math.floor(t/2)}get num_samples_per_audio_chunk(){const{hop_length:e,n_fft:t}=this.feature_extractor.config;return sa*e+t}get num_right_pad_tokens(){return bi+1+zA}get audio_length_per_tok(){return sa}get raw_audio_length_per_tok(){return sa*this.feature_extractor.config.hop_length}async _call(e,{is_streaming:t=!1,is_first_audio_chunk:r=!0}={}){if(st(e,"VoxtralRealtimeProcessor"),!t&&!r)throw new Error("In non-streaming mode (`is_streaming=false`), `is_first_audio_chunk` must be `true`.");if(r)if(t){const n=U_*this.raw_audio_length_per_tok,s=new Float32Array(n+e.length);s.set(e,n);const a=await this.feature_extractor(s,{center:!0}),i=1+(U_+bi),l=new BigInt64Array(i).fill(BigInt(BA));return l[0]=1n,{input_ids:new j("int64",l,[1,i]),...a}}else{const n=this.num_right_pad_tokens*this.raw_audio_length_per_tok,s=new Float32Array(e.length+n);return s.set(e),await this.feature_extractor(s,{center:!0})}else return await this.feature_extractor(e,{center:!1})}},k(is,"tokenizer_class",Te),k(is,"feature_extractor_class",Lt),k(is,"uses_processor_config",!1),is),wa,GA=(wa=class extends Ee{async _call(e){return await this.feature_extractor(e)}},k(wa,"tokenizer_class",Te),k(wa,"feature_extractor_class",Lt),wa),va,$A=(va=class extends Ee{async _call(e){return await this.feature_extractor(e)}},k(va,"tokenizer_class",Te),k(va,"feature_extractor_class",Lt),va),ya,VA=(ya=class extends Ee{async _call(e){return await this.feature_extractor(e)}},k(ya,"tokenizer_class",Te),k(ya,"feature_extractor_class",Lt),ya),UA=class{static async from_pretrained(e,t={}){const r=await nr(e,gs,!0,t),{image_processor_type:n,feature_extractor_type:s,processor_class:a}=r;if(a&&ml[a])return ml[a].from_pretrained(e,t);if(!n&&!s)throw new Error("No `image_processor_type` or `feature_extractor_type` found in the config.");const o={};if(n){const l=Ba[n.replace(/Fast$/,"")];if(!l)throw new Error(`Unknown image_processor_type: '${n}'.`);o.image_processor=new l(r)}if(s){const l=Ba[s];if(l)o.image_processor=new l(r);else{const c=rc[s];if(!c)throw new Error(`Unknown feature_extractor_type: '${s}'.`);o.feature_extractor=new c(r)}}const i={};return new Ee(i,o,null)}};async function jA(e,t){return await nr(e,"config.json",!0,t)}function un(e){const t={};let r={};switch(e.model_type){case"llava":case"paligemma":case"gemma3":case"florence2":case"llava_onevision":case"idefics3":case"granite_speech":case"ultravox":case"voxtral":case"voxtral_realtime":case"smolvlm":case"gemma3n":case"gemma4":case"lfm2_vl":case"chatterbox":case"lighton_ocr":case"glm_ocr":case"mistral3":case"qwen2_5_vl":case"qwen3_vl":case"qwen3_vl_moe":r=un(e.text_config);break;case"moondream1":r=un(e.phi_config);break;case"musicgen":r=un(e.decoder);break;case"multi_modality":r=un(e.language_config);break;case"gpt2":case"gptj":case"jais":case"codegen":case"gpt_bigcode":t.num_heads="n_head",t.num_layers="n_layer",t.hidden_size="n_embd";break;case"gpt_neox":case"stablelm":case"opt":case"falcon":case"modernbert-decoder":t.num_heads="num_attention_heads",t.num_layers="num_hidden_layers",t.hidden_size="hidden_size";break;case"gpt_oss":case"llama":case"llama4_text":case"nanochat":case"apertus":case"arcee":case"afmoe":case"lfm2":case"lfm2_moe":case"smollm3":case"olmo":case"olmo2":case"olmo3":case"mobilellm":case"granite":case"granitemoehybrid":case"cohere":case"cohere2":case"mistral":case"voxtral_realtime_text":case"voxtral_realtime_encoder":case"starcoder2":case"qwen2":case"qwen2_moe":case"qwen2_vl":case"qwen2_vl_text":case"qwen2_5_vl_text":case"qwen3_moe":case"qwen3_vl_text":case"qwen3_vl_moe_text":case"phi":case"phi3":case"phi3_v":case"llava_qwen2":t.num_heads="num_key_value_heads",t.num_layers="num_hidden_layers",t.hidden_size="hidden_size",t.num_attention_heads="num_attention_heads",t.dim_kv="head_dim";break;case"qwen3":case"solar_open":case"glm_ocr_text":case"gemma":case"gemma2":case"vaultgemma":case"gemma3_text":case"gemma3n_text":case"gemma4_text":case"glm":case"helium":case"ernie4_5":case"hunyuan_v1_dense":case"falcon_h1":case"nemotron_h":case"ministral":case"ministral3":t.num_heads="num_key_value_heads",t.num_layers="num_hidden_layers",t.dim_kv="head_dim";break;case"openelm":t.num_heads="num_kv_heads",t.num_layers="num_transformer_layers",t.dim_kv="head_dim";break;case"gpt_neo":case"donut-swin":t.num_heads="num_heads",t.num_layers="num_layers",t.hidden_size="hidden_size";break;case"bloom":t.num_heads="n_head",t.num_layers="n_layer",t.hidden_size="hidden_size";break;case"mpt":t.num_heads="n_heads",t.num_layers="n_layers",t.hidden_size="d_model";break;case"exaone":t.num_heads="num_key_value_heads",t.num_layers="num_layers",t.dim_kv="head_dim",t.num_attention_heads="num_attention_heads";break;case"youtu":case"deepseek_v3":case"glm_moe_dsa":case"mistral4":t.num_heads="num_key_value_heads",t.num_layers="num_hidden_layers",t.dim_kv="qk_head_dim",t.num_attention_heads="num_attention_heads";break;case"t5":case"mt5":case"longt5":t.num_decoder_layers="num_decoder_layers",t.num_decoder_heads="num_heads",t.decoder_dim_kv="d_kv",t.num_encoder_layers="num_layers",t.num_encoder_heads="num_heads",t.encoder_dim_kv="d_kv";break;case"bart":case"mbart":case"marian":case"whisper":case"lite-whisper":case"m2m_100":case"blenderbot":case"blenderbot-small":case"florence2_language":t.num_decoder_layers="decoder_layers",t.num_decoder_heads="decoder_attention_heads",t.decoder_hidden_size="d_model",t.num_encoder_layers="encoder_layers",t.num_encoder_heads="encoder_attention_heads",t.encoder_hidden_size="d_model";break;case"speecht5":t.num_decoder_layers="decoder_layers",t.num_decoder_heads="decoder_attention_heads",t.decoder_hidden_size="hidden_size",t.num_encoder_layers="encoder_layers",t.num_encoder_heads="encoder_attention_heads",t.encoder_hidden_size="hidden_size";break;case"trocr":t.num_encoder_layers=t.num_decoder_layers="decoder_layers",t.num_encoder_heads=t.num_decoder_heads="decoder_attention_heads",t.encoder_hidden_size=t.decoder_hidden_size="d_model";break;case"musicgen_decoder":t.num_encoder_layers=t.num_decoder_layers="num_hidden_layers",t.num_encoder_heads=t.num_decoder_heads="num_attention_heads",t.encoder_hidden_size=t.decoder_hidden_size="hidden_size";break;case"moonshine":t.num_decoder_layers="decoder_num_hidden_layers",t.num_decoder_heads="decoder_num_key_value_heads",t.num_encoder_layers="encoder_num_hidden_layers",t.num_encoder_heads="encoder_num_key_value_heads",t.encoder_hidden_size=t.decoder_hidden_size="hidden_size";break;case"cohere_asr":t.num_decoder_layers="num_hidden_layers",t.num_decoder_heads="num_key_value_heads",t.decoder_hidden_size="hidden_size",t.decoder_dim_kv="head_dim";const{num_hidden_layers:s,num_attention_heads:a,hidden_size:o}=e.encoder_config;r={num_encoder_layers:s,num_encoder_heads:a,encoder_hidden_size:o,encoder_dim_kv:e.head_dim};break;case"vision-encoder-decoder":const i=un(e.decoder),l="num_decoder_layers"in i,c=Ze(e,["model_type","is_encoder_decoder"]);return l?(c.num_decoder_layers=i.num_decoder_layers,c.num_decoder_heads=i.num_decoder_heads,c.decoder_hidden_size=i.decoder_hidden_size,c.num_encoder_layers=i.num_encoder_layers,c.num_encoder_heads=i.num_encoder_heads,c.encoder_hidden_size=i.encoder_hidden_size):(c.num_layers=i.num_layers,c.num_heads=i.num_heads,c.hidden_size=i.hidden_size),c}const n={...r,...Ze(e,["model_type","multi_query","is_encoder_decoder"])};for(const s in t)n[s]=e[t[s]];return n}function Qa(e,t){e instanceof wl||(e=new wl(e));const r=(t==null?void 0:t.prefix)??"past_key_values",n=r==="present"?"present":"past",s=new Set;if(["lfm2","lfm2_moe"].includes(e.model_type)){const{layer_types:a}=e;for(let o=0;o<a.length;++o)if(a[o]==="full_attention")s.add(`${r}.${o}.key`),s.add(`${r}.${o}.value`);else if(a[o]==="conv")s.add(`${n}_conv.${o}`);else throw new Error(`Unsupported layer type: ${a[o]}`);return s}else if(["granitemoehybrid","falcon_h1","nemotron_h"].includes(e.model_type)){const a=e,o=a.layer_types??a.layers_block_type,i=a.num_hidden_layers??(o==null?void 0:o.length);for(let l=0;l<i;++l)(!o||o[l]==="mamba")&&(s.add(`${n}_conv.${l}`),s.add(`${n}_ssm.${l}`)),(!o||o[l]==="attention")&&(s.add(`${r}.${l}.key`),s.add(`${r}.${l}.value`));return s}else if(["qwen3_next","qwen3_5_text","qwen3_5_moe_text","olmo_hybrid"].includes(e.model_type)){const{layer_types:a}=e;for(let o=0;o<a.length;++o)if(a[o]==="full_attention")s.add(`${r}.${o}.key`),s.add(`${r}.${o}.value`);else if(a[o]==="linear_attention")e.model_type==="olmo_hybrid"?(s.add(`${n}_conv.${o}.key`),s.add(`${n}_conv.${o}.value`),s.add(`${n}_conv.${o}.query`)):s.add(`${n}_conv.${o}`),s.add(`${n}_recurrent.${o}`);else throw new Error(`Unsupported layer type: ${a[o]}`);return s}else if(["gemma4","gemma4_text"].includes(e.model_type)){const a=e.model_type==="gemma4"?e.text_config:e,o=a.num_hidden_layers,i=a.num_kv_shared_layers??0,l=o-i;for(let c=0;c<l;++c)s.add(`${r}.${c}.key`),s.add(`${r}.${c}.value`);return s}else if(["lfm2_vl","qwen3_5","qwen3_5_moe","voxtral_realtime"].includes(e.model_type)){let a;return e.model_type==="voxtral_realtime"&&(t==null?void 0:t.session_name)==="audio_encoder"?a=e.audio_config:a=e.text_config,Qa(a,t)}return qA(e,{prefix:r})}function qA(e,{prefix:t="past_key_values"}={}){const r=new Set,n=e.normalized_config;if(n.is_encoder_decoder&&"num_encoder_heads"in n&&"num_decoder_heads"in n)for(let s=0;s<n.num_decoder_layers;++s)r.add(`${t}.${s}.encoder.key`),r.add(`${t}.${s}.encoder.value`),r.add(`${t}.${s}.decoder.key`),r.add(`${t}.${s}.decoder.value`);else if(n.multi_query)for(let s=0;s<n.num_layers;++s)r.add(`${t}.${s}.key_value`);else for(let s=0;s<n.num_layers;++s)r.add(`${t}.${s}.key`),r.add(`${t}.${s}.value`);return r}var wl=class vl{constructor(t){k(this,"model_type",null);k(this,"is_encoder_decoder",!1);k(this,"max_position_embeddings");k(this,"transformers.js_config");Object.assign(this,t),this.normalized_config=un(this)}static async from_pretrained(t,{progress_callback:r=null,config:n=null,cache_dir:s=null,local_files_only:a=!1,revision:o="main"}={}){n&&!(n instanceof vl)&&(n=new vl(n));const i=n??await jA(t,{progress_callback:r,config:n,cache_dir:s,local_files_only:a,revision:o});return new this(i)}},ws=class{static async from_pretrained(...e){return wl.from_pretrained(...e)}};function wg(e,t,r){return e?typeof e=="object"&&e!==null?e.hasOwnProperty(t)?+e[t]:e.hasOwnProperty(r)?+e[r]:0:+e:0}function vg(e,t){const r=[];for(let n=0;n<t;++n)r.push(`${e}_data${n===0?"":"_"+n}`);return r}async function WA(e,t,r,n){const s=`${t}${n}.onnx`,a=`${r.subfolder??""}/${s}`;return await za(e,a,!0,r,_e.IS_NODE_ENV)}async function HA(e,t,r,n,s,a={}){const o=`${t}${r}.onnx`,i=_e.IS_NODE_ENV;let l=[];const c=wg(s,o,t);if(c>0){if(c>b_)throw new Error(`The number of external data chunks (${c}) exceeds the maximum allowed value (${b_}).`);const d=vg(o,c);for(const h of d){const _=`${n.subfolder??""}/${h}`;l.push(new Promise(async(p,w)=>{const v=await za(e,_,!0,n,i);p(v instanceof Uint8Array?{path:h,data:v}:h)}))}}else a.externalData!==void 0&&(l=a.externalData.map(async d=>{if(typeof d.data=="string"){const h=await za(e,d.data,!0,n);return{...d,data:h}}return d}));return Promise.all(l)}async function QA(e,t,r,n=!1,s=void 0){var T;let a=((T=r.config)==null?void 0:T["transformers.js_config"])??{};const o=Tm(r.device??a.device,t,{warn:A=>ue.info(A)}),i=wT(o),l=a.device_config??{};l.hasOwnProperty(o)&&(a={...a,...l[o]});const c=Em(r.dtype??a.dtype,t,o,{configDtype:a.dtype,warn:A=>ue.info(A)});if(_l.hasOwnProperty(c)){if(o==="webgpu"&&!_e.IS_NODE_ENV&&c===qe.fp16&&!await bT())throw new Error(`The device (${o}) does not support fp16.`)}else throw new Error(`Invalid dtype: ${c}. Should be one of: ${Object.keys(qe).join(", ")}`);const d=_l[c],h={...r.session_options};h.executionProviders??(h.executionProviders=i);const _=a.free_dimension_overrides;_?h.freeDimensionOverrides??(h.freeDimensionOverrides=_):o.startsWith("webnn")&&!h.freeDimensionOverrides&&ue.warn(`WebNN does not currently support dynamic shapes and requires 'free_dimension_overrides' to be set in config.json, preferably as a field within config["transformers.js_config"]["device_config"]["${o}"]. When 'free_dimension_overrides' is not set, you may experience significant performance degradation.`);const p=WA(e,t,r,d),w=r.use_external_data_format??a.use_external_data_format,v=await HA(e,t,d,r,w,h);if(v.length>0&&(!_e.IS_NODE_ENV||v.some(A=>typeof A!="string"))&&(h.externalData=v),n&&o==="webgpu"){const A=Qa(r.config,{prefix:"present",session_name:s});if(A.size>0&&!Yl()){const S={};for(const C of A)S[C]="gpu-buffer";h.preferredOutputLocation=S}}return{buffer_or_path:await p,session_options:h,session_config:{dtype:c,device:o}}}async function XA(e,t,r,n=void 0){return Object.fromEntries(await Promise.all(Object.keys(t).map(async s=>{const a=(n==null?void 0:n[s])??!1,{buffer_or_path:o,session_options:i,session_config:l}=await QA(e,t[s],r,a,s),c=await Mm(o,i,l);return[s,c]})))}function yg(e){for(let t in e)km(e[t])?e[t]=new j(e[t]):typeof e[t]=="object"&&yg(e[t]);return e}async function xe(e,t){const r=YA(e,t);try{const n=Object.fromEntries(Object.entries(r).map(([a,o])=>{const i=o.ort_tensor;return _e.IS_NODE_ENV&&typeof Float16Array<"u"&&i.cpuData instanceof Float16Array&&(i.cpuData=new Uint16Array(i.cpuData.buffer)),[a,i]})),s=await xm(e,n);return yg(s)}catch(n){const s=Object.fromEntries(Object.entries(r).map(([a,o])=>{const i={type:o.type,dims:o.dims,location:o.location};return i.location!=="gpu-buffer"&&(i.data=o.data),[a,i]}));throw ue.error(`An error occurred during model execution: "${n}".`),ue.error("Inputs given to model:",s),n}}function YA(e,t){const r=Object.create(null),n=[];for(const o of e.inputNames){const i=t[o];if(!(i instanceof j)){n.push(o);continue}r[o]=Yl()?i.clone():i}if(n.length>0)throw new Error(`An error occurred during model execution: "Missing the following inputs: ${n.join(", ")}.`);const s=Object.keys(t).length,a=e.inputNames.length;if(s>a){let o=Object.keys(t).filter(i=>!e.inputNames.includes(i));ue.warn(`WARNING: Too many inputs were provided (${s} > ${a}). The following inputs will be ignored: "${o.join(", ")}".`)}return r}var Qe=class{},oe=class extends Qe{constructor({logits:e,...t}){super(),this.logits=e;const r=Object.values(t);r.length>0&&(this.attentions=r)}},We=class extends Qe{constructor({logits:e}){super(),this.logits=e}},Xe=class extends Qe{constructor({logits:e}){super(),this.logits=e}},dt=class extends Qe{constructor({start_logits:e,end_logits:t}){super(),this.start_logits=e,this.end_logits=t}},Xr=class extends Qe{constructor({logits:e}){super(),this.logits=e}},JA=class extends Qe{constructor({alphas:e}){super(),this.alphas=e}},jt=class extends wt{_call(e,t){throw Error("`_call` should be implemented in a subclass")}},KA=class extends wt{_call(e,t){throw Error("`_call` should be implemented in a subclass")}},yl=class extends wt{constructor(){super(),this.processors=[]}push(e){this.processors.push(e)}extend(e){this.processors.push(...e)}_call(e,t){let r=t;for(const n of this.processors)r=n(e,r);return r}[Symbol.iterator](){return this.processors.values()}},ZA=class extends jt{constructor(e){super(),this.bos_token_id=e}_call(e,t){for(let r=0;r<e.length;++r)if(e[r].length===1){const n=t[r].data;n.fill(-1/0),n[this.bos_token_id]=0}return t}},eC=class extends jt{constructor(e,t){super(),this.max_length=e,this.eos_token_id=Array.isArray(t)?t:[t]}_call(e,t){for(let r=0;r<e.length;++r)if(e[r].length===this.max_length-1){const n=t[r].data;n.fill(-1/0);for(const s of this.eos_token_id)n[s]=0}return t}},tC=class extends jt{constructor(e){super(),this.suppress_tokens=e}_call(e,t){for(let r=0;r<e.length;++r){const n=t[r].data;for(const s of this.suppress_tokens)n[s]=-1/0}return t}},bg=class extends jt{constructor(e,t){super(),this.begin_suppress_tokens=e,this.begin_index=t}_call(e,t){for(let r=0;r<e.length;++r)if(e[r].length===this.begin_index){const n=t[r].data;for(const s of this.begin_suppress_tokens)n[s]=-1/0}return t}},rC=class extends jt{constructor(e,t){super(),this.eos_token_id=Array.isArray(e.eos_token_id)?e.eos_token_id[0]:e.eos_token_id,this.no_timestamps_token_id=e.no_timestamps_token_id,this.timestamp_begin=this.no_timestamps_token_id+1,this.begin_index=t.length,t.at(-1)===this.no_timestamps_token_id&&(this.begin_index-=1),this.max_initial_timestamp_index=e.max_initial_timestamp_index}_call(e,t){for(let r=0;r<e.length;++r){const n=t[r].data;if(n[this.no_timestamps_token_id]=-1/0,e[r].length===this.begin_index){n.subarray(0,this.timestamp_begin).fill(-1/0);continue}const s=e[r].slice(this.begin_index),a=s.length>=1&&s[s.length-1]>=this.timestamp_begin,o=s.length<2||s[s.length-2]>=this.timestamp_begin;if(a&&(o?n.subarray(this.timestamp_begin).fill(-1/0):n.subarray(0,this.eos_token_id).fill(-1/0)),e[r].length===this.begin_index&&this.max_initial_timestamp_index!==null){const d=this.timestamp_begin+this.max_initial_timestamp_index;n.subarray(d+1).fill(-1/0)}const i=aT(n),l=Math.log(i.subarray(this.timestamp_begin).map(Math.exp).reduce((d,h)=>d+h)),c=Ue(i.subarray(0,this.timestamp_begin))[0];l>c&&n.subarray(0,this.timestamp_begin).fill(-1/0)}return t}},nC=class extends jt{constructor(e){super(),this.no_repeat_ngram_size=e}getNgrams(e){const t=e.length,r=[];for(let s=0;s<t+1-this.no_repeat_ngram_size;++s){const a=[];for(let o=0;o<this.no_repeat_ngram_size;++o)a.push(e[s+o]);r.push(a.map(Number))}const n=new Map;for(const s of r){const a=s.slice(0,s.length-1),o=JSON.stringify(a),i=n.get(o)??[];i.push(s[s.length-1]),n.set(o,i)}return n}getGeneratedNgrams(e,t){const r=t.slice(t.length+1-this.no_repeat_ngram_size,t.length);return e.get(JSON.stringify(r.map(Number)))??[]}calcBannedNgramTokens(e){const t=[];if(e.length+1<this.no_repeat_ngram_size)return t;{const r=this.getNgrams(e);return this.getGeneratedNgrams(r,e)}}_call(e,t){for(let r=0;r<e.length;++r){const n=t[r].data,s=this.calcBannedNgramTokens(e[r]);for(const a of s)n[a]=-1/0}return t}},sC=class extends jt{constructor(e){super(),this.penalty=e}_call(e,t){for(let r=0;r<e.length;++r){const n=t[r].data;for(const s of new Set(e[r])){const a=Number(s);n[a]<0?n[a]*=this.penalty:n[a]/=this.penalty}}return t}},aC=class extends jt{constructor(e,t){super(),this.min_length=e,this.eos_token_id=Array.isArray(t)?t:[t]}_call(e,t){for(let r=0;r<e.length;++r)if(e[r].length<this.min_length){const n=t[r].data;for(const s of this.eos_token_id)n[s]=-1/0}return t}},oC=class extends jt{constructor(e,t,r){super(),this.prompt_length_to_skip=e,this.min_new_tokens=t,this.eos_token_id=Array.isArray(r)?r:[r]}_call(e,t){for(let r=0;r<e.length;++r)if(e[r].length-this.prompt_length_to_skip<this.min_new_tokens){const s=t[r].data;for(const a of this.eos_token_id)s[a]=-1/0}return t}},iC=class extends jt{constructor(e,t){super(),this.bad_words_ids=e,this.eos_token_id=Array.isArray(t)?t:[t]}_call(e,t){for(let r=0;r<e.length;++r){const n=t[r].data,s=e[r];for(const a of this.bad_words_ids){if(s.length<a.length-1)continue;let o=!0;for(let i=1;i<=a.length-1;++i)if(a.at(-i-1)!=s.at(-i)){o=!1;break}o&&(n[a.at(-1)]=-1/0)}}return t}},lC=class extends jt{constructor(e){if(super(),e<=1)throw new Error(`Require guidance scale >1 to use the classifier free guidance processor, got guidance scale ${e}.`);this.guidance_scale=e}_call(e,t){if(t.dims[0]!==2*e.length)throw new Error(`Logits should have twice the batch size of the input ids, the first half of batches corresponding to the conditional inputs, and the second half of batches corresponding to the unconditional inputs. Got batch size ${t.dims[0]} for the logits and ${e.length} for the input ids.`);const r=e.length,n=t.slice([0,r],null),s=t.slice([r,t.dims[0]],null);for(let a=0;a<s.data.length;++a)s.data[a]+=(n.data[a]-s.data[a])*this.guidance_scale;return s}},cC=class extends KA{constructor(e){super(),this.temperature=e}_call(e,t){const r=t.data;for(let n=0;n<r.length;++n)r[n]/=this.temperature;return t}},Mg=class{constructor(e){k(this,"max_length",20);k(this,"max_new_tokens",null);k(this,"min_length",0);k(this,"min_new_tokens",null);k(this,"early_stopping",!1);k(this,"max_time",null);k(this,"do_sample",!1);k(this,"num_beams",1);k(this,"num_beam_groups",1);k(this,"penalty_alpha",null);k(this,"use_cache",!0);k(this,"temperature",1);k(this,"top_k",50);k(this,"top_p",1);k(this,"typical_p",1);k(this,"epsilon_cutoff",0);k(this,"eta_cutoff",0);k(this,"diversity_penalty",0);k(this,"repetition_penalty",1);k(this,"encoder_repetition_penalty",1);k(this,"length_penalty",1);k(this,"no_repeat_ngram_size",0);k(this,"bad_words_ids",null);k(this,"force_words_ids",null);k(this,"renormalize_logits",!1);k(this,"constraints",null);k(this,"forced_bos_token_id",null);k(this,"forced_eos_token_id",null);k(this,"remove_invalid_values",!1);k(this,"exponential_decay_length_penalty",null);k(this,"suppress_tokens",null);k(this,"streamer",null);k(this,"begin_suppress_tokens",null);k(this,"forced_decoder_ids",null);k(this,"guidance_scale",null);k(this,"num_return_sequences",1);k(this,"output_attentions",!1);k(this,"output_hidden_states",!1);k(this,"output_scores",!1);k(this,"return_dict_in_generate",!1);k(this,"pad_token_id",null);k(this,"bos_token_id",null);k(this,"eos_token_id",null);k(this,"encoder_no_repeat_ngram_size",0);k(this,"decoder_start_token_id",null);k(this,"generation_kwargs",{});Object.assign(this,Ze(e,Object.getOwnPropertyNames(this)))}},Xa=class extends wt{_call(e,t){throw Error("StoppingCriteria needs to be subclassed")}},xg=class kg extends wt{constructor(){super(),this.criteria=[]}push(t){this.criteria.push(t)}extend(t){t instanceof kg?t=t.criteria:t instanceof Xa&&(t=[t]),this.criteria.push(...t)}_call(t,r){const n=new Array(t.length).fill(!1);for(const s of this.criteria){const a=s(t,r);for(let o=0;o<n.length;++o)n[o]||(n[o]=a[o])}return n}[Symbol.iterator](){return this.criteria.values()}},uC=class extends Xa{constructor(e,t=null){super(),this.max_length=e,this.max_position_embeddings=t}_call(e){return e.map(t=>t.length>=this.max_length)}},dC=class extends Xa{constructor(e){super(),Array.isArray(e)||(e=[e]),this.eos_token_id=e}_call(e,t){return e.map(r=>{const n=r.at(-1);return this.eos_token_id.some(s=>n==s)})}},Ya=class extends wt{constructor(e){super(),this.generation_config=e}async _call(e){return this.sample(e)}async sample(e){throw Error("sample should be implemented in subclasses.")}getLogits(e,t){let r=e.dims.at(-1),n=e.data;if(t===-1)n=n.slice(-r);else{let s=t*r;n=n.slice(s,s+r)}return n}randomSelect(e){return Vk(e)}static getSampler(e){if(e.do_sample)return new fC(e);if(e.num_beams>1)return new _C(e);if(e.num_return_sequences>1)throw Error(`num_return_sequences has to be 1 when doing greedy search, but is ${e.num_return_sequences}.`);return new hC(e)}},hC=class extends Ya{async sample(e){const t=Ue(e.data)[1];return[[BigInt(t),0]]}},fC=class extends Ya{async sample(e){let t=e.dims.at(-1);this.generation_config.top_k>0&&(t=Math.min(this.generation_config.top_k,t));const[r,n]=await Mn(e,t),s=nt(r.data);return Array.from({length:this.generation_config.num_beams},()=>{const a=this.randomSelect(s);return[n.data[a],Math.log(s[a])]})}},_C=class extends Ya{async sample(e){let t=e.dims.at(-1);this.generation_config.top_k>0&&(t=Math.min(this.generation_config.top_k,t));const[r,n]=await Mn(e,t),s=nt(r.data);return Array.from({length:this.generation_config.num_beams},(a,o)=>[n.data[o],Math.log(s[o])])}},pC=class{constructor(e){if(e)for(const t in e){if(t in this)throw new TypeError(`Key "${t}" conflicts with an existing property on DynamicCache`);const r=e[t];if(!(r instanceof j))throw new TypeError(`Expected a Tensor for key "${t}", got ${typeof r}`);this[t]=r}}get_seq_length(){const e=this;if(Object.keys(e).length===0)return 0;for(const t in e)if(t.startsWith("past_key_values."))return e[t].dims.at(-2);throw new Error("Unable to determine sequence length from the cache.")}update(e){for(const t in e){const r=this[t],n=e[t];r&&r!==n&&r.location==="gpu-buffer"&&r.dispose(),this[t]=n}}async dispose(){const e=[];for(const t of Object.values(this))t.location==="gpu-buffer"&&e.push(t.dispose());await Promise.all(e)}},lc=pC,q={EncoderOnly:0,EncoderDecoder:1,Seq2Seq:2,Vision2Seq:3,DecoderOnly:4,DecoderOnlyWithoutHead:5,MaskGeneration:6,ImageTextToText:7,Musicgen:8,MultiModality:9,Phi3V:10,AudioTextToText:11,AutoEncoder:12,ImageAudioTextToText:13,Supertonic:14,Chatterbox:15,VoxtralRealtime:16},hr={[q.DecoderOnly]:{sessions:(e,t)=>({model:t.model_file_name??"model"}),cache_sessions:{model:!0},optional_configs:{generation_config:"generation_config.json"}},[q.DecoderOnlyWithoutHead]:{sessions:(e,t)=>({model:t.model_file_name??"model"})},[q.Seq2Seq]:{sessions:()=>({model:"encoder_model",decoder_model_merged:"decoder_model_merged"}),cache_sessions:{decoder_model_merged:!0},optional_configs:{generation_config:"generation_config.json"}},[q.Vision2Seq]:{sessions:()=>({model:"encoder_model",decoder_model_merged:"decoder_model_merged"}),cache_sessions:{decoder_model_merged:!0},optional_configs:{generation_config:"generation_config.json"}},[q.Musicgen]:{sessions:()=>({model:"text_encoder",decoder_model_merged:"decoder_model_merged",encodec_decode:"encodec_decode"}),cache_sessions:{decoder_model_merged:!0},optional_configs:{generation_config:"generation_config.json"}},[q.EncoderDecoder]:{sessions:()=>({model:"encoder_model",decoder_model_merged:"decoder_model_merged"}),cache_sessions:{decoder_model_merged:!0}},[q.MaskGeneration]:{sessions:()=>({model:"vision_encoder",prompt_encoder_mask_decoder:"prompt_encoder_mask_decoder"})},[q.ImageTextToText]:{text_only_sessions:{embed_tokens:"embed_tokens",decoder_model_merged:"decoder_model_merged"},sessions:(e,t,r)=>{const n={...hr[q.ImageTextToText].text_only_sessions};return r||(n.vision_encoder="vision_encoder"),e.is_encoder_decoder&&(n.model="encoder_model"),n},cache_sessions:{decoder_model_merged:!0},optional_configs:{generation_config:"generation_config.json"}},[q.AudioTextToText]:{text_only_sessions:{embed_tokens:"embed_tokens",decoder_model_merged:"decoder_model_merged"},sessions:(e,t,r)=>{const n={...hr[q.AudioTextToText].text_only_sessions};return r||(n.audio_encoder="audio_encoder"),n},cache_sessions:{decoder_model_merged:!0},optional_configs:{generation_config:"generation_config.json"}},[q.ImageAudioTextToText]:{text_only_sessions:{embed_tokens:"embed_tokens",decoder_model_merged:"decoder_model_merged"},sessions:(e,t,r)=>{const n={...hr[q.ImageAudioTextToText].text_only_sessions};return r||(n.audio_encoder="audio_encoder",n.vision_encoder="vision_encoder"),n},optional_configs:{generation_config:"generation_config.json"}},[q.Phi3V]:{sessions:()=>({prepare_inputs_embeds:"prepare_inputs_embeds",model:"model",vision_encoder:"vision_encoder"}),cache_sessions:{model:!0},optional_configs:{generation_config:"generation_config.json"}},[q.MultiModality]:{sessions:()=>({prepare_inputs_embeds:"prepare_inputs_embeds",model:"language_model",lm_head:"lm_head",gen_head:"gen_head",gen_img_embeds:"gen_img_embeds",image_decode:"image_decode"}),cache_sessions:{model:!0},optional_configs:{generation_config:"generation_config.json"}},[q.AutoEncoder]:{sessions:()=>({encoder_model:"encoder_model",decoder_model:"decoder_model"})},[q.Supertonic]:{sessions:()=>({text_encoder:"text_encoder",latent_denoiser:"latent_denoiser",voice_decoder:"voice_decoder"})},[q.Chatterbox]:{sessions:()=>({embed_tokens:"embed_tokens",speech_encoder:"speech_encoder",model:"language_model",conditional_decoder:"conditional_decoder"}),cache_sessions:{model:!0},optional_configs:{generation_config:"generation_config.json"}},[q.VoxtralRealtime]:{text_only_sessions:{embed_tokens:"embed_tokens",decoder_model_merged:"decoder_model_merged"},sessions:(e,t,r)=>{const n={...hr[q.VoxtralRealtime].text_only_sessions};return r||(n.audio_encoder="audio_encoder"),n},cache_sessions:{decoder_model_merged:!0,audio_encoder:!0},optional_configs:{generation_config:"generation_config.json"}},default:{sessions:(e,t)=>({model:t.model_file_name??"model"})}};function mC(e){const t=hr[e];return(t==null?void 0:t.text_only_sessions)??null}function gC(e,t,r={}){const n=hr[e]??hr.default;return{sessions:n.sessions(t,r,r.textOnly??!1),cache_sessions:n.cache_sessions,optional_configs:n.optional_configs}}function Tg(e,{warn:t=!0}={}){const r=e.architectures||[];for(const n of r){const s=fr.get(n);if(s!==void 0)return s}if(e.model_type){const n=fr.get(e.model_type);if(n!==void 0)return n;for(const s of Object.values(hn))if(s.has(e.model_type)){const a=fr.get(s.get(e.model_type));if(a!==void 0)return a}}if(t){const n=r.length>0?r.join(", "):"(none)";ue.warn(`[resolve_model_type] Architecture(s) not found in MODEL_TYPE_MAPPING: [${n}] for model type '${e.model_type}'. Falling back to EncoderOnly (single model.onnx file). If you encounter issues, please report at: ${Wa}`)}return q.EncoderOnly}function Eg(e,{config:t=null,cache_dir:r=null,local_files_only:n=!1,revision:s="main"}={}){if(t!==null)return ws.from_pretrained(e,{config:t,cache_dir:r,local_files_only:n,revision:s});const a=JSON.stringify([e,r,n,s]);return fm(a,()=>ws.from_pretrained(e,{config:t,cache_dir:r,local_files_only:n,revision:s}))}async function Ag(e,{config:t=null,dtype:r=null,device:n=null,model_file_name:s=null}={}){t=await Eg(e,{config:t});const a=["config.json"],o=t["transformers.js_config"]??{},i=o.use_external_data_format,l="onnx",c=n??o.device;let d=r??o.dtype;const h=Tg(t),_=(v,y=null)=>{y=y??v;const M=Tm(c,v),T=Em(d,v,M),A=_l[T]??"",S=`${y}${A}.onnx`,C=`${l}/${S}`;a.push(C);const I=wg(i,S,v);for(const x of vg(S,I)){const R=`${l}/${x}`;a.push(R)}},{sessions:p,optional_configs:w}=gC(h,t,{model_file_name:s});for(const[v,y]of Object.entries(p))_(v,y);if(w)for(const v of Object.values(w))a.push(v);return a}var hn=null;function wC(e){hn=e}function bl(e){if(e instanceof j)return e;if(e.length===0)throw Error("items must be non-empty");if(Array.isArray(e[0])){if(e.some(t=>t.length!==e[0].length))throw Error("Unable to create tensor, you should probably activate truncation and/or padding with 'padding=True' and/or 'truncation=True' to have batched tensors with the same length.");return new j("int64",BigInt64Array.from(e.flat().map(t=>BigInt(t))),[e.length,e[0].length])}else return new j("int64",BigInt64Array.from(e.map(t=>BigInt(t))),[1,e.length])}function Cg(e){return new j("bool",[e],[1])}var j_={[q.DecoderOnly]:{can_generate:!0,forward:pr,prepare_inputs:fs},[q.DecoderOnlyWithoutHead]:{can_generate:!1,forward:pr,prepare_inputs:fs},[q.Seq2Seq]:{can_generate:!0,forward:aa,prepare_inputs:Ra},[q.Vision2Seq]:{can_generate:!0,forward:aa,prepare_inputs:Ra},[q.Musicgen]:{can_generate:!0,forward:aa},[q.EncoderDecoder]:{can_generate:!1,forward:aa},[q.ImageTextToText]:{can_generate:!0,forward:MC,prepare_inputs:oa},[q.AudioTextToText]:{can_generate:!0,forward:bC,prepare_inputs:oa},[q.ImageAudioTextToText]:{can_generate:!0,prepare_inputs:oa},[q.Phi3V]:{can_generate:!0,prepare_inputs:oa},[q.MultiModality]:{can_generate:!0},[q.AutoEncoder]:{can_generate:!1,forward:vC},[q.Chatterbox]:{can_generate:!0,forward:Fr},[q.VoxtralRealtime]:{can_generate:!0,prepare_inputs:fs},default:{can_generate:!1,forward:Fr}};function q_(e,t){var i;let r=fr.get(e),n=!1;const s=(i=t==null?void 0:t.architectures)==null?void 0:i[0];if(s&&s!==e&&(e!=null&&e.endsWith("ForCausalLM"))&&s.endsWith("ForConditionalGeneration")){const l=fr.get(s);l!==void 0&&(r=l,n=!0)}const a=j_[r]??j_.default,o=hr[r]??hr.default;return{typeConfig:{...a,...o},textOnly:n,modelType:r}}var fr=new Map,cc=new Map,gn=new Map,P=class extends wt{constructor(t,r,n){super();k(this,"main_input_name","input_ids");k(this,"forward_params",["input_ids","attention_mask"]);k(this,"_return_dict_in_generate_keys",null);this.config=t,this.sessions=r,this.configs=n;const s=gn.get(this.constructor),{typeConfig:a}=q_(s,t);this.can_generate=a.can_generate,this._forward=a.forward,this._prepare_inputs_for_generation=a.prepare_inputs,this.can_generate&&this.forward_params.push("past_key_values"),this.custom_config=this.config["transformers.js_config"]??{}}async dispose(){var r;const t=[];for(const n of Object.values(this.sessions))t.push((r=n.release)==null?void 0:r.call(n));return await Promise.all(t)}static async from_pretrained(t,{progress_callback:r=null,config:n=null,cache_dir:s=null,local_files_only:a=!1,revision:o="main",model_file_name:i=null,subfolder:l="onnx",device:c=null,dtype:d=null,use_external_data_format:h=null,session_options:_={}}={}){const p={progress_callback:r,config:n,cache_dir:s,local_files_only:a,revision:o,model_file_name:i,subfolder:l,device:c,dtype:d,use_external_data_format:h,session_options:_},w=gn.get(this);n=p.config=await ws.from_pretrained(t,p);const{typeConfig:v,textOnly:y,modelType:M}=q_(w,n);if(M===void 0){const C=w??(n==null?void 0:n.model_type);C!=="custom"&&ue.warn(`Model type for '${C}' not found, assuming encoder-only architecture. Please report this at ${Wa}.`)}if(r&&!(r instanceof ul)){const C={};try{const I=await Ag(t,{config:n,dtype:d,device:c,model_file_name:i});(await Promise.all(I.map(R=>ks(t,R,p)))).forEach((R,z)=>{if(R.exists){const $=I[z]==="config.json";C[I[z]]={loaded:$?R.size??0:0,total:R.size??0}}})}catch(I){ue.warn(`Unable to fetch model file metadata for total progress tracking: ${I}`)}Object.keys(C).length>0&&(p.progress_callback=new ul(r,C))}const T=v.sessions(n,p,y),A=[XA(t,T,p,v.cache_sessions)];v.optional_configs&&A.push(kC(t,v.optional_configs,p));const S=await Promise.all(A);return new this(n,...S)}async _call(t){return await this.forward(t)}async forward(t){return await this._forward(this,t)}get generation_config(){var t;return((t=this.configs)==null?void 0:t.generation_config)??null}_get_logits_processor(t,r,n=null){const s=new yl;if(t.repetition_penalty!==null&&t.repetition_penalty!==1&&s.push(new sC(t.repetition_penalty)),t.no_repeat_ngram_size!==null&&t.no_repeat_ngram_size>0&&s.push(new nC(t.no_repeat_ngram_size)),t.bad_words_ids!==null&&s.push(new iC(t.bad_words_ids,t.eos_token_id)),t.min_length!==null&&t.eos_token_id!==null&&t.min_length>0&&s.push(new aC(t.min_length,t.eos_token_id)),t.min_new_tokens!==null&&t.eos_token_id!==null&&t.min_new_tokens>0&&s.push(new oC(r,t.min_new_tokens,t.eos_token_id)),t.forced_bos_token_id!==null&&s.push(new ZA(t.forced_bos_token_id)),t.forced_eos_token_id!==null&&s.push(new eC(t.max_length,t.forced_eos_token_id)),t.suppress_tokens!==null&&s.push(new tC(t.suppress_tokens)),t.begin_suppress_tokens!==null){const a=r>1||t.forced_bos_token_id===null?r:r+1;s.push(new bg(t.begin_suppress_tokens,a))}return t.guidance_scale!==null&&t.guidance_scale>1&&s.push(new lC(t.guidance_scale)),t.temperature===0&&t.do_sample&&(ue.warn("`do_sample` changed to false because `temperature: 0` implies greedy sampling (always selecting the most likely token), which is incompatible with `do_sample: true`."),t.do_sample=!1),t.do_sample&&t.temperature!==null&&t.temperature!==1&&s.push(new cC(t.temperature)),n!==null&&s.extend(n),s}_prepare_generation_config(t,r,n=Mg){const s={...this.config};for(const o of["decoder","generator","text_config"])o in s&&Object.assign(s,s[o]);const a=new n(s);return Object.assign(a,this.generation_config??{}),t&&Object.assign(a,t),r&&Object.assign(a,Ze(r,Object.getOwnPropertyNames(a))),a}_get_stopping_criteria(t,r=null){const n=new xg;return t.max_length!==null&&n.push(new uC(t.max_length,this.config.max_position_embeddings??null)),t.eos_token_id!==null&&n.push(new dC(t.eos_token_id)),r&&n.extend(r),n}_validate_model_class(){if(!this.can_generate){const t=[hn.MODEL_FOR_CAUSAL_LM_MAPPING_NAMES,hn.MODEL_FOR_VISION_2_SEQ_MAPPING_NAMES,hn.MODEL_FOR_SEQ_TO_SEQ_CAUSAL_LM_MAPPING_NAMES,hn.MODEL_FOR_SPEECH_SEQ_2_SEQ_MAPPING_NAMES].filter(Boolean),r=gn.get(this.constructor),n=new Set,s=this.config.model_type;for(const o of t){const i=o==null?void 0:o.get(s);i&&n.add(i)}let a=`The current model class (${r}) is not compatible with \`.generate()\`, as it doesn't have a language model head.`;throw n.size>0&&(a+=` Please use the following class instead: ${[...n].join(", ")}`),Error(a)}}prepare_inputs_for_generation(...t){if(!this._prepare_inputs_for_generation)throw new Error("prepare_inputs_for_generation is not implemented for this model.");return this._prepare_inputs_for_generation(this,...t)}_update_model_kwargs_for_generation({generated_input_ids:t,outputs:r,model_inputs:n,is_encoder_decoder:s}){return n.past_key_values=Ml(r,n.past_key_values),n.input_ids=new j("int64",t.flat(),[t.length,1]),s?"decoder_attention_mask"in n&&(n.decoder_attention_mask=De([n.decoder_attention_mask,gt([n.decoder_attention_mask.dims[0],1])],1)):n.attention_mask=De([n.attention_mask,gt([n.attention_mask.dims[0],1])],1),n.position_ids=null,n}_prepare_model_inputs({inputs:t,bos_token_id:r,model_kwargs:n}){const s=Ze(n,this.forward_params),a=this.main_input_name;if(a in s){if(t)throw new Error("`inputs`: {inputs}` were passed alongside {input_name} which is not allowed. Make sure to either pass {inputs} or {input_name}=...")}else s[a]=t;return{inputs_tensor:s[a],model_inputs:s,model_input_name:a}}async _prepare_encoder_decoder_kwargs_for_generation({inputs_tensor:t,model_inputs:r,model_input_name:n,generation_config:s}){if(this.sessions.model.inputNames.includes("inputs_embeds")&&!r.inputs_embeds&&"_prepare_inputs_embeds"in this){const{input_ids:o,pixel_values:i,attention_mask:l,...c}=r,d=await this._prepare_inputs_embeds(r);r={...c,...Ze(d,["inputs_embeds","attention_mask"])}}let{last_hidden_state:a}=await Fr(this,r);if(s.guidance_scale!==null&&s.guidance_scale>1)a=De([a,pl(a,0)],0),"attention_mask"in r&&(r.attention_mask=De([r.attention_mask,Fm(r.attention_mask)],0));else if(r.decoder_input_ids){const o=bl(r.decoder_input_ids).dims[0];if(o!==a.dims[0]){if(a.dims[0]!==1)throw new Error(`The encoder outputs have a different batch size (${a.dims[0]}) than the decoder inputs (${o}).`);a=De(Array.from({length:o},()=>a),0)}}return r.encoder_outputs=a,r}_prepare_decoder_input_ids_for_generation({batch_size:t,model_input_name:r,model_kwargs:n,decoder_start_token_id:s,bos_token_id:a,generation_config:o}){let{decoder_input_ids:i,...l}=n;if(!(i instanceof j)){if(i)Array.isArray(i[0])||(i=Array.from({length:t},()=>i));else if(s??(s=a),this.config.model_type==="musicgen")i=Array.from({length:t*this.config.decoder.num_codebooks},()=>[s]);else if(Array.isArray(s)){if(s.length!==t)throw new Error(`\`decoder_start_token_id\` expcted to have length ${t} but got ${s.length}`);i=s}else i=Array.from({length:t},()=>[s]);i=bl(i)}return l.decoder_attention_mask=Sm(i),{input_ids:i,model_inputs:l}}async generate({inputs:t=null,generation_config:r=null,logits_processor:n=null,stopping_criteria:s=null,streamer:a=null,...o}){this._validate_model_class(),r=this._prepare_generation_config(r,o);let{inputs_tensor:i,model_inputs:l,model_input_name:c}=this._prepare_model_inputs({inputs:t,model_kwargs:o});const d=this.config.is_encoder_decoder;d&&("encoder_outputs"in l||(l=await this._prepare_encoder_decoder_kwargs_for_generation({inputs_tensor:i,model_inputs:l,model_input_name:c,generation_config:r})));let h;d?{input_ids:h,model_inputs:l}=this._prepare_decoder_input_ids_for_generation({batch_size:l[c].dims.at(0),model_input_name:c,model_kwargs:l,decoder_start_token_id:r.decoder_start_token_id,bos_token_id:r.bos_token_id,generation_config:r}):h=l[c];let _=h.dims.at(-1);r.max_new_tokens!==null&&(r.max_length=_+r.max_new_tokens);const p=this._get_logits_processor(r,_,n),w=this._get_stopping_criteria(r,s),v=l[c].dims.at(0),y=Ya.getSampler(r),M=new Array(v).fill(0),T=h.tolist();a&&a.put(T);let A,S={},C={};for(;;){if(l=this.prepare_inputs_for_generation(T,l,r),A=await this.forward(l),r.return_dict_in_generate)if(r.output_attentions){const O=yC(A);for(const te in O)te in S||(S[te]=[]),S[te].push(O[te])}else this._return_dict_in_generate_keys&&Object.assign(C,Ze(A,this._return_dict_in_generate_keys));const $=A.logits.slice(null,-1,null).to("float32"),Q=p(T,$),H=[];for(let O=0;O<Q.dims.at(0);++O){const te=Q[O],W=await y(te);for(const[ee,G]of W){const L=BigInt(ee);M[O]+=G,T[O].push(L),H.push([L]);break}}if(a&&a.put(H),w(T).every(O=>O))break;l=this._update_model_kwargs_for_generation({generated_input_ids:H,outputs:A,model_inputs:l,is_encoder_decoder:d})}a&&a.end();const I=new j("int64",T.flat(),[T.length,T[0].length]),x=Ml(A,l.past_key_values),R=new Set(Object.values(x));for(const $ of Object.values(A))$.location==="gpu-buffer"&&!R.has($)&&$.dispose();return"past_key_values"in o||r.return_dict_in_generate||await x.dispose(),r.return_dict_in_generate?{sequences:I,past_key_values:x,...S,...C}:I}async _encode_input(t,r,n){if(!Object.hasOwn(this.sessions,t))throw new Error(`Model does not have a ${t} session.`);const s=this.sessions[t];return(await xe(s,Ze(r,s.inputNames)))[n]}async encode_image(t){return this._encode_input("vision_encoder",t,"image_features")}async encode_text(t){return this._encode_input("embed_tokens",t,"inputs_embeds")}async encode_audio(t){return this._encode_input("audio_encoder",t,"audio_features")}};async function aa(e,t){let{encoder_outputs:r,input_ids:n,decoder_input_ids:s,decoder_attention_mask:a,...o}=t;if(!r){const i=Ze(t,e.sessions.model.inputNames);r=(await Fr(e,i)).last_hidden_state}return o.input_ids=s,o.encoder_hidden_states=r,e.sessions.decoder_model_merged.inputNames.includes("encoder_attention_mask")&&(o.encoder_attention_mask=t.attention_mask),a&&!o.attention_mask&&(o.attention_mask=a),await pr(e,o,!0)}async function Fr(e,t){const r=e.sessions.model,n=Ze(t,r.inputNames);if(r.inputNames.includes("inputs_embeds")&&!n.inputs_embeds){if(!t.input_ids)throw new Error("Both `input_ids` and `inputs_embeds` are missing in the model inputs.");n.inputs_embeds=await e.encode_text({input_ids:t.input_ids})}if(r.inputNames.includes("token_type_ids")&&!n.token_type_ids){if(!n.input_ids)throw new Error("Both `input_ids` and `token_type_ids` are missing in the model inputs.");n.token_type_ids=Fm(n.input_ids)}if(r.inputNames.includes("pixel_mask")&&!n.pixel_mask){if(!n.pixel_values)throw new Error("Both `pixel_values` and `pixel_mask` are missing in the model inputs.");const s=n.pixel_values.dims;n.pixel_mask=gt([s[0],s[2],s[3]])}return await xe(r,n)}async function vC(e,t){const r=await e.encode(t);return await e.decode(r)}function Ml(e,t){const r=Object.create(null);for(const n in e)if(n.startsWith("present")){const s=n.replace("present_ssm","past_ssm").replace("present_conv","past_conv").replace("present_recurrent","past_recurrent").replace("present","past_key_values");n.includes("encoder")&&t?r[s]=t[s]:r[s]=e[n]}return t?(t.update(r),t):new lc(r)}function yC(e){const t={};for(const r of["cross_attentions","encoder_attentions","decoder_attentions"])for(const n in e)n.startsWith(r)&&(r in t||(t[r]=[]),t[r].push(e[n]));return t}function Sg(e,t){return e.map(r=>typeof r=="number"?r:t[r]??0)}function uc(e,t,r){var c,d,h,_;if(r&&Object.keys(r).length>0)return Object.assign(t,r),r;const n=e.sessions.decoder_model_merged??e.sessions.model,s=((d=(c=t[e.main_input_name]??t.attention_mask)==null?void 0:c.dims)==null?void 0:d[0])??1,a=Qa(e.config),o=(_=(h=e.config)==null?void 0:h.normalized_config)==null?void 0:_.num_heads,i={batch_size:s};typeof o=="number"&&(i["batch_size x num_heads"]=s*o);const l=Object.create(null);for(const p of n.inputMetadata){if(!a.has(p.name))continue;const w=Sg(p.shape,i),v=w.reduce((T,A)=>T*A,1),y=ms[p.type],M=new j(p.type,new y(v),w);t[p.name]=M,l[p.name]=M}return r?(r.update(l),r):new lc(l)}async function pr(e,t,r=!1){const n=e.sessions[r?"decoder_model_merged":"model"],{past_key_values:s,...a}=t;if(n.inputNames.includes("use_cache_branch")&&(a.use_cache_branch=Cg(s!=null&&Object.keys(s).length>0)),n.inputNames.includes("position_ids")&&a.attention_mask&&!a.position_ids){const i=["paligemma","gemma3_text","gemma3"].includes(e.config.model_type)?1:0;a.position_ids=xC(a,s,i)}n.inputNames.includes("num_logits_to_keep")&&!a.num_logits_to_keep&&(a.num_logits_to_keep=new j("int64",[0n],[])),uc(e,a,s);const o=Ze(a,n.inputNames);return await xe(n,o)}async function Pg(e,{encode_function:t,merge_function:r,modality_input_names:n,modality_output_name:s,input_ids:a=null,attention_mask:o=null,position_ids:i=null,inputs_embeds:l=null,past_key_values:c=null,generation_config:d=null,logits_processor:h=null,..._}){if(!l){l=await e.encode_text({input_ids:a,..._});const w=Ze(_,n);if(Object.keys(w).length>0){if(a.dims[1]!==1){const v=await t({...w,..._});({inputs_embeds:l,attention_mask:o}=r({[s]:v,inputs_embeds:l,input_ids:a,attention_mask:o}))}else if(c&&a.dims[1]===1){const v=a.dims[1],y=c.get_seq_length();o=De([gt([a.dims[0],y]),o.slice(null,[o.dims[1]-v,o.dims[1]])],1)}}}if(!i&&["qwen2_vl","qwen2_vl_text","qwen2_5_vl","qwen2_5_vl_text","qwen3_vl","qwen3_vl_text","qwen3_vl_moe","qwen3_vl_moe_text","qwen3_5","qwen3_5_text","qwen3_5_moe","qwen3_5_moe_text","glm_ocr","glm_ocr_text"].includes(e.config.model_type)){const{image_grid_thw:w,video_grid_thw:v}=_;[i]=e.get_rope_index(a,w,v,o)}return await pr(e,{inputs_embeds:l,past_key_values:c,attention_mask:o,position_ids:i,generation_config:d,logits_processor:h},!0)}async function bC(e,t){return await Pg(e,{...t,modality_input_names:["audio_values","input_features"],modality_output_name:"audio_features",encode_function:e.encode_audio.bind(e),merge_function:e._merge_input_ids_with_audio_features.bind(e)})}async function MC(e,t){return await Pg(e,{...t,modality_input_names:["pixel_values"],modality_output_name:"image_features",encode_function:e.encode_image.bind(e),merge_function:e._merge_input_ids_with_image_features.bind(e)})}function Fg(e,t=0){const[r,n]=e.dims,s=e.data,a=new BigInt64Array(s.length);for(let o=0;o<r;++o){const i=o*n;let l=BigInt(t);for(let c=0;c<n;++c){const d=i+c;s[d]===0n?a[d]=BigInt(1):(a[d]=l,l+=s[d])}}return{data:a,dims:e.dims}}function xC(e,t=null,r=0){const{input_ids:n,inputs_embeds:s,attention_mask:a}=e,{data:o,dims:i}=Fg(a,r);let l=new j("int64",o,i);if(t){const c=-(n??s).dims.at(1);l=l.slice(null,[c,null])}return l}function fs(e,t,r,n){const s=r.past_key_values?r.past_key_values.get_seq_length():0,a=e.sessions.decoder_model_merged??e.sessions.model;if(a!=null&&a.inputNames.includes("num_logits_to_keep")&&!r.num_logits_to_keep&&(r.num_logits_to_keep=new j("int64",[1n],[])),!r.attention_mask){let o;for(const i of["input_ids","inputs_embeds","position_ids"])if(r[i]){o=r[i].dims;break}if(!o)throw new Error("attention_mask is not provided, and unable to infer its shape from model inputs.");r.attention_mask=gt([o[0],s+o[1]])}if(r.past_key_values){const{input_ids:o,attention_mask:i}=r;i&&i.dims[1]>o.dims[1]||s<o.dims[1]&&(r.input_ids=o.slice(null,[s,null]))}return r}function Ra(e,t,r,n){return r.past_key_values&&(t=t.map(s=>[s.at(-1)])),{...r,decoder_input_ids:bl(t)}}function oa(e,...t){return e.config.is_encoder_decoder?Ra(e,...t):fs(e,...t)}function Lg({modality_token_id:e,inputs_embeds:t,modality_features:r,input_ids:n,attention_mask:s}){const a=n.tolist().map(c=>c.reduce((d,h,_)=>(h==e&&d.push(_),d),[])),o=a.reduce((c,d)=>c+d.length,0),i=r.dims[0];if(o!==i)throw new Error(`Number of tokens and features do not match: tokens: ${o}, features ${i}`);let l=0;for(let c=0;c<a.length;++c){const d=a[c],h=t[c];for(let _=0;_<d.length;++_)h[d[_]].data.set(r[l++].data)}return{inputs_embeds:t,attention_mask:s}}function dc({image_token_id:e,inputs_embeds:t,image_features:r,input_ids:n,attention_mask:s}){return Lg({modality_token_id:e,inputs_embeds:t,modality_features:r,input_ids:n,attention_mask:s})}function Ig({audio_token_id:e,inputs_embeds:t,audio_features:r,input_ids:n,attention_mask:s}){return Lg({modality_token_id:e,inputs_embeds:t,modality_features:r,input_ids:n,attention_mask:s})}async function kC(e,t,r){return Object.fromEntries(await Promise.all(Object.keys(t).map(async n=>{const s=await nr(e,t[n],!1,r);return[n,s]})))}var hc={};vn(hc,{ASTForAudioClassification:()=>DC,ASTModel:()=>NC,ASTPreTrainedModel:()=>mc,AfmoeForCausalLM:()=>LC,AfmoeModel:()=>FC,AfmoePreTrainedModel:()=>_c,AlbertForMaskedLM:()=>CC,AlbertForQuestionAnswering:()=>AC,AlbertForSequenceClassification:()=>EC,AlbertModel:()=>TC,AlbertPreTrainedModel:()=>Ts,ApertusForCausalLM:()=>PC,ApertusModel:()=>SC,ApertusPreTrainedModel:()=>fc,ArceeForCausalLM:()=>OC,ArceeModel:()=>IC,ArceePreTrainedModel:()=>pc,BartForConditionalGeneration:()=>BC,BartForSequenceClassification:()=>RC,BartModel:()=>zC,BartPretrainedModel:()=>Ja,BeitForImageClassification:()=>$C,BeitModel:()=>GC,BeitPreTrainedModel:()=>gc,BertForMaskedLM:()=>UC,BertForQuestionAnswering:()=>WC,BertForSequenceClassification:()=>jC,BertForTokenClassification:()=>qC,BertModel:()=>VC,BertPreTrainedModel:()=>xn,BlenderbotForConditionalGeneration:()=>QC,BlenderbotModel:()=>HC,BlenderbotPreTrainedModel:()=>wc,BlenderbotSmallForConditionalGeneration:()=>YC,BlenderbotSmallModel:()=>XC,BlenderbotSmallPreTrainedModel:()=>vc,BloomForCausalLM:()=>KC,BloomModel:()=>JC,BloomPreTrainedModel:()=>yc,CHMv2ForDepthEstimation:()=>oS,CHMv2PreTrainedModel:()=>zg,CLIPModel:()=>lS,CLIPPreTrainedModel:()=>Yr,CLIPSegForImageSegmentation:()=>fS,CLIPSegModel:()=>hS,CLIPSegPreTrainedModel:()=>bc,CLIPTextModel:()=>cS,CLIPTextModelWithProjection:()=>Gg,CLIPVisionModel:()=>uS,CLIPVisionModelWithProjection:()=>dS,CamembertForMaskedLM:()=>eS,CamembertForQuestionAnswering:()=>nS,CamembertForSequenceClassification:()=>tS,CamembertForTokenClassification:()=>rS,CamembertModel:()=>ZC,CamembertPreTrainedModel:()=>kn,ChatterboxModel:()=>Ng,ChatterboxPreTrainedModel:()=>Og,ChineseCLIPModel:()=>aS,ChineseCLIPPreTrainedModel:()=>Dg,ClapAudioModelWithProjection:()=>Rg,ClapModel:()=>iS,ClapPreTrainedModel:()=>Ka,ClapTextModelWithProjection:()=>Bg,CodeGenForCausalLM:()=>pS,CodeGenModel:()=>_S,CodeGenPreTrainedModel:()=>Mc,Cohere2ForCausalLM:()=>vS,Cohere2Model:()=>wS,Cohere2PreTrainedModel:()=>kc,CohereAsrForConditionalGeneration:()=>bS,CohereAsrModel:()=>yS,CohereAsrPreTrainedModel:()=>Tc,CohereForCausalLM:()=>gS,CohereModel:()=>mS,CoherePreTrainedModel:()=>xc,ConvBertForMaskedLM:()=>xS,ConvBertForQuestionAnswering:()=>ES,ConvBertForSequenceClassification:()=>kS,ConvBertForTokenClassification:()=>TS,ConvBertModel:()=>MS,ConvBertPreTrainedModel:()=>Tn,ConvNextForImageClassification:()=>CS,ConvNextModel:()=>AS,ConvNextPreTrainedModel:()=>Ec,ConvNextV2ForImageClassification:()=>PS,ConvNextV2Model:()=>SS,ConvNextV2PreTrainedModel:()=>Ac,DFineForObjectDetection:()=>OS,DFineModel:()=>IS,DFinePreTrainedModel:()=>Sc,DINOv3ConvNextModel:()=>oP,DINOv3ConvNextPreTrainedModel:()=>Xg,DINOv3ViTModel:()=>iP,DINOv3ViTPreTrainedModel:()=>Yg,DPTForDepthEstimation:()=>pP,DPTModel:()=>_P,DPTPreTrainedModel:()=>Nc,DacDecoderModel:()=>jg,DacDecoderOutput:()=>Vg,DacEncoderModel:()=>Ug,DacEncoderOutput:()=>$g,DacModel:()=>NS,DacPreTrainedModel:()=>Za,DebertaForMaskedLM:()=>zS,DebertaForQuestionAnswering:()=>GS,DebertaForSequenceClassification:()=>BS,DebertaForTokenClassification:()=>RS,DebertaModel:()=>DS,DebertaPreTrainedModel:()=>En,DebertaV2ForMaskedLM:()=>jS,DebertaV2ForQuestionAnswering:()=>HS,DebertaV2ForSequenceClassification:()=>qS,DebertaV2ForTokenClassification:()=>WS,DebertaV2Model:()=>US,DebertaV2PreTrainedModel:()=>An,DecisionTransformerModel:()=>QS,DecisionTransformerPreTrainedModel:()=>qg,DeepseekV3ForCausalLM:()=>VS,DeepseekV3Model:()=>$S,DeepseekV3PreTrainedModel:()=>Pc,DeiTForImageClassification:()=>YS,DeiTModel:()=>XS,DeiTPreTrainedModel:()=>Fc,DepthAnythingForDepthEstimation:()=>JS,DepthAnythingPreTrainedModel:()=>Wg,DepthProForDepthEstimation:()=>KS,DepthProPreTrainedModel:()=>Hg,DetrForObjectDetection:()=>eP,DetrForSegmentation:()=>tP,DetrModel:()=>ZS,DetrObjectDetectionOutput:()=>Lc,DetrPreTrainedModel:()=>eo,DetrSegmentationOutput:()=>Qg,Dinov2ForImageClassification:()=>nP,Dinov2Model:()=>rP,Dinov2PreTrainedModel:()=>Ic,Dinov2WithRegistersForImageClassification:()=>aP,Dinov2WithRegistersModel:()=>sP,Dinov2WithRegistersPreTrainedModel:()=>Oc,DistilBertForMaskedLM:()=>hP,DistilBertForQuestionAnswering:()=>dP,DistilBertForSequenceClassification:()=>cP,DistilBertForTokenClassification:()=>uP,DistilBertModel:()=>lP,DistilBertPreTrainedModel:()=>Cn,DonutSwinModel:()=>fP,DonutSwinPreTrainedModel:()=>Jg,EdgeTamModel:()=>EO,EfficientNetForImageClassification:()=>gP,EfficientNetModel:()=>mP,EfficientNetPreTrainedModel:()=>Dc,ElectraForMaskedLM:()=>vP,ElectraForQuestionAnswering:()=>MP,ElectraForSequenceClassification:()=>yP,ElectraForTokenClassification:()=>bP,ElectraModel:()=>wP,ElectraPreTrainedModel:()=>Sn,Ernie4_5ForCausalLM:()=>kP,Ernie4_5Model:()=>xP,Ernie4_5PretrainedModel:()=>zc,EsmForMaskedLM:()=>EP,EsmForSequenceClassification:()=>AP,EsmForTokenClassification:()=>CP,EsmModel:()=>TP,EsmPreTrainedModel:()=>As,EuroBertForMaskedLM:()=>PP,EuroBertForSequenceClassification:()=>FP,EuroBertForTokenClassification:()=>LP,EuroBertModel:()=>SP,EuroBertPreTrainedModel:()=>Cs,ExaoneForCausalLM:()=>OP,ExaoneModel:()=>IP,ExaonePreTrainedModel:()=>Bc,FalconForCausalLM:()=>DP,FalconH1ForCausalLM:()=>BP,FalconH1Model:()=>zP,FalconH1PreTrainedModel:()=>Gc,FalconModel:()=>NP,FalconPreTrainedModel:()=>Rc,FastViTForImageClassification:()=>GP,FastViTModel:()=>RP,FastViTPreTrainedModel:()=>$c,Florence2ForConditionalGeneration:()=>$P,Florence2PreTrainedModel:()=>Kg,GLPNForDepthEstimation:()=>sF,GLPNModel:()=>nF,GLPNPreTrainedModel:()=>Xc,GPT2LMHeadModel:()=>_F,GPT2Model:()=>fF,GPT2PreTrainedModel:()=>eu,GPTBigCodeForCausalLM:()=>oF,GPTBigCodeModel:()=>aF,GPTBigCodePreTrainedModel:()=>Yc,GPTJForCausalLM:()=>mF,GPTJModel:()=>pF,GPTJPreTrainedModel:()=>tu,GPTNeoForCausalLM:()=>lF,GPTNeoModel:()=>iF,GPTNeoPreTrainedModel:()=>Jc,GPTNeoXForCausalLM:()=>uF,GPTNeoXModel:()=>cF,GPTNeoXPreTrainedModel:()=>Kc,Gemma2ForCausalLM:()=>qP,Gemma2Model:()=>jP,Gemma2PreTrainedModel:()=>Uc,Gemma3ForCausalLM:()=>XP,Gemma3ForConditionalGeneration:()=>tw,Gemma3Model:()=>QP,Gemma3PreTrainedModel:()=>ew,Gemma3nForCausalLM:()=>YP,Gemma3nForConditionalGeneration:()=>to,Gemma3nPreTrainedModel:()=>rw,Gemma4ForCausalLM:()=>JP,Gemma4ForConditionalGeneration:()=>jc,GemmaForCausalLM:()=>UP,GemmaModel:()=>VP,GemmaPreTrainedModel:()=>Vc,GlmForCausalLM:()=>ZP,GlmModel:()=>KP,GlmMoeDsaForCausalLM:()=>tF,GlmMoeDsaModel:()=>eF,GlmMoeDsaPreTrainedModel:()=>Wc,GlmOcrForConditionalGeneration:()=>rF,GlmPreTrainedModel:()=>qc,GptOssForCausalLM:()=>hF,GptOssModel:()=>dF,GptOssPreTrainedModel:()=>Zc,GraniteForCausalLM:()=>wF,GraniteModel:()=>gF,GraniteMoeHybridForCausalLM:()=>yF,GraniteMoeHybridModel:()=>vF,GraniteMoeHybridPreTrainedModel:()=>nu,GranitePreTrainedModel:()=>ru,GraniteSpeechForConditionalGeneration:()=>bF,GroundingDinoForObjectDetection:()=>MF,GroundingDinoPreTrainedModel:()=>iw,GroupViTModel:()=>xF,GroupViTPreTrainedModel:()=>lw,HeliumForCausalLM:()=>TF,HeliumModel:()=>kF,HeliumPreTrainedModel:()=>au,HieraForImageClassification:()=>AF,HieraModel:()=>EF,HieraPreTrainedModel:()=>ou,HubertForCTC:()=>OF,HubertForSequenceClassification:()=>NF,HubertModel:()=>IF,HubertPreTrainedModel:()=>LF,HunYuanDenseV1ForCausalLM:()=>zF,HunYuanDenseV1Model:()=>DF,HunYuanDenseV1PreTrainedModel:()=>iu,IJepaForImageClassification:()=>RF,IJepaModel:()=>BF,IJepaPreTrainedModel:()=>lu,Idefics3ForConditionalGeneration:()=>cw,JAISLMHeadModel:()=>$F,JAISModel:()=>GF,JAISPreTrainedModel:()=>cu,JinaCLIPModel:()=>VF,JinaCLIPPreTrainedModel:()=>ro,JinaCLIPTextModel:()=>uw,JinaCLIPVisionModel:()=>UF,Lfm2ForCausalLM:()=>qF,Lfm2Model:()=>jF,Lfm2MoeForCausalLM:()=>QF,Lfm2MoeModel:()=>HF,Lfm2MoePreTrainedModel:()=>du,Lfm2PreTrainedModel:()=>uu,Lfm2VlForConditionalGeneration:()=>XF,LightOnOcrForConditionalGeneration:()=>WF,LiteWhisperForConditionalGeneration:()=>HN,Llama4ForCausalLM:()=>KF,Llama4PreTrainedModel:()=>dw,LlamaForCausalLM:()=>JF,LlamaModel:()=>YF,LlamaPreTrainedModel:()=>hu,LlavaForConditionalGeneration:()=>mr,LlavaOnevisionForConditionalGeneration:()=>mr,LlavaPreTrainedModel:()=>Zg,LlavaQwen2ForCausalLM:()=>HP,LongT5ForConditionalGeneration:()=>eL,LongT5Model:()=>ZF,LongT5PreTrainedModel:()=>fu,M2M100ForConditionalGeneration:()=>rL,M2M100Model:()=>tL,M2M100PreTrainedModel:()=>_u,MBartForCausalLM:()=>uL,MBartForConditionalGeneration:()=>lL,MBartForSequenceClassification:()=>cL,MBartModel:()=>iL,MBartPreTrainedModel:()=>Ss,MPNetForMaskedLM:()=>YL,MPNetForQuestionAnswering:()=>ZL,MPNetForSequenceClassification:()=>JL,MPNetForTokenClassification:()=>KL,MPNetModel:()=>XL,MPNetPreTrainedModel:()=>Pn,MT5ForConditionalGeneration:()=>nI,MT5Model:()=>rI,MT5PreTrainedModel:()=>Tu,MarianMTModel:()=>sL,MarianModel:()=>nL,MarianPreTrainedModel:()=>pu,MaskFormerForInstanceSegmentation:()=>oL,MaskFormerModel:()=>aL,MaskFormerPreTrainedModel:()=>mu,Metric3DForDepthEstimation:()=>dL,Metric3DPreTrainedModel:()=>hw,Metric3Dv2ForDepthEstimation:()=>hL,Metric3Dv2PreTrainedModel:()=>fw,MgpstrForSceneTextRecognition:()=>fL,MgpstrModelOutput:()=>_w,MgpstrPreTrainedModel:()=>pw,MimiDecoderModel:()=>vw,MimiDecoderOutput:()=>gw,MimiEncoderModel:()=>ww,MimiEncoderOutput:()=>mw,MimiModel:()=>_L,MimiPreTrainedModel:()=>no,Mistral4ForCausalLM:()=>wL,Mistral4Model:()=>gL,Mistral4PreTrainedModel:()=>wu,MistralForCausalLM:()=>mL,MistralModel:()=>pL,MistralPreTrainedModel:()=>gu,MobileBertForMaskedLM:()=>yL,MobileBertForQuestionAnswering:()=>ML,MobileBertForSequenceClassification:()=>bL,MobileBertModel:()=>vL,MobileBertPreTrainedModel:()=>Ps,MobileLLMForCausalLM:()=>kL,MobileLLMModel:()=>xL,MobileLLMPreTrainedModel:()=>vu,MobileNetV1ForImageClassification:()=>EL,MobileNetV1ForSemanticSegmentation:()=>AL,MobileNetV1Model:()=>TL,MobileNetV1PreTrainedModel:()=>so,MobileNetV2ForImageClassification:()=>SL,MobileNetV2ForSemanticSegmentation:()=>PL,MobileNetV2Model:()=>CL,MobileNetV2PreTrainedModel:()=>ao,MobileNetV3ForImageClassification:()=>LL,MobileNetV3ForSemanticSegmentation:()=>IL,MobileNetV3Model:()=>FL,MobileNetV3PreTrainedModel:()=>oo,MobileNetV4ForImageClassification:()=>NL,MobileNetV4ForSemanticSegmentation:()=>DL,MobileNetV4Model:()=>OL,MobileNetV4PreTrainedModel:()=>io,MobileViTForImageClassification:()=>BL,MobileViTModel:()=>zL,MobileViTPreTrainedModel:()=>yu,MobileViTV2ForImageClassification:()=>GL,MobileViTV2Model:()=>RL,MobileViTV2PreTrainedModel:()=>bu,ModernBertDecoderForCausalLM:()=>WL,ModernBertDecoderModel:()=>qL,ModernBertDecoderPreTrainedModel:()=>Mu,ModernBertForMaskedLM:()=>VL,ModernBertForSequenceClassification:()=>UL,ModernBertForTokenClassification:()=>jL,ModernBertModel:()=>$L,ModernBertPreTrainedModel:()=>Fs,Moondream1ForConditionalGeneration:()=>WP,MoonshineForConditionalGeneration:()=>QL,MoonshineModel:()=>HL,MoonshinePreTrainedModel:()=>xu,MptForCausalLM:()=>tI,MptModel:()=>eI,MptPreTrainedModel:()=>ku,MultiModalityCausalLM:()=>sI,MultiModalityPreTrainedModel:()=>yw,MusicgenForCausalLM:()=>oI,MusicgenForConditionalGeneration:()=>bw,MusicgenModel:()=>aI,MusicgenPreTrainedModel:()=>Eu,NanoChatForCausalLM:()=>lI,NanoChatModel:()=>iI,NanoChatPreTrainedModel:()=>Au,NemotronHForCausalLM:()=>uI,NemotronHModel:()=>cI,NemotronHPreTrainedModel:()=>Cu,NeoBertForMaskedLM:()=>hI,NeoBertForQuestionAnswering:()=>pI,NeoBertForSequenceClassification:()=>fI,NeoBertForTokenClassification:()=>_I,NeoBertModel:()=>dI,NeoBertPreTrainedModel:()=>Fn,NomicBertModel:()=>mI,NomicBertPreTrainedModel:()=>Mw,OPTForCausalLM:()=>PI,OPTModel:()=>SI,OPTPreTrainedModel:()=>Nu,Olmo2ForCausalLM:()=>yI,Olmo2Model:()=>vI,Olmo2PreTrainedModel:()=>Pu,Olmo3ForCausalLM:()=>MI,Olmo3Model:()=>bI,Olmo3PreTrainedModel:()=>Fu,OlmoForCausalLM:()=>wI,OlmoHybridForCausalLM:()=>kI,OlmoHybridModel:()=>xI,OlmoHybridPreTrainedModel:()=>Lu,OlmoModel:()=>gI,OlmoPreTrainedModel:()=>Su,OpenAIPrivacyFilterForTokenClassification:()=>EI,OpenAIPrivacyFilterModel:()=>TI,OpenAIPrivacyFilterPreTrainedModel:()=>Iu,OpenELMForCausalLM:()=>CI,OpenELMModel:()=>AI,OpenELMPreTrainedModel:()=>Ou,OwlViTForObjectDetection:()=>OI,OwlViTModel:()=>II,OwlViTPreTrainedModel:()=>zu,Owlv2ForObjectDetection:()=>LI,Owlv2Model:()=>FI,Owlv2PreTrainedModel:()=>Du,PaliGemmaForConditionalGeneration:()=>NI,ParakeetForCTC:()=>DI,ParakeetPreTrainedModel:()=>xw,PatchTSMixerForPrediction:()=>BI,PatchTSMixerModel:()=>zI,PatchTSMixerPreTrainedModel:()=>Bu,PatchTSTForPrediction:()=>GI,PatchTSTModel:()=>RI,PatchTSTPreTrainedModel:()=>Ru,Phi3ForCausalLM:()=>jI,Phi3Model:()=>UI,Phi3PreTrainedModel:()=>$u,Phi3VForCausalLM:()=>Tw,Phi3VPreTrainedModel:()=>kw,PhiForCausalLM:()=>VI,PhiModel:()=>$I,PhiPreTrainedModel:()=>Gu,PreTrainedModel:()=>P,PvtForImageClassification:()=>WI,PvtModel:()=>qI,PvtPreTrainedModel:()=>Vu,PyAnnoteForAudioFrameClassification:()=>QI,PyAnnoteModel:()=>HI,PyAnnotePreTrainedModel:()=>Uu,Qwen2ForCausalLM:()=>YI,Qwen2Model:()=>XI,Qwen2MoeForCausalLM:()=>KI,Qwen2MoeModel:()=>JI,Qwen2MoePreTrainedModel:()=>qu,Qwen2PreTrainedModel:()=>ju,Qwen2VLForCausalLM:()=>sw,Qwen2VLForConditionalGeneration:()=>Hc,Qwen2VLPreTrainedModel:()=>nw,Qwen2_5_VLForCausalLM:()=>aw,Qwen2_5_VLForConditionalGeneration:()=>Qc,Qwen3ForCausalLM:()=>eO,Qwen3Model:()=>ZI,Qwen3MoeForCausalLM:()=>rO,Qwen3MoeModel:()=>tO,Qwen3MoePreTrainedModel:()=>Hu,Qwen3NextForCausalLM:()=>sO,Qwen3NextModel:()=>nO,Qwen3NextPreTrainedModel:()=>Qu,Qwen3PreTrainedModel:()=>Wu,Qwen3VLForCausalLM:()=>Ew,Qwen3VLForConditionalGeneration:()=>Xu,Qwen3VLMoeForCausalLM:()=>oO,Qwen3VLMoeForConditionalGeneration:()=>aO,Qwen3_5ForCausalLM:()=>Aw,Qwen3_5ForConditionalGeneration:()=>Yu,Qwen3_5MoeForCausalLM:()=>lO,Qwen3_5MoeForConditionalGeneration:()=>iO,RFDetrForObjectDetection:()=>hO,RFDetrModel:()=>dO,RFDetrObjectDetectionOutput:()=>Cw,RFDetrPreTrainedModel:()=>Ku,RTDetrForObjectDetection:()=>LS,RTDetrModel:()=>FS,RTDetrObjectDetectionOutput:()=>Es,RTDetrPreTrainedModel:()=>Cc,RTDetrV2ForObjectDetection:()=>kO,RTDetrV2Model:()=>xO,RTDetrV2ObjectDetectionOutput:()=>Sw,RTDetrV2PreTrainedModel:()=>Zu,ResNetForImageClassification:()=>uO,ResNetModel:()=>cO,ResNetPreTrainedModel:()=>Ju,RoFormerForMaskedLM:()=>vO,RoFormerForQuestionAnswering:()=>MO,RoFormerForSequenceClassification:()=>yO,RoFormerForTokenClassification:()=>bO,RoFormerModel:()=>wO,RoFormerPreTrainedModel:()=>In,RobertaForMaskedLM:()=>_O,RobertaForQuestionAnswering:()=>gO,RobertaForSequenceClassification:()=>pO,RobertaForTokenClassification:()=>mO,RobertaModel:()=>fO,RobertaPreTrainedModel:()=>Ln,Sam2ImageSegmentationOutput:()=>Lw,Sam2Model:()=>ed,Sam2PreTrainedModel:()=>Iw,Sam3TrackerModel:()=>AO,SamImageSegmentationOutput:()=>Pw,SamModel:()=>TO,SamPreTrainedModel:()=>Fw,SapiensForDepthEstimation:()=>SO,SapiensForNormalEstimation:()=>PO,SapiensForSemanticSegmentation:()=>CO,SapiensPreTrainedModel:()=>lo,SegformerForImageClassification:()=>LO,SegformerForSemanticSegmentation:()=>IO,SegformerModel:()=>FO,SegformerPreTrainedModel:()=>co,SiglipModel:()=>OO,SiglipPreTrainedModel:()=>td,SiglipTextModel:()=>Ow,SiglipVisionModel:()=>NO,SmolLM3ForCausalLM:()=>zO,SmolLM3Model:()=>DO,SmolLM3PreTrainedModel:()=>rd,SmolVLMForConditionalGeneration:()=>BO,SnacDecoderModel:()=>Dw,SnacEncoderModel:()=>Nw,SnacModel:()=>RO,SnacPreTrainedModel:()=>uo,SolarOpenForCausalLM:()=>$O,SolarOpenModel:()=>GO,SolarOpenPreTrainedModel:()=>nd,SpeechT5ForSpeechToText:()=>UO,SpeechT5ForTextToSpeech:()=>jO,SpeechT5HifiGan:()=>qO,SpeechT5Model:()=>VO,SpeechT5PreTrainedModel:()=>ho,SqueezeBertForMaskedLM:()=>HO,SqueezeBertForQuestionAnswering:()=>XO,SqueezeBertForSequenceClassification:()=>QO,SqueezeBertModel:()=>WO,SqueezeBertPreTrainedModel:()=>Ls,StableLmForCausalLM:()=>JO,StableLmModel:()=>YO,StableLmPreTrainedModel:()=>sd,Starcoder2ForCausalLM:()=>ZO,Starcoder2Model:()=>KO,Starcoder2PreTrainedModel:()=>ad,StyleTextToSpeech2Model:()=>eN,StyleTextToSpeech2PreTrainedModel:()=>zw,SupertonicForConditionalGeneration:()=>Rw,SupertonicPreTrainedModel:()=>Bw,Swin2SRForImageSuperResolution:()=>aN,Swin2SRModel:()=>sN,Swin2SRPreTrainedModel:()=>od,SwinForImageClassification:()=>rN,SwinForSemanticSegmentation:()=>nN,SwinModel:()=>tN,SwinPreTrainedModel:()=>fo,T5ForConditionalGeneration:()=>iN,T5Model:()=>oN,T5PreTrainedModel:()=>id,TableTransformerForObjectDetection:()=>cN,TableTransformerModel:()=>lN,TableTransformerObjectDetectionOutput:()=>Gw,TableTransformerPreTrainedModel:()=>ld,TrOCRForCausalLM:()=>uN,TrOCRPreTrainedModel:()=>$w,UltravoxModel:()=>su,UltravoxPreTrainedModel:()=>ow,UniSpeechForCTC:()=>hN,UniSpeechForSequenceClassification:()=>fN,UniSpeechModel:()=>dN,UniSpeechPreTrainedModel:()=>_o,UniSpeechSatForAudioFrameClassification:()=>gN,UniSpeechSatForCTC:()=>pN,UniSpeechSatForSequenceClassification:()=>mN,UniSpeechSatModel:()=>_N,UniSpeechSatPreTrainedModel:()=>Is,VaultGemmaForCausalLM:()=>vN,VaultGemmaModel:()=>wN,VaultGemmaPreTrainedModel:()=>cd,ViTForImageClassification:()=>MN,ViTMAEModel:()=>xN,ViTMAEPreTrainedModel:()=>Vw,ViTMSNForImageClassification:()=>TN,ViTMSNModel:()=>kN,ViTMSNPreTrainedModel:()=>dd,ViTModel:()=>bN,ViTPreTrainedModel:()=>ud,VisionEncoderDecoderModel:()=>yN,VitMatteForImageMatting:()=>EN,VitMattePreTrainedModel:()=>Uw,VitPoseForPoseEstimation:()=>AN,VitPosePreTrainedModel:()=>jw,VitsModel:()=>CN,VitsModelOutput:()=>qw,VitsPreTrainedModel:()=>Ww,VoxtralForConditionalGeneration:()=>SN,VoxtralRealtimeForConditionalGeneration:()=>Qw,VoxtralRealtimePreTrainedModel:()=>Hw,Wav2Vec2BertForCTC:()=>zN,Wav2Vec2BertForSequenceClassification:()=>BN,Wav2Vec2BertModel:()=>DN,Wav2Vec2BertPreTrainedModel:()=>po,Wav2Vec2ForAudioFrameClassification:()=>FF,Wav2Vec2ForCTC:()=>SF,Wav2Vec2ForSequenceClassification:()=>PF,Wav2Vec2Model:()=>CF,Wav2Vec2PreTrainedModel:()=>Lr,WavLMForAudioFrameClassification:()=>UN,WavLMForCTC:()=>GN,WavLMForSequenceClassification:()=>$N,WavLMForXVector:()=>VN,WavLMModel:()=>RN,WavLMPreTrainedModel:()=>On,WeSpeakerResNetModel:()=>jN,WeSpeakerResNetPreTrainedModel:()=>Yw,WhisperForConditionalGeneration:()=>Jw,WhisperModel:()=>WN,WhisperPreTrainedModel:()=>hd,XLMForQuestionAnswering:()=>KN,XLMForSequenceClassification:()=>YN,XLMForTokenClassification:()=>JN,XLMModel:()=>QN,XLMPreTrainedModel:()=>Nn,XLMRobertaForMaskedLM:()=>e3,XLMRobertaForQuestionAnswering:()=>n3,XLMRobertaForSequenceClassification:()=>t3,XLMRobertaForTokenClassification:()=>r3,XLMRobertaModel:()=>ZN,XLMRobertaPreTrainedModel:()=>Dn,XLMWithLMHeadModel:()=>XN,XVectorOutput:()=>Xw,YolosForObjectDetection:()=>a3,YolosModel:()=>s3,YolosObjectDetectionOutput:()=>Kw,YolosPreTrainedModel:()=>fd,YoutuForCausalLM:()=>i3,YoutuModel:()=>o3,YoutuPreTrainedModel:()=>_d});var Ts=class extends P{},TC=class extends Ts{},EC=class extends Ts{async _call(e){return new oe(await super._call(e))}},AC=class extends Ts{async _call(e){return new dt(await super._call(e))}},CC=class extends Ts{async _call(e){return new Xe(await super._call(e))}},fc=class extends P{},SC=class extends fc{},PC=class extends fc{},_c=class extends P{},FC=class extends _c{},LC=class extends _c{},pc=class extends P{},IC=class extends pc{},OC=class extends pc{},mc=class extends P{},NC=class extends mc{},DC=class extends mc{},Ja=class extends P{},zC=class extends Ja{},BC=class extends Ja{},RC=class extends Ja{async _call(e){return new oe(await super._call(e))}},gc=class extends P{},GC=class extends gc{},$C=class extends gc{async _call(e){return new oe(await super._call(e))}},xn=class extends P{},VC=class extends xn{},UC=class extends xn{async _call(e){return new Xe(await super._call(e))}},jC=class extends xn{async _call(e){return new oe(await super._call(e))}},qC=class extends xn{async _call(e){return new We(await super._call(e))}},WC=class extends xn{async _call(e){return new dt(await super._call(e))}},wc=class extends P{},HC=class extends wc{},QC=class extends wc{},vc=class extends P{},XC=class extends vc{},YC=class extends vc{},yc=class extends P{},JC=class extends yc{},KC=class extends yc{},kn=class extends P{},ZC=class extends kn{},eS=class extends kn{async _call(e){return new Xe(await super._call(e))}},tS=class extends kn{async _call(e){return new oe(await super._call(e))}},rS=class extends kn{async _call(e){return new We(await super._call(e))}},nS=class extends kn{async _call(e){return new dt(await super._call(e))}},sS=4299n,W_=6561n,Og=class extends P{constructor(){super(...arguments);k(this,"forward_params",["input_ids","inputs_embeds","attention_mask","position_ids","audio_values","exaggeration","audio_features","audio_tokens","speaker_embeddings","speaker_features","past_key_values"]);k(this,"main_input_name","input_ids");k(this,"_return_dict_in_generate_keys",["audio_tokens","speaker_embeddings","speaker_features"])}},Ng=class extends Og{async encode_speech(e){return xe(this.sessions.speech_encoder,{audio_values:e})}async forward({input_ids:e=null,attention_mask:t=null,audio_values:r=null,exaggeration:n=null,position_ids:s=null,inputs_embeds:a=null,past_key_values:o=null,generation_config:i=null,logits_processor:l=null,audio_features:c=null,audio_tokens:d=null,speaker_embeddings:h=null,speaker_features:_=null,...p}){let w;if(!a){const y=this.sessions.embed_tokens.inputNames,M={input_ids:e};if(y.includes("exaggeration")){if(!(n instanceof j)){const T=e.dims[0];if(n==null)n=lt([T],.5);else if(typeof n=="number")n=lt([T],n);else if(Array.isArray(n))n=new j("float32",n,[T]);else throw new Error("Unsupported type for `exaggeration` input")}M.exaggeration=n}if(y.includes("position_ids")&&(M.position_ids=s),{inputs_embeds:a}=await xe(this.sessions.embed_tokens,M),c&&d&&h&&_&&(w={audio_features:c,audio_tokens:d,speaker_embeddings:h,speaker_features:_}),w||r)w??(w=await this.encode_speech(r)),a=De([w.audio_features,a],1),t=gt([a.dims[0],a.dims[1]]);else{const T=a.dims[1];if(!o||T!==1)throw new Error("Incorrect state encountered during generation.");const A=o.get_seq_length();t=gt([a.dims[0],A+T])}}return{...await pr(this,{inputs_embeds:a,past_key_values:o,attention_mask:t,generation_config:i,logits_processor:l},!1),...w}}prepare_inputs_for_generation(e,t,r){if(!t.position_ids&&this.sessions.embed_tokens.inputNames.includes("position_ids"))if(t.input_ids.dims[1]===1){const n=Array.from({length:e.length},(s,a)=>e[a].length-e[a].findLastIndex(o=>o==W_)-1);t.position_ids=new j("int64",n,[e.length,1])}else{const s=t.input_ids.tolist().map(a=>{let o=0;return a.map(i=>i>=W_?0:o++)});t.position_ids=new j("int64",s.flat(),t.input_ids.dims)}return t.input_ids.dims[1]===1&&(delete t.audio_values,delete t.audio_features,delete t.audio_tokens,delete t.speaker_embeddings,delete t.speaker_features),fs(this,e,t)}async generate(e){const{sequences:t,audio_tokens:r,speaker_embeddings:n,speaker_features:s}=await super.generate({...e,return_dict_in_generate:!0}),a=t.slice(null,[e.input_ids.dims[1],-1]),o=lt([a.dims[0],3],sS),i=De([r,a,o],1),{waveform:l}=await xe(this.sessions.conditional_decoder,{speech_tokens:i,speaker_features:s,speaker_embeddings:n});return l}},Dg=class extends P{},aS=class extends Dg{},zg=class extends P{},oS=class extends zg{},Ka=class extends P{},iS=class extends Ka{},Bg=class extends Ka{static async from_pretrained(e,t={}){return super.from_pretrained(e,{...t,model_file_name:t.model_file_name??"text_model"})}},Rg=class extends Ka{static async from_pretrained(e,t={}){return super.from_pretrained(e,{...t,model_file_name:t.model_file_name??"audio_model"})}},Yr=class extends P{},lS=class extends Yr{},cS=class extends Yr{static async from_pretrained(e,t={}){return super.from_pretrained(e,{...t,model_file_name:t.model_file_name??"text_model"})}},Gg=class extends Yr{static async from_pretrained(e,t={}){return super.from_pretrained(e,{...t,model_file_name:t.model_file_name??"text_model"})}},uS=class extends Yr{static async from_pretrained(e,t={}){return super.from_pretrained(e,{...t,model_file_name:t.model_file_name??"vision_model"})}},dS=class extends Yr{static async from_pretrained(e,t={}){return super.from_pretrained(e,{...t,model_file_name:t.model_file_name??"vision_model"})}},bc=class extends P{},hS=class extends bc{},fS=class extends bc{},Mc=class extends P{},_S=class extends Mc{},pS=class extends Mc{},xc=class extends P{},mS=class extends xc{},gS=class extends xc{},kc=class extends P{},wS=class extends kc{},vS=class extends kc{},Tc=class extends P{constructor(){super(...arguments);k(this,"requires_attention_mask",!1);k(this,"main_input_name","input_features");k(this,"forward_params",["input_features","decoder_input_ids","decoder_attention_mask","past_key_values"])}},yS=class extends Tc{},bS=class extends Tc{},Tn=class extends P{},MS=class extends Tn{},xS=class extends Tn{async _call(e){return new Xe(await super._call(e))}},kS=class extends Tn{async _call(e){return new oe(await super._call(e))}},TS=class extends Tn{async _call(e){return new We(await super._call(e))}},ES=class extends Tn{async _call(e){return new dt(await super._call(e))}},Ec=class extends P{},AS=class extends Ec{},CS=class extends Ec{async _call(e){return new oe(await super._call(e))}},Ac=class extends P{},SS=class extends Ac{},PS=class extends Ac{async _call(e){return new oe(await super._call(e))}},Cc=class extends P{},FS=class extends Cc{},LS=class extends Cc{async _call(e){return new Es(await super._call(e))}},Es=class extends Qe{constructor({logits:e,pred_boxes:t}){super(),this.logits=e,this.pred_boxes=t}},Sc=class extends P{},IS=class extends Sc{},OS=class extends Sc{async _call(e){return new Es(await super._call(e))}},$g=class extends Qe{constructor({audio_codes:e}){super(),this.audio_codes=e}},Vg=class extends Qe{constructor({audio_values:e}){super(),this.audio_values=e}},Za=class extends P{constructor(){super(...arguments);k(this,"main_input_name","input_values");k(this,"forward_params",["input_values"])}},NS=class extends Za{async encode(e){return new $g(await xe(this.sessions.encoder_model,e))}async decode(e){return new Vg(await xe(this.sessions.decoder_model,e))}},Ug=class extends Za{static async from_pretrained(e,t={}){return super.from_pretrained(e,{...t,model_file_name:t.model_file_name??"encoder_model"})}},jg=class extends Za{static async from_pretrained(e,t={}){return super.from_pretrained(e,{...t,model_file_name:t.model_file_name??"decoder_model"})}},En=class extends P{},DS=class extends En{},zS=class extends En{async _call(e){return new Xe(await super._call(e))}},BS=class extends En{async _call(e){return new oe(await super._call(e))}},RS=class extends En{async _call(e){return new We(await super._call(e))}},GS=class extends En{async _call(e){return new dt(await super._call(e))}},Pc=class extends P{},$S=class extends Pc{},VS=class extends Pc{},An=class extends P{},US=class extends An{},jS=class extends An{async _call(e){return new Xe(await super._call(e))}},qS=class extends An{async _call(e){return new oe(await super._call(e))}},WS=class extends An{async _call(e){return new We(await super._call(e))}},HS=class extends An{async _call(e){return new dt(await super._call(e))}},qg=class extends P{},QS=class extends qg{},Fc=class extends P{},XS=class extends Fc{},YS=class extends Fc{async _call(e){return new oe(await super._call(e))}},Wg=class extends P{},JS=class extends Wg{},Hg=class extends P{},KS=class extends Hg{},eo=class extends P{},ZS=class extends eo{},eP=class extends eo{async _call(e){return new Lc(await super._call(e))}},tP=class extends eo{async _call(e){return new Qg(await super._call(e))}},Lc=class extends Qe{constructor({logits:e,pred_boxes:t}){super(),this.logits=e,this.pred_boxes=t}},Qg=class extends Qe{constructor({logits:e,pred_boxes:t,pred_masks:r}){super(),this.logits=e,this.pred_boxes=t,this.pred_masks=r}},Ic=class extends P{},rP=class extends Ic{},nP=class extends Ic{async _call(e){return new oe(await super._call(e))}},Oc=class extends P{},sP=class extends Oc{},aP=class extends Oc{async _call(e){return new oe(await super._call(e))}},Xg=class extends P{},oP=class extends Xg{},Yg=class extends P{},iP=class extends Yg{},Cn=class extends P{},lP=class extends Cn{},cP=class extends Cn{async _call(e){return new oe(await super._call(e))}},uP=class extends Cn{async _call(e){return new We(await super._call(e))}},dP=class extends Cn{async _call(e){return new dt(await super._call(e))}},hP=class extends Cn{async _call(e){return new Xe(await super._call(e))}},Jg=class extends P{},fP=class extends Jg{},Nc=class extends P{},_P=class extends Nc{},pP=class extends Nc{},Dc=class extends P{},mP=class extends Dc{},gP=class extends Dc{async _call(e){return new oe(await super._call(e))}},Sn=class extends P{},wP=class extends Sn{},vP=class extends Sn{async _call(e){return new Xe(await super._call(e))}},yP=class extends Sn{async _call(e){return new oe(await super._call(e))}},bP=class extends Sn{async _call(e){return new We(await super._call(e))}},MP=class extends Sn{async _call(e){return new dt(await super._call(e))}},zc=class extends P{},xP=class extends zc{},kP=class extends zc{},As=class extends P{},TP=class extends As{},EP=class extends As{async _call(e){return new Xe(await super._call(e))}},AP=class extends As{async _call(e){return new oe(await super._call(e))}},CP=class extends As{async _call(e){return new We(await super._call(e))}},Cs=class extends P{},SP=class extends Cs{},PP=class extends Cs{async _call(e){return new Xe(await super._call(e))}},FP=class extends Cs{async _call(e){return new oe(await super._call(e))}},LP=class extends Cs{async _call(e){return new We(await super._call(e))}},Bc=class extends P{},IP=class extends Bc{},OP=class extends Bc{},Rc=class extends P{},NP=class extends Rc{},DP=class extends Rc{},Gc=class extends P{},zP=class extends Gc{},BP=class extends Gc{},$c=class extends P{},RP=class extends $c{},GP=class extends $c{async _call(e){return new oe(await super._call(e))}},Kg=class extends P{constructor(){super(...arguments);k(this,"forward_params",["input_ids","inputs_embeds","attention_mask","pixel_values","encoder_outputs","decoder_input_ids","decoder_inputs_embeds","decoder_attention_mask","past_key_values"]);k(this,"main_input_name","inputs_embeds")}},$P=class extends Kg{_merge_input_ids_with_image_features({inputs_embeds:e,image_features:t,input_ids:r,attention_mask:n}){return{inputs_embeds:De([t,e],1),attention_mask:De([gt(t.dims.slice(0,2)),n],1)}}async _prepare_inputs_embeds({input_ids:e,pixel_values:t,inputs_embeds:r,attention_mask:n}){if(!e&&!t)throw new Error("Either `input_ids` or `pixel_values` should be provided.");let s,a;return e&&(s=await this.encode_text({input_ids:e})),t&&(a=await this.encode_image({pixel_values:t})),s&&a?{inputs_embeds:r,attention_mask:n}=this._merge_input_ids_with_image_features({inputs_embeds:s,image_features:a,input_ids:e,attention_mask:n}):r=s||a,{inputs_embeds:r,attention_mask:n}}async forward({input_ids:e,pixel_values:t,attention_mask:r,decoder_input_ids:n,decoder_attention_mask:s,encoder_outputs:a,past_key_values:o,inputs_embeds:i,decoder_inputs_embeds:l}){if(i||({inputs_embeds:i,attention_mask:r}=await this._prepare_inputs_embeds({input_ids:e,pixel_values:t,inputs_embeds:i,attention_mask:r})),!a){let{last_hidden_state:d}=await Fr(this,{inputs_embeds:i,attention_mask:r});a=d}if(!l){if(!n)throw new Error("Either `decoder_input_ids` or `decoder_inputs_embeds` should be provided.");l=await this.encode_text({input_ids:n})}return await pr(this,{inputs_embeds:l,attention_mask:s,encoder_attention_mask:r,encoder_hidden_states:a,past_key_values:o},!0)}},Vc=class extends P{},VP=class extends Vc{},UP=class extends Vc{},Uc=class extends P{},jP=class extends Uc{},qP=class extends Uc{},Zg=class extends P{constructor(){super(...arguments);k(this,"forward_params",["input_ids","attention_mask","pixel_values","position_ids","past_key_values"])}},mr=class extends Zg{_merge_input_ids_with_image_features(e){const t=e.image_features.dims.at(-1),r=e.image_features.view(-1,t);return dc({image_token_id:this.config.image_token_index??this.config.image_token_id,...e,image_features:r})}},WP=class extends mr{},HP=class extends mr{},ew=class extends P{},QP=class extends ew{},tw=class extends mr{},XP=class extends tw{},rw=class extends P{constructor(){super(...arguments);k(this,"forward_params",["input_ids","attention_mask","inputs_embeds","per_layer_inputs","position_ids","pixel_values","input_features","input_features_mask","past_key_values"])}},to=class extends rw{async forward({input_ids:e=null,attention_mask:t=null,pixel_values:r=null,input_features:n=null,input_features_mask:s=null,position_ids:a=null,inputs_embeds:o=null,per_layer_inputs:i=null,past_key_values:l=null,generation_config:c=null,logits_processor:d=null,...h}){if((!o||!i)&&({inputs_embeds:o,per_layer_inputs:i}=await xe(this.sessions.embed_tokens,{input_ids:e}),e.dims[1]!==1)){if(r){const{image_features:p}=await this._encode_vision({pixel_values:r,...h});({inputs_embeds:o,attention_mask:t}=this._merge_input_ids_with_image_features({image_features:p,inputs_embeds:o,input_ids:e,attention_mask:t}))}if(n){const{audio_features:p}=await xe(this.sessions.audio_encoder,{input_features:n,input_features_mask:s});({inputs_embeds:o,attention_mask:t}=this._merge_input_ids_with_audio_features({audio_features:p,inputs_embeds:o,input_ids:e,attention_mask:t}))}}return await pr(this,{inputs_embeds:o,per_layer_inputs:i,past_key_values:l,attention_mask:t,position_ids:a,generation_config:c,logits_processor:d},!0)}_encode_vision(e){return xe(this.sessions.vision_encoder,{pixel_values:e.pixel_values})}_merge_input_ids_with_image_features(e){const t=e.image_features.dims.at(-1),r=e.image_features.view(-1,t);return dc({image_token_id:this.config.image_token_id,...e,image_features:r})}_merge_input_ids_with_audio_features(e){const t=e.audio_features.dims.at(-1),r=e.audio_features.view(-1,t);return Ig({audio_token_id:this.config.audio_token_id,...e,audio_features:r})}},YP=class extends to{},jc=class extends to{constructor(){super(...arguments);k(this,"forward_params",["input_ids","attention_mask","inputs_embeds","per_layer_inputs","position_ids","pixel_values","image_position_ids","input_features","input_features_mask","past_key_values"])}_encode_vision(t){return xe(this.sessions.vision_encoder,{pixel_values:t.pixel_values,pixel_position_ids:t.image_position_ids})}},JP=class extends jc{},qc=class extends P{},KP=class extends qc{},ZP=class extends qc{},Wc=class extends P{},eF=class extends Wc{},tF=class extends Wc{},nw=class extends P{constructor(){super(...arguments);k(this,"forward_params",["input_ids","attention_mask","position_ids","past_key_values","pixel_values","image_grid_thw"])}},Hc=class extends nw{constructor(){super(...arguments);k(this,"image_grid_thw_name","grid_thw")}_get_text_only_rope_index(t,r){if(r){const{data:n,dims:s}=Fg(r),a=BigInt64Array.from({length:3*n.length},(i,l)=>n[l%n.length]),o=Array.from({length:s[0]},(i,l)=>Ue(n.subarray(s[1]*l,s[1]*(l+1)))[0]+1n+BigInt(s[1]));return[new j("int64",a,[3,...s]),new j("int64",o,[o.length,1])]}else{const[n,s]=t.dims,a=BigInt64Array.from({length:3*n*s},(o,i)=>BigInt(Math.floor(i%s/n)));return[new j("int64",a,[3,...t.dims]),Pm([n,1])]}}_reorder_and_write_positions(t,r,n,s){const a=t.reduce((c,d)=>c+d.length,0),o=new Array(a);let i=0;for(let c=0;c<3;++c)for(const d of t){const h=d.length/3;for(let _=c*h;_<(c+1)*h;++_)o[i++]=d[_]}let l=0;for(let c=0;c<r.length;++c)if(r[c]==1){for(let d=0;d<3;++d)n[d][s][c]=o[d*a/3+l];++l}return o}_get_multimodal_rope_positions({filtered_ids:t,image_grid_thw_list:r,video_grid_thw_list:n,spatial_merge_size:s,state:a}){const{image_token_id:o,video_token_id:i,vision_start_token_id:l}=this.config,c=t,h=c.reduce((T,A,S)=>(A==l&&T.push(S),T),[]).map(T=>c[T+1]),_=h.filter(T=>T==o).length,p=h.filter(T=>T==i).length,w=[];let v=0,y=_,M=p;for(let T=0;T<h.length;++T){const A=c.findIndex((X,J)=>J>v&&X==o),S=c.findIndex((X,J)=>J>v&&X==i),C=y>0&&A!==-1?A:c.length+1,I=M>0&&S!==-1?S:c.length+1;let x,R,z,$;C<I?([R,z,$]=r[a.image_index],++a.image_index,--y,x=C):([R,z,$]=n[a.video_index],++a.video_index,--M,x=I);const[Q,H,D]=[Number(R),Math.floor(Number(z)/s),Math.floor(Number($)/s)],O=x-v,te=w.length>0?Ue(w.at(-1))[0]+1:0;w.push(Array.from({length:3*O},(X,J)=>te+J%O));const W=O+te,ee=Q*H*D,G=Array.from({length:ee},(X,J)=>W+Math.floor(J/(H*D))),L=Array.from({length:ee},(X,J)=>W+Math.floor(J/D)%H),V=Array.from({length:ee},(X,J)=>W+J%D);w.push([G,L,V].flat()),v=x+ee}if(v<c.length){const T=w.length>0?Ue(w.at(-1))[0]+1:0,A=c.length-v;w.push(Array.from({length:3*A},(S,C)=>T+C%A))}return w}get_rope_index(t,r,n,s){const{vision_config:a}=this.config,o=a.spatial_merge_size??2;if(r||n){const i=t.tolist();s||(s=Sm(t));const l=s.tolist(),c=Array.from({length:3},()=>Array.from({length:t.dims[0]},()=>Array.from({length:t.dims[1]},()=>0))),d=r?r.tolist():[],h=n?n.tolist():[],_={image_index:0,video_index:0},p=[];for(let w=0;w<i.length;++w){const v=i[w].filter((T,A)=>l[w][A]==1),y=this._get_multimodal_rope_positions({filtered_ids:v,image_grid_thw_list:d,video_grid_thw_list:h,spatial_merge_size:o,state:_}),M=this._reorder_and_write_positions(y,l[w],c,w);p.push(Ue(M)[0]+1-i[w].length)}return[new j("int64",c.flat(1/0),[3,t.dims[0],t.dims[1]]),new j("int64",p,[p.length,1])]}else return this._get_text_only_rope_index(t,s)}async encode_image({pixel_values:t,image_grid_thw:r}){return(await xe(this.sessions.vision_encoder,{pixel_values:t,[this.image_grid_thw_name]:r})).image_features}_merge_input_ids_with_image_features(t){return dc({image_token_id:this.config.image_token_id,...t})}prepare_inputs_for_generation(t,r,n){if(!r.attention_mask||r.position_ids||!(this.sessions.decoder_model_merged??this.sessions.model).inputNames.includes("position_ids"))return r;if(!r.past_key_values)[r.position_ids,r.rope_deltas]=this.get_rope_index(r.input_ids,r.image_grid_thw,r.video_grid_thw,r.attention_mask);else{r.pixel_values=null;const a=r.past_key_values.get_seq_length();if(a<r.input_ids.dims[1]){const[o,i]=this.get_rope_index(r.input_ids,r.image_grid_thw,r.video_grid_thw,r.attention_mask);r.rope_deltas=i,r.position_ids=o.slice(null,null,[a,null]),r.input_ids=r.input_ids.slice(null,[a,null])}else{r.rope_deltas||([,r.rope_deltas]=this.get_rope_index(r.input_ids,r.image_grid_thw,r.video_grid_thw,r.attention_mask));const o=BigInt(a),i=r.rope_deltas.map(l=>o+l);r.position_ids=_r([i,i,i],0)}}return r}},sw=class extends Hc{},Qc=class extends Hc{constructor(){super(...arguments);k(this,"image_grid_thw_name","image_grid_thw")}},aw=class extends sw{constructor(){super(...arguments);k(this,"image_grid_thw_name","image_grid_thw")}},rF=class extends Qc{get_vision_position_ids(e,t,r,n){const s=Math.floor(t[0]/r),a=Math.floor(t[1]/n),o=Math.floor(t[2]/n),i=a*o*s,l=Array.from({length:i},()=>e),c=Array.from({length:i},(h,_)=>e+Math.floor(_/(o*s))),d=Array.from({length:i},(h,_)=>e+_%o);return[...l,...c,...d]}_get_multimodal_rope_positions({filtered_ids:e,image_grid_thw_list:t,video_grid_thw_list:r,spatial_merge_size:n,state:s}){const{image_token_id:a}=this.config,o=[];let i=0,l=e[0]==a?1:0;for(let h=1;h<=e.length;++h){const _=h<e.length?e[h]==a?1:0:-1;_!==l&&(o.push([l,i,h]),i=h,l=_)}let c=0;const d=[];for(const[h,_,p]of o)if(h===0){const w=p-_;d.push(Array.from({length:3*w},(v,y)=>c+y%w)),c+=w}else{const w=t[s.image_index++].map(Number),v=w[0];d.push(this.get_vision_position_ids(c,w,v,n)),c+=Math.max(w[1],w[2])/n}return d}},Xc=class extends P{},nF=class extends Xc{},sF=class extends Xc{},Yc=class extends P{},aF=class extends Yc{},oF=class extends Yc{},Jc=class extends P{},iF=class extends Jc{},lF=class extends Jc{},Kc=class extends P{},cF=class extends Kc{},uF=class extends Kc{},Zc=class extends P{},dF=class extends Zc{},hF=class extends Zc{},eu=class extends P{},fF=class extends eu{},_F=class extends eu{},tu=class extends P{},pF=class extends tu{},mF=class extends tu{},ru=class extends P{},gF=class extends ru{},wF=class extends ru{},nu=class extends P{},vF=class extends nu{},yF=class extends nu{},ow=class extends P{constructor(){super(...arguments);k(this,"forward_params",["input_ids","attention_mask","position_ids","audio_values","past_key_values"])}},su=class extends ow{_merge_input_ids_with_audio_features(e){const t=e.audio_features.dims.at(-1),r=e.audio_features.view(-1,t);return Ig({audio_token_id:this.config.ignore_index??this.config.audio_token_id??this.config.audio_token_index,...e,audio_features:r})}},bF=class extends su{constructor(){super(...arguments);k(this,"forward_params",["input_ids","attention_mask","input_features","past_key_values"])}},iw=class extends P{},MF=class extends iw{},lw=class extends P{},xF=class extends lw{},au=class extends P{},kF=class extends au{},TF=class extends au{},ou=class extends P{},EF=class extends ou{},AF=class extends ou{async _call(e){return new oe(await super._call(e))}},Lr=class extends P{},CF=class extends Lr{},SF=class extends Lr{async _call(e){return new Xr(await super._call(e))}},PF=class extends Lr{async _call(e){return new oe(await super._call(e))}},FF=class extends Lr{async _call(e){return new We(await super._call(e))}},LF=class extends P{},IF=class extends Lr{},OF=class extends Lr{async _call(e){return new Xr(await super._call(e))}},NF=class extends Lr{async _call(e){return new oe(await super._call(e))}},iu=class extends P{},DF=class extends iu{},zF=class extends iu{},cw=class extends mr{constructor(){super(...arguments);k(this,"forward_params",["input_ids","attention_mask","pixel_values","pixel_attention_mask","position_ids","past_key_values"])}},lu=class extends P{},BF=class extends lu{},RF=class extends lu{async _call(e){return new oe(await super._call(e))}},cu=class extends P{},GF=class extends cu{},$F=class extends cu{},ro=class extends P{},VF=class extends ro{async forward(e){const t=!e.input_ids,r=!e.pixel_values;if(t&&r)throw new Error("Either `input_ids` or `pixel_values` should be provided.");if(t&&(e.input_ids=gt([e.pixel_values.dims[0],1])),r){const{image_size:l}=this.config.vision_config;e.pixel_values=lt([0,3,l,l],0)}const{text_embeddings:n,image_embeddings:s,l2norm_text_embeddings:a,l2norm_image_embeddings:o}=await super.forward(e),i={};return t||(i.text_embeddings=n,i.l2norm_text_embeddings=a),r||(i.image_embeddings=s,i.l2norm_image_embeddings=o),i}},uw=class extends ro{static async from_pretrained(e,t={}){return super.from_pretrained(e,{...t,model_file_name:t.model_file_name??"text_model"})}},UF=class extends ro{static async from_pretrained(e,t={}){return super.from_pretrained(e,{...t,model_file_name:t.model_file_name??"vision_model"})}},uu=class extends P{},jF=class extends uu{},qF=class extends uu{},WF=class extends mr{},du=class extends P{},HF=class extends du{},QF=class extends du{},XF=class extends mr{constructor(){super(...arguments);k(this,"forward_params",["input_ids","attention_mask","pixel_values","pixel_attention_mask","spatial_shapes","position_ids","past_key_values"])}},hu=class extends P{},YF=class extends hu{},JF=class extends hu{},dw=class extends P{},KF=class extends dw{},fu=class extends P{},ZF=class extends fu{},eL=class extends fu{},_u=class extends P{},tL=class extends _u{},rL=class extends _u{},pu=class extends P{},nL=class extends pu{},sL=class extends pu{},mu=class extends P{},aL=class extends mu{},oL=class extends mu{},Ss=class extends P{},iL=class extends Ss{},lL=class extends Ss{},cL=class extends Ss{async _call(e){return new oe(await super._call(e))}},uL=class extends Ss{},hw=class extends P{},dL=class extends hw{},fw=class extends P{},hL=class extends fw{},_w=class extends Qe{constructor({char_logits:e,bpe_logits:t,wp_logits:r}){super(),this.char_logits=e,this.bpe_logits=t,this.wp_logits=r}get logits(){return[this.char_logits,this.bpe_logits,this.wp_logits]}},pw=class extends P{},fL=class extends pw{async _call(e){return new _w(await super._call(e))}},mw=class extends Qe{constructor({audio_codes:e}){super(),this.audio_codes=e}},gw=class extends Qe{constructor({audio_values:e}){super(),this.audio_values=e}},no=class extends P{constructor(){super(...arguments);k(this,"main_input_name","input_values");k(this,"forward_params",["input_values"])}},_L=class extends no{async encode(e){return new mw(await xe(this.sessions.encoder_model,e))}async decode(e){return new gw(await xe(this.sessions.decoder_model,e))}},ww=class extends no{static async from_pretrained(e,t={}){return super.from_pretrained(e,{...t,model_file_name:t.model_file_name??"encoder_model"})}},vw=class extends no{static async from_pretrained(e,t={}){return super.from_pretrained(e,{...t,model_file_name:t.model_file_name??"decoder_model"})}},gu=class extends P{},pL=class extends gu{},mL=class extends gu{},wu=class extends P{},gL=class extends wu{},wL=class extends wu{},Ps=class extends P{},vL=class extends Ps{},yL=class extends Ps{async _call(e){return new Xe(await super._call(e))}},bL=class extends Ps{async _call(e){return new oe(await super._call(e))}},ML=class extends Ps{async _call(e){return new dt(await super._call(e))}},vu=class extends P{},xL=class extends vu{},kL=class extends vu{},so=class extends P{},TL=class extends so{},EL=class extends so{async _call(e){return new oe(await super._call(e))}},AL=class extends so{},ao=class extends P{},CL=class extends ao{},SL=class extends ao{async _call(e){return new oe(await super._call(e))}},PL=class extends ao{},oo=class extends P{},FL=class extends oo{},LL=class extends oo{async _call(e){return new oe(await super._call(e))}},IL=class extends oo{},io=class extends P{},OL=class extends io{},NL=class extends io{async _call(e){return new oe(await super._call(e))}},DL=class extends io{},yu=class extends P{},zL=class extends yu{},BL=class extends yu{async _call(e){return new oe(await super._call(e))}},bu=class extends P{},RL=class extends bu{},GL=class extends bu{async _call(e){return new oe(await super._call(e))}},Fs=class extends P{},$L=class extends Fs{},VL=class extends Fs{async _call(e){return new Xe(await super._call(e))}},UL=class extends Fs{async _call(e){return new oe(await super._call(e))}},jL=class extends Fs{async _call(e){return new We(await super._call(e))}},Mu=class extends P{},qL=class extends Mu{},WL=class extends Mu{},xu=class extends P{constructor(){super(...arguments);k(this,"requires_attention_mask",!1);k(this,"main_input_name","input_values");k(this,"forward_params",["input_values","decoder_input_ids","past_key_values"])}},HL=class extends xu{},QL=class extends xu{},Pn=class extends P{},XL=class extends Pn{},YL=class extends Pn{async _call(e){return new Xe(await super._call(e))}},JL=class extends Pn{async _call(e){return new oe(await super._call(e))}},KL=class extends Pn{async _call(e){return new We(await super._call(e))}},ZL=class extends Pn{async _call(e){return new dt(await super._call(e))}},ku=class extends P{},eI=class extends ku{},tI=class extends ku{},Tu=class extends P{},rI=class extends Tu{},nI=class extends Tu{},yw=class extends P{},sI=class extends yw{constructor(...t){super(...t);k(this,"forward_params",["input_ids","pixel_values","images_seq_mask","images_emb_mask","attention_mask","position_ids","past_key_values"]);this._generation_mode="text"}async forward(t){const r=this._generation_mode??"text";let n;if(r==="text"||!t.past_key_values){const l=this.sessions.prepare_inputs_embeds,c=Ze(t,l.inputNames);n=await xe(l,c)}else{const l=this.sessions.gen_img_embeds,c=Ze({image_ids:t.input_ids},l.inputNames);n=await xe(l,c)}const s={...t,...n},a=await pr(this,s),o=this.sessions[r==="text"?"lm_head":"gen_head"];if(!o)throw new Error(`Unable to find "${o}" generation head`);const i=await xe(o,Ze(a,o.inputNames));return{...n,...a,...i}}prepare_inputs_for_generation(t,r,n){const s=!!r.past_key_values;return n.guidance_scale!==null&&n.guidance_scale>1&&(s?r.input_ids=De([r.input_ids,r.input_ids],0):(r.input_ids=De([r.input_ids,pl(r.input_ids,BigInt(n.pad_token_id))],0),r.attention_mask=De([r.attention_mask,pl(r.attention_mask,0n)],0))),(s||!r.pixel_values)&&(r.pixel_values=lt([0,0,3,384,384],1)),s&&(r.images_seq_mask=new j("bool",new Array(1).fill(!0).fill(!1,0,1),[1,1]),r.images_emb_mask=new j("bool",new Array(0).fill(!1),[1,1,0])),r}async generate(t){return this._generation_mode="text",super.generate(t)}async generate_images(t){this._generation_mode="image";const r=(t.inputs??t[this.main_input_name]).dims[1],s=(await super.generate(t)).slice(null,[r,null]),a=this.sessions.image_decode,{decoded_image:o}=await xe(a,{generated_tokens:s}),i=o.add_(1).mul_(255/2).clamp_(0,255).to("uint8"),l=[];for(const c of i){const d=Gt.fromTensor(c);l.push(d)}return l}},Eu=class extends P{},aI=class extends Eu{},oI=class extends Eu{},bw=class extends P{constructor(){super(...arguments);k(this,"forward_params",["input_ids","attention_mask","encoder_outputs","decoder_input_ids","decoder_attention_mask","past_key_values"])}_apply_and_filter_by_delay_pattern_mask(t){const[r,n]=t.dims,s=this.config.decoder.num_codebooks,a=n-s;let o=0;for(let c=0;c<t.size;++c){if(t.data[c]==this.config.decoder.pad_token_id)continue;const d=c%n,h=Math.floor(c/n)%s,_=d-h;_>0&&_<=a&&(t.data[o++]=t.data[c])}const i=Math.floor(r/s),l=o/(i*s);return new j(t.type,t.data.slice(0,o),[i,s,l])}prepare_inputs_for_generation(t,r,n){const s=BigInt(this.config.decoder.pad_token_id);let a=structuredClone(t);for(let o=0;o<a.length;++o)for(let i=0;i<a[o].length;++i)o%this.config.decoder.num_codebooks>=i&&(a[o][i]=s);return n.guidance_scale!==null&&n.guidance_scale>1&&(a=a.concat(a)),Ra(this,a,r)}async generate(t){const r=await super.generate(t),n=this._apply_and_filter_by_delay_pattern_mask(r).unsqueeze_(0),{audio_values:s}=await xe(this.sessions.encodec_decode,{audio_codes:n});return s}},Au=class extends P{},iI=class extends Au{},lI=class extends Au{},Cu=class extends P{},cI=class extends Cu{},uI=class extends Cu{},Fn=class extends P{},dI=class extends Fn{},hI=class extends Fn{async _call(e){return new Xe(await super._call(e))}},fI=class extends Fn{async _call(e){return new oe(await super._call(e))}},_I=class extends Fn{async _call(e){return new We(await super._call(e))}},pI=class extends Fn{async _call(e){return new dt(await super._call(e))}},Mw=class extends P{},mI=class extends Mw{},Su=class extends P{},gI=class extends Su{},wI=class extends Su{},Pu=class extends P{},vI=class extends Pu{},yI=class extends Pu{},Fu=class extends P{},bI=class extends Fu{},MI=class extends Fu{},Lu=class extends P{},xI=class extends Lu{},kI=class extends Lu{},Iu=class extends P{},TI=class extends Iu{},EI=class extends Iu{async _call(e){return new oe(await super._call(e))}},Ou=class extends P{},AI=class extends Ou{},CI=class extends Ou{},Nu=class extends P{},SI=class extends Nu{},PI=class extends Nu{},Du=class extends P{},FI=class extends Du{},LI=class extends Du{},zu=class extends P{},II=class extends zu{},OI=class extends zu{},NI=class extends mr{},xw=class extends P{},DI=class extends xw{async _call(e){return new Xr(await super._call(e))}},Bu=class extends P{},zI=class extends Bu{},BI=class extends Bu{},Ru=class extends P{},RI=class extends Ru{},GI=class extends Ru{},Gu=class extends P{},$I=class extends Gu{},VI=class extends Gu{},$u=class extends P{},UI=class extends $u{},jI=class extends $u{},kw=class extends P{constructor(){super(...arguments);k(this,"forward_params",["input_ids","inputs_embeds","attention_mask","position_ids","pixel_values","image_sizes","past_key_values"])}},Tw=class extends kw{async forward({input_ids:e=null,attention_mask:t=null,pixel_values:r=null,image_sizes:n=null,position_ids:s=null,inputs_embeds:a=null,past_key_values:o=null,generation_config:i=null,logits_processor:l=null,...c}){if(!a){let h;if(r&&e.dims[1]!==1){if(!n)throw new Error("`image_sizes` must be provided when `pixel_values` is provided.");({image_features:h}=await xe(this.sessions.vision_encoder,{pixel_values:r,image_sizes:n}))}else{const _=this.config.normalized_config.hidden_size;h=new j("float32",[],[0,_])}({inputs_embeds:a}=await xe(this.sessions.prepare_inputs_embeds,{input_ids:e,image_features:h}))}return await pr(this,{inputs_embeds:a,past_key_values:o,attention_mask:t,position_ids:s,generation_config:i,logits_processor:l},!1)}},Vu=class extends P{},qI=class extends Vu{},WI=class extends Vu{async _call(e){return new oe(await super._call(e))}},Uu=class extends P{},HI=class extends Uu{},QI=class extends Uu{async _call(e){return new We(await super._call(e))}},ju=class extends P{},XI=class extends ju{},YI=class extends ju{},qu=class extends P{},JI=class extends qu{},KI=class extends qu{},Wu=class extends P{},ZI=class extends Wu{},eO=class extends Wu{},Hu=class extends P{},tO=class extends Hu{},rO=class extends Hu{},Qu=class extends P{},nO=class extends Qu{},sO=class extends Qu{},Xu=class extends Qc{},Ew=class extends aw{},aO=class extends Xu{},oO=class extends Ew{},Yu=class extends Xu{},Aw=class extends Yu{},iO=class extends Yu{},lO=class extends Aw{},Ju=class extends P{},cO=class extends Ju{},uO=class extends Ju{async _call(e){return new oe(await super._call(e))}},Ku=class extends P{},dO=class extends Ku{},hO=class extends Ku{async _call(e){return new Cw(await super._call(e))}},Cw=class extends Es{},Ln=class extends P{},fO=class extends Ln{},_O=class extends Ln{async _call(e){return new Xe(await super._call(e))}},pO=class extends Ln{async _call(e){return new oe(await super._call(e))}},mO=class extends Ln{async _call(e){return new We(await super._call(e))}},gO=class extends Ln{async _call(e){return new dt(await super._call(e))}},In=class extends P{},wO=class extends In{},vO=class extends In{async _call(e){return new Xe(await super._call(e))}},yO=class extends In{async _call(e){return new oe(await super._call(e))}},bO=class extends In{async _call(e){return new We(await super._call(e))}},MO=class extends In{async _call(e){return new dt(await super._call(e))}},Zu=class extends P{},xO=class extends Zu{},kO=class extends Zu{async _call(e){return new Sw(await super._call(e))}},Sw=class extends Es{},Pw=class extends Qe{constructor({iou_scores:e,pred_masks:t}){super(),this.iou_scores=e,this.pred_masks=t}},Fw=class extends P{},TO=class extends Fw{async get_image_embeddings({pixel_values:e}){return await Fr(this,{pixel_values:e})}async forward(e){!e.image_embeddings||!e.image_positional_embeddings?e={...e,...await this.get_image_embeddings(e)}:e={...e},e.input_labels??(e.input_labels=gt(e.input_points.dims.slice(0,-1)));const t={image_embeddings:e.image_embeddings,image_positional_embeddings:e.image_positional_embeddings};return e.input_points&&(t.input_points=e.input_points),e.input_labels&&(t.input_labels=e.input_labels),e.input_boxes&&(t.input_boxes=e.input_boxes),await xe(this.sessions.prompt_encoder_mask_decoder,t)}async _call(e){return new Pw(await super._call(e))}},Lw=class extends Qe{constructor({iou_scores:e,pred_masks:t,object_score_logits:r}){super(),this.iou_scores=e,this.pred_masks=t,this.object_score_logits=r}},Iw=class extends P{},ed=class extends Iw{async get_image_embeddings({pixel_values:e}){return await Fr(this,{pixel_values:e})}async forward(e){const{num_feature_levels:t}=this.config.vision_config;if(Array.from({length:t},(a,o)=>`image_embeddings.${o}`).some(a=>!e[a])?e={...e,...await this.get_image_embeddings(e)}:e={...e},e.input_points){if(e.input_boxes&&e.input_boxes.dims[1]!==1)throw new Error("When both `input_points` and `input_boxes` are provided, the number of boxes per image must be 1.");const a=e.input_points.dims;e.input_labels??(e.input_labels=gt(a.slice(0,-1))),e.input_boxes??(e.input_boxes=lt([a[0],0,4],0))}else if(e.input_boxes){const a=e.input_boxes.dims;e.input_labels=lt([a[0],a[1],0],-1n),e.input_points=lt([a[0],1,0,2],0)}else throw new Error("At least one of `input_points` or `input_boxes` must be provided.");const n=this.sessions.prompt_encoder_mask_decoder,s=Ze(e,n.inputNames);return await xe(n,s)}async _call(e){return new Lw(await super._call(e))}},EO=class extends ed{},AO=class extends ed{},lo=class extends P{},CO=class extends lo{},SO=class extends lo{},PO=class extends lo{},co=class extends P{},FO=class extends co{},LO=class extends co{},IO=class extends co{},td=class extends P{},OO=class extends td{},Ow=class extends td{static async from_pretrained(e,t={}){return super.from_pretrained(e,{...t,model_file_name:t.model_file_name??"text_model"})}},NO=class extends Yr{static async from_pretrained(e,t={}){return super.from_pretrained(e,{...t,model_file_name:t.model_file_name??"vision_model"})}},rd=class extends P{},DO=class extends rd{},zO=class extends rd{},BO=class extends cw{},uo=class extends P{constructor(){super(...arguments);k(this,"main_input_name","input_values");k(this,"forward_params",["input_values"])}},RO=class extends uo{async encode(e){return await xe(this.sessions.encoder_model,e)}async decode(e){return await xe(this.sessions.decoder_model,e)}},Nw=class extends uo{static async from_pretrained(e,t={}){return super.from_pretrained(e,{...t,model_file_name:t.model_file_name??"encoder_model"})}},Dw=class extends uo{static async from_pretrained(e,t={}){return super.from_pretrained(e,{...t,model_file_name:t.model_file_name??"decoder_model"})}},nd=class extends P{},GO=class extends nd{},$O=class extends nd{},ho=class extends P{},VO=class extends ho{},UO=class extends ho{},jO=class extends ho{async generate_speech(e,t,{threshold:r=.5,minlenratio:n=0,maxlenratio:s=20,vocoder:a=null}={}){const o={input_ids:e},{encoder_outputs:i,encoder_attention_mask:l}=await Fr(this,o),c=i.dims[1]/this.config.reduction_factor,d=Math.floor(c*s),h=Math.floor(c*n),_=this.config.num_mel_bins;let p=[],w=null,v=null,y=0;for(;;){++y;const A=Cg(!!v);let S;v?S=v.output_sequence_out:S=new j("float32",new Float32Array(_),[1,1,_]);let C={use_cache_branch:A,output_sequence:S,encoder_attention_mask:l,speaker_embeddings:t,encoder_hidden_states:i};uc(this,C,w),v=await xe(this.sessions.decoder_model_merged,C),w=Ml(v,w);const{prob:I,spectrum:x}=v;if(p.push(x),y>=h&&(Array.from(I.data).filter(R=>R>=r).length>0||y>=d))break}const M=De(p),{waveform:T}=await xe(a.sessions.model,{spectrogram:M});return{spectrogram:M,waveform:T}}},qO=class extends P{constructor(){super(...arguments);k(this,"main_input_name","spectrogram")}},Ls=class extends P{},WO=class extends Ls{},HO=class extends Ls{async _call(e){return new Xe(await super._call(e))}},QO=class extends Ls{async _call(e){return new oe(await super._call(e))}},XO=class extends Ls{async _call(e){return new dt(await super._call(e))}},sd=class extends P{},YO=class extends sd{},JO=class extends sd{},ad=class extends P{},KO=class extends ad{},ZO=class extends ad{},zw=class extends P{},eN=class extends zw{},Bw=class extends P{},Rw=class extends Bw{async generate_speech({input_ids:e,attention_mask:t,style:r,num_inference_steps:n=5,speed:s=1.05}){const{sampling_rate:a,chunk_compress_factor:o,base_chunk_size:i,latent_dim:l}=this.config,{last_hidden_state:c,durations:d}=await xe(this.sessions.text_encoder,{input_ids:e,attention_mask:t,style:r}),h=d.div(s).mul_(a),_=i*o,p=h.data,w=Int32Array.from(p,z=>Math.ceil(z/_)),v=Math.max(...w),y=e.dims[0],M=new BigInt64Array(y*v);for(let z=0;z<y;++z)M.fill(1n,z*v,z*v+w[z]);const T=new j("int64",M,[y,v]),A=l*o,S=A*v;let C=AT([y,A,v]);const I=C.data;for(let z=0;z<y;++z)if(w[z]!==v)for(let $=0;$<A;++$)I.fill(0,z*S+$*v+w[z],z*S+($+1)*v);const x=lt([y],n);for(let z=0;z<n;++z){const $=lt([y],z);({denoised_latents:C}=await xe(this.sessions.latent_denoiser,{style:r,noisy_latents:C,latent_mask:T,encoder_outputs:c,attention_mask:t,timestep:$,num_inference_steps:x}))}const{waveform:R}=await xe(this.sessions.voice_decoder,{latents:C});return{waveform:R,durations:h}}},fo=class extends P{},tN=class extends fo{},rN=class extends fo{async _call(e){return new oe(await super._call(e))}},nN=class extends fo{},od=class extends P{},sN=class extends od{},aN=class extends od{},id=class extends P{constructor(){super(...arguments);k(this,"forward_params",["input_ids","attention_mask","encoder_outputs","decoder_input_ids","decoder_attention_mask","past_key_values"])}},oN=class extends id{},iN=class extends id{},ld=class extends P{},lN=class extends ld{},cN=class extends ld{async _call(e){return new Gw(await super._call(e))}},Gw=class extends Lc{},$w=class extends P{},uN=class extends $w{},_o=class extends P{},dN=class extends _o{},hN=class extends _o{async _call(e){return new Xr(await super._call(e))}},fN=class extends _o{async _call(e){return new oe(await super._call(e))}},Is=class extends P{},_N=class extends Is{},pN=class extends Is{async _call(e){return new Xr(await super._call(e))}},mN=class extends Is{async _call(e){return new oe(await super._call(e))}},gN=class extends Is{async _call(e){return new We(await super._call(e))}},cd=class extends P{},wN=class extends cd{},vN=class extends cd{},yN=class extends P{constructor(){super(...arguments);k(this,"main_input_name","pixel_values");k(this,"forward_params",["pixel_values","decoder_input_ids","encoder_hidden_states","past_key_values"])}},ud=class extends P{},bN=class extends ud{},MN=class extends ud{async _call(e){return new oe(await super._call(e))}},Vw=class extends P{},xN=class extends Vw{},dd=class extends P{},kN=class extends dd{},TN=class extends dd{async _call(e){return new oe(await super._call(e))}},Uw=class extends P{},EN=class extends Uw{async _call(e){return new JA(await super._call(e))}},jw=class extends P{},AN=class extends jw{},qw=class extends Qe{constructor({waveform:e,spectrogram:t}){super(),this.waveform=e,this.spectrogram=t}},Ww=class extends P{},CN=class extends Ww{async _call(e){return new qw(await super._call(e))}},SN=class extends su{},H_=2,PN=1,Mi=new WeakMap;function FN(e,t){var v,y;const{text_config:r,audio_config:n}=e.config,s=e.sessions.audio_encoder,{num_mel_bins:a,hidden_size:o}=n,i=a+o,l=new lc,c=Qa(n),d={batch_size:1};let h="float32";for(const M of s.inputMetadata){if(M.name==="past_padding_cache"){h=M.type;continue}if(!c.has(M.name))continue;const T=Sg(M.shape,d),A=T.reduce((C,I)=>C*I,1),S=ms[M.type];l[M.name]=new j(M.type,new S(A),T)}const _=ms[h],p=new j(h,new _(i*H_),[1,i,H_]),w=((v=t[Symbol.asyncIterator])==null?void 0:v.call(t))??((y=t[Symbol.iterator])==null?void 0:y.call(t));if(!w)throw new Error("input_features must be iterable or async iterable");return{encoder_session:s,enc_kv_cache:l,enc_padding_cache:p,enc_past_seq_len:0,audio_embed_queue:[],audio_embed_total_tokens:0,audio_queue_offset:0,audio_consumed:0,stream_exhausted:!1,chunks_iter:w,text_hidden_size:r.hidden_size}}async function LN(e,t){const r=t.dims[2],n=Math.floor((PN+r-3)/2)+1,s=new j("int64",BigInt64Array.from({length:n},(d,h)=>BigInt(e.enc_past_seq_len+h)),[1,n]),a=e.enc_past_seq_len+n,o=gt([1,a]),{audio_embeds:i,present_padding_cache:l,...c}=await xe(e.encoder_session,{input_features:t,attention_mask:o,position_ids:s,past_padding_cache:e.enc_padding_cache,...e.enc_kv_cache});e.enc_padding_cache.location==="gpu-buffer"&&e.enc_padding_cache.dispose(),e.enc_padding_cache=l;for(const d in c)if(d.startsWith("present.")){const h=d.replace("present","past_key_values"),_=e.enc_kv_cache[h];(_==null?void 0:_.location)==="gpu-buffer"&&_.dispose(),e.enc_kv_cache[h]=c[d]}return e.enc_past_seq_len=a,i}async function IN(e,t){for(;e.audio_embed_total_tokens<t&&!e.stream_exhausted;){const r=await e.chunks_iter.next();if(r.done){e.stream_exhausted=!0;break}const n=await LN(e,r.value);e.audio_embed_queue.push({data:n.data,tokens:n.dims[1]}),e.audio_embed_total_tokens+=n.dims[1]}}function ON(e,t,r){if(e.audio_embed_queue.length===0)return;const n=t.data;let s=0,a=r;for(;a>0&&e.audio_embed_queue.length>0;){const o=e.audio_embed_queue[0],i=o.tokens-e.audio_queue_offset,l=Math.min(a,i),c=e.audio_queue_offset*e.text_hidden_size;for(let d=0;d<l*e.text_hidden_size;++d)n[s*e.text_hidden_size+d]+=o.data[c+d];s+=l,a-=l,e.audio_queue_offset+=l,e.audio_queue_offset>=o.tokens&&(e.audio_embed_queue.shift(),e.audio_queue_offset=0)}e.audio_consumed+=r-a}var NN=class extends Xa{constructor(e){super(),this._s=e}_call(e){const t=this._s.stream_exhausted&&this._s.audio_embed_queue.length===0;return e.map(()=>t)}},Hw=class extends P{constructor(){super(...arguments);k(this,"forward_params",["input_ids","attention_mask","position_ids","past_key_values"])}},Qw=class extends Hw{async forward({input_ids:e,past_key_values:t,...r}){const n=e.dims[1],s=Mi.get(this);s&&await IN(s,s.audio_consumed+n);const{inputs_embeds:a}=await xe(this.sessions.embed_tokens,{input_ids:e});s&&ON(s,a,n);const o={inputs_embeds:a,...r};uc(this,o,t);const i=this.sessions.decoder_model_merged,l=Ze(o,i.inputNames);return await xe(i,l)}async generate({input_features:e,stopping_criteria:t,...r}){if(!e)throw new Error("input_features (generator/iterable) must be provided");const n=FN(this,e);Mi.set(this,n);const s=new xg;s.push(new NN(n)),t&&s.extend(t);try{return await super.generate({...r,stopping_criteria:s})}finally{n.enc_kv_cache.dispose(),Mi.delete(this)}}},po=class extends P{},DN=class extends po{},zN=class extends po{async _call(e){return new Xr(await super._call(e))}},BN=class extends po{async _call(e){return new oe(await super._call(e))}},Xw=class extends Qe{constructor({logits:e,embeddings:t}){super(),this.logits=e,this.embeddings=t}},On=class extends P{},RN=class extends On{},GN=class extends On{async _call(e){return new Xr(await super._call(e))}},$N=class extends On{async _call(e){return new oe(await super._call(e))}},VN=class extends On{async _call(e){return new Xw(await super._call(e))}},UN=class extends On{async _call(e){return new We(await super._call(e))}},Yw=class extends P{},jN=class extends Yw{},qN=class extends Mg{constructor(){super(...arguments);k(this,"return_timestamps",null);k(this,"return_token_timestamps",null);k(this,"num_frames",null);k(this,"alignment_heads",null);k(this,"task",null);k(this,"language",null);k(this,"no_timestamps_token_id",null);k(this,"prompt_ids",null);k(this,"is_multilingual",null);k(this,"lang_to_id",null);k(this,"task_to_id",null);k(this,"max_initial_timestamp_index",1)}},hd=class extends P{constructor(){super(...arguments);k(this,"requires_attention_mask",!1);k(this,"main_input_name","input_features");k(this,"forward_params",["input_features","attention_mask","decoder_input_ids","decoder_attention_mask","past_key_values"])}},WN=class extends hd{},Jw=class extends hd{_prepare_generation_config(e,t){return super._prepare_generation_config(e,t,qN)}_retrieve_init_tokens(e){const t=[e.decoder_start_token_id];let r=e.language;const n=e.task;if(e.is_multilingual){r||(ue.warn("No language specified - defaulting to English (en)."),r="en");const a=`<|${ME(r)}|>`;t.push(e.lang_to_id[a]),t.push(e.task_to_id[n??"transcribe"])}else if(r||n)throw new Error("Cannot specify `task` or `language` for an English-only model. If the model is intended to be multilingual, pass `is_multilingual=true` to generate, or update the generation config.");return!e.return_timestamps&&e.no_timestamps_token_id&&t.at(-1)!==e.no_timestamps_token_id?t.push(e.no_timestamps_token_id):e.return_timestamps&&t.at(-1)===e.no_timestamps_token_id&&(ue.warn("<|notimestamps|> prompt token is removed from generation_config since `return_timestamps` is set to `true`."),t.pop()),t.filter(s=>s!=null)}async generate({inputs:e=null,generation_config:t=null,logits_processor:r=null,stopping_criteria:n=null,...s}){t=this._prepare_generation_config(t,s);const a=s.decoder_input_ids instanceof j?Zl(s.decoder_input_ids):s.decoder_input_ids??this._retrieve_init_tokens(t);if(t.return_timestamps&&(r??(r=new yl),r.push(new rC(t,a))),t.begin_suppress_tokens&&(r??(r=new yl),r.push(new bg(t.begin_suppress_tokens,a.length))),t.return_token_timestamps){if(!t.alignment_heads)throw new Error("Model generation config has no `alignment_heads`, token-level timestamps not available. See https://gist.github.com/hollance/42e32852f24243b748ae6bc1f985b13a on how to add this property to the generation config.");t.task==="translate"&&ue.warn("Token-level timestamps may not be reliable for task 'translate'."),t.output_attentions=!0,t.return_dict_in_generate=!0}if(t.return_timestamps&&!s.max_new_tokens)return this._generate_with_seek({inputs:e,generation_config:t,logits_processor:r,init_tokens:a,kwargs:s});const o=await super.generate({inputs:e,generation_config:t,logits_processor:r,decoder_input_ids:a,...s});return t.return_token_timestamps&&(o.token_timestamps=this._extract_token_timestamps(o,t.alignment_heads,t.num_frames,.02,a.length)),o}async _generate_with_seek({inputs:e,generation_config:t,logits_processor:r,init_tokens:n,kwargs:s}){const a=t.no_timestamps_token_id+1,o=Array.isArray(t.eos_token_id)?t.eos_token_id[0]:t.eos_token_id,i=t.return_token_timestamps,l=e,c=l.dims[2],d=2,h=this.config.max_source_positions,_=d*h;let p=0;const w=[],v=[];for(;p<c;){const M=Math.min(p+_,c),T=l.slice(null,null,[p,M]);let A;const S=T.dims[2];if(S<_){const W=l.dims[1],ee=new Float32Array(W*_),G=T.data;for(let L=0;L<W;++L)ee.set(G.subarray(L*S,(L+1)*S),L*_);A=new j("float32",ee,[1,W,_])}else A=T;if(r)for(const W of r)"begin_index"in W&&(W.begin_index=n.length);const C=await super.generate({inputs:A,generation_config:t,logits_processor:r,decoder_input_ids:n,...s}),x=(i?C.sequences:C)[0].tolist().map(Number).slice(n.length);let R;if(i){C.token_timestamps=this._extract_token_timestamps(C,t.alignment_heads,Math.floor((M-p)/d),.02,n.length);const W=p/d*.02;R=C.token_timestamps[0].tolist().slice(n.length).map(ee=>ee+W)}if(x.length>0&&x.at(-1)===o&&x.pop(),x.length===0)break;const z=x.map(W=>W>=a),$=x.length>=2&&z[x.length-1]&&!z[x.length-2],Q=[];for(let W=0;W<x.length-1;++W)z[W]&&z[W+1]&&Q.push(W+1);let H,D=x.length;if(Q.length>0)if($)H=M-p;else{const W=Q.at(-1);H=(x[W-1]-a)*d,D=W}else H=M-p;const O=Math.floor(p/d),te=a+1500;for(let W=0;W<D;++W)x[W]>=a&&(x[W]=Math.min(x[W]+O,te));w.push(...x.slice(0,D)),R&&v.push(...R.slice(0,D)),p+=H}w.push(o);const y=[...n,...w];if(i){const M=new j("int64",y.map(BigInt),[1,y.length]),T=[...new Array(n.length).fill(0),...v,0],A=new j("float32",new Float32Array(T),[1,T.length]);return{sequences:M,token_timestamps:A}}return new j("int64",y.map(BigInt),[1,y.length])}_extract_token_timestamps(e,t,r=null,n=.02,s=0){if(!e.cross_attentions)throw new Error("Model outputs must contain cross attentions to extract timestamps. This is most likely because the model was not exported with `output_attentions=True`.");r==null&&ue.warn("`num_frames` has not been set, meaning the entire audio will be analyzed. This may lead to inaccurate token-level timestamps for short audios (< 30 seconds).");let a=this.config.median_filter_width;a===void 0&&(ue.warn("Model config has no `median_filter_width`, using default value of 7."),a=7);const o=e.cross_attentions,i=Array.from({length:this.config.decoder_layers},(y,M)=>De(o.map(T=>T[M]),2)),l=_r(t.map(([y,M])=>{if(y>=i.length)throw new Error(`Layer index ${y} is out of bounds for cross attentions (length ${i.length}).`);return r?i[y].slice(null,M,null,[0,r]):i[y].slice(null,M)})).transpose(1,0,2,3),[c,d]=ET(l,-2,0,!0),h=l.clone();for(let y=0;y<h.dims[0];++y){const M=h[y];for(let T=0;T<M.dims[0];++T){const A=M[T],S=c[y][T][0].data,C=d[y][T][0].data;for(let I=0;I<A.dims[0];++I){let x=A[I].data;for(let R=0;R<x.length;++R)x[R]=(x[R]-C[R])/S[R];x.set(lT(x,a))}}}const _=s>0?h.slice(null,null,[s,h.dims[2]],null):h,p=[Jl(_,1)],w=e.sequences.dims,v=new j("float32",new Float32Array(w[0]*w[1]),w);for(let y=0;y<w[0];++y){const M=p[y].neg().squeeze_(0),[T,A]=uT(M.tolist()),S=Array.from({length:T.length-1},(R,z)=>T[z+1]-T[z]),C=er([1],S).map(R=>!!R),I=[];for(let R=0;R<C.length;++R)C[R]&&I.push(A[R]*n);const x=new Array(s).fill(0);x.push(...I),I.length>0&&x.push(I.at(-1)),v[y].data.set(x)}return v}},HN=class extends Jw{},Nn=class extends P{},QN=class extends Nn{},XN=class extends Nn{async _call(e){return new Xe(await super._call(e))}},YN=class extends Nn{async _call(e){return new oe(await super._call(e))}},JN=class extends Nn{async _call(e){return new We(await super._call(e))}},KN=class extends Nn{async _call(e){return new dt(await super._call(e))}},Dn=class extends P{},ZN=class extends Dn{},e3=class extends Dn{async _call(e){return new Xe(await super._call(e))}},t3=class extends Dn{async _call(e){return new oe(await super._call(e))}},r3=class extends Dn{async _call(e){return new We(await super._call(e))}},n3=class extends Dn{async _call(e){return new dt(await super._call(e))}},fd=class extends P{},s3=class extends fd{},a3=class extends fd{async _call(e){return new Kw(await super._call(e))}},Kw=class extends Qe{constructor({logits:e,pred_boxes:t}){super(),this.logits=e,this.pred_boxes=t}},_d=class extends P{},o3=class extends _d{},i3=class extends _d{},l3=new Map([["bert","BertModel"],["eurobert","EuroBertModel"],["neobert","NeoBertModel"],["modernbert","ModernBertModel"],["nomic_bert","NomicBertModel"],["roformer","RoFormerModel"],["electra","ElectraModel"],["esm","EsmModel"],["convbert","ConvBertModel"],["camembert","CamembertModel"],["deberta","DebertaModel"],["deberta-v2","DebertaV2Model"],["mpnet","MPNetModel"],["albert","AlbertModel"],["distilbert","DistilBertModel"],["roberta","RobertaModel"],["xlm","XLMModel"],["xlm-roberta","XLMRobertaModel"],["clap","ClapModel"],["clip","CLIPModel"],["clipseg","CLIPSegModel"],["chinese_clip","ChineseCLIPModel"],["siglip","SiglipModel"],["jina_clip","JinaCLIPModel"],["mobilebert","MobileBertModel"],["squeezebert","SqueezeBertModel"],["wav2vec2","Wav2Vec2Model"],["wav2vec2-bert","Wav2Vec2BertModel"],["unispeech","UniSpeechModel"],["unispeech-sat","UniSpeechSatModel"],["hubert","HubertModel"],["wavlm","WavLMModel"],["audio-spectrogram-transformer","ASTModel"],["vits","VitsModel"],["pyannote","PyAnnoteModel"],["wespeaker-resnet","WeSpeakerResNetModel"],["detr","DetrModel"],["rt_detr","RTDetrModel"],["rt_detr_v2","RTDetrV2Model"],["rf_detr","RFDetrModel"],["d_fine","DFineModel"],["table-transformer","TableTransformerModel"],["vit","ViTModel"],["ijepa","IJepaModel"],["pvt","PvtModel"],["vit_msn","ViTMSNModel"],["vit_mae","ViTMAEModel"],["groupvit","GroupViTModel"],["fastvit","FastViTModel"],["mobilevit","MobileViTModel"],["mobilevitv2","MobileViTV2Model"],["owlvit","OwlViTModel"],["owlv2","Owlv2Model"],["beit","BeitModel"],["deit","DeiTModel"],["hiera","HieraModel"],["convnext","ConvNextModel"],["convnextv2","ConvNextV2Model"],["dinov2","Dinov2Model"],["dinov2_with_registers","Dinov2WithRegistersModel"],["dinov3_vit","DINOv3ViTModel"],["dinov3_convnext","DINOv3ConvNextModel"],["resnet","ResNetModel"],["swin","SwinModel"],["swin2sr","Swin2SRModel"],["donut-swin","DonutSwinModel"],["yolos","YolosModel"],["dpt","DPTModel"],["glpn","GLPNModel"],["hifigan","SpeechT5HifiGan"],["efficientnet","EfficientNetModel"],["decision_transformer","DecisionTransformerModel"],["patchtst","PatchTSTModel"],["patchtsmixer","PatchTSMixerModel"],["mobilenet_v1","MobileNetV1Model"],["mobilenet_v2","MobileNetV2Model"],["mobilenet_v3","MobileNetV3Model"],["mobilenet_v4","MobileNetV4Model"],["maskformer","MaskFormerModel"],["mgp-str","MgpstrForSceneTextRecognition"],["style_text_to_speech_2","StyleTextToSpeech2Model"],["openai_privacy_filter","OpenAIPrivacyFilterModel"]]),c3=new Map([["t5","T5Model"],["longt5","LongT5Model"],["mt5","MT5Model"],["bart","BartModel"],["mbart","MBartModel"],["marian","MarianModel"],["whisper","WhisperModel"],["cohere_asr","CohereAsrModel"],["m2m_100","M2M100Model"],["blenderbot","BlenderbotModel"],["blenderbot-small","BlenderbotSmallModel"]]),u3=new Map([["mimi","MimiModel"],["dac","DacModel"],["snac","SnacModel"]]),d3=new Map([["bloom","BloomModel"],["jais","JAISModel"],["gpt2","GPT2Model"],["gpt_oss","GptOssModel"],["gptj","GPTJModel"],["gpt_bigcode","GPTBigCodeModel"],["gpt_neo","GPTNeoModel"],["gpt_neox","GPTNeoXModel"],["codegen","CodeGenModel"],["llama","LlamaModel"],["apertus","ApertusModel"],["nanochat","NanoChatModel"],["arcee","ArceeModel"],["afmoe","AfmoeModel"],["lfm2","Lfm2Model"],["lfm2_moe","Lfm2MoeModel"],["smollm3","SmolLM3Model"],["exaone","ExaoneModel"],["olmo","OlmoModel"],["olmo2","Olmo2Model"],["olmo3","Olmo3Model"],["olmo_hybrid","OlmoHybridModel"],["mobilellm","MobileLLMModel"],["granite","GraniteModel"],["granitemoehybrid","GraniteMoeHybridModel"],["cohere","CohereModel"],["cohere2","Cohere2Model"],["gemma","GemmaModel"],["gemma2","Gemma2Model"],["vaultgemma","VaultGemmaModel"],["gemma3_text","Gemma3Model"],["helium","HeliumModel"],["glm","GlmModel"],["glm_moe_dsa","GlmMoeDsaModel"],["openelm","OpenELMModel"],["qwen2","Qwen2Model"],["qwen2_moe","Qwen2MoeModel"],["qwen3","Qwen3Model"],["qwen3_moe","Qwen3MoeModel"],["qwen3_next","Qwen3NextModel"],["phi","PhiModel"],["phi3","Phi3Model"],["mpt","MptModel"],["opt","OPTModel"],["mistral","MistralModel"],["mistral4","Mistral4Model"],["ministral","MinistralModel"],["ministral3","Ministral3Model"],["ernie4_5","Ernie4_5ForCausalLM"],["starcoder2","Starcoder2Model"],["deepseek_v3","DeepseekV3Model"],["falcon","FalconModel"],["falcon_h1","FalconH1Model"],["nemotron_h","NemotronHModel"],["solar_open","SolarOpenModel"],["stablelm","StableLmModel"],["modernbert-decoder","ModernBertDecoderModel"],["hunyuan_v1_dense","HunYuanDenseV1Model"],["youtu","YoutuModel"]]),Zw=new Map([["speecht5","SpeechT5ForSpeechToText"],["whisper","WhisperForConditionalGeneration"],["lite-whisper","LiteWhisperForConditionalGeneration"],["moonshine","MoonshineForConditionalGeneration"],["cohere_asr","CohereAsrForConditionalGeneration"]]),ev=new Map([["speecht5","SpeechT5ForTextToSpeech"]]),tv=new Map([["vits","VitsModel"],["musicgen","MusicgenForConditionalGeneration"],["supertonic","SupertonicForConditionalGeneration"]]),rv=new Map([["bert","BertForSequenceClassification"],["eurobert","EuroBertForSequenceClassification"],["neobert","NeoBertForSequenceClassification"],["modernbert","ModernBertForSequenceClassification"],["roformer","RoFormerForSequenceClassification"],["electra","ElectraForSequenceClassification"],["esm","EsmForSequenceClassification"],["convbert","ConvBertForSequenceClassification"],["camembert","CamembertForSequenceClassification"],["deberta","DebertaForSequenceClassification"],["deberta-v2","DebertaV2ForSequenceClassification"],["mpnet","MPNetForSequenceClassification"],["albert","AlbertForSequenceClassification"],["distilbert","DistilBertForSequenceClassification"],["roberta","RobertaForSequenceClassification"],["xlm","XLMForSequenceClassification"],["xlm-roberta","XLMRobertaForSequenceClassification"],["bart","BartForSequenceClassification"],["mbart","MBartForSequenceClassification"],["mobilebert","MobileBertForSequenceClassification"],["squeezebert","SqueezeBertForSequenceClassification"]]),nv=new Map([["bert","BertForTokenClassification"],["eurobert","EuroBertForTokenClassification"],["neobert","NeoBertForTokenClassification"],["modernbert","ModernBertForTokenClassification"],["roformer","RoFormerForTokenClassification"],["electra","ElectraForTokenClassification"],["esm","EsmForTokenClassification"],["convbert","ConvBertForTokenClassification"],["camembert","CamembertForTokenClassification"],["deberta","DebertaForTokenClassification"],["deberta-v2","DebertaV2ForTokenClassification"],["mpnet","MPNetForTokenClassification"],["distilbert","DistilBertForTokenClassification"],["roberta","RobertaForTokenClassification"],["xlm","XLMForTokenClassification"],["xlm-roberta","XLMRobertaForTokenClassification"],["openai_privacy_filter","OpenAIPrivacyFilterForTokenClassification"]]),sv=new Map([["t5","T5ForConditionalGeneration"],["longt5","LongT5ForConditionalGeneration"],["mt5","MT5ForConditionalGeneration"],["bart","BartForConditionalGeneration"],["mbart","MBartForConditionalGeneration"],["marian","MarianMTModel"],["m2m_100","M2M100ForConditionalGeneration"],["blenderbot","BlenderbotForConditionalGeneration"],["blenderbot-small","BlenderbotSmallForConditionalGeneration"]]),av=new Map([["bloom","BloomForCausalLM"],["gpt2","GPT2LMHeadModel"],["gpt_oss","GptOssForCausalLM"],["jais","JAISLMHeadModel"],["gptj","GPTJForCausalLM"],["gpt_bigcode","GPTBigCodeForCausalLM"],["gpt_neo","GPTNeoForCausalLM"],["gpt_neox","GPTNeoXForCausalLM"],["codegen","CodeGenForCausalLM"],["llama","LlamaForCausalLM"],["nanochat","NanoChatForCausalLM"],["apertus","ApertusForCausalLM"],["llama4_text","Llama4ForCausalLM"],["arcee","ArceeForCausalLM"],["afmoe","AfmoeForCausalLM"],["lfm2","Lfm2ForCausalLM"],["lfm2_moe","Lfm2MoeForCausalLM"],["smollm3","SmolLM3ForCausalLM"],["exaone","ExaoneForCausalLM"],["olmo","OlmoForCausalLM"],["olmo2","Olmo2ForCausalLM"],["olmo3","Olmo3ForCausalLM"],["olmo_hybrid","OlmoHybridForCausalLM"],["mobilellm","MobileLLMForCausalLM"],["granite","GraniteForCausalLM"],["granitemoehybrid","GraniteMoeHybridForCausalLM"],["cohere","CohereForCausalLM"],["cohere2","Cohere2ForCausalLM"],["gemma","GemmaForCausalLM"],["gemma2","Gemma2ForCausalLM"],["vaultgemma","VaultGemmaForCausalLM"],["gemma3_text","Gemma3ForCausalLM"],["gemma3","Gemma3ForCausalLM"],["helium","HeliumForCausalLM"],["glm","GlmForCausalLM"],["glm_moe_dsa","GlmMoeDsaForCausalLM"],["openelm","OpenELMForCausalLM"],["qwen2","Qwen2ForCausalLM"],["qwen2_moe","Qwen2MoeForCausalLM"],["qwen3","Qwen3ForCausalLM"],["qwen3_moe","Qwen3MoeForCausalLM"],["qwen3_next","Qwen3NextForCausalLM"],["qwen2_vl","Qwen2VLForCausalLM"],["qwen2_5_vl","Qwen2_5_VLForCausalLM"],["qwen3_vl","Qwen3VLForCausalLM"],["qwen3_vl_moe","Qwen3VLMoeForCausalLM"],["qwen3_5","Qwen3_5ForCausalLM"],["qwen3_5_text","Qwen3_5ForCausalLM"],["qwen3_5_moe","Qwen3_5MoeForCausalLM"],["gemma3n","Gemma3nForCausalLM"],["gemma4","Gemma4ForCausalLM"],["phi","PhiForCausalLM"],["phi3","Phi3ForCausalLM"],["mpt","MptForCausalLM"],["opt","OPTForCausalLM"],["mbart","MBartForCausalLM"],["mistral","MistralForCausalLM"],["mistral4","Mistral4ForCausalLM"],["ministral","MinistralForCausalLM"],["ministral3","Ministral3ForCausalLM"],["ernie4_5","Ernie4_5ForCausalLM"],["starcoder2","Starcoder2ForCausalLM"],["deepseek_v3","DeepseekV3ForCausalLM"],["falcon","FalconForCausalLM"],["falcon_h1","FalconH1ForCausalLM"],["nemotron_h","NemotronHForCausalLM"],["trocr","TrOCRForCausalLM"],["solar_open","SolarOpenForCausalLM"],["stablelm","StableLmForCausalLM"],["modernbert-decoder","ModernBertDecoderForCausalLM"],["hunyuan_v1_dense","HunYuanDenseV1ForCausalLM"],["youtu","YoutuForCausalLM"],["phi3_v","Phi3VForCausalLM"]]),h3=new Map([["multi_modality","MultiModalityCausalLM"]]),ov=new Map([["bert","BertForMaskedLM"],["eurobert","EuroBertForMaskedLM"],["neobert","NeoBertForMaskedLM"],["modernbert","ModernBertForMaskedLM"],["roformer","RoFormerForMaskedLM"],["electra","ElectraForMaskedLM"],["esm","EsmForMaskedLM"],["convbert","ConvBertForMaskedLM"],["camembert","CamembertForMaskedLM"],["deberta","DebertaForMaskedLM"],["deberta-v2","DebertaV2ForMaskedLM"],["mpnet","MPNetForMaskedLM"],["albert","AlbertForMaskedLM"],["distilbert","DistilBertForMaskedLM"],["roberta","RobertaForMaskedLM"],["xlm","XLMWithLMHeadModel"],["xlm-roberta","XLMRobertaForMaskedLM"],["mobilebert","MobileBertForMaskedLM"],["squeezebert","SqueezeBertForMaskedLM"]]),iv=new Map([["bert","BertForQuestionAnswering"],["neobert","NeoBertForQuestionAnswering"],["roformer","RoFormerForQuestionAnswering"],["electra","ElectraForQuestionAnswering"],["convbert","ConvBertForQuestionAnswering"],["camembert","CamembertForQuestionAnswering"],["deberta","DebertaForQuestionAnswering"],["deberta-v2","DebertaV2ForQuestionAnswering"],["mpnet","MPNetForQuestionAnswering"],["albert","AlbertForQuestionAnswering"],["distilbert","DistilBertForQuestionAnswering"],["roberta","RobertaForQuestionAnswering"],["xlm","XLMForQuestionAnswering"],["xlm-roberta","XLMRobertaForQuestionAnswering"],["mobilebert","MobileBertForQuestionAnswering"],["squeezebert","SqueezeBertForQuestionAnswering"]]),lv=new Map([["vision-encoder-decoder","VisionEncoderDecoderModel"],["idefics3","Idefics3ForConditionalGeneration"],["smolvlm","SmolVLMForConditionalGeneration"]]),cv=new Map([["llava","LlavaForConditionalGeneration"],["llava_onevision","LlavaOnevisionForConditionalGeneration"],["moondream1","Moondream1ForConditionalGeneration"],["florence2","Florence2ForConditionalGeneration"],["qwen2_vl","Qwen2VLForConditionalGeneration"],["qwen2_5_vl","Qwen2_5_VLForConditionalGeneration"],["qwen3_vl","Qwen3VLForConditionalGeneration"],["qwen3_vl_moe","Qwen3VLMoeForConditionalGeneration"],["qwen3_5","Qwen3_5ForConditionalGeneration"],["qwen3_5_moe","Qwen3_5MoeForConditionalGeneration"],["lfm2_vl","Lfm2VlForConditionalGeneration"],["idefics3","Idefics3ForConditionalGeneration"],["smolvlm","SmolVLMForConditionalGeneration"],["paligemma","PaliGemmaForConditionalGeneration"],["llava_qwen2","LlavaQwen2ForCausalLM"],["gemma3","Gemma3ForConditionalGeneration"],["gemma3n","Gemma3nForConditionalGeneration"],["gemma4","Gemma4ForConditionalGeneration"],["mistral3","Mistral3ForConditionalGeneration"],["lighton_ocr","LightOnOcrForConditionalGeneration"],["glm_ocr","GlmOcrForConditionalGeneration"]]),uv=new Map([["granite_speech","GraniteSpeechForConditionalGeneration"],["ultravox","UltravoxModel"],["voxtral","VoxtralForConditionalGeneration"],["voxtral_realtime","VoxtralRealtimeForConditionalGeneration"]]),f3=new Map([["vision-encoder-decoder","VisionEncoderDecoderModel"]]),dv=new Map([["vit","ViTForImageClassification"],["ijepa","IJepaForImageClassification"],["pvt","PvtForImageClassification"],["vit_msn","ViTMSNForImageClassification"],["fastvit","FastViTForImageClassification"],["mobilevit","MobileViTForImageClassification"],["mobilevitv2","MobileViTV2ForImageClassification"],["beit","BeitForImageClassification"],["deit","DeiTForImageClassification"],["hiera","HieraForImageClassification"],["convnext","ConvNextForImageClassification"],["convnextv2","ConvNextV2ForImageClassification"],["dinov2","Dinov2ForImageClassification"],["dinov2_with_registers","Dinov2WithRegistersForImageClassification"],["resnet","ResNetForImageClassification"],["swin","SwinForImageClassification"],["segformer","SegformerForImageClassification"],["efficientnet","EfficientNetForImageClassification"],["mobilenet_v1","MobileNetV1ForImageClassification"],["mobilenet_v2","MobileNetV2ForImageClassification"],["mobilenet_v3","MobileNetV3ForImageClassification"],["mobilenet_v4","MobileNetV4ForImageClassification"]]),hv=new Map([["detr","DetrForObjectDetection"],["rt_detr","RTDetrForObjectDetection"],["rt_detr_v2","RTDetrV2ForObjectDetection"],["rf_detr","RFDetrForObjectDetection"],["d_fine","DFineForObjectDetection"],["table-transformer","TableTransformerForObjectDetection"],["yolos","YolosForObjectDetection"]]),fv=new Map([["owlvit","OwlViTForObjectDetection"],["owlv2","Owlv2ForObjectDetection"],["grounding-dino","GroundingDinoForObjectDetection"]]),fn=new Map([["detr","DetrForSegmentation"],["clipseg","CLIPSegForImageSegmentation"]]),_v=new Map([["segformer","SegformerForSemanticSegmentation"],["sapiens","SapiensForSemanticSegmentation"],["swin","SwinForSemanticSegmentation"],["mobilenet_v1","MobileNetV1ForSemanticSegmentation"],["mobilenet_v2","MobileNetV2ForSemanticSegmentation"],["mobilenet_v3","MobileNetV3ForSemanticSegmentation"],["mobilenet_v4","MobileNetV4ForSemanticSegmentation"]]),pv=new Map([["detr","DetrForSegmentation"],["maskformer","MaskFormerForInstanceSegmentation"]]),mv=new Map([["sam","SamModel"],["sam2","Sam2Model"],["edgetam","EdgeTamModel"],["sam3_tracker","Sam3TrackerModel"]]),gv=new Map([["wav2vec2","Wav2Vec2ForCTC"],["wav2vec2-bert","Wav2Vec2BertForCTC"],["unispeech","UniSpeechForCTC"],["unispeech-sat","UniSpeechSatForCTC"],["wavlm","WavLMForCTC"],["hubert","HubertForCTC"],["parakeet_ctc","ParakeetForCTC"]]),wv=new Map([["wav2vec2","Wav2Vec2ForSequenceClassification"],["wav2vec2-bert","Wav2Vec2BertForSequenceClassification"],["unispeech","UniSpeechForSequenceClassification"],["unispeech-sat","UniSpeechSatForSequenceClassification"],["wavlm","WavLMForSequenceClassification"],["hubert","HubertForSequenceClassification"],["audio-spectrogram-transformer","ASTForAudioClassification"]]),vv=new Map([["wavlm","WavLMForXVector"]]),yv=new Map([["unispeech-sat","UniSpeechSatForAudioFrameClassification"],["wavlm","WavLMForAudioFrameClassification"],["wav2vec2","Wav2Vec2ForAudioFrameClassification"],["pyannote","PyAnnoteForAudioFrameClassification"]]),bv=new Map([["vitmatte","VitMatteForImageMatting"]]),_3=new Map([["patchtst","PatchTSTForPrediction"],["patchtsmixer","PatchTSMixerForPrediction"]]),Mv=new Map([["swin2sr","Swin2SRForImageSuperResolution"]]),xv=new Map([["chmv2","CHMv2ForDepthEstimation"],["dpt","DPTForDepthEstimation"],["depth_anything","DepthAnythingForDepthEstimation"],["glpn","GLPNForDepthEstimation"],["sapiens","SapiensForDepthEstimation"],["depth_pro","DepthProForDepthEstimation"],["metric3d","Metric3DForDepthEstimation"],["metric3dv2","Metric3Dv2ForDepthEstimation"]]),kv=new Map([["sapiens","SapiensForNormalEstimation"]]),Tv=new Map([["vitpose","VitPoseForPoseEstimation"]]),Ev=new Map([["clip","CLIPVisionModelWithProjection"],["siglip","SiglipVisionModel"],["jina_clip","JinaCLIPVisionModel"]]),Av=[[l3,q.EncoderOnly],[c3,q.EncoderDecoder],[d3,q.DecoderOnlyWithoutHead],[u3,q.AutoEncoder],[rv,q.EncoderOnly],[nv,q.EncoderOnly],[sv,q.Seq2Seq],[Zw,q.Seq2Seq],[av,q.DecoderOnly],[h3,q.MultiModality],[ov,q.EncoderOnly],[iv,q.EncoderOnly],[lv,q.Vision2Seq],[cv,q.ImageTextToText],[uv,q.AudioTextToText],[dv,q.EncoderOnly],[fn,q.EncoderOnly],[pv,q.EncoderOnly],[_v,q.EncoderOnly],[bv,q.EncoderOnly],[_3,q.EncoderOnly],[Mv,q.EncoderOnly],[xv,q.EncoderOnly],[kv,q.EncoderOnly],[Tv,q.EncoderOnly],[hv,q.EncoderOnly],[fv,q.EncoderOnly],[mv,q.MaskGeneration],[gv,q.EncoderOnly],[wv,q.EncoderOnly],[ev,q.Seq2Seq],[tv,q.EncoderOnly],[vv,q.EncoderOnly],[yv,q.EncoderOnly],[Ev,q.EncoderOnly]];for(const[e,t]of Av)for(const r of e.values()){fr.set(r,t);const n=hc[r];gn.set(n,r),cc.set(r,n)}var p3=[["MusicgenForConditionalGeneration",bw,q.Musicgen],["Phi3VForCausalLM",Tw,q.Phi3V],["CLIPTextModelWithProjection",Gg,q.EncoderOnly],["SiglipTextModel",Ow,q.EncoderOnly],["JinaCLIPTextModel",uw,q.EncoderOnly],["ClapTextModelWithProjection",Bg,q.EncoderOnly],["ClapAudioModelWithProjection",Rg,q.EncoderOnly],["DacEncoderModel",Ug,q.EncoderOnly],["DacDecoderModel",jg,q.EncoderOnly],["MimiEncoderModel",ww,q.EncoderOnly],["MimiDecoderModel",vw,q.EncoderOnly],["SnacEncoderModel",Nw,q.EncoderOnly],["SnacDecoderModel",Dw,q.EncoderOnly],["Gemma3nForConditionalGeneration",to,q.ImageAudioTextToText],["Gemma4ForConditionalGeneration",jc,q.ImageAudioTextToText],["SupertonicForConditionalGeneration",Rw,q.Supertonic],["ChatterboxModel",Ng,q.Chatterbox],["VoxtralRealtimeForConditionalGeneration",Qw,q.VoxtralRealtime]];for(const[e,t,r]of p3)fr.set(e,r),gn.set(t,e),cc.set(e,t);var Cv=new Map([["modnet",fn],["birefnet",fn],["isnet",fn],["ben",fn]]);for(const[e,t]of Cv.entries())t.set(e,"PreTrainedModel"),fr.set(e,q.EncoderOnly),cc.set(e,P);var m3=new Set(Cv.keys());fr.set("PreTrainedModel",q.EncoderOnly);gn.set(P,"PreTrainedModel");var Ae={MODEL_FOR_SEQUENCE_CLASSIFICATION_MAPPING_NAMES:rv,MODEL_FOR_TOKEN_CLASSIFICATION_MAPPING_NAMES:nv,MODEL_FOR_TEXT_TO_SPECTROGRAM_MAPPING_NAMES:ev,MODEL_FOR_TEXT_TO_WAVEFORM_MAPPING_NAMES:tv,MODEL_FOR_MASKED_LM_MAPPING_NAMES:ov,MODEL_FOR_QUESTION_ANSWERING_MAPPING_NAMES:iv,MODEL_FOR_IMAGE_CLASSIFICATION_MAPPING_NAMES:dv,MODEL_FOR_IMAGE_SEGMENTATION_MAPPING_NAMES:fn,MODEL_FOR_SEMANTIC_SEGMENTATION_MAPPING_NAMES:_v,MODEL_FOR_UNIVERSAL_SEGMENTATION_MAPPING_NAMES:pv,MODEL_FOR_OBJECT_DETECTION_MAPPING_NAMES:hv,MODEL_FOR_ZERO_SHOT_OBJECT_DETECTION_MAPPING_NAMES:fv,MODEL_FOR_MASK_GENERATION_MAPPING_NAMES:mv,MODEL_FOR_CTC_MAPPING_NAMES:gv,MODEL_FOR_AUDIO_CLASSIFICATION_MAPPING_NAMES:wv,MODEL_FOR_AUDIO_XVECTOR_MAPPING_NAMES:vv,MODEL_FOR_AUDIO_FRAME_CLASSIFICATION_MAPPING_NAMES:yv,MODEL_FOR_DOCUMENT_QUESTION_ANSWERING_MAPPING_NAMES:f3,MODEL_FOR_IMAGE_MATTING_MAPPING_NAMES:bv,MODEL_FOR_IMAGE_TO_IMAGE_MAPPING_NAMES:Mv,MODEL_FOR_DEPTH_ESTIMATION_MAPPING_NAMES:xv,MODEL_FOR_NORMAL_ESTIMATION_MAPPING_NAMES:kv,MODEL_FOR_POSE_ESTIMATION_MAPPING_NAMES:Tv,MODEL_FOR_IMAGE_FEATURE_EXTRACTION_MAPPING_NAMES:Ev,MODEL_FOR_IMAGE_TEXT_TO_TEXT_MAPPING_NAMES:cv,MODEL_FOR_AUDIO_TEXT_TO_TEXT_MAPPING_NAMES:uv,MODEL_FOR_SEQ_TO_SEQ_CAUSAL_LM_MAPPING_NAMES:sv,MODEL_FOR_SPEECH_SEQ_2_SEQ_MAPPING_NAMES:Zw,MODEL_FOR_CAUSAL_LM_MAPPING_NAMES:av,MODEL_FOR_VISION_2_SEQ_MAPPING_NAMES:lv};wC(Ae);var ba,Ce=(ba=class{static supports(e){if(!this.MODEL_CLASS_MAPPINGS)return!1;for(const t of this.MODEL_CLASS_MAPPINGS)if(t.has(e))return!0;return this.BASE_IF_FAIL}static async from_pretrained(e,{progress_callback:t=null,config:r=null,cache_dir:n=null,local_files_only:s=!1,revision:a="main",model_file_name:o=null,subfolder:i="onnx",device:l=null,dtype:c=null,use_external_data_format:d=null,session_options:h={}}={}){const _={progress_callback:t,config:r,cache_dir:n,local_files_only:s,revision:a,model_file_name:o,subfolder:i,device:l,dtype:c,use_external_data_format:d,session_options:h};if(_.config=await ws.from_pretrained(e,_),!this.MODEL_CLASS_MAPPINGS)throw new Error("`MODEL_CLASS_MAPPINGS` not implemented for this type of `AutoClass`: "+this.name);const{model_type:p}=_.config;for(const w of this.MODEL_CLASS_MAPPINGS){let v=w.get(p);if(!v){for(const y of w.values())if(y[0]===p){v=y;break}if(!v)continue}return await hc[v].from_pretrained(e,_)}if(this.BASE_IF_FAIL)return m3.has(p)||ue.warn(`Unknown model class "${p}", attempting to construct from base class.`),await P.from_pretrained(e,_);throw Error(`Unsupported model type: ${p}`)}},k(ba,"MODEL_CLASS_MAPPINGS",null),k(ba,"BASE_IF_FAIL",!1),ba),Ma,ds=(Ma=class extends Ce{},k(Ma,"MODEL_CLASS_MAPPINGS",Av.map(e=>e[0])),k(Ma,"BASE_IF_FAIL",!0),Ma),Si,Q_=(Si=class extends Ce{},k(Si,"MODEL_CLASS_MAPPINGS",[Ae.MODEL_FOR_SEQUENCE_CLASSIFICATION_MAPPING_NAMES]),Si),Pi,g3=(Pi=class extends Ce{},k(Pi,"MODEL_CLASS_MAPPINGS",[Ae.MODEL_FOR_TOKEN_CLASSIFICATION_MAPPING_NAMES]),Pi),Fi,xi=(Fi=class extends Ce{},k(Fi,"MODEL_CLASS_MAPPINGS",[Ae.MODEL_FOR_SEQ_TO_SEQ_CAUSAL_LM_MAPPING_NAMES]),Fi),Li,w3=(Li=class extends Ce{},k(Li,"MODEL_CLASS_MAPPINGS",[Ae.MODEL_FOR_SPEECH_SEQ_2_SEQ_MAPPING_NAMES]),Li),Ii,v3=(Ii=class extends Ce{},k(Ii,"MODEL_CLASS_MAPPINGS",[Ae.MODEL_FOR_TEXT_TO_SPECTROGRAM_MAPPING_NAMES]),Ii),Oi,y3=(Oi=class extends Ce{},k(Oi,"MODEL_CLASS_MAPPINGS",[Ae.MODEL_FOR_TEXT_TO_WAVEFORM_MAPPING_NAMES]),Oi),Ni,b3=(Ni=class extends Ce{},k(Ni,"MODEL_CLASS_MAPPINGS",[Ae.MODEL_FOR_CAUSAL_LM_MAPPING_NAMES]),Ni),Di,M3=(Di=class extends Ce{},k(Di,"MODEL_CLASS_MAPPINGS",[Ae.MODEL_FOR_MASKED_LM_MAPPING_NAMES]),Di),zi,x3=(zi=class extends Ce{},k(zi,"MODEL_CLASS_MAPPINGS",[Ae.MODEL_FOR_QUESTION_ANSWERING_MAPPING_NAMES]),zi),Bi,k3=(Bi=class extends Ce{},k(Bi,"MODEL_CLASS_MAPPINGS",[Ae.MODEL_FOR_VISION_2_SEQ_MAPPING_NAMES]),Bi),Ri,T3=(Ri=class extends Ce{},k(Ri,"MODEL_CLASS_MAPPINGS",[Ae.MODEL_FOR_IMAGE_CLASSIFICATION_MAPPING_NAMES]),Ri),Gi,X_=(Gi=class extends Ce{},k(Gi,"MODEL_CLASS_MAPPINGS",[Ae.MODEL_FOR_IMAGE_SEGMENTATION_MAPPING_NAMES]),Gi),$i,Y_=($i=class extends Ce{},k($i,"MODEL_CLASS_MAPPINGS",[Ae.MODEL_FOR_SEMANTIC_SEGMENTATION_MAPPING_NAMES]),$i),Vi,J_=(Vi=class extends Ce{},k(Vi,"MODEL_CLASS_MAPPINGS",[Ae.MODEL_FOR_UNIVERSAL_SEGMENTATION_MAPPING_NAMES]),Vi),Ui,E3=(Ui=class extends Ce{},k(Ui,"MODEL_CLASS_MAPPINGS",[Ae.MODEL_FOR_OBJECT_DETECTION_MAPPING_NAMES]),Ui),ji,A3=(ji=class extends Ce{},k(ji,"MODEL_CLASS_MAPPINGS",[Ae.MODEL_FOR_ZERO_SHOT_OBJECT_DETECTION_MAPPING_NAMES]),ji),qi;qi=class extends Ce{},k(qi,"MODEL_CLASS_MAPPINGS",[Ae.MODEL_FOR_MASK_GENERATION_MAPPING_NAMES]);var Wi,C3=(Wi=class extends Ce{},k(Wi,"MODEL_CLASS_MAPPINGS",[Ae.MODEL_FOR_CTC_MAPPING_NAMES]),Wi),Hi,S3=(Hi=class extends Ce{},k(Hi,"MODEL_CLASS_MAPPINGS",[Ae.MODEL_FOR_AUDIO_CLASSIFICATION_MAPPING_NAMES]),Hi),Qi;Qi=class extends Ce{},k(Qi,"MODEL_CLASS_MAPPINGS",[Ae.MODEL_FOR_AUDIO_XVECTOR_MAPPING_NAMES]);var Xi;Xi=class extends Ce{},k(Xi,"MODEL_CLASS_MAPPINGS",[Ae.MODEL_FOR_AUDIO_FRAME_CLASSIFICATION_MAPPING_NAMES]);var Yi,P3=(Yi=class extends Ce{},k(Yi,"MODEL_CLASS_MAPPINGS",[Ae.MODEL_FOR_DOCUMENT_QUESTION_ANSWERING_MAPPING_NAMES]),Yi),Ji;Ji=class extends Ce{},k(Ji,"MODEL_CLASS_MAPPINGS",[Ae.MODEL_FOR_IMAGE_MATTING_MAPPING_NAMES]);var Ki,F3=(Ki=class extends Ce{},k(Ki,"MODEL_CLASS_MAPPINGS",[Ae.MODEL_FOR_IMAGE_TO_IMAGE_MAPPING_NAMES]),Ki),Zi,L3=(Zi=class extends Ce{},k(Zi,"MODEL_CLASS_MAPPINGS",[Ae.MODEL_FOR_DEPTH_ESTIMATION_MAPPING_NAMES]),Zi),el;el=class extends Ce{},k(el,"MODEL_CLASS_MAPPINGS",[Ae.MODEL_FOR_NORMAL_ESTIMATION_MAPPING_NAMES]);var tl;tl=class extends Ce{},k(tl,"MODEL_CLASS_MAPPINGS",[Ae.MODEL_FOR_POSE_ESTIMATION_MAPPING_NAMES]);var rl,I3=(rl=class extends Ce{},k(rl,"MODEL_CLASS_MAPPINGS",[Ae.MODEL_FOR_IMAGE_FEATURE_EXTRACTION_MAPPING_NAMES]),rl),nl;nl=class extends Ce{},k(nl,"MODEL_CLASS_MAPPINGS",[Ae.MODEL_FOR_IMAGE_TEXT_TO_TEXT_MAPPING_NAMES]);var sl;sl=class extends Ce{},k(sl,"MODEL_CLASS_MAPPINGS",[Ae.MODEL_FOR_AUDIO_TEXT_TO_TEXT_MAPPING_NAMES]);async function qt(e){return Array.isArray(e)||(e=[e]),await Promise.all(e.map(t=>Gt.read(t)))}async function _n(e,t){return Array.isArray(e)||(e=[e]),await Promise.all(e.map(r=>typeof r=="string"||r instanceof URL?FE(r,t):r instanceof Float64Array?new Float32Array(r):r))}function xl(e,t){t&&(e=e.map(o=>o|0));const[r,n,s,a]=e;return{xmin:r,ymin:n,xmax:s,ymax:a}}var $e=class extends wt{constructor({task:e,model:t,tokenizer:r=null,processor:n=null}){super(),this.task=e,this.model=t,this.tokenizer=r,this.processor=n}async dispose(){await this.model.dispose()}},O3=class extends $e{async _call(e,{top_k:t=1}={}){const r=this.tokenizer(e,{padding:!0,truncation:!0}),n=await this.model(r),{problem_type:s,id2label:a}=this.model.config,o=s==="multi_label_classification"?l=>l.sigmoid():l=>new j("float32",nt(l.data),l.dims),i=[];for(const l of n.logits){const c=o(l),d=await Mn(c,t),h=d[0].tolist(),p=d[1].tolist().map((w,v)=>({label:a?a[w]:`LABEL_${w}`,score:h[v]}));t===1?i.push(...p):i.push(p)}return Array.isArray(e)||t===1?i:i[0]}},N3=class extends $e{async _call(e,{ignore_labels:t=["O"],aggregation_strategy:r="none"}={}){if(r!=="none"&&r!=="simple")throw new Error(`Invalid aggregation_strategy: "${r}". Must be one of "none" or "simple".`);const n=Array.isArray(e),s=this.tokenizer(n?e:[e],{padding:!0,truncation:!0}),o=(await this.model(s)).logits,i=this.model.config.id2label,l=[];for(let c=0;c<o.dims[0];++c){const d=s.input_ids[c].tolist(),h=o[c],_=[];for(let p=0;p<h.dims[0];++p){const w=h[p],v=Ue(w.data)[1],y=i?i[v]:`LABEL_${v}`;if(t.includes(y))continue;const M=this.tokenizer.decode([d[p]],{skip_special_tokens:!0});if(M==="")continue;const T=nt(w.data);_.push({entity:y,score:T[v],index:p,word:M})}l.push(r==="simple"?z3(_,d,this.tokenizer):_)}return n?l:l[0]}};function D3(e){const t=e[0];return e[1]==="-"&&(t==="B"||t==="I"||t==="E"||t==="S")?[t,e.slice(2)]:["I",e]}function z3(e,t,r){const n=[];let s=null;for(let a=0;a<e.length;++a){const[o,i]=D3(e[a].entity);s===i&&o!=="B"&&o!=="S"?(n[n.length-1].end=a+1,o==="E"&&(s=null)):(n.push({tag:i,start:a,end:a+1}),s=o==="S"?null:i)}return n.map(({tag:a,start:o,end:i})=>{let l=0;const c=[];for(let d=o;d<i;++d)l+=e[d].score,c.push(t[e[d].index]);return{entity_group:a,score:l/(i-o),word:r.decode(c,{skip_special_tokens:!0})}})}var B3=class extends $e{async _call(e,t,{top_k:r=1}={}){const n=this.tokenizer(e,{text_pair:t,padding:!0,truncation:!0}),s=Array.isArray(e),{start_logits:a,end_logits:o}=await this.model(n),i=n.input_ids.tolist(),l=n.attention_mask.tolist(),{all_special_ids:c,sep_token_id:d}=this.tokenizer,h=[];for(let _=0;_<a.dims[0];++_){const p=i[_],w=p.findIndex(C=>C==d),v=a[_].tolist(),y=o[_].tolist();for(let C=1;C<v.length;++C)(l[_]==0||C<=w||c.findIndex(I=>I==p[C])!==-1)&&(v[C]=-1/0,y[C]=-1/0);const M=nt(v).map((C,I)=>[C,I]),T=nt(y).map((C,I)=>[C,I]);M[0][0]=0,T[0][0]=0;const A=IM(M,T).filter(C=>C[0][1]<=C[1][1]).map(C=>[C[0][1],C[1][1],C[0][0]*C[1][0]]).sort((C,I)=>I[2]-C[2]),S=[];for(let C=0;C<Math.min(A.length,r);++C){const[I,x,R]=A[C],z=p.slice(I,x+1),$=this.tokenizer.decode(z,{skip_special_tokens:!0});S.push({answer:$,score:R})}r===1?h.push(...S):h.push(S)}return s?h:h[0]}},R3=class extends $e{async _call(e,{top_k:t=5}={}){const{mask_token_id:r,mask_token:n}=this.tokenizer,s=this.tokenizer(e,{padding:!0,truncation:!0}),{logits:a}=await this.model(s),o=[],i=s.input_ids.tolist();for(let l=0;l<i.length;++l){const c=i[l],d=c.findIndex(v=>v==r);if(d===-1)throw Error(`Mask token (${n}) not found in text.`);const h=a[l][d],_=await Mn(new j("float32",nt(h.data),h.dims),t),p=_[0].tolist(),w=_[1].tolist();o.push(w.map((v,y)=>{const M=c.slice();return M[d]=v,{score:p[y],token:Number(v),token_str:this.tokenizer.decode([v]),sequence:this.tokenizer.decode(M,{skip_special_tokens:!0})}}))}return Array.isArray(e)?o:o[0]}},pd=class extends $e{constructor(){super(...arguments);k(this,"_default_generation_config",{max_new_tokens:256});k(this,"_key","generated_text")}async _call(t,r={}){Array.isArray(t)||(t=[t]),this.model.config.prefix&&(t=t.map(l=>this.model.config.prefix+l));const n=this.model.config.task_specific_params;n&&n[this.task]&&n[this.task].prefix&&(t=t.map(l=>n[this.task].prefix+l));const s=this.tokenizer,a={padding:!0,truncation:!0};let o;this.task==="translation"&&"_build_translation_inputs"in s?o=s._build_translation_inputs(t,a,r):o=s(t,a);const i=await this.model.generate({...o,...this._default_generation_config,...r});return s.batch_decode(i,{skip_special_tokens:!0}).map(l=>({[this._key]:l}))}},G3=class extends pd{constructor(){super(...arguments);k(this,"_key","summary_text")}},$3=class extends pd{constructor(){super(...arguments);k(this,"_key","translation_text")}};function K_(e){return Array.isArray(e)&&e.every(t=>"role"in t&&"content"in t)}var V3=class extends $e{constructor(){super(...arguments);k(this,"_default_generation_config",{max_new_tokens:256})}async _call(t,r={}){const{add_special_tokens:n,return_full_text:s,tools:a,documents:o,chat_template:i,tokenizer_encode_kwargs:l,...c}=r;let d=!1,h=!1,_=n??(this.tokenizer.add_bos_token||this.tokenizer.add_eos_token)??!1,p=l,w;if(typeof t=="string")w=t=[t];else if(Array.isArray(t)&&t.every(C=>typeof C=="string"))d=!0,w=t;else{if(K_(t))t=[t];else if(Array.isArray(t)&&t.every(K_))d=!0;else throw new Error("Input must be a string, an array of strings, a Chat, or an array of Chats");h=!0;const C={tokenize:!1,add_generation_prompt:!0,...Ze({tools:a,documents:o,chat_template:i},["tools","documents","chat_template"]),...p};w=t.map(I=>this.tokenizer.apply_chat_template(I,C)),_=!1,p=void 0}const v=h?!1:s??!0;this.tokenizer.padding_side="left";const y=this.tokenizer(w,{add_special_tokens:_,padding:!0,truncation:!0,...p}),M=await this.model.generate({...y,...this._default_generation_config,...c}),T=this.tokenizer.batch_decode(M,{skip_special_tokens:!0});let A;!v&&y.input_ids.dims.at(-1)>0&&(A=this.tokenizer.batch_decode(y.input_ids,{skip_special_tokens:!0}).map(C=>C.length));const S=Array.from({length:t.length},C=>[]);for(let C=0;C<T.length;++C){const I=Math.floor(C/M.dims[0]*t.length);A&&(T[C]=T[C].slice(A[I])),S[I].push({generated_text:h?[...t[I],{role:"assistant",content:T[C]}]:T[C]})}return!d&&S.length===1?S[0]:S}},U3=class extends $e{constructor(e){super(e),this.label2id=Object.fromEntries(Object.entries(this.model.config.label2id).map(([t,r])=>[t.toLowerCase(),r])),this.entailment_id=this.label2id.entailment,this.entailment_id===void 0&&(ue.warn("Could not find 'entailment' in label2id mapping. Using 2 as entailment_id."),this.entailment_id=2),this.contradiction_id=this.label2id.contradiction??this.label2id.not_entailment,this.contradiction_id===void 0&&(ue.warn("Could not find 'contradiction' in label2id mapping. Using 0 as contradiction_id."),this.contradiction_id=0)}async _call(e,t,{hypothesis_template:r="This example is {}.",multi_label:n=!1}={}){const s=Array.isArray(e);s||(e=[e]),Array.isArray(t)||(t=[t]);const a=t.map(l=>r.replace("{}",l)),o=n||t.length===1,i=[];for(const l of e){const c=[];for(const _ of a){const p=this.tokenizer(l,{text_pair:_,padding:!0,truncation:!0}),w=await this.model(p);o?c.push([w.logits.data[this.contradiction_id],w.logits.data[this.entailment_id]]):c.push(w.logits.data[this.entailment_id])}const h=(o?c.map(_=>nt(_)[1]):nt(c)).map((_,p)=>[_,p]).sort((_,p)=>p[0]-_[0]);i.push({sequence:l,labels:h.map(_=>t[_[1]]),scores:h.map(_=>_[0])})}return s?i:i[0]}},j3=class extends $e{async _call(e,{top_k:t=5}={}){const r=this.processor.feature_extractor.config.sampling_rate,n=await _n(e,r),s=this.model.config.id2label,a=[];for(const o of n){const i=await this.processor(o),c=(await this.model(i)).logits[0],d=await Mn(new j("float32",nt(c.data),c.dims),t),h=d[0].tolist(),p=d[1].tolist().map((w,v)=>({label:s?s[w]:`LABEL_${w}`,score:h[v]}));a.push(p)}return Array.isArray(e)?a:a[0]}},q3=class extends $e{async _call(e,t,{hypothesis_template:r="This is a sound of {}."}={}){const n=!Array.isArray(e);n&&(e=[e]);const s=t.map(c=>r.replace("{}",c)),a=this.tokenizer(s,{padding:!0,truncation:!0}),o=this.processor.feature_extractor.config.sampling_rate,i=await _n(e,o),l=[];for(const c of i){const d=await this.processor(c),h=await this.model({...a,...d}),_=nt(h.logits_per_audio.data);l.push([..._].map((p,w)=>({score:p,label:t[w]})))}return n?l[0]:l}},W3=class extends $e{constructor(){super(...arguments);k(this,"_default_generation_config",{})}async _call(t,r={}){switch(r={...this._default_generation_config,...r},this.model.config.model_type){case"whisper":case"lite-whisper":return this._call_whisper(t,r);case"wav2vec2":case"wav2vec2-bert":case"unispeech":case"unispeech-sat":case"hubert":case"parakeet_ctc":return this._call_wav2vec2(t,r);case"moonshine":return this._call_moonshine(t,r);case"cohere_asr":return this._call_cohere_asr(t,r);default:throw new Error(`AutomaticSpeechRecognitionPipeline does not support model type '${this.model.config.model_type}'.`)}}async _call_wav2vec2(t,r){r.language&&ue.warn('`language` parameter is not yet supported for `wav2vec2` models, defaulting to "English".'),r.task&&ue.warn('`task` parameter is not yet supported for `wav2vec2` models, defaulting to "transcribe".');const n=!Array.isArray(t),s=n?[t]:t,a=this.processor.feature_extractor.config.sampling_rate,o=await _n(s,a),i=[];for(const l of o){const c=await this.processor(l),h=(await this.model(c)).logits[0],_=[];for(const w of h)_.push(Ue(w.data)[1]);const p=this.tokenizer.decode(_,{skip_special_tokens:!0}).trim();i.push({text:p})}return n?i[0]:i}async _call_whisper(t,r){const n=r.return_timestamps??!1,s=r.chunk_length_s??0,a=r.force_full_sequences??!1;let o=r.stride_length_s??null;const i={...r};n==="word"&&(i.return_token_timestamps=!0,i.return_timestamps=!0);const l=!Array.isArray(t),c=l?[t]:t,d=this.processor.feature_extractor.config,h=d.chunk_length/this.model.config.max_source_positions,_=d.hop_length,p=d.sampling_rate,w=await _n(c,p),v=[];for(const y of w){let M=[];if(s>0){if(o===null)o=s/6;else if(s<=o)throw Error("`chunk_length_s` must be larger than `stride_length_s`.");const S=p*s,C=p*o,I=S-2*C;let x=0;for(;;){const R=x+S,z=y.subarray(x,R),$=await this.processor(z),Q=x===0,H=R>=y.length;if(M.push({stride:[z.length,Q?0:C,H?0:C],input_features:$.input_features,is_last:H}),H)break;x+=I}}else M=[{stride:[y.length,0,0],input_features:(await this.processor(y)).input_features,is_last:!0}];for(const S of M){i.num_frames=Math.floor(S.stride[0]/_);const C=await this.model.generate({inputs:S.input_features,...i});if(n==="word"){const I=C.sequences.tolist()[0],x=C.token_timestamps.tolist()[0],R=this.tokenizer.timestamp_begin,z=Math.max(I.findIndex($=>Number($)>=R),0);S.tokens=I.slice(z),S.token_timestamps=x.slice(z).map($=>us($,2))}else S.tokens=C[0].tolist();S.stride=S.stride.map(I=>I/p)}const[T,A]=this.tokenizer._decode_asr(M,{time_precision:h,return_timestamps:n,force_full_sequences:a});v.push({text:T,...A})}return l?v[0]:v}async _call_moonshine(t,r){const n=!Array.isArray(t),s=n?[t]:t,a=this.processor.feature_extractor.config.sampling_rate,o=await _n(s,a),i=[];for(const l of o){const c=await this.processor(l),d=Math.floor(l.length/a)*6,h=await this.model.generate({max_new_tokens:d,...r,...c}),_=this.processor.batch_decode(h,{skip_special_tokens:!0})[0];i.push({text:_})}return n?i[0]:i}async _call_cohere_asr(t,r){const n=!Array.isArray(t),s=n?[t]:t,a=this.processor.feature_extractor,o=a.config.sampling_rate,i=await _n(s,o),l=r.language??"en",c=this.processor.get_decoder_prompt_ids(l),d=[];for(const h of i){const _=a.split_audio(h),p=[];for(const v of _){const y=await this.processor(v),M=await this.model.generate({...y,decoder_input_ids:c,...r}),T=this.tokenizer.decode(M[0].tolist(),{skip_special_tokens:!0}).trim();p.push(T)}const w=this.processor.constructor.join_chunks(p,l);d.push({text:w})}return n?d[0]:d}},H3=class extends $e{constructor(t){super(t);k(this,"DEFAULT_VOCODER_ID","Xenova/speecht5_hifigan");this.vocoder=t.vocoder??null}async _prepare_speaker_embeddings(t,r){if((typeof t=="string"||t instanceof URL)&&(t=new Float32Array(await(await Me.fetch(t)).arrayBuffer())),t instanceof Float32Array)t=new j("float32",t,[t.length]);else if(!(t instanceof j))throw new Error("Speaker embeddings must be a `Tensor`, `Float32Array`, `string`, or `URL`.");if(r>1){if(t.dims[0]===1)t=t.repeat(r,1);else if(t.dims[0]!==r)throw new Error(`Expected speaker embeddings batch size to be 1 or ${r}, but got ${t.dims[0]}.`)}return t}_postprocess_waveform(t,r,n,s=null){const a=r.data,[o,i]=r.dims,l=s?s.data:null,c=[];for(let d=0;d<o;++d){const h=l?Math.min(Math.ceil(l[d]),i):i,_=d*i;c.push(new $E(a.slice(_,_+h),n))}return Array.isArray(t)?c:c[0]}async _call(t,r){return this.processor?this._call_text_to_spectrogram(t,r):this.model.config.model_type==="supertonic"?this._call_supertonic(t,r):this._call_text_to_waveform(t)}async _call_supertonic(t,{speaker_embeddings:r,num_inference_steps:n,speed:s}){if(!r)throw new Error("Speaker embeddings must be provided for Supertonic models.");const{sampling_rate:a,style_dim:o}=this.model.config,i=this.tokenizer(t,{padding:!0,truncation:!0}),l=i.input_ids.dims[0];r=await this._prepare_speaker_embeddings(r,l),r=r.view(l,-1,o);const{waveform:c,durations:d}=await this.model.generate_speech({...i,style:r,num_inference_steps:n,speed:s});return this._postprocess_waveform(t,c,a,d)}async _call_text_to_waveform(t){const r=this.tokenizer(t,{padding:!0,truncation:!0}),{waveform:n}=await this.model(r),s=this.model.config.sampling_rate;return this._postprocess_waveform(t,n,s)}async _call_text_to_spectrogram(t,{speaker_embeddings:r}){this.vocoder||(ue.info("No vocoder specified, using default HifiGan vocoder."),this.vocoder=await ds.from_pretrained(this.DEFAULT_VOCODER_ID,{dtype:"fp32"}));const{input_ids:n}=this.tokenizer(t,{padding:!0,truncation:!0}),s=n.dims[0];r=await this._prepare_speaker_embeddings(r,s),r=r.view(s,-1);const{waveform:a}=await this.model.generate_speech(n,r,{vocoder:this.vocoder}),o=this.processor.feature_extractor.config.sampling_rate;return this._postprocess_waveform(t,a,o)}},Q3=class extends $e{async _call(e,t={}){const r=Array.isArray(e),n=await qt(e),{pixel_values:s}=await this.processor(n),a=[];for(const o of s){o.dims=[1,...o.dims];const i=await this.model.generate({inputs:o,...t}),l=this.tokenizer.batch_decode(i,{skip_special_tokens:!0}).map(c=>({generated_text:c.trim()}));a.push(l)}return r?a:a[0]}},X3=class extends $e{async _call(e,{top_k:t=5}={}){const r=await qt(e),{pixel_values:n}=await this.processor(r),s=await this.model({pixel_values:n}),{id2label:a}=this.model.config,o=[];for(const i of s.logits){const l=await Mn(new j("float32",nt(i.data),i.dims),t),c=l[0].tolist(),h=l[1].tolist().map((_,p)=>({label:a?a[_]:`LABEL_${_}`,score:c[p]}));o.push(h)}return Array.isArray(e)?o:o[0]}},Z_={panoptic:"post_process_panoptic_segmentation",instance:"post_process_instance_segmentation",semantic:"post_process_semantic_segmentation"},Sv=class extends $e{async _call(e,{threshold:t=.5,mask_threshold:r=.5,overlap_mask_area_threshold:n=.8,label_ids_to_fuse:s=null,target_sizes:a=null,subtask:o=null}={}){if(Array.isArray(e)&&e.length!==1)throw Error("Image segmentation pipeline currently only supports a batch size of 1.");const l=await qt(e),c=l.map(M=>[M.height,M.width]),d=await this.processor(l),{inputNames:h,outputNames:_}=this.model.sessions.model;if(!h.includes("pixel_values")){if(h.length!==1)throw Error(`Expected a single input name, but got ${h.length} inputs: ${h}.`);const M=h[0];if(M in d)throw Error(`Input name ${M} already exists in the inputs.`);d[M]=d.pixel_values}const p=await this.model(d);let w=null;if(o!==null)w=Z_[o];else if(this.processor.image_processor){for(const[M,T]of Object.entries(Z_))if(T in this.processor.image_processor){w=this.processor.image_processor[T].bind(this.processor.image_processor),o=M;break}}const v=this.model.config.id2label,y=[];if(o)if(o==="panoptic"||o==="instance"){const M=w(p,t,r,n,s,a??c)[0],T=M.segmentation;for(const A of M.segments_info){const S=new Uint8ClampedArray(T.data.length);for(let I=0;I<T.data.length;++I)T.data[I]===A.id&&(S[I]=255);const C=new Gt(S,T.dims[1],T.dims[0],1);y.push({score:A.score,label:v[A.label_id],mask:C})}}else if(o==="semantic"){const{segmentation:M,labels:T}=w(p,a??c)[0];for(const A of T){const S=new Uint8ClampedArray(M.data.length);for(let I=0;I<M.data.length;++I)M.data[I]===A&&(S[I]=255);const C=new Gt(S,M.dims[1],M.dims[0],1);y.push({score:null,label:v[A],mask:C})}}else throw Error(`Subtask ${o} not supported.`);else{const T=p[_[0]];for(let A=0;A<c.length;++A){const S=c[A],C=T[A];C.data.some(x=>x<-1e-5||x>1+1e-5)&&C.sigmoid_();const I=await Gt.fromTensor(C.mul_(255).to("uint8")).resize(S[1],S[0]);y.push({label:null,score:null,mask:I})}}return y}},Y3=class extends Sv{async _call(e,t={}){const r=await qt(e),n=await super._call(e,t),s=r.map((a,o)=>{const i=a.clone();return i.putAlpha(n[o].mask),i});return Array.isArray(e)?s:s[0]}},J3=class extends $e{async _call(e,t,{hypothesis_template:r="This is a photo of {}"}={}){const n=Array.isArray(e),s=await qt(e),a=t.map(h=>r.replace("{}",h)),o=this.tokenizer(a,{padding:this.model.config.model_type==="siglip"?"max_length":!0,truncation:!0}),{pixel_values:i}=await this.processor(s),l=await this.model({...o,pixel_values:i}),c=this.model.config.model_type==="siglip"?h=>h.sigmoid().data:h=>nt(h.data),d=[];for(const h of l.logits_per_image){const p=[...c(h)].map((w,v)=>({score:w,label:t[v]}));p.sort((w,v)=>v.score-w.score),d.push(p)}return n?d:d[0]}},K3=class extends $e{async _call(e,{threshold:t=.9,percentage:r=!1}={}){const n=Array.isArray(e);if(n&&e.length!==1)throw Error("Object detection pipeline currently only supports a batch size of 1.");const s=await qt(e),a=r?null:s.map(_=>[_.height,_.width]),{pixel_values:o,pixel_mask:i}=await this.processor(s),l=await this.model({pixel_values:o,pixel_mask:i}),c=this.processor.image_processor.post_process_object_detection(l,t,a),{id2label:d}=this.model.config,h=c.map(_=>_.boxes.map((p,w)=>({score:_.scores[w],label:d[_.classes[w]],box:xl(p,!r)})));return n?h:h[0]}},Z3=class extends $e{async _call(e,t,{threshold:r=.1,top_k:n=null,percentage:s=!1}={}){const a=Array.isArray(e),o=await qt(e),i=this.tokenizer(t,{padding:!0,truncation:!0}),l=await this.processor(o),c=[];for(let d=0;d<o.length;++d){const h=o[d],_=s?null:[[h.height,h.width]],p=l.pixel_values[d].unsqueeze_(0),w=await this.model({...i,pixel_values:p});let v;if("post_process_grounded_object_detection"in this.processor){const y=this.processor.post_process_grounded_object_detection(w,i.input_ids,{box_threshold:r,text_threshold:r,target_sizes:_})[0];v=y.boxes.map((M,T)=>({score:y.scores[T],label:y.labels[T],box:xl(M,!s)}))}else{const y=this.processor.image_processor.post_process_object_detection(w,r,_,!0)[0];v=y.boxes.map((M,T)=>({score:y.scores[T],label:t[y.classes[T]],box:xl(M,!s)}))}v.sort((y,M)=>M.score-y.score),n!==null&&(v=v.slice(0,n)),c.push(v)}return a?c:c[0]}},eD=class extends $e{constructor(){super(...arguments);k(this,"_default_generation_config",{max_new_tokens:256})}async _call(t,r,n={}){if(Array.isArray(t)){if(t.length!==1)throw Error("Document Question Answering pipeline currently only supports a batch size of 1.");t=t[0]}const s=(await qt(t))[0],{pixel_values:a}=await this.processor(s),o=`<s_docvqa><s_question>${r}</s_question><s_answer>`,i=this.tokenizer(o,{add_special_tokens:!1,padding:!0,truncation:!0}).input_ids,l=await this.model.generate({inputs:a,max_length:this.model.config.decoder.max_position_embeddings,decoder_input_ids:i,...this._default_generation_config,...n}),d=this.tokenizer.batch_decode(l)[0].match(/<s_answer>(.*?)<\/s_answer>/);let h=null;return d&&d.length>=2&&(h=d[1].trim()),[{answer:h}]}},tD=class extends $e{async _call(e){const t=await qt(e),r=await this.processor(t),n=await this.model(r),s=[];for(const a of n.reconstruction){const o=a.squeeze().clamp_(0,1).mul_(255).round_().to("uint8");s.push(Gt.fromTensor(o))}return Array.isArray(e)?s:s[0]}},rD=class extends $e{async _call(e){const t=await qt(e),r=await this.processor(t),{predicted_depth:n}=await this.model(r),s=[];for(let a=0;a<t.length;++a){const o=n[a],[i,l]=o.dims.slice(-2),[c,d]=t[a].size,h=(await Rt(o.view(1,1,i,l),{size:[d,c],mode:"bilinear"})).view(d,c),_=h.min().item(),p=h.max().item(),w=h.sub(_).div_(p-_).mul_(255).to("uint8").unsqueeze(0),v=Gt.fromTensor(w);s.push({predicted_depth:h,depth:v})}return Array.isArray(e)?s:s[0]}},nD=class extends $e{async _call(e,{pooling:t="none",normalize:r=!1,quantize:n=!1,precision:s="binary"}={}){const a=this.tokenizer(e,{padding:!0,truncation:!0}),o=await this.model(a);let i=o.last_hidden_state??o.logits??o.token_embeddings;switch(t){case"none":break;case"mean":i=TT(i,a.attention_mask);break;case"first_token":case"cls":i=i.slice(null,0);break;case"last_token":case"eos":i=i.slice(null,-1);break;default:throw Error(`Pooling method '${t}' not supported.`)}return r&&(i=i.normalize(2,-1)),n&&(i=CT(i,s)),i}},sD=class extends $e{async _call(e,{pool:t=null}={}){const r=await qt(e),{pixel_values:n}=await this.processor(r),s=await this.model({pixel_values:n});let a;if(t){if(!("pooler_output"in s))throw Error("No pooled output was returned. Make sure the model has a 'pooler' layer when using the 'pool' option.");a=s.pooler_output}else a=s.last_hidden_state??s.logits??s.image_embeds;return a}},Ga=Object.freeze({"text-classification":{pipeline:O3,model:Q_,default:{model:"Xenova/distilbert-base-uncased-finetuned-sst-2-english"},type:"text"},"token-classification":{pipeline:N3,model:g3,default:{model:"Xenova/bert-base-multilingual-cased-ner-hrl"},type:"text"},"question-answering":{pipeline:B3,model:x3,default:{model:"Xenova/distilbert-base-cased-distilled-squad"},type:"text"},"fill-mask":{pipeline:R3,model:M3,default:{model:"onnx-community/ettin-encoder-32m-ONNX",dtype:"fp32"},type:"text"},summarization:{pipeline:G3,model:xi,default:{model:"Xenova/distilbart-cnn-6-6"},type:"text"},translation:{pipeline:$3,model:xi,default:{model:"Xenova/t5-small"},type:"text"},"text2text-generation":{pipeline:pd,model:xi,default:{model:"Xenova/flan-t5-small"},type:"text"},"text-generation":{pipeline:V3,model:b3,default:{model:"onnx-community/Qwen3-0.6B-ONNX",dtype:"q4"},type:"text"},"zero-shot-classification":{pipeline:U3,model:Q_,default:{model:"Xenova/distilbert-base-uncased-mnli"},type:"text"},"audio-classification":{pipeline:j3,model:S3,default:{model:"Xenova/wav2vec2-base-superb-ks"},type:"audio"},"zero-shot-audio-classification":{pipeline:q3,model:ds,default:{model:"Xenova/clap-htsat-unfused"},type:"multimodal"},"automatic-speech-recognition":{pipeline:W3,model:[w3,C3],default:{model:"Xenova/whisper-tiny.en"},type:"multimodal"},"text-to-audio":{pipeline:H3,model:[y3,v3],default:{model:"onnx-community/Supertonic-TTS-ONNX",dtype:"fp32"},type:"text"},"image-to-text":{pipeline:Q3,model:k3,default:{model:"Xenova/vit-gpt2-image-captioning"},type:"multimodal"},"image-classification":{pipeline:X3,model:T3,default:{model:"Xenova/vit-base-patch16-224"},type:"multimodal"},"image-segmentation":{pipeline:Sv,model:[X_,Y_,J_],default:{model:"Xenova/detr-resnet-50-panoptic"},type:"multimodal"},"background-removal":{pipeline:Y3,model:[X_,Y_,J_],default:{model:"Xenova/modnet"},type:"image"},"zero-shot-image-classification":{pipeline:J3,model:ds,default:{model:"Xenova/clip-vit-base-patch32"},type:"multimodal"},"object-detection":{pipeline:K3,model:E3,default:{model:"Xenova/detr-resnet-50"},type:"multimodal"},"zero-shot-object-detection":{pipeline:Z3,model:A3,default:{model:"Xenova/owlvit-base-patch32"},type:"multimodal"},"document-question-answering":{pipeline:eD,model:P3,default:{model:"Xenova/donut-base-finetuned-docvqa"},type:"multimodal"},"image-to-image":{pipeline:tD,model:F3,default:{model:"Xenova/swin2SR-classical-sr-x2-64"},type:"image"},"depth-estimation":{pipeline:rD,model:L3,default:{model:"onnx-community/depth-anything-v2-small"},type:"image"},"feature-extraction":{pipeline:nD,model:ds,default:{model:"onnx-community/all-MiniLM-L6-v2-ONNX",dtype:"fp32"},type:"text"},"image-feature-extraction":{pipeline:sD,model:[I3,ds],default:{model:"onnx-community/dinov3-vits16-pretrain-lvd1689m-ONNX",dtype:"fp32"},type:"image"}}),Pv=Object.freeze({"sentiment-analysis":"text-classification",ner:"token-classification",asr:"automatic-speech-recognition","text-to-speech":"text-to-audio",embeddings:"feature-extraction"});async function aD(e){if(!e)throw new Error("modelId is required");return(await ks(e,gs,{})).exists?[gs]:[]}async function oD(e,{config:t=null,dtype:r=null,device:n=null,model_file_name:s=null,include_tokenizer:a=!0,include_processor:o=!0}={}){const i=await Ag(e,{config:t,dtype:r,device:n,model_file_name:s});if(a){const l=await Lm(e);i.push(...l)}if(o){const l=await aD(e);i.push(...l)}return i}async function iD(e,t,r={}){e=Pv[e]??e;const n=Ga[e];if(!n)throw new Error(`Unsupported pipeline task: ${e}. Must be one of [${Object.keys(Ga).join(", ")}]`);const{type:s}=n,i=await oD(t,{...r,include_tokenizer:s!=="audio"&&s!=="image",include_processor:s!=="text"});if(e==="text-generation"){const l=await Eg(t,r),c=Tg(l),d=mC(c);if(d){const h=Object.values(d).map(_=>`onnx/${_}`);return i.filter(_=>!_.startsWith("onnx/")||h.some(p=>_.startsWith(p)))}}return i}async function uD(e,t=null,{progress_callback:r=null,config:n=null,cache_dir:s=null,local_files_only:a=!1,revision:o="main",device:i=null,dtype:l=null,subfolder:c="onnx",use_external_data_format:d=null,model_file_name:h=null,session_options:_={}}={}){e=Pv[e]??e;const p=Ga[e.split("_",1)[0]];if(!p)throw Error(`Unsupported pipeline: ${e}. Must be one of [${Object.keys(Ga)}]`);t||(t=p.default.model,ue.info(`No model specified. Using default model: "${t}".`),!l&&p.default.dtype&&(l=p.default.dtype));const w=await iD(e,t,{device:i,dtype:l});let v={};r&&(await Promise.all(w.map(async Q=>ks(t,Q)))).forEach((Q,H)=>{Q.exists&&(v[w[H]]={loaded:0,total:Q.size??0})});const y={progress_callback:r?new ul(r,v):void 0,config:n,cache_dir:s,local_files_only:a,revision:o,device:i,dtype:l,subfolder:c,use_external_data_format:d,model_file_name:h,session_options:_},M=w.includes("tokenizer.json"),T=w.includes("preprocessor_config.json"),A=p.model;let S;if(Array.isArray(A)){const $=n??await ws.from_pretrained(t,y),{model_type:Q}=$,H=A.find(D=>D.supports(Q));if(!H)throw Error(`Unsupported model type "${Q}" for task "${e}". None of the candidate model classes support this type.`);S=H.from_pretrained(t,{...y,config:$})}else S=A.from_pretrained(t,y);const[C,I,x]=await Promise.all([M?Te.from_pretrained(t,y):null,T?UA.from_pretrained(t,y):null,S]),R={task:e,model:x};C&&(R.tokenizer=C),I&&(R.processor=I),Ar(r,{status:"ready",task:e,model:t});const z=p.pipeline;return new z(R)}_e.IS_PROCESS_AVAILABLE;export{VE as ASTFeatureExtractor,DC as ASTForAudioClassification,NC as ASTModel,mc as ASTPreTrainedModel,LC as AfmoeForCausalLM,FC as AfmoeModel,_c as AfmoePreTrainedModel,CC as AlbertForMaskedLM,AC as AlbertForQuestionAnswering,EC as AlbertForSequenceClassification,TC as AlbertModel,Ts as AlbertPreTrainedModel,IT as AlbertTokenizer,PC as ApertusForCausalLM,SC as ApertusModel,fc as ApertusPreTrainedModel,OC as ArceeForCausalLM,IC as ArceeModel,pc as ArceePreTrainedModel,j3 as AudioClassificationPipeline,ws as AutoConfig,Lt as AutoFeatureExtractor,ut as AutoImageProcessor,ds as AutoModel,S3 as AutoModelForAudioClassification,C3 as AutoModelForCTC,b3 as AutoModelForCausalLM,L3 as AutoModelForDepthEstimation,P3 as AutoModelForDocumentQuestionAnswering,T3 as AutoModelForImageClassification,I3 as AutoModelForImageFeatureExtraction,X_ as AutoModelForImageSegmentation,F3 as AutoModelForImageToImage,M3 as AutoModelForMaskedLM,E3 as AutoModelForObjectDetection,x3 as AutoModelForQuestionAnswering,Y_ as AutoModelForSemanticSegmentation,xi as AutoModelForSeq2SeqLM,Q_ as AutoModelForSequenceClassification,w3 as AutoModelForSpeechSeq2Seq,v3 as AutoModelForTextToSpectrogram,y3 as AutoModelForTextToWaveform,g3 as AutoModelForTokenClassification,J_ as AutoModelForUniversalSegmentation,k3 as AutoModelForVision2Seq,A3 as AutoModelForZeroShotObjectDetection,UA as AutoProcessor,Te as AutoTokenizer,W3 as AutomaticSpeechRecognitionPipeline,Y3 as BackgroundRemovalPipeline,BC as BartForConditionalGeneration,RC as BartForSequenceClassification,zC as BartModel,Ja as BartPretrainedModel,OT as BartTokenizer,u2 as BeitFeatureExtractor,$C as BeitForImageClassification,GC as BeitModel,gc as BeitPreTrainedModel,UC as BertForMaskedLM,WC as BertForQuestionAnswering,jC as BertForSequenceClassification,qC as BertForTokenClassification,VC as BertModel,xn as BertPreTrainedModel,NT as BertTokenizer,d2 as BitImageProcessor,QC as BlenderbotForConditionalGeneration,HC as BlenderbotModel,wc as BlenderbotPreTrainedModel,YC as BlenderbotSmallForConditionalGeneration,XC as BlenderbotSmallModel,vc as BlenderbotSmallPreTrainedModel,DT as BlenderbotSmallTokenizer,zT as BlenderbotTokenizer,KC as BloomForCausalLM,JC as BloomModel,yc as BloomPreTrainedModel,BT as BloomTokenizer,oS as CHMv2ForDepthEstimation,f2 as CHMv2ImageProcessor,zg as CHMv2PreTrainedModel,_2 as CLIPFeatureExtractor,Zm as CLIPImageProcessor,lS as CLIPModel,Yr as CLIPPreTrainedModel,fS as CLIPSegForImageSegmentation,hS as CLIPSegModel,bc as CLIPSegPreTrainedModel,cS as CLIPTextModel,Gg as CLIPTextModelWithProjection,GT as CLIPTokenizer,uS as CLIPVisionModel,dS as CLIPVisionModelWithProjection,eS as CamembertForMaskedLM,nS as CamembertForQuestionAnswering,tS as CamembertForSequenceClassification,rS as CamembertForTokenClassification,ZC as CamembertModel,kn as CamembertPreTrainedModel,RT as CamembertTokenizer,UE as ChatterboxFeatureExtractor,Ng as ChatterboxModel,Og as ChatterboxPreTrainedModel,r2 as ChatterboxProcessor,h2 as ChineseCLIPFeatureExtractor,aS as ChineseCLIPModel,Dg as ChineseCLIPPreTrainedModel,Rg as ClapAudioModelWithProjection,jE as ClapFeatureExtractor,iS as ClapModel,Ka as ClapPreTrainedModel,Bg as ClapTextModelWithProjection,lC as ClassifierFreeGuidanceLogitsProcessor,pS as CodeGenForCausalLM,_S as CodeGenModel,Mc as CodeGenPreTrainedModel,VT as CodeGenTokenizer,$T as CodeLlamaTokenizer,vS as Cohere2ForCausalLM,wS as Cohere2Model,kc as Cohere2PreTrainedModel,WE as CohereAsrFeatureExtractor,bS as CohereAsrForConditionalGeneration,yS as CohereAsrModel,Tc as CohereAsrPreTrainedModel,s2 as CohereAsrProcessor,jT as CohereAsrTokenizer,gS as CohereForCausalLM,mS as CohereModel,xc as CoherePreTrainedModel,UT as CohereTokenizer,xS as ConvBertForMaskedLM,ES as ConvBertForQuestionAnswering,kS as ConvBertForSequenceClassification,TS as ConvBertForTokenClassification,MS as ConvBertModel,Tn as ConvBertPreTrainedModel,qT as ConvBertTokenizer,p2 as ConvNextFeatureExtractor,CS as ConvNextForImageClassification,eg as ConvNextImageProcessor,AS as ConvNextModel,Ec as ConvNextPreTrainedModel,PS as ConvNextV2ForImageClassification,SS as ConvNextV2Model,Ac as ConvNextV2PreTrainedModel,OS as DFineForObjectDetection,IS as DFineModel,Sc as DFinePreTrainedModel,oP as DINOv3ConvNextModel,Xg as DINOv3ConvNextPreTrainedModel,w2 as DINOv3ViTImageProcessor,iP as DINOv3ViTModel,Yg as DINOv3ViTPreTrainedModel,y2 as DPTFeatureExtractor,pP as DPTForDepthEstimation,ng as DPTImageProcessor,_P as DPTModel,Nc as DPTPreTrainedModel,jg as DacDecoderModel,Vg as DacDecoderOutput,Ug as DacEncoderModel,$g as DacEncoderOutput,jm as DacFeatureExtractor,NS as DacModel,Za as DacPreTrainedModel,zS as DebertaForMaskedLM,GS as DebertaForQuestionAnswering,BS as DebertaForSequenceClassification,RS as DebertaForTokenClassification,DS as DebertaModel,En as DebertaPreTrainedModel,HT as DebertaTokenizer,jS as DebertaV2ForMaskedLM,HS as DebertaV2ForQuestionAnswering,qS as DebertaV2ForSequenceClassification,WS as DebertaV2ForTokenClassification,US as DebertaV2Model,An as DebertaV2PreTrainedModel,WT as DebertaV2Tokenizer,QS as DecisionTransformerModel,qg as DecisionTransformerPreTrainedModel,VS as DeepseekV3ForCausalLM,$S as DeepseekV3Model,Pc as DeepseekV3PreTrainedModel,m2 as DeiTFeatureExtractor,YS as DeiTForImageClassification,tg as DeiTImageProcessor,XS as DeiTModel,Fc as DeiTPreTrainedModel,JS as DepthAnythingForDepthEstimation,Wg as DepthAnythingPreTrainedModel,rD as DepthEstimationPipeline,KS as DepthProForDepthEstimation,Hg as DepthProPreTrainedModel,g2 as DetrFeatureExtractor,eP as DetrForObjectDetection,tP as DetrForSegmentation,rg as DetrImageProcessor,ZS as DetrModel,Lc as DetrObjectDetectionOutput,eo as DetrPreTrainedModel,Qg as DetrSegmentationOutput,nP as Dinov2ForImageClassification,rP as Dinov2Model,Ic as Dinov2PreTrainedModel,aP as Dinov2WithRegistersForImageClassification,sP as Dinov2WithRegistersModel,Oc as Dinov2WithRegistersPreTrainedModel,hP as DistilBertForMaskedLM,dP as DistilBertForQuestionAnswering,cP as DistilBertForSequenceClassification,uP as DistilBertForTokenClassification,lP as DistilBertModel,Cn as DistilBertPreTrainedModel,QT as DistilBertTokenizer,eD as DocumentQuestionAnsweringPipeline,v2 as DonutFeatureExtractor,sc as DonutImageProcessor,fP as DonutSwinModel,Jg as DonutSwinPreTrainedModel,lc as DynamicCache,EO as EdgeTamModel,gP as EfficientNetForImageClassification,b2 as EfficientNetImageProcessor,mP as EfficientNetModel,Dc as EfficientNetPreTrainedModel,vP as ElectraForMaskedLM,MP as ElectraForQuestionAnswering,yP as ElectraForSequenceClassification,bP as ElectraForTokenClassification,wP as ElectraModel,Sn as ElectraPreTrainedModel,XT as ElectraTokenizer,Vm as EncodecFeatureExtractor,dC as EosTokenCriteria,kP as Ernie4_5ForCausalLM,xP as Ernie4_5Model,zc as Ernie4_5PretrainedModel,EP as EsmForMaskedLM,AP as EsmForSequenceClassification,CP as EsmForTokenClassification,TP as EsmModel,As as EsmPreTrainedModel,YT as EsmTokenizer,PP as EuroBertForMaskedLM,FP as EuroBertForSequenceClassification,LP as EuroBertForTokenClassification,SP as EuroBertModel,Cs as EuroBertPreTrainedModel,OP as ExaoneForCausalLM,IP as ExaoneModel,Bc as ExaonePreTrainedModel,DP as FalconForCausalLM,BP as FalconH1ForCausalLM,zP as FalconH1Model,Gc as FalconH1PreTrainedModel,NP as FalconModel,Rc as FalconPreTrainedModel,JT as FalconTokenizer,GP as FastViTForImageClassification,RP as FastViTModel,$c as FastViTPreTrainedModel,nD as FeatureExtractionPipeline,ct as FeatureExtractor,R3 as FillMaskPipeline,$P as Florence2ForConditionalGeneration,Kg as Florence2PreTrainedModel,aA as Florence2Processor,ZA as ForcedBOSTokenLogitsProcessor,eC as ForcedEOSTokenLogitsProcessor,E2 as GLPNFeatureExtractor,sF as GLPNForDepthEstimation,nF as GLPNModel,Xc as GLPNPreTrainedModel,_F as GPT2LMHeadModel,fF as GPT2Model,eu as GPT2PreTrainedModel,eE as GPT2Tokenizer,oF as GPTBigCodeForCausalLM,aF as GPTBigCodeModel,Yc as GPTBigCodePreTrainedModel,mF as GPTJForCausalLM,pF as GPTJModel,tu as GPTJPreTrainedModel,lF as GPTNeoForCausalLM,iF as GPTNeoModel,Jc as GPTNeoPreTrainedModel,uF as GPTNeoXForCausalLM,cF as GPTNeoXModel,Kc as GPTNeoXPreTrainedModel,ZT as GPTNeoXTokenizer,qP as Gemma2ForCausalLM,jP as Gemma2Model,Uc as Gemma2PreTrainedModel,XP as Gemma3ForCausalLM,tw as Gemma3ForConditionalGeneration,M2 as Gemma3ImageProcessor,QP as Gemma3Model,ew as Gemma3PreTrainedModel,oA as Gemma3Processor,qm as Gemma3nAudioFeatureExtractor,YP as Gemma3nForCausalLM,to as Gemma3nForConditionalGeneration,rw as Gemma3nPreTrainedModel,iA as Gemma3nProcessor,Wm as Gemma4AudioFeatureExtractor,JP as Gemma4ForCausalLM,jc as Gemma4ForConditionalGeneration,sg as Gemma4ImageProcessor,lA as Gemma4Processor,UP as GemmaForCausalLM,VP as GemmaModel,Vc as GemmaPreTrainedModel,KT as GemmaTokenizer,T2 as Glm46VImageProcessor,cA as Glm46VProcessor,ZP as GlmForCausalLM,KP as GlmModel,tF as GlmMoeDsaForCausalLM,eF as GlmMoeDsaModel,Wc as GlmMoeDsaPreTrainedModel,rF as GlmOcrForConditionalGeneration,qc as GlmPreTrainedModel,hF as GptOssForCausalLM,dF as GptOssModel,Zc as GptOssPreTrainedModel,wF as GraniteForCausalLM,gF as GraniteModel,yF as GraniteMoeHybridForCausalLM,vF as GraniteMoeHybridModel,nu as GraniteMoeHybridPreTrainedModel,ru as GranitePreTrainedModel,HE as GraniteSpeechFeatureExtractor,bF as GraniteSpeechForConditionalGeneration,uA as GraniteSpeechProcessor,MF as GroundingDinoForObjectDetection,A2 as GroundingDinoImageProcessor,iw as GroundingDinoPreTrainedModel,hA as GroundingDinoProcessor,xF as GroupViTModel,lw as GroupViTPreTrainedModel,TF as HeliumForCausalLM,kF as HeliumModel,au as HeliumPreTrainedModel,tE as HerbertTokenizer,AF as HieraForImageClassification,EF as HieraModel,ou as HieraPreTrainedModel,OF as HubertForCTC,NF as HubertForSequenceClassification,IF as HubertModel,LF as HubertPreTrainedModel,zF as HunYuanDenseV1ForCausalLM,DF as HunYuanDenseV1Model,iu as HunYuanDenseV1PreTrainedModel,RF as IJepaForImageClassification,BF as IJepaModel,lu as IJepaPreTrainedModel,cw as Idefics3ForConditionalGeneration,B_ as Idefics3ImageProcessor,G_ as Idefics3Processor,X3 as ImageClassificationPipeline,sD as ImageFeatureExtractionPipeline,de as ImageFeatureExtractor,de as ImageProcessor,Sv as ImageSegmentationPipeline,tD as ImageToImagePipeline,Q3 as ImageToTextPipeline,$F as JAISLMHeadModel,GF as JAISModel,cu as JAISPreTrainedModel,S2 as JinaCLIPImageProcessor,VF as JinaCLIPModel,ro as JinaCLIPPreTrainedModel,gA as JinaCLIPProcessor,uw as JinaCLIPTextModel,UF as JinaCLIPVisionModel,qF as Lfm2ForCausalLM,jF as Lfm2Model,QF as Lfm2MoeForCausalLM,HF as Lfm2MoeModel,du as Lfm2MoePreTrainedModel,uu as Lfm2PreTrainedModel,XF as Lfm2VlForConditionalGeneration,O2 as Lfm2VlImageProcessor,wA as Lfm2VlProcessor,WF as LightOnOcrForConditionalGeneration,HN as LiteWhisperForConditionalGeneration,KF as Llama4ForCausalLM,dw as Llama4PreTrainedModel,JF as LlamaForCausalLM,YF as LlamaModel,hu as LlamaPreTrainedModel,rE as LlamaTokenizer,mr as LlavaForConditionalGeneration,mr as LlavaOnevisionForConditionalGeneration,N2 as LlavaOnevisionImageProcessor,Zg as LlavaPreTrainedModel,vA as LlavaProcessor,HP as LlavaQwen2ForCausalLM,Dt as LogLevel,jt as LogitsProcessor,yl as LogitsProcessorList,KA as LogitsWarper,eL as LongT5ForConditionalGeneration,ZF as LongT5Model,fu as LongT5PreTrainedModel,rL as M2M100ForConditionalGeneration,tL as M2M100Model,_u as M2M100PreTrainedModel,nE as M2M100Tokenizer,aE as MBart50Tokenizer,uL as MBartForCausalLM,lL as MBartForConditionalGeneration,cL as MBartForSequenceClassification,iL as MBartModel,Ss as MBartPreTrainedModel,Nm as MBartTokenizer,YL as MPNetForMaskedLM,ZL as MPNetForQuestionAnswering,JL as MPNetForSequenceClassification,KL as MPNetForTokenClassification,XL as MPNetModel,Pn as MPNetPreTrainedModel,lE as MPNetTokenizer,nI as MT5ForConditionalGeneration,rI as MT5Model,Tu as MT5PreTrainedModel,sL as MarianMTModel,nL as MarianModel,pu as MarianPreTrainedModel,sE as MarianTokenizer,z2 as Mask2FormerImageProcessor,D2 as MaskFormerFeatureExtractor,oL as MaskFormerForInstanceSegmentation,ac as MaskFormerImageProcessor,aL as MaskFormerModel,mu as MaskFormerPreTrainedModel,uC as MaxLengthCriteria,dL as Metric3DForDepthEstimation,hw as Metric3DPreTrainedModel,hL as Metric3Dv2ForDepthEstimation,fw as Metric3Dv2PreTrainedModel,fL as MgpstrForSceneTextRecognition,_w as MgpstrModelOutput,pw as MgpstrPreTrainedModel,yA as MgpstrProcessor,oE as MgpstrTokenizer,vw as MimiDecoderModel,gw as MimiDecoderOutput,ww as MimiEncoderModel,mw as MimiEncoderOutput,_L as MimiModel,no as MimiPreTrainedModel,aC as MinLengthLogitsProcessor,oC as MinNewTokensLengthLogitsProcessor,wL as Mistral4ForCausalLM,gL as Mistral4Model,wu as Mistral4PreTrainedModel,mL as MistralForCausalLM,pL as MistralModel,gu as MistralPreTrainedModel,yL as MobileBertForMaskedLM,ML as MobileBertForQuestionAnswering,bL as MobileBertForSequenceClassification,vL as MobileBertModel,Ps as MobileBertPreTrainedModel,iE as MobileBertTokenizer,kL as MobileLLMForCausalLM,xL as MobileLLMModel,vu as MobileLLMPreTrainedModel,B2 as MobileNetV1FeatureExtractor,EL as MobileNetV1ForImageClassification,AL as MobileNetV1ForSemanticSegmentation,og as MobileNetV1ImageProcessor,TL as MobileNetV1Model,so as MobileNetV1PreTrainedModel,R2 as MobileNetV2FeatureExtractor,SL as MobileNetV2ForImageClassification,PL as MobileNetV2ForSemanticSegmentation,ig as MobileNetV2ImageProcessor,CL as MobileNetV2Model,ao as MobileNetV2PreTrainedModel,G2 as MobileNetV3FeatureExtractor,LL as MobileNetV3ForImageClassification,IL as MobileNetV3ForSemanticSegmentation,lg as MobileNetV3ImageProcessor,FL as MobileNetV3Model,oo as MobileNetV3PreTrainedModel,$2 as MobileNetV4FeatureExtractor,NL as MobileNetV4ForImageClassification,DL as MobileNetV4ForSemanticSegmentation,cg as MobileNetV4ImageProcessor,OL as MobileNetV4Model,io as MobileNetV4PreTrainedModel,V2 as MobileViTFeatureExtractor,BL as MobileViTForImageClassification,ug as MobileViTImageProcessor,zL as MobileViTModel,yu as MobileViTPreTrainedModel,GL as MobileViTV2ForImageClassification,RL as MobileViTV2Model,bu as MobileViTV2PreTrainedModel,WL as ModernBertDecoderForCausalLM,qL as ModernBertDecoderModel,Mu as ModernBertDecoderPreTrainedModel,VL as ModernBertForMaskedLM,UL as ModernBertForSequenceClassification,jL as ModernBertForTokenClassification,$L as ModernBertModel,Fs as ModernBertPreTrainedModel,WP as Moondream1ForConditionalGeneration,QE as MoonshineFeatureExtractor,QL as MoonshineForConditionalGeneration,HL as MoonshineModel,xu as MoonshinePreTrainedModel,bA as MoonshineProcessor,tI as MptForCausalLM,eI as MptModel,ku as MptPreTrainedModel,sI as MultiModalityCausalLM,yw as MultiModalityPreTrainedModel,oI as MusicgenForCausalLM,bw as MusicgenForConditionalGeneration,aI as MusicgenModel,Eu as MusicgenPreTrainedModel,lI as NanoChatForCausalLM,iI as NanoChatModel,Au as NanoChatPreTrainedModel,uI as NemotronHForCausalLM,cI as NemotronHModel,Cu as NemotronHPreTrainedModel,hI as NeoBertForMaskedLM,pI as NeoBertForQuestionAnswering,fI as NeoBertForSequenceClassification,_I as NeoBertForTokenClassification,dI as NeoBertModel,Fn as NeoBertPreTrainedModel,cE as NllbTokenizer,iC as NoBadWordsLogitsProcessor,nC as NoRepeatNGramLogitsProcessor,mI as NomicBertModel,Mw as NomicBertPreTrainedModel,U2 as NougatImageProcessor,uE as NougatTokenizer,PI as OPTForCausalLM,SI as OPTModel,Nu as OPTPreTrainedModel,K3 as ObjectDetectionPipeline,yI as Olmo2ForCausalLM,vI as Olmo2Model,Pu as Olmo2PreTrainedModel,MI as Olmo3ForCausalLM,bI as Olmo3Model,Fu as Olmo3PreTrainedModel,wI as OlmoForCausalLM,kI as OlmoHybridForCausalLM,xI as OlmoHybridModel,Lu as OlmoHybridPreTrainedModel,gI as OlmoModel,Su as OlmoPreTrainedModel,EI as OpenAIPrivacyFilterForTokenClassification,TI as OpenAIPrivacyFilterModel,Iu as OpenAIPrivacyFilterPreTrainedModel,CI as OpenELMForCausalLM,AI as OpenELMModel,Ou as OpenELMPreTrainedModel,j2 as OwlViTFeatureExtractor,OI as OwlViTForObjectDetection,oc as OwlViTImageProcessor,II as OwlViTModel,zu as OwlViTPreTrainedModel,MA as OwlViTProcessor,LI as Owlv2ForObjectDetection,q2 as Owlv2ImageProcessor,FI as Owlv2Model,Du as Owlv2PreTrainedModel,NI as PaliGemmaForConditionalGeneration,kA as PaliGemmaProcessor,Um as ParakeetFeatureExtractor,DI as ParakeetForCTC,xw as ParakeetPreTrainedModel,BI as PatchTSMixerForPrediction,zI as PatchTSMixerModel,Bu as PatchTSMixerPreTrainedModel,GI as PatchTSTForPrediction,RI as PatchTSTModel,Ru as PatchTSTPreTrainedModel,jI as Phi3ForCausalLM,UI as Phi3Model,$u as Phi3PreTrainedModel,Tw as Phi3VForCausalLM,H2 as Phi3VImageProcessor,kw as Phi3VPreTrainedModel,EA as Phi3VProcessor,VI as PhiForCausalLM,$I as PhiModel,Gu as PhiPreTrainedModel,Q2 as PixtralImageProcessor,AA as PixtralProcessor,P as PreTrainedModel,ce as PreTrainedTokenizer,wl as PretrainedConfig,Ee as Processor,WI as PvtForImageClassification,X2 as PvtImageProcessor,qI as PvtModel,Vu as PvtPreTrainedModel,Hm as PyAnnoteFeatureExtractor,QI as PyAnnoteForAudioFrameClassification,HI as PyAnnoteModel,Uu as PyAnnotePreTrainedModel,CA as PyAnnoteProcessor,B3 as QuestionAnsweringPipeline,YI as Qwen2ForCausalLM,XI as Qwen2Model,KI as Qwen2MoeForCausalLM,JI as Qwen2MoeModel,qu as Qwen2MoePreTrainedModel,ju as Qwen2PreTrainedModel,dE as Qwen2Tokenizer,sw as Qwen2VLForCausalLM,Hc as Qwen2VLForConditionalGeneration,ag as Qwen2VLImageProcessor,nw as Qwen2VLPreTrainedModel,ic as Qwen2VLProcessor,aw as Qwen2_5_VLForCausalLM,Qc as Qwen2_5_VLForConditionalGeneration,pg as Qwen2_5_VLProcessor,eO as Qwen3ForCausalLM,ZI as Qwen3Model,rO as Qwen3MoeForCausalLM,tO as Qwen3MoeModel,Hu as Qwen3MoePreTrainedModel,sO as Qwen3NextForCausalLM,nO as Qwen3NextModel,Qu as Qwen3NextPreTrainedModel,Wu as Qwen3PreTrainedModel,Ew as Qwen3VLForCausalLM,Xu as Qwen3VLForConditionalGeneration,oO as Qwen3VLMoeForCausalLM,aO as Qwen3VLMoeForConditionalGeneration,SA as Qwen3VLProcessor,Aw as Qwen3_5ForCausalLM,Yu as Qwen3_5ForConditionalGeneration,lO as Qwen3_5MoeForCausalLM,iO as Qwen3_5MoeForConditionalGeneration,hO as RFDetrForObjectDetection,dO as RFDetrModel,Cw as RFDetrObjectDetectionOutput,Ku as RFDetrPreTrainedModel,LS as RTDetrForObjectDetection,Y2 as RTDetrImageProcessor,FS as RTDetrModel,Es as RTDetrObjectDetectionOutput,Cc as RTDetrPreTrainedModel,kO as RTDetrV2ForObjectDetection,xO as RTDetrV2Model,Sw as RTDetrV2ObjectDetectionOutput,Zu as RTDetrV2PreTrainedModel,$E as RawAudio,Gt as RawImage,sC as RepetitionPenaltyLogitsProcessor,uO as ResNetForImageClassification,cO as ResNetModel,Ju as ResNetPreTrainedModel,vO as RoFormerForMaskedLM,MO as RoFormerForQuestionAnswering,yO as RoFormerForSequenceClassification,bO as RoFormerForTokenClassification,wO as RoFormerModel,In as RoFormerPreTrainedModel,fE as RoFormerTokenizer,_O as RobertaForMaskedLM,gO as RobertaForQuestionAnswering,pO as RobertaForSequenceClassification,mO as RobertaForTokenClassification,fO as RobertaModel,Ln as RobertaPreTrainedModel,hE as RobertaTokenizer,yi as Sam2ImageProcessor,Lw as Sam2ImageSegmentationOutput,ed as Sam2Model,Iw as Sam2PreTrainedModel,gg as Sam2Processor,PA as Sam2VideoProcessor,yi as Sam3ImageProcessor,AO as Sam3TrackerModel,yi as SamImageProcessor,Pw as SamImageSegmentationOutput,TO as SamModel,Fw as SamPreTrainedModel,mg as SamProcessor,J2 as SapiensFeatureExtractor,SO as SapiensForDepthEstimation,PO as SapiensForNormalEstimation,CO as SapiensForSemanticSegmentation,dg as SapiensImageProcessor,lo as SapiensPreTrainedModel,XE as SeamlessM4TFeatureExtractor,K2 as SegformerFeatureExtractor,LO as SegformerForImageClassification,IO as SegformerForSemanticSegmentation,hg as SegformerImageProcessor,FO as SegformerModel,co as SegformerPreTrainedModel,Z2 as SiglipImageProcessor,OO as SiglipModel,td as SiglipPreTrainedModel,Ow as SiglipTextModel,_E as SiglipTokenizer,NO as SiglipVisionModel,zO as SmolLM3ForCausalLM,DO as SmolLM3Model,rd as SmolLM3PreTrainedModel,BO as SmolVLMForConditionalGeneration,B_ as SmolVLMImageProcessor,G_ as SmolVLMProcessor,Dw as SnacDecoderModel,Nw as SnacEncoderModel,YE as SnacFeatureExtractor,RO as SnacModel,uo as SnacPreTrainedModel,$O as SolarOpenForCausalLM,GO as SolarOpenModel,nd as SolarOpenPreTrainedModel,JE as SpeechT5FeatureExtractor,UO as SpeechT5ForSpeechToText,jO as SpeechT5ForTextToSpeech,qO as SpeechT5HifiGan,VO as SpeechT5Model,ho as SpeechT5PreTrainedModel,FA as SpeechT5Processor,pE as SpeechT5Tokenizer,HO as SqueezeBertForMaskedLM,XO as SqueezeBertForQuestionAnswering,QO as SqueezeBertForSequenceClassification,WO as SqueezeBertModel,Ls as SqueezeBertPreTrainedModel,mE as SqueezeBertTokenizer,JO as StableLmForCausalLM,YO as StableLmModel,sd as StableLmPreTrainedModel,ZO as Starcoder2ForCausalLM,KO as Starcoder2Model,ad as Starcoder2PreTrainedModel,Xa as StoppingCriteria,xg as StoppingCriteriaList,eN as StyleTextToSpeech2Model,zw as StyleTextToSpeech2PreTrainedModel,G3 as SummarizationPipeline,Rw as SupertonicForConditionalGeneration,Bw as SupertonicPreTrainedModel,bg as SuppressTokensAtBeginLogitsProcessor,tC as SuppressTokensLogitsProcessor,aN as Swin2SRForImageSuperResolution,eA as Swin2SRImageProcessor,sN as Swin2SRModel,od as Swin2SRPreTrainedModel,rN as SwinForImageClassification,nN as SwinForSemanticSegmentation,tN as SwinModel,fo as SwinPreTrainedModel,iN as T5ForConditionalGeneration,oN as T5Model,id as T5PreTrainedModel,gE as T5Tokenizer,cN as TableTransformerForObjectDetection,lN as TableTransformerModel,Gw as TableTransformerObjectDetectionOutput,ld as TableTransformerPreTrainedModel,cC as TemperatureLogitsWarper,j as Tensor,pd as Text2TextGenerationPipeline,O3 as TextClassificationPipeline,V3 as TextGenerationPipeline,H3 as TextToAudioPipeline,N3 as TokenClassificationPipeline,ce as TokenizersBackend,uN as TrOCRForCausalLM,$w as TrOCRPreTrainedModel,$3 as TranslationPipeline,su as UltravoxModel,ow as UltravoxPreTrainedModel,LA as UltravoxProcessor,hN as UniSpeechForCTC,fN as UniSpeechForSequenceClassification,dN as UniSpeechModel,_o as UniSpeechPreTrainedModel,gN as UniSpeechSatForAudioFrameClassification,pN as UniSpeechSatForCTC,mN as UniSpeechSatForSequenceClassification,_N as UniSpeechSatModel,Is as UniSpeechSatPreTrainedModel,mA as VLChatProcessor,C2 as VLMImageProcessor,vN as VaultGemmaForCausalLM,wN as VaultGemmaModel,cd as VaultGemmaPreTrainedModel,tA as ViTFeatureExtractor,MN as ViTForImageClassification,fg as ViTImageProcessor,xN as ViTMAEModel,Vw as ViTMAEPreTrainedModel,TN as ViTMSNForImageClassification,kN as ViTMSNModel,dd as ViTMSNPreTrainedModel,bN as ViTModel,ud as ViTPreTrainedModel,yN as VisionEncoderDecoderModel,EN as VitMatteForImageMatting,rA as VitMatteImageProcessor,Uw as VitMattePreTrainedModel,AN as VitPoseForPoseEstimation,nA as VitPoseImageProcessor,jw as VitPosePreTrainedModel,CN as VitsModel,qw as VitsModelOutput,Ww as VitsPreTrainedModel,vE as VitsTokenizer,SN as VoxtralForConditionalGeneration,DA as VoxtralProcessor,e2 as VoxtralRealtimeFeatureExtractor,Qw as VoxtralRealtimeForConditionalGeneration,Hw as VoxtralRealtimePreTrainedModel,RA as VoxtralRealtimeProcessor,zN as Wav2Vec2BertForCTC,BN as Wav2Vec2BertForSequenceClassification,DN as Wav2Vec2BertModel,po as Wav2Vec2BertPreTrainedModel,yE as Wav2Vec2CTCTokenizer,KE as Wav2Vec2FeatureExtractor,FF as Wav2Vec2ForAudioFrameClassification,SF as Wav2Vec2ForCTC,PF as Wav2Vec2ForSequenceClassification,CF as Wav2Vec2Model,Lr as Wav2Vec2PreTrainedModel,GA as Wav2Vec2Processor,$A as Wav2Vec2ProcessorWithLM,UN as WavLMForAudioFrameClassification,GN as WavLMForCTC,$N as WavLMForSequenceClassification,VN as WavLMForXVector,RN as WavLMModel,On as WavLMPreTrainedModel,ZE as WeSpeakerFeatureExtractor,jN as WeSpeakerResNetModel,Yw as WeSpeakerResNetPreTrainedModel,t2 as WhisperFeatureExtractor,Jw as WhisperForConditionalGeneration,WN as WhisperModel,hd as WhisperPreTrainedModel,VA as WhisperProcessor,rC as WhisperTimeStampLogitsProcessor,TE as WhisperTokenizer,KN as XLMForQuestionAnswering,YN as XLMForSequenceClassification,JN as XLMForTokenClassification,QN as XLMModel,Nn as XLMPreTrainedModel,e3 as XLMRobertaForMaskedLM,n3 as XLMRobertaForQuestionAnswering,t3 as XLMRobertaForSequenceClassification,r3 as XLMRobertaForTokenClassification,ZN as XLMRobertaModel,Dn as XLMRobertaPreTrainedModel,EE as XLMRobertaTokenizer,AE as XLMTokenizer,XN as XLMWithLMHeadModel,Xw as XVectorOutput,sA as YolosFeatureExtractor,a3 as YolosForObjectDetection,_g as YolosImageProcessor,s3 as YolosModel,Kw as YolosObjectDetectionOutput,fd as YolosPreTrainedModel,i3 as YoutuForCausalLM,o3 as YoutuModel,_d as YoutuPreTrainedModel,q3 as ZeroShotAudioClassificationPipeline,U3 as ZeroShotClassificationPipeline,J3 as ZeroShotImageClassificationPipeline,Z3 as ZeroShotObjectDetectionPipeline,De as cat,Me as env,lt as full,pl as full_like,Am as interpolate,Rt as interpolate_4d,PE as load_audio,aT as log_softmax,kT as matmul,Jl as mean,TT as mean_pooling,gt as ones,Sm as ones_like,xT as permute,uD as pipeline,CT as quantize_embeddings,AT as randn,Hl as random,FE as read_audio,Cm as slice,nt as softmax,_r as stack,ET as std_mean,Mn as topk,Pm as zeros,Fm as zeros_like};