@huggingface/transformers 4.0.0-next.7 → 4.0.0-next.8

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.
Files changed (79) hide show
  1. package/README.md +13 -2
  2. package/dist/transformers.js +689 -382
  3. package/dist/transformers.min.js +19 -19
  4. package/dist/transformers.node.cjs +716 -382
  5. package/dist/transformers.node.min.cjs +19 -19
  6. package/dist/transformers.node.min.mjs +19 -19
  7. package/dist/transformers.node.mjs +689 -382
  8. package/dist/transformers.web.js +697 -390
  9. package/dist/transformers.web.min.js +17 -17
  10. package/package.json +2 -2
  11. package/src/configs.js +28 -22
  12. package/src/env.js +1 -1
  13. package/src/image_processors_utils.js +25 -15
  14. package/src/models/chmv2/image_processing_chmv2.js +3 -0
  15. package/src/models/chmv2/modeling_chmv2.js +4 -0
  16. package/src/models/deepseek_v3/modeling_deepseek_v3.js +5 -0
  17. package/src/models/eurobert/modeling_eurobert.js +41 -0
  18. package/src/models/glm46v/image_processing_glm46v.js +12 -0
  19. package/src/models/glm46v/processing_glm46v.js +5 -0
  20. package/src/models/glm_moe_dsa/modeling_glm_moe_dsa.js +5 -0
  21. package/src/models/glm_ocr/modeling_glm_ocr.js +78 -0
  22. package/src/models/image_processors.js +2 -0
  23. package/src/models/lfm2_vl/image_processing_lfm2_vl.js +1 -1
  24. package/src/models/lighton_ocr/modeling_lighton_ocr.js +3 -0
  25. package/src/models/mistral4/modeling_mistral4.js +5 -0
  26. package/src/models/modeling_utils.js +2 -0
  27. package/src/models/models.js +10 -1
  28. package/src/models/nemotron_h/modeling_nemotron_h.js +5 -0
  29. package/src/models/processors.js +1 -0
  30. package/src/models/qwen2_vl/modeling_qwen2_vl.js +187 -136
  31. package/src/models/qwen2_vl/processing_qwen2_vl.js +5 -4
  32. package/src/models/registry.js +17 -0
  33. package/src/models/solar_open/modeling_solar_open.js +5 -0
  34. package/src/pipelines.js +1 -0
  35. package/src/utils/hub.js +4 -1
  36. package/src/utils/model_registry/get_file_metadata.js +1 -0
  37. package/types/configs.d.ts.map +1 -1
  38. package/types/image_processors_utils.d.ts +3 -2
  39. package/types/image_processors_utils.d.ts.map +1 -1
  40. package/types/models/{ast/modeling_ast.d.ts → audio_spectrogram_transformer/modeling_audio_spectrogram_transformer.d.ts} +1 -1
  41. package/types/models/audio_spectrogram_transformer/modeling_audio_spectrogram_transformer.d.ts.map +1 -0
  42. package/types/models/chmv2/image_processing_chmv2.d.ts +4 -0
  43. package/types/models/chmv2/image_processing_chmv2.d.ts.map +1 -0
  44. package/types/models/chmv2/modeling_chmv2.d.ts +6 -0
  45. package/types/models/chmv2/modeling_chmv2.d.ts.map +1 -0
  46. package/types/models/deepseek_v3/modeling_deepseek_v3.d.ts +8 -0
  47. package/types/models/deepseek_v3/modeling_deepseek_v3.d.ts.map +1 -0
  48. package/types/models/eurobert/modeling_eurobert.d.ts +36 -0
  49. package/types/models/eurobert/modeling_eurobert.d.ts.map +1 -0
  50. package/types/models/glm46v/image_processing_glm46v.d.ts +4 -0
  51. package/types/models/glm46v/image_processing_glm46v.d.ts.map +1 -0
  52. package/types/models/glm46v/processing_glm46v.d.ts +4 -0
  53. package/types/models/glm46v/processing_glm46v.d.ts.map +1 -0
  54. package/types/models/glm_moe_dsa/modeling_glm_moe_dsa.d.ts +8 -0
  55. package/types/models/glm_moe_dsa/modeling_glm_moe_dsa.d.ts.map +1 -0
  56. package/types/models/glm_ocr/modeling_glm_ocr.d.ts +26 -0
  57. package/types/models/glm_ocr/modeling_glm_ocr.d.ts.map +1 -0
  58. package/types/models/image_processors.d.ts +2 -0
  59. package/types/models/lighton_ocr/modeling_lighton_ocr.d.ts +4 -0
  60. package/types/models/lighton_ocr/modeling_lighton_ocr.d.ts.map +1 -0
  61. package/types/models/mistral4/modeling_mistral4.d.ts +8 -0
  62. package/types/models/mistral4/modeling_mistral4.d.ts.map +1 -0
  63. package/types/models/modeling_utils.d.ts.map +1 -1
  64. package/types/models/models.d.ts +10 -1
  65. package/types/models/nemotron_h/modeling_nemotron_h.d.ts +8 -0
  66. package/types/models/nemotron_h/modeling_nemotron_h.d.ts.map +1 -0
  67. package/types/models/processors.d.ts +1 -0
  68. package/types/models/qwen2_vl/modeling_qwen2_vl.d.ts +41 -6
  69. package/types/models/qwen2_vl/modeling_qwen2_vl.d.ts.map +1 -1
  70. package/types/models/qwen2_vl/processing_qwen2_vl.d.ts +1 -0
  71. package/types/models/qwen2_vl/processing_qwen2_vl.d.ts.map +1 -1
  72. package/types/models/registry.d.ts.map +1 -1
  73. package/types/models/solar_open/modeling_solar_open.d.ts +8 -0
  74. package/types/models/solar_open/modeling_solar_open.d.ts.map +1 -0
  75. package/types/pipelines.d.ts +1 -0
  76. package/types/pipelines.d.ts.map +1 -1
  77. package/types/utils/hub.d.ts.map +1 -1
  78. package/types/models/ast/modeling_ast.d.ts.map +0 -1
  79. /package/src/models/{ast/modeling_ast.js → audio_spectrogram_transformer/modeling_audio_spectrogram_transformer.js} +0 -0
@@ -1,27 +1,27 @@
1
- var kO=Object.defineProperty;var ps=(t=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(t,{get:(e,r)=>(typeof require<"u"?require:e)[r]}):t)(function(t){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+t+'" is not supported')});var Ys=(t,e)=>{for(var r in e)kO(t,r,{get:e[r],enumerable:!0})};import EO from"fs";import Js from"path";import AO from"url";var MO="4.0.0-next.7",Zp=typeof self<"u",Zs=!hk(EO),fk=!hk(Js),Dl=Zp&&"caches"in self,SO=typeof globalThis.Deno<"u",Qz=typeof globalThis.Bun<"u",Bl=SO&&Dl&&!Zs,_k=typeof process<"u",mk=_k&&process?.release?.name==="node"&&!Bl,ed=typeof window<"u"&&typeof window.document<"u",td=Zp&&["DedicatedWorkerGlobalScope","ServiceWorkerGlobalScope","SharedWorkerGlobalScope"].includes(self.constructor?.name),TO=ed||td||Bl,OO=mk||typeof navigator<"u"&&"gpu"in navigator,IO=typeof navigator<"u"&&"ml"in navigator,CO=typeof crypto<"u"&&typeof crypto.getRandomValues=="function",LO=typeof chrome<"u"&&typeof chrome.runtime<"u"&&typeof chrome.runtime.id=="string",PO=typeof ServiceWorkerGlobalScope<"u"&&Zp&&self instanceof ServiceWorkerGlobalScope,zO=()=>{if(typeof navigator>"u")return!1;let t=navigator.userAgent,r=(navigator.vendor||"").indexOf("Apple")>-1,s=!t.match(/CriOS|FxiOS|EdgiOS|OPiOS|mercury|brave/i)&&!t.includes("Chrome")&&!t.includes("Android");return r&&s},NO=zO(),ie=Object.freeze({IS_BROWSER_ENV:ed,IS_WEBWORKER_ENV:td,IS_WEB_ENV:TO,IS_SERVICE_WORKER_ENV:PO,IS_DENO_WEB_RUNTIME:Bl,IS_WEB_CACHE_AVAILABLE:Dl,IS_WEBGPU_AVAILABLE:OO,IS_WEBNN_AVAILABLE:IO,IS_SAFARI:NO,IS_PROCESS_AVAILABLE:_k,IS_NODE_ENV:mk,IS_FS_AVAILABLE:Zs,IS_PATH_AVAILABLE:fk,IS_CRYPTO_AVAILABLE:CO,IS_CHROME_AVAILABLE:LO}),rd=Zs&&fk,Fl="./";if(rd){let t=Object(import.meta).url;t?Fl=Js.dirname(Js.dirname(AO.fileURLToPath(t))):typeof __dirname<"u"&&(Fl=Js.dirname(__dirname))}var $O=rd?Js.join(Fl,"/.cache/"):null,pk="/models/",RO=rd?Js.join(Fl,pk):pk,DO=typeof globalThis.fetch=="function"?globalThis.fetch.bind(globalThis):void 0,Ot=Object.freeze({DEBUG:10,INFO:20,WARNING:30,ERROR:40,NONE:50}),dk=Ot.WARNING,_e={version:MO,backends:{onnx:{}},get logLevel(){return dk},set logLevel(t){dk=t,_e.backends.onnx?.setLogLevel?.(t)},allowRemoteModels:!0,remoteHost:"https://huggingface.co/",remotePathTemplate:"{model}/resolve/{revision}/",allowLocalModels:!(ed||td||Bl),localModelPath:RO,useFS:Zs,useBrowserCache:Dl,useFSCache:Zs,cacheDir:$O,useCustomCache:!1,customCache:null,useWasmCache:Dl||Zs,cacheKey:"transformers-cache",experimental_useCrossOriginStorage:!1,fetch:DO};function hk(t){return Object.keys(t).length===0}function xr(t,e){t&&t(e)}function gk(t){return Number.isInteger(t)||typeof t=="bigint"}function sd(t){return t==null||t===-1}function nd(t){let e=[],r=t;for(;Array.isArray(r);)e.push(r.length),r=r[0];return e}function wt(...t){return Array.prototype.concat.apply([],t)}function wk(...t){return t.reduce((e,r)=>e.flatMap(s=>r.map(n=>[s,n])))}function en(t,e){return Math.abs((t+e)%(2*e)-e)}function Qe(t,e){return Object.assign({},...e.map(r=>{if(t[r]!==void 0)return{[r]:t[r]}}))}function xk(t,e){let r=0;for(let s of t)s===e&&++r;return r}var Z={error(...t){_e.logLevel<=Ot.ERROR&&console.error(...t)},warn(...t){_e.logLevel<=Ot.WARNING&&console.warn(...t)},info(...t){_e.logLevel<=Ot.INFO&&console.log(...t)},debug(...t){_e.logLevel<=Ot.DEBUG&&console.log(...t)},log(...t){this.info(...t)}};var FO=class{constructor(t){this.trie=this._build_trie(t)}_build_trie(t){let e=Object.create(null);for(let r of t){let s=e;for(let n=0;n<r.length;++n){let o=r[n];s=s[o]??=Object.create(null)}s.end=r}return e}split(t){let e=[],r=t.length,s=0,n=0;for(;n<r;){let o=this.trie,a=null,i=n;for(;i<r&&(o=o[t[i]]);)o.end&&(a=o.end),++i;a?(n>s&&e.push(t.slice(s,n)),e.push(a),n+=a.length,s=n):++n}return s<r&&e.push(t.slice(s)),e}},yk=FO,BO=class{constructor(t){this.content=t.content,this.id=t.id,this.single_word=t.single_word??!1,this.lstrip=t.lstrip??!1,this.rstrip=t.rstrip??!1,this.special=t.special??!1,this.normalized=t.normalized??!this.special}},UO=BO,Sk=(()=>{let t=[...Array.from({length:94},(n,o)=>o+33),...Array.from({length:12},(n,o)=>o+161),...Array.from({length:82},(n,o)=>o+174)],e=t.slice(),r=0;for(let n=0;n<256;++n)t.includes(n)||(t.push(n),e.push(256+r),r+=1);let s=e.map(n=>String.fromCharCode(n));return Object.fromEntries(t.map((n,o)=>[n,s[o]]))})(),jO=t=>Object.fromEntries(Object.entries(t).map(([e,r])=>[r,e])),GO=jO(Sk),bk=".,!?\u2026\u3002\uFF0C\u3001\u0964\u06D4\u060C",qO=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|[${bk}])]+`,` ?[^\\s${bk}]+`]]),Ul="\\p{P}\\u0021-\\u002F\\u003A-\\u0040\\u005B-\\u0060\\u007B-\\u007E",ad=t=>t.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"),jl=(t,e=!0)=>{if(t.Regex!==void 0){let r=t.Regex.replace(/\\([#&~])/g,"$1");r=r.replace(/\\A/g,"^").replace(/\\z/g,"$").replace(/\\Z/g,"(?=\\r?\\n?$)");for(let[s,n]of qO)r=r.replaceAll(s,n);try{return new RegExp(r,"gu")}catch(s){if(!(s instanceof SyntaxError)||!s.message.toLowerCase().includes("invalid property name"))throw s;let n=!1,o=r.replace(/(\\[pP])\{([^}=]+)\}/g,(a,i,l)=>{try{return new RegExp(`\\p{${l}}`,"u"),`${i}{${l}}`}catch{return n=!0,`${i}{Script=${l}}`}});if(!n)throw s;try{return new RegExp(o,"gu")}catch{throw s}}}else if(t.String!==void 0){let r=WO(t.String);return new RegExp(e?r:`(${r})`,"gu")}else return console.warn("Unknown pattern type:",t),null},WO=t=>t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"),VO=(t,e,r)=>{let s=[],n=0;for(;n<t.length;){if(s.push(t[n]),(e.get(t[n])??r)!==r){++n;continue}for(;++n<t.length&&(e.get(t[n])??r)===r;)e.get(s.at(-1))!==r&&(s[s.length-1]+=t[n])}return s},HO=t=>t>=19968&&t<=40959||t>=13312&&t<=19903||t>=131072&&t<=173791||t>=173824&&t<=177983||t>=177984&&t<=178207||t>=178208&&t<=183983||t>=63744&&t<=64255||t>=194560&&t<=195103,XO=t=>Number.isInteger(t)||typeof t=="bigint",KO=t=>{let e=0;for(let r of t)++e;return e},QO=t=>Tk(t.toLowerCase()),Xt=(...t)=>Array.prototype.concat.apply([],t),id=t=>new Map(Object.entries(t)),YO=(t,e)=>{let r=[],s=0;for(let n of t.matchAll(e)){let o=n[0];s<n.index&&r.push(t.slice(s,n.index)),o.length>0&&r.push(o),s=n.index+o.length}return s<t.length&&r.push(t.slice(s)),r},Tk=t=>t.replace(/\p{M}/gu,""),vk=(t,e,r=[])=>{if(!t||Array.isArray(t)||typeof t!="object")return`${e} must be a valid object`;for(let s of r)if(!(s in t))return`${e} must contain a "${s}" property`;return null},JO=t=>t.match(/\S+/g)||[],ZO=class{constructor(){let t=function(...e){return t._call(...e)};return Object.setPrototypeOf(t,new.target.prototype)}},so=ZO,eI=class extends so{constructor(t){super(),this.config=t}_call(t){return this.normalize(t)}},yr=eI,tI=class extends yr{tokenize_chinese_chars(t){let e=[];for(let r=0;r<t.length;++r){let s=t[r],n=s.charCodeAt(0);HO(n)?(e.push(" "),e.push(s),e.push(" ")):e.push(s)}return e.join("")}strip_accents(t){return t.normalize("NFD").replace(/\p{Mn}/gu,"")}is_control(t){switch(t){case" ":case`
2
- `:case"\r":return!1;default:return/^\p{Cc}|\p{Cf}|\p{Co}|\p{Cs}$/u.test(t)}}clean_text(t){let e=[];for(let r of t){let s=r.charCodeAt(0);s===0||s===65533||this.is_control(r)||(/^\s$/.test(r)?e.push(" "):e.push(r))}return e.join("")}normalize(t){return this.config.clean_text&&(t=this.clean_text(t)),this.config.handle_chinese_chars&&(t=this.tokenize_chinese_chars(t)),this.config.lowercase?(t=t.toLowerCase(),this.config.strip_accents!==!1&&(t=this.strip_accents(t))):this.config.strip_accents&&(t=this.strip_accents(t)),t}},rI=tI,sI=class extends yr{constructor(t){super(t),this.charsmap=t.precompiled_charsmap??null}normalize(t){return t=t.replace(/[\u0001-\u0008\u000B\u000E-\u001F\u007F\u008F\u009F]/gm,""),t=t.replace(/[\u0009\u000A\u000C\u000D\u00A0\u1680\u2000-\u200F\u2028\u2029\u202F\u205F\u2581\u3000\uFEFF\uFFFD]/gm," "),t.includes("\uFF5E")?t=t.split("\uFF5E").map(r=>r.normalize("NFKC")).join("\uFF5E"):t=t.normalize("NFKC"),t}},nI=sI,oI=class extends yr{constructor(t){super(t),this.normalizers=(t.normalizers??[]).map(e=>Ok(e))}normalize(t){return this.normalizers.reduce((e,r)=>r?r.normalize(e):e,t)}},aI=oI,iI=class extends yr{normalize(t){let e=jl(this.config.pattern??{});return e===null?t:t.replaceAll(e,this.config.content??"")}},lI=iI,cI=class extends yr{constructor(){super(...arguments),this.form="NFC"}normalize(t){return t=t.normalize(this.form),t}},Gl=cI,uI=class extends Gl{constructor(){super(...arguments),this.form="NFC"}},pI=uI,dI=class extends Gl{constructor(){super(...arguments),this.form="NFD"}},fI=dI,_I=class extends Gl{constructor(){super(...arguments),this.form="NFKC"}},mI=_I,hI=class extends Gl{constructor(){super(...arguments),this.form="NFKD"}},gI=hI,wI=class extends yr{normalize(t){return this.config.strip_left&&this.config.strip_right?t=t.trim():(this.config.strip_left&&(t=t.trimStart()),this.config.strip_right&&(t=t.trimEnd())),t}},xI=wI,yI=class extends yr{normalize(t){return Tk(t)}},bI=yI,vI=class extends yr{normalize(t){return t.toLowerCase()}},kI=vI,EI=class extends yr{normalize(t){return t=this.config.prepend+t,t}},AI=EI;function MI(t){if(t===null)return null;switch(t.type){case"BertNormalizer":return new rI(t);case"Precompiled":return new nI(t);case"Sequence":return new aI(t);case"Replace":return new lI(t);case"NFC":return new pI(t);case"NFD":return new fI(t);case"NFKC":return new mI(t);case"NFKD":return new gI(t);case"Strip":return new xI(t);case"StripAccents":return new bI(t);case"Lowercase":return new kI(t);case"Prepend":return new AI(t);default:throw new Error(`Unknown Normalizer type: ${t.type}`)}}var Ok=MI,SI=class extends so{pre_tokenize(t,e){return(Array.isArray(t)?t.map(r=>this.pre_tokenize_text(r,e)):this.pre_tokenize_text(t,e)).flat()}_call(t,e){return this.pre_tokenize(t,e)}},Kt=SI,TI=class extends Kt{constructor(t){super(),this.config=t,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=/'s|'t|'re|'ve|'m|'ll|'d| ?\p{L}+| ?\p{N}+| ?[^\s\p{L}\p{N}]+|\s+(?!\S)|\s+/gu,this.byte_encoder=Sk,this.text_encoder=new TextEncoder}pre_tokenize_text(t,e){return this.add_prefix_space&&!t.startsWith(" ")&&(t=" "+t),(this.use_regex?t.match(this.pattern)||[]:[t]).map(s=>Array.from(this.text_encoder.encode(s),n=>this.byte_encoder[n]).join(""))}},OI=TI,II=class extends Kt{pre_tokenize_text(t,e){return t.match(/\w+|[^\w\s]+/g)||[]}},CI=II,LI=class extends Kt{constructor(t){super(),this.replacement=t.replacement??"\u2581",this.str_rep=t.str_rep||this.replacement,this.prepend_scheme=t.prepend_scheme??"always"}pre_tokenize_text(t,e){let{section_index:r=void 0}=e??{},s=t.replaceAll(" ",this.str_rep);return!s.startsWith(this.replacement)&&(this.prepend_scheme==="always"||this.prepend_scheme==="first"&&r===0)&&(s=this.str_rep+s),[s]}},PI=LI,zI=class extends Kt{constructor(t){super(),this.config=t,this.pattern=jl(this.config.pattern??{},this.config.invert??!0)}pre_tokenize_text(t){return this.pattern===null?[]:this.config.invert?t.match(this.pattern)||[]:this.config.behavior?.toLowerCase()==="removed"?t.split(this.pattern).filter(e=>e):YO(t,this.pattern)}},NI=zI,$I=class extends Kt{constructor(t){super(),this.config=t,this.pattern=new RegExp(`[^${Ul}]+|[${Ul}]+`,"gu")}pre_tokenize_text(t){return t.match(this.pattern)||[]}},RI=$I,DI=class extends Kt{constructor(t){super(),this.config=t;let e=`[^\\d]+|\\d${this.config.individual_digits?"":"+"}`;this.pattern=new RegExp(e,"gu")}pre_tokenize_text(t){return t.match(this.pattern)||[]}},FI=DI,BI=class extends Kt{constructor(){super(),this.pattern=new RegExp(`[^\\s${Ul}]+|[${Ul}]`,"gu")}pre_tokenize_text(t,e){return t.trim().match(this.pattern)||[]}},UI=BI,jI=class extends Kt{constructor(t){super(),this.config=t,this.pattern=jl(this.config.pattern??{}),this.content=this.config.content??""}pre_tokenize_text(t){return this.pattern===null?[t]:[t.replaceAll(this.pattern,this.config.content??"")]}},GI=jI,qI=class extends Kt{constructor(t){super(),this.tokenizers=(t.pretokenizers??[]).map(e=>Ik(e))}pre_tokenize_text(t,e){return this.tokenizers.reduce((r,s)=>s?s.pre_tokenize(r,e):r,[t])}},WI=qI,VI=class extends Kt{pre_tokenize_text(t){return JO(t)}},HI=VI,XI=class extends Kt{constructor(t){super(),this.config=t,this._length=t.length}pre_tokenize_text(t){let e=[];for(let r=0;r<t.length;r+=this._length)e.push(t.slice(r,r+this._length));return e}},KI=XI;function QI(t){if(t===null)return null;switch(t.type){case"BertPreTokenizer":return new UI;case"Sequence":return new WI(t);case"Whitespace":return new CI;case"WhitespaceSplit":return new HI;case"Metaspace":return new PI(t);case"ByteLevel":return new OI(t);case"Split":return new NI(t);case"Punctuation":return new RI(t);case"Digits":return new FI(t);case"Replace":return new GI(t);case"FixedLength":return new KI(t);default:throw new Error(`Unknown PreTokenizer type: ${t.type}`)}}var Ik=QI,YI=class extends so{constructor(t){super(),this.config=t,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(t){let e=this.encode(t);return this.fuse_unk&&(e=VO(e,this.tokens_to_ids,this.unk_token_id)),e}},ql=YI,JI=class extends ql{constructor(t){super(t),this.max_input_chars_per_word=100,this.tokens_to_ids=id(t.vocab),this.unk_token_id=this.tokens_to_ids.get(t.unk_token),this.unk_token=t.unk_token,this.max_input_chars_per_word=t.max_input_chars_per_word??100,this.vocab=new Array(this.tokens_to_ids.size);for(let[e,r]of this.tokens_to_ids)this.vocab[r]=e}encode(t){let e=[];for(let r of t){let s=[...r];if(s.length>this.max_input_chars_per_word){e.push(this.unk_token);continue}let n=!1,o=0,a=[];for(;o<s.length;){let i=s.length,l=null;for(;o<i;){let c=s.slice(o,i).join("");if(o>0&&(c=this.config.continuing_subword_prefix+c),this.tokens_to_ids.has(c)){l=c;break}--i}if(l===null){n=!0;break}a.push(l),o=i}n?e.push(this.unk_token):e.push(...a)}return e}},kk=JI,Ek=class Ck{constructor(e,r){this.is_leaf=e,this.children=r}static default(){return new Ck(!1,new Map)}},ZI=class{constructor(){this.root=Ek.default()}extend(t){for(let e of t)this.push(e)}push(t){let e=this.root;for(let r of t){let s=e.children.get(r);s===void 0&&(s=Ek.default(),e.children.set(r,s)),e=s}e.is_leaf=!0}*common_prefix_search(t){let e=this.root;if(e===void 0)return;let r="";for(let s of t){if(r+=s,e=e.children.get(s),e===void 0)return;e.is_leaf&&(yield r)}}},eC=ZI,od=class Lk{constructor(e,r,s,n,o){this.token_id=e,this.node_id=r,this.pos=s,this.length=n,this.score=o,this.prev=null,this.backtrace_score=0}clone(){let e=new Lk(this.token_id,this.node_id,this.pos,this.length,this.score);return e.prev=this.prev,e.backtrace_score=this.backtrace_score,e}},tC=class{constructor(t,e,r){this.chars=Array.from(t),this.len=this.chars.length,this.bos_token_id=e,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},()=>[]);let s=new od(this.bos_token_id??0,0,0,0,0),n=new od(this.eos_token_id??0,1,this.len,0,0);this.nodes.push(s.clone()),this.nodes.push(n.clone()),this.begin_nodes[this.len].push(n),this.end_nodes[0].push(s)}insert(t,e,r,s){let n=this.nodes.length,o=new od(s,n,t,e,r);this.begin_nodes[t].push(o),this.end_nodes[t+e].push(o),this.nodes.push(o)}viterbi(){let t=this.len,e=0;for(;e<=t;){if(this.begin_nodes[e].length==0)return[];for(let a of this.begin_nodes[e]){a.prev=null;let i=0,l=null;for(let c of this.end_nodes[e]){let p=c.backtrace_score+a.score;(l===null||p>i)&&(l=c.clone(),i=p)}if(l!==null)a.prev=l,a.backtrace_score=i;else return[]}++e}let r=[],n=this.begin_nodes[t][0].prev;if(n===null)return[];let o=n.clone();for(;o.prev!==null;)r.push(o.clone()),o=o.clone().prev.clone();return r.reverse(),r}piece(t){return this.chars.slice(t.pos,t.pos+t.length).join("")}tokens(){return this.viterbi().map(e=>this.piece(e))}token_ids(){return this.viterbi().map(e=>e.token_id)}},rC=tC;function sC(t){if(t.length===0)throw new Error("Array must not be empty");let e=t[0],r=0;for(let s=1;s<t.length;++s)t[s]<e&&(e=t[s],r=s);return[e,r]}var nC=class extends ql{constructor(t,e){super(t);let r=t.vocab.length;this.vocab=new Array(r),this.scores=new Array(r);for(let s=0;s<r;++s)[this.vocab[s],this.scores[s]]=t.vocab[s];this.unk_token_id=t.unk_id,this.unk_token=this.vocab[t.unk_id],this.tokens_to_ids=new Map(this.vocab.map((s,n)=>[s,n])),this.bos_token=" ",this.bos_token_id=this.tokens_to_ids.get(this.bos_token),this.eos_token=e,this.eos_token_id=this.tokens_to_ids.get(this.eos_token),this.unk_token=this.vocab[this.unk_token_id],this.min_score=sC(this.scores)[0],this.unk_score=this.min_score-10,this.scores[this.unk_token_id]=this.unk_score,this.trie=new eC,this.trie.extend(this.vocab),this.fuse_unk=!0}populate_nodes(t){let e=t.chars,r=1,s=0;for(;s<e.length;){let n=!1,o=[],a=e.slice(s).join(""),i=this.trie.common_prefix_search(a);for(let l of i){o.push(l);let c=this.tokens_to_ids.get(l),p=this.scores[c],f=KO(l);t.insert(s,f,p,c),!n&&f===r&&(n=!0)}n||t.insert(s,r,this.unk_score,this.unk_token_id),s+=r}}tokenize(t){let e=new rC(t,this.bos_token_id,this.eos_token_id);return this.populate_nodes(e),e.tokens()}encode(t){let e=[];for(let r of t){let s=this.tokenize(r);e.push(...s)}return e}},Ak=nC,oC=class{constructor(t=(r,s)=>r>s,e=1/0){this._heap=[],this._comparator=t,this._max_size=e}get size(){return this._heap.length}is_empty(){return this.size===0}peek(){return this._heap[0]}push(...t){return this.extend(t)}extend(t){for(let e of t)if(this.size<this._max_size)this._heap.push(e),this._sift_up();else{let r=this._smallest();this._comparator(e,this._heap[r])&&(this._heap[r]=e,this._sift_up_from(r))}return this.size}pop(){let t=this.peek(),e=this.size-1;return e>0&&this._swap(0,e),this._heap.pop(),this._sift_down(),t}replace(t){let e=this.peek();return this._heap[0]=t,this._sift_down(),e}_parent(t){return(t+1>>>1)-1}_left(t){return(t<<1)+1}_right(t){return t+1<<1}_greater(t,e){return this._comparator(this._heap[t],this._heap[e])}_swap(t,e){let r=this._heap[t];this._heap[t]=this._heap[e],this._heap[e]=r}_sift_up(){this._sift_up_from(this.size-1)}_sift_up_from(t){for(;t>0&&this._greater(t,this._parent(t));)this._swap(t,this._parent(t)),t=this._parent(t)}_sift_down(){let t=0;for(;this._left(t)<this.size&&this._greater(this._left(t),t)||this._right(t)<this.size&&this._greater(this._right(t),t);){let e=this._right(t)<this.size&&this._greater(this._right(t),this._left(t))?this._right(t):this._left(t);this._swap(t,e),t=e}}_smallest(){return 2**Math.floor(Math.log2(this.size))-1}},aC=oC,iC=class{constructor(t){this.capacity=t,this.cache=new Map}get(t){if(!this.cache.has(t))return;let e=this.cache.get(t);return this.cache.delete(t),this.cache.set(t,e),e}put(t,e){this.cache.has(t)&&this.cache.delete(t),this.cache.set(t,e),this.cache.size>this.capacity&&this.cache.delete(this.cache.keys().next().value)}clear(){this.cache.clear()}},lC=iC,cC=class extends ql{constructor(t){super(t),this.tokens_to_ids=id(t.vocab),this.unk_token_id=this.tokens_to_ids.get(t.unk_token),this.unk_token=t.unk_token,this.vocab=new Array(this.tokens_to_ids.size);for(let[r,s]of this.tokens_to_ids)this.vocab[s]=r;let e=Array.isArray(t.merges[0]);this.merges=e?t.merges:t.merges.map(r=>r.split(" ",2)),this.bpe_ranks=new Map(this.merges.map((r,s)=>[JSON.stringify(r),s])),this.end_of_word_suffix=t.end_of_word_suffix,this.continuing_subword_suffix=t.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 lC(this.cache_capacity)}clear_cache(){this.cache.clear()}bpe(t){if(t.length===0)return[];let e=this.cache.get(t);if(e!==void 0)return e;let r=Array.from(t);this.end_of_word_suffix&&(r[r.length-1]+=this.end_of_word_suffix);let s=[];if(r.length>1){let n=new aC((i,l)=>i.score<l.score),o={token:r[0],bias:0,prev:null,next:null},a=o;for(let i=1;i<r.length;++i){let l={bias:i/r.length,token:r[i],prev:a,next:null};a.next=l,this.add_node(n,a),a=l}for(;!n.is_empty();){let i=n.pop();if(i.deleted||!i.next||i.next.deleted)continue;if(i.deleted=!0,i.next.deleted=!0,i.prev){let c={...i.prev};i.prev.deleted=!0,i.prev=c,c.prev?c.prev.next=c:o=c}let 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(n,l.prev)):o=l,l.next&&(l.next.prev=l,this.add_node(n,l))}for(let i=o;i!==null;i=i.next)s.push(i.token)}else s=r;if(this.continuing_subword_suffix)for(let n=0;n<s.length-1;++n)s[n]+=this.continuing_subword_suffix;return t.length<this.max_length_to_cache&&this.cache.put(t,s),s}add_node(t,e){let r=this.bpe_ranks.get(JSON.stringify([e.token,e.next.token]));r!==void 0&&(e.score=r+e.bias,t.push(e))}encode(t){let e=[];for(let r of t){if(this.ignore_merges&&this.tokens_to_ids.has(r)){e.push(r);continue}let s=this.bpe(r);for(let n of s)if(this.tokens_to_ids.has(n))e.push(n);else if(this.byte_fallback){let o=Array.from(this.text_encoder.encode(n)).map(a=>`<0x${a.toString(16).toUpperCase().padStart(2,"0")}>`);o.every(a=>this.tokens_to_ids.has(a))?e.push(...o):e.push(this.unk_token)}else e.push(this.unk_token)}return e}},Mk=cC,uC=class extends ql{constructor(t,e){super(t);let r=t.vocab;this.tokens_to_ids=id(e.target_lang?r[e.target_lang]:r),this.bos_token=e.bos_token,this.bos_token_id=this.tokens_to_ids.get(this.bos_token),this.eos_token=e.eos_token,this.eos_token_id=this.tokens_to_ids.get(this.eos_token),this.pad_token=e.pad_token,this.pad_token_id=this.tokens_to_ids.get(this.pad_token),this.unk_token=e.unk_token,this.unk_token_id=this.tokens_to_ids.get(this.unk_token),this.vocab=new Array(this.tokens_to_ids.size);for(let[s,n]of this.tokens_to_ids)this.vocab[n]=s}encode(t){return t}},pC=uC;function dC(t,e){switch(t.type){case"WordPiece":return new kk(t);case"Unigram":return new Ak(t,e.eos_token);case"BPE":return new Mk(t);default:if(t.vocab)return Array.isArray(t.vocab)?new Ak(t,e.eos_token):Object.hasOwn(t,"continuing_subword_prefix")&&Object.hasOwn(t,"unk_token")?Object.hasOwn(t,"merges")?new Mk(t):new kk(t):new pC(t,{target_lang:e.target_lang,bos_token:e.bos_token,eos_token:e.eos_token,pad_token:e.pad_token,unk_token:e.unk_token});throw new Error(`Unknown TokenizerModel type: ${t?.type}`)}}var fC=dC,_C=class extends so{constructor(t){super(),this.config=t}_call(t,...e){return this.post_process(t,...e)}},no=_C,mC=class extends no{post_process(t,e=null,r=!0){let s=e===null?this.config.single:this.config.pair,n=[],o=[];for(let a of s)"SpecialToken"in a?r&&(n.push(a.SpecialToken.id),o.push(a.SpecialToken.type_id)):"Sequence"in a&&(a.Sequence.id==="A"?(n=Xt(n,t),o=Xt(o,new Array(t.length).fill(a.Sequence.type_id))):a.Sequence.id==="B"&&(n=Xt(n,e),o=Xt(o,new Array(e.length).fill(a.Sequence.type_id))));return{tokens:n,token_type_ids:o}}},hC=mC,gC=class extends no{post_process(t,e=null){return{tokens:t,tokens_pair:e}}},wC=gC,xC=class extends no{constructor(t){super(t),this.sep=t.sep,this.cls=t.cls}post_process(t,e=null,r=!0){r&&(t=Xt([this.cls[0]],t,[this.sep[0]]));let s=new Array(t.length).fill(0);if(e){let n=[],o=r?[this.sep[0]]:[];t=Xt(t,n,e,o),s=Xt(s,new Array(e.length+n.length+o.length).fill(1))}return{tokens:t,token_type_ids:s}}},yC=xC,bC=class extends no{constructor(t){super(t),this.sep=t.sep,this.cls=t.cls}post_process(t,e,r=!0){r&&(t=Xt([this.cls[0]],t,[this.sep[0]]));let s=new Array(t.length).fill(0);if(e){let n=r?[this.sep[0]]:[],o=r?[this.sep[0]]:[];t=Xt(t,n,e,o),s=Xt(s,new Array(e.length+n.length+o.length).fill(1))}return{tokens:t,token_type_ids:s}}},vC=bC,kC=class extends no{constructor(t){super(t),this.processors=(t.processors??[]).map(e=>Pk(e))}post_process(t,e=null,r=!0){let s={tokens:t,tokens_pair:e};for(let n of this.processors)s=n.post_process(s.tokens,s.tokens_pair,r);return s}},EC=kC;function AC(t){if(t===null)return null;switch(t.type){case"TemplateProcessing":return new hC(t);case"ByteLevel":return new wC(t);case"BertProcessing":return new yC(t);case"RobertaProcessing":return new vC(t);case"Sequence":return new EC(t);default:throw new Error(`Unknown PostProcessor type: ${t.type}`)}}var Pk=AC,MC=class extends so{constructor(t){super(),this.config=t,this.added_tokens=[],this.end_of_word_suffix=null,this.trim_offsets="trim_offsets"in t?t.trim_offsets:!1}_call(t){return this.decode(t)}decode(t){return this.decode_chain(t).join("")}},Dt=MC,SC=class extends Dt{constructor(t){super(t),this.byte_decoder=GO,this.text_decoder=new TextDecoder("utf-8",{fatal:!1,ignoreBOM:!0}),this.end_of_word_suffix=null}convert_tokens_to_string(t){let e=t.join(""),r=new Uint8Array([...e].map(s=>this.byte_decoder[s]));return this.text_decoder.decode(r)}decode_chain(t){let e=[],r=[];for(let s of t)this.added_tokens.find(n=>n.content===s)!==void 0?(r.length>0&&(e.push(this.convert_tokens_to_string(r)),r=[]),e.push(s)):r.push(s);return r.length>0&&e.push(this.convert_tokens_to_string(r)),e}},TC=SC,OC=class extends Dt{constructor(t){super(t),this.cleanup=t.cleanup}decode_chain(t){return t.map((e,r)=>{if(r!==0){let s=this.config.prefix;s&&e.startsWith(s)?e=e.replace(s,""):e=" "+e}return this.cleanup&&(e=ad(e)),e})}},IC=OC,CC=class extends Dt{constructor(t){super(t),this.replacement=t.replacement??"\u2581"}decode_chain(t){let e=[];for(let r=0;r<t.length;++r){let s=t[r].replaceAll(this.replacement," ");r==0&&s.startsWith(" ")&&(s=s.substring(1)),e.push(s)}return e}},LC=CC,PC=class extends Dt{constructor(t){super(t),this.suffix=t.suffix??""}decode_chain(t){return t.map((e,r)=>e.replaceAll(this.suffix,r===t.length-1?"":" "))}},zC=PC,NC=class extends Dt{constructor(t){super(t),this.pad_token=t.pad_token??"",this.word_delimiter_token=t.word_delimiter_token??"",this.cleanup=t.cleanup}convert_tokens_to_string(t){if(t.length===0)return"";let e=[t[0]];for(let n=1;n<t.length;++n)t[n]!==e.at(-1)&&e.push(t[n]);let s=e.filter(n=>n!==this.pad_token).join("");return this.cleanup&&(s=ad(s).replaceAll(this.word_delimiter_token," ").trim()),s}decode_chain(t){return[this.convert_tokens_to_string(t)]}},$C=NC,RC=class extends Dt{constructor(t){super(t),this.decoders=(t.decoders??[]).map(e=>zk(e))}decode_chain(t){return this.decoders.reduce((e,r)=>r.decode_chain(e),t)}},DC=RC,FC=class extends Dt{decode_chain(t){let e=jl(this.config.pattern),r=this.config.content??"";return e===null?t:t.map(s=>s.replaceAll(e,r))}},BC=FC,UC=class extends Dt{decode_chain(t){return[t.join("")]}},jC=UC,GC=class extends Dt{constructor(t){super(t),this.content=t.content??"",this.start=t.start??0,this.stop=t.stop??0}decode_chain(t){return t.map(e=>{let r=0;for(let n=0;n<this.start&&e[n]===this.content;++n){r=n+1;continue}let s=e.length;for(let n=0;n<this.stop;++n){let o=e.length-n-1;if(e[o]===this.content){s=o;continue}else break}return e.slice(r,s)})}},qC=GC,WC=class extends Dt{constructor(t){super(t),this.text_decoder=new TextDecoder}decode_chain(t){let e=[],r=[];for(let s of t){let n=null;if(s.length===6&&s.startsWith("<0x")&&s.endsWith(">")){let o=parseInt(s.slice(3,5),16);isNaN(o)||(n=o)}if(n!==null)r.push(n);else{if(r.length>0){let o=this.text_decoder.decode(Uint8Array.from(r));e.push(o),r=[]}e.push(s)}}if(r.length>0){let s=this.text_decoder.decode(Uint8Array.from(r));e.push(s),r=[]}return e}},VC=WC;function HC(t){if(t===null)return null;switch(t.type){case"ByteLevel":return new TC(t);case"WordPiece":return new IC(t);case"Metaspace":return new LC(t);case"BPEDecoder":return new zC(t);case"CTC":return new $C(t);case"Sequence":return new DC(t);case"Replace":return new BC(t);case"Fuse":return new jC(t);case"Strip":return new qC(t);case"ByteFallback":return new VC(t);default:throw new Error(`Unknown Decoder type: ${t.type}`)}}var zk=HC,XC=class{constructor(t,e){let r=vk(t,"Tokenizer",["model","decoder","post_processor","pre_tokenizer","normalizer"]);if(r)throw new Error(r);let s=vk(e,"Config");if(s)throw new Error(s);this.tokenizer=t,this.config=e,this.normalizer=Ok(this.tokenizer.normalizer),this.pre_tokenizer=Ik(this.tokenizer.pre_tokenizer),this.model=fC(this.tokenizer.model,this.config),this.post_processor=Pk(this.tokenizer.post_processor),this.decoder=zk(this.tokenizer.decoder),this.special_tokens=[],this.all_special_ids=[],this.added_tokens=[];let n=[],o=[];this.added_tokens_map=new Map;for(let a of this.tokenizer.added_tokens){let i=new UO(a);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){let l=this.normalizer(i.content);o.push(l),this.added_tokens_map.set(l,i)}else n.push(i.content)}(this.config.additional_special_tokens??[]).forEach(a=>{this.special_tokens.includes(a)||this.special_tokens.push(a)}),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 yk(n),this.splitter_normalized=new yk(o),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(t,{text_pair:e=null,add_special_tokens:r=!0,return_token_type_ids:s=null}={}){let{tokens:n,token_type_ids:o}=this.tokenize_helper(t,{text_pair:e,add_special_tokens:r}),a=n.map(l=>this.added_tokens_map.get(l)?.id??this.model.tokens_to_ids.get(l)??this.model.unk_token_id),i={ids:a,tokens:n,attention_mask:new Array(a.length).fill(1)};return s&&o&&(i.token_type_ids=o),i}decode(t,e={}){if(!Array.isArray(t)||t.length===0||!XO(t[0]))throw Error("token_ids must be a non-empty array of integers.");let r=t.map(n=>this.model.vocab[Number(n)]??this.model.unk_token);e.skip_special_tokens&&(r=r.filter(n=>!this.special_tokens.includes(n)));let s=this.decoder?this.decoder(r):r.join(" ");return this.decoder&&this.decoder.end_of_word_suffix&&(s=s.replaceAll(this.decoder.end_of_word_suffix," "),e.skip_special_tokens&&(s=s.trim())),(e.clean_up_tokenization_spaces??this.clean_up_tokenization_spaces)&&(s=ad(s)),s}tokenize(t,{text_pair:e=null,add_special_tokens:r=!1}={}){return this.tokenize_helper(t,{text_pair:e,add_special_tokens:r}).tokens}encode_text(t){if(t===null)return null;let e=this.splitter_unnormalized.split(t);return e.forEach((r,s)=>{let n=this.added_tokens_map.get(r);n&&(n.lstrip&&s>0&&(e[s-1]=e[s-1].trimEnd()),n.rstrip&&s<e.length-1&&(e[s+1]=e[s+1].trimStart()))}),e.flatMap((r,s)=>{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=QO(r)),this.normalizer!==null&&(r=this.normalizer(r)),r.length===0)return[];let n=this.splitter_normalized.split(r);return n.forEach((o,a)=>{let i=this.added_tokens_map.get(o);i&&(i.lstrip&&a>0&&(n[a-1]=n[a-1].trimEnd()),i.rstrip&&a<n.length-1&&(n[a+1]=n[a+1].trimStart()))}),n.flatMap(o=>{if(o.length===0)return[];if(this.added_tokens_map.has(o))return[o];let a=this.pre_tokenizer!==null?this.pre_tokenizer(o,{section_index:s}):[o];return this.model(a)})})}tokenize_helper(t,{text_pair:e=null,add_special_tokens:r=!0}){let s=this.encode_text(t),n=this.encode_text(e||null);return this.post_processor?this.post_processor(s,n,r):{tokens:Xt(s??[],n??[])}}token_to_id(t){return this.model.tokens_to_ids.get(t)}id_to_token(t){return this.model.vocab[t]}get_added_tokens_decoder(){let t=new Map;for(let e of this.added_tokens)t.set(e.id,e);return t}get_vocab(t=!0){let e=new Map;for(let r=0;r<this.model.vocab.length;++r){let s=this.model.vocab[r];(t||!this.added_tokens_map.has(s))&&e.set(s,r)}return e}},Nk=XC;var D=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"}),Ft=class{constructor(t,e){this.value=t,this.type=e}};function $k(t){return/\w/.test(t)}function oo(t){return/[0-9]/.test(t)}function Rk(t){return/\s/.test(t)}var KC=[["{%",D.OpenStatement],["%}",D.CloseStatement],["{{",D.OpenExpression],["}}",D.CloseExpression],["(",D.OpenParen],[")",D.CloseParen],["{",D.OpenCurlyBracket],["}",D.CloseCurlyBracket],["[",D.OpenSquareBracket],["]",D.CloseSquareBracket],[",",D.Comma],[".",D.Dot],[":",D.Colon],["|",D.Pipe],["<=",D.ComparisonBinaryOperator],[">=",D.ComparisonBinaryOperator],["==",D.ComparisonBinaryOperator],["!=",D.ComparisonBinaryOperator],["<",D.ComparisonBinaryOperator],[">",D.ComparisonBinaryOperator],["+",D.AdditiveBinaryOperator],["-",D.AdditiveBinaryOperator],["~",D.AdditiveBinaryOperator],["*",D.MultiplicativeBinaryOperator],["/",D.MultiplicativeBinaryOperator],["%",D.MultiplicativeBinaryOperator],["=",D.Equals]],QC=new Map([["n",`
3
- `],["t"," "],["r","\r"],["b","\b"],["f","\f"],["v","\v"],["'","'"],['"','"'],["\\","\\"]]);function YC(t,e={}){return t.endsWith(`
4
- `)&&(t=t.slice(0,-1)),e.lstrip_blocks&&(t=t.replace(/^[ \t]*({[#%-])/gm,"$1")),e.trim_blocks&&(t=t.replace(/([#%-]})\n/g,"$1")),t.replace(/{%\s*(end)?generation\s*%}/gs,"")}function JC(t,e={}){let r=[],s=YC(t,e),n=0,o=0,a=c=>{let p="";for(;c(s[n]);){if(s[n]==="\\"){if(++n,n>=s.length)throw new SyntaxError("Unexpected end of input");let f=s[n++],_=QC.get(f);if(_===void 0)throw new SyntaxError(`Unexpected escaped character: ${f}`);p+=_;continue}if(p+=s[n++],n>=s.length)throw new SyntaxError("Unexpected end of input")}return p},i=()=>{let c=r.at(-1);c&&c.type===D.Text&&(c.value=c.value.trimEnd(),c.value===""&&r.pop())},l=()=>{for(;n<s.length&&Rk(s[n]);)++n};e:for(;n<s.length;){let c=r.at(-1)?.type;if(c===void 0||c===D.CloseStatement||c===D.CloseExpression||c===D.Comment){let f="";for(;n<s.length&&!(s[n]==="{"&&(s[n+1]==="%"||s[n+1]==="{"||s[n+1]==="#"));)f+=s[n++];if(f.length>0){r.push(new Ft(f,D.Text));continue}}if(s[n]==="{"&&s[n+1]==="#"){n+=2;let f=s[n]==="-";f&&++n;let _="";for(;s[n]!=="#"||s[n+1]!=="}";){if(n+2>=s.length)throw new SyntaxError("Missing end of comment tag");_+=s[n++]}let m=_.endsWith("-");m&&(_=_.slice(0,-1)),f&&i(),r.push(new Ft(_,D.Comment)),n+=2,m&&l();continue}if(s.slice(n,n+3)==="{%-"){i(),r.push(new Ft("{%",D.OpenStatement)),n+=3;continue}if(s.slice(n,n+3)==="{{-"){i(),r.push(new Ft("{{",D.OpenExpression)),o=0,n+=3;continue}if(a(Rk),s.slice(n,n+3)==="-%}"){r.push(new Ft("%}",D.CloseStatement)),n+=3,l();continue}if(s.slice(n,n+3)==="-}}"){r.push(new Ft("}}",D.CloseExpression)),n+=3,l();continue}let p=s[n];if(p==="-"||p==="+"){let f=r.at(-1)?.type;if(f===D.Text||f===void 0)throw new SyntaxError(`Unexpected character: ${p}`);switch(f){case D.Identifier:case D.NumericLiteral:case D.StringLiteral:case D.CloseParen:case D.CloseSquareBracket:break;default:{++n;let _=a(oo);r.push(new Ft(`${p}${_}`,_.length>0?D.NumericLiteral:D.UnaryOperator));continue}}}for(let[f,_]of KC){if(f==="}}"&&o>0)continue;if(s.slice(n,n+f.length)===f){r.push(new Ft(f,_)),_===D.OpenExpression?o=0:_===D.OpenCurlyBracket?++o:_===D.CloseCurlyBracket&&--o,n+=f.length;continue e}}if(p==="'"||p==='"'){++n;let f=a(_=>_!==p);r.push(new Ft(f,D.StringLiteral)),++n;continue}if(oo(p)){let f=a(oo);if(s[n]==="."&&oo(s[n+1])){++n;let _=a(oo);f=`${f}.${_}`}r.push(new Ft(f,D.NumericLiteral));continue}if($k(p)){let f=a($k);r.push(new Ft(f,D.Identifier));continue}throw new SyntaxError(`Unexpected character: ${p}`)}return r}var Yt=class{type="Statement"},ZC=class extends Yt{constructor(t){super(),this.body=t}type="Program"},eL=class extends Yt{constructor(t,e,r){super(),this.test=t,this.body=e,this.alternate=r}type="If"},tL=class extends Yt{constructor(t,e,r,s){super(),this.loopvar=t,this.iterable=e,this.body=r,this.defaultBlock=s}type="For"},rL=class extends Yt{type="Break"},sL=class extends Yt{type="Continue"},nL=class extends Yt{constructor(t,e,r){super(),this.assignee=t,this.value=e,this.body=r}type="Set"},oL=class extends Yt{constructor(t,e,r){super(),this.name=t,this.args=e,this.body=r}type="Macro"},aL=class extends Yt{constructor(t){super(),this.value=t}type="Comment"},Lt=class extends Yt{type="Expression"},iL=class extends Lt{constructor(t,e,r){super(),this.object=t,this.property=e,this.computed=r}type="MemberExpression"},Dk=class extends Lt{constructor(t,e){super(),this.callee=t,this.args=e}type="CallExpression"},tn=class extends Lt{constructor(t){super(),this.value=t}type="Identifier"},rn=class extends Lt{constructor(t){super(),this.value=t}type="Literal"},lL=class extends rn{type="IntegerLiteral"},cL=class extends rn{type="FloatLiteral"},Fk=class extends rn{type="StringLiteral"},uL=class extends rn{type="ArrayLiteral"},Bk=class extends rn{type="TupleLiteral"},pL=class extends rn{type="ObjectLiteral"},ao=class extends Lt{constructor(t,e,r){super(),this.operator=t,this.left=e,this.right=r}type="BinaryExpression"},dL=class extends Lt{constructor(t,e){super(),this.operand=t,this.filter=e}type="FilterExpression"},fL=class extends Yt{constructor(t,e){super(),this.filter=t,this.body=e}type="FilterStatement"},_L=class extends Lt{constructor(t,e){super(),this.lhs=t,this.test=e}type="SelectExpression"},mL=class extends Lt{constructor(t,e,r){super(),this.operand=t,this.negate=e,this.test=r}type="TestExpression"},hL=class extends Lt{constructor(t,e){super(),this.operator=t,this.argument=e}type="UnaryExpression"},gL=class extends Lt{constructor(t=void 0,e=void 0,r=void 0){super(),this.start=t,this.stop=e,this.step=r}type="SliceExpression"},wL=class extends Lt{constructor(t,e){super(),this.key=t,this.value=e}type="KeywordArgumentExpression"},xL=class extends Lt{constructor(t){super(),this.argument=t}type="SpreadExpression"},yL=class extends Yt{constructor(t,e,r){super(),this.call=t,this.callerArgs=e,this.body=r}type="CallStatement"},bL=class extends Lt{constructor(t,e,r){super(),this.condition=t,this.trueExpr=e,this.falseExpr=r}type="Ternary"};function vL(t){let e=new ZC([]),r=0;function s(L,z){let R=t[r++];if(!R||R.type!==L)throw new Error(`Parser Error: ${z}. ${R.type} !== ${L}.`);return R}function n(L){if(!l(L))throw new SyntaxError(`Expected ${L}`);++r}function o(){switch(t[r].type){case D.Comment:return new aL(t[r++].value);case D.Text:return c();case D.OpenStatement:return p();case D.OpenExpression:return f();default:throw new SyntaxError(`Unexpected token type: ${t[r].type}`)}}function a(...L){return r+L.length<=t.length&&L.every((z,R)=>z===t[r+R].type)}function i(...L){return t[r]?.type===D.OpenStatement&&t[r+1]?.type===D.Identifier&&L.includes(t[r+1]?.value)}function l(...L){return r+L.length<=t.length&&L.every((z,R)=>t[r+R].type==="Identifier"&&z===t[r+R].value)}function c(){return new Fk(s(D.Text,"Expected text token").value)}function p(){if(s(D.OpenStatement,"Expected opening statement token"),t[r].type!==D.Identifier)throw new SyntaxError(`Unknown statement, got ${t[r].type}`);let L=t[r].value,z;switch(L){case"set":++r,z=_();break;case"if":++r,z=m(),s(D.OpenStatement,"Expected {% token"),n("endif"),s(D.CloseStatement,"Expected %} token");break;case"macro":++r,z=w(),s(D.OpenStatement,"Expected {% token"),n("endmacro"),s(D.CloseStatement,"Expected %} token");break;case"for":++r,z=k(),s(D.OpenStatement,"Expected {% token"),n("endfor"),s(D.CloseStatement,"Expected %} token");break;case"call":{++r;let R=null;a(D.OpenParen)&&(R=B());let J=le();if(J.type!=="Identifier")throw new SyntaxError("Expected identifier following call statement");let Ie=B();s(D.CloseStatement,"Expected closing statement token");let ae=[];for(;!i("endcall");)ae.push(o());s(D.OpenStatement,"Expected '{%'"),n("endcall"),s(D.CloseStatement,"Expected closing statement token");let Ue=new Dk(J,Ie);z=new yL(Ue,R,ae);break}case"break":++r,s(D.CloseStatement,"Expected closing statement token"),z=new rL;break;case"continue":++r,s(D.CloseStatement,"Expected closing statement token"),z=new sL;break;case"filter":{++r;let R=le();R instanceof tn&&a(D.OpenParen)&&(R=H(R)),s(D.CloseStatement,"Expected closing statement token");let J=[];for(;!i("endfilter");)J.push(o());s(D.OpenStatement,"Expected '{%'"),n("endfilter"),s(D.CloseStatement,"Expected '%}'"),z=new fL(R,J);break}default:throw new SyntaxError(`Unknown statement type: ${L}`)}return z}function f(){s(D.OpenExpression,"Expected opening expression token");let L=E();return s(D.CloseExpression,"Expected closing expression token"),L}function _(){let L=x(),z=null,R=[];if(a(D.Equals))++r,z=x();else{for(s(D.CloseStatement,"Expected %} token");!i("endset");)R.push(o());s(D.OpenStatement,"Expected {% token"),n("endset")}return s(D.CloseStatement,"Expected closing statement token"),new nL(L,z,R)}function m(){let L=E();s(D.CloseStatement,"Expected closing statement token");let z=[],R=[];for(;!i("elif","else","endif");)z.push(o());if(i("elif")){++r,++r;let J=m();R.push(J)}else if(i("else"))for(++r,++r,s(D.CloseStatement,"Expected closing statement token");!i("endif");)R.push(o());return new eL(L,z,R)}function w(){let L=le();if(L.type!=="Identifier")throw new SyntaxError("Expected identifier following macro statement");let z=B();s(D.CloseStatement,"Expected closing statement token");let R=[];for(;!i("endmacro");)R.push(o());return new oL(L,z,R)}function x(L=!1){let z=L?le:E,R=[z()],J=a(D.Comma);for(;J&&(++r,R.push(z()),!!a(D.Comma)););return J?new Bk(R):R[0]}function k(){let L=x(!0);if(!(L instanceof tn||L instanceof Bk))throw new SyntaxError(`Expected identifier/tuple for the loop variable, got ${L.type} instead`);if(!l("in"))throw new SyntaxError("Expected `in` keyword following loop variable");++r;let z=E();s(D.CloseStatement,"Expected closing statement token");let R=[];for(;!i("endfor","else");)R.push(o());let J=[];if(i("else"))for(++r,++r,s(D.CloseStatement,"Expected closing statement token");!i("endfor");)J.push(o());return new tL(L,z,R,J)}function E(){return A()}function A(){let L=T();if(l("if")){++r;let z=T();if(l("else")){++r;let R=A();return new bL(z,L,R)}else return new _L(L,z)}return L}function T(){let L=S();for(;l("or");){let z=t[r];++r;let R=S();L=new ao(z,L,R)}return L}function S(){let L=P();for(;l("and");){let z=t[r];++r;let R=P();L=new ao(z,L,R)}return L}function P(){let L;for(;l("not");){let z=t[r];++r;let R=P();L=new hL(z,R)}return L??O()}function O(){let L=v();for(;;){let z;if(l("not","in"))z=new Ft("not in",D.Identifier),r+=2;else if(l("in"))z=t[r++];else if(a(D.ComparisonBinaryOperator))z=t[r++];else break;let R=v();L=new ao(z,L,R)}return L}function v(){let L=F();for(;a(D.AdditiveBinaryOperator);){let z=t[r];++r;let R=F();L=new ao(z,L,R)}return L}function j(){let L=Q(le());return a(D.OpenParen)?H(L):L}function H(L){let z=new Dk(L,B());return z=Q(z),a(D.OpenParen)&&(z=H(z)),z}function B(){s(D.OpenParen,"Expected opening parenthesis for arguments list");let L=V();return s(D.CloseParen,"Expected closing parenthesis for arguments list"),L}function V(){let L=[];for(;!a(D.CloseParen);){let z;if(t[r].type===D.MultiplicativeBinaryOperator&&t[r].value==="*"){++r;let R=E();z=new xL(R)}else if(z=E(),a(D.Equals)){if(++r,!(z instanceof tn))throw new SyntaxError("Expected identifier for keyword argument");let R=E();z=new wL(z,R)}L.push(z),a(D.Comma)&&++r}return L}function q(){let L=[],z=!1;for(;!a(D.CloseSquareBracket);)a(D.Colon)?(L.push(void 0),++r,z=!0):(L.push(E()),a(D.Colon)&&(++r,z=!0));if(L.length===0)throw new SyntaxError("Expected at least one argument for member/slice expression");if(z){if(L.length>3)throw new SyntaxError("Expected 0-3 arguments for slice expression");return new gL(...L)}return L[0]}function Q(L){for(;a(D.Dot)||a(D.OpenSquareBracket);){let z=t[r];++r;let R,J=z.type===D.OpenSquareBracket;if(J)R=q(),s(D.CloseSquareBracket,"Expected closing square bracket");else if(R=le(),R.type!=="Identifier")throw new SyntaxError("Expected identifier following dot operator");L=new iL(L,R,J)}return L}function F(){let L=C();for(;a(D.MultiplicativeBinaryOperator);){let z=t[r++],R=C();L=new ao(z,L,R)}return L}function C(){let L=te();for(;l("is");){++r;let z=l("not");z&&++r;let R=le();if(!(R instanceof tn))throw new SyntaxError("Expected identifier for the test");L=new mL(L,z,R)}return L}function te(){let L=j();for(;a(D.Pipe);){++r;let z=le();if(!(z instanceof tn))throw new SyntaxError("Expected identifier for the filter");a(D.OpenParen)&&(z=H(z)),L=new dL(L,z)}return L}function le(){let L=t[r++];switch(L.type){case D.NumericLiteral:{let z=L.value;return z.includes(".")?new cL(Number(z)):new lL(Number(z))}case D.StringLiteral:{let z=L.value;for(;a(D.StringLiteral);)z+=t[r++].value;return new Fk(z)}case D.Identifier:return new tn(L.value);case D.OpenParen:{let z=x();return s(D.CloseParen,"Expected closing parenthesis, got ${tokens[current].type} instead."),z}case D.OpenSquareBracket:{let z=[];for(;!a(D.CloseSquareBracket);)z.push(E()),a(D.Comma)&&++r;return++r,new uL(z)}case D.OpenCurlyBracket:{let z=new Map;for(;!a(D.CloseCurlyBracket);){let R=E();s(D.Colon,"Expected colon between key and value in object literal");let J=E();z.set(R,J),a(D.Comma)&&++r}return++r,new pL(z)}default:throw new SyntaxError(`Unexpected token: ${L.type}`)}}for(;r<t.length;)e.body.push(o());return e}function kL(t,e,r=1){if(e===void 0&&(e=t,t=0),r===0)throw new Error("range() step must not be zero");let s=[];if(r>0)for(let n=t;n<e;n+=r)s.push(n);else for(let n=t;n>e;n+=r)s.push(n);return s}function Uk(t,e,r,s=1){let n=Math.sign(s);n>=0?(e=(e??=0)<0?Math.max(t.length+e,0):Math.min(e,t.length),r=(r??=t.length)<0?Math.max(t.length+r,0):Math.min(r,t.length)):(e=(e??=t.length-1)<0?Math.max(t.length+e,-1):Math.min(e,t.length-1),r=(r??=-1)<-1?Math.max(t.length+r,-1):Math.min(r,t.length-1));let o=[];for(let a=e;n*a<n*r;a+=s)o.push(t[a]);return o}function EL(t){return t.replace(/\b\w/g,e=>e.toUpperCase())}function AL(t){return ML(new Date,t)}function ML(t,e){let r=new Intl.DateTimeFormat(void 0,{month:"long"}),s=new Intl.DateTimeFormat(void 0,{month:"short"}),n=o=>o<10?"0"+o:o.toString();return e.replace(/%[YmdbBHM%]/g,o=>{switch(o){case"%Y":return t.getFullYear().toString();case"%m":return n(t.getMonth()+1);case"%d":return n(t.getDate());case"%b":return s.format(t);case"%B":return r.format(t);case"%H":return n(t.getHours());case"%M":return n(t.getMinutes());case"%%":return"%";default:return o}})}function SL(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function TL(t,e,r,s){if(s===0)return t;let n=s==null||s<0?1/0:s,o=e.length===0?new RegExp("(?=)","gu"):new RegExp(SL(e),"gu");return t.replaceAll(o,a=>n>0?(--n,r):a)}var jk=class extends Error{},Gk=class extends Error{},ar=class{type="RuntimeValue";value;builtins=new Map;constructor(t=void 0){this.value=t}__bool__(){return new pe(!!this.value)}toString(){return String(this.value)}},me=class extends ar{type="IntegerValue"},Ze=class extends ar{type="FloatValue";toString(){return this.value%1===0?this.value.toFixed(1):this.value.toString()}},ee=class extends ar{type="StringValue";builtins=new Map([["upper",new qe(()=>new ee(this.value.toUpperCase()))],["lower",new qe(()=>new ee(this.value.toLowerCase()))],["strip",new qe(()=>new ee(this.value.trim()))],["title",new qe(()=>new ee(EL(this.value)))],["capitalize",new qe(()=>new ee(this.value.charAt(0).toUpperCase()+this.value.slice(1)))],["length",new me(this.value.length)],["rstrip",new qe(()=>new ee(this.value.trimEnd()))],["lstrip",new qe(()=>new ee(this.value.trimStart()))],["startswith",new qe(t=>{if(t.length===0)throw new Error("startswith() requires at least one argument");let e=t[0];if(e instanceof ee)return new pe(this.value.startsWith(e.value));if(e instanceof ye){for(let r of e.value){if(!(r instanceof ee))throw new Error("startswith() tuple elements must be strings");if(this.value.startsWith(r.value))return new pe(!0)}return new pe(!1)}throw new Error("startswith() argument must be a string or tuple of strings")})],["endswith",new qe(t=>{if(t.length===0)throw new Error("endswith() requires at least one argument");let e=t[0];if(e instanceof ee)return new pe(this.value.endsWith(e.value));if(e instanceof ye){for(let r of e.value){if(!(r instanceof ee))throw new Error("endswith() tuple elements must be strings");if(this.value.endsWith(r.value))return new pe(!0)}return new pe(!1)}throw new Error("endswith() argument must be a string or tuple of strings")})],["split",new qe(t=>{let e=t[0]??new Ve;if(!(e instanceof ee||e instanceof Ve))throw new Error("sep argument must be a string or null");let r=t[1]??new me(-1);if(!(r instanceof me))throw new Error("maxsplit argument must be a number");let s=[];if(e instanceof Ve){let n=this.value.trimStart();for(let{0:o,index:a}of n.matchAll(/\S+/g)){if(r.value!==-1&&s.length>=r.value&&a!==void 0){s.push(o+n.slice(a+o.length));break}s.push(o)}}else{if(e.value==="")throw new Error("empty separator");s=this.value.split(e.value),r.value!==-1&&s.length>r.value&&s.push(s.splice(r.value).join(e.value))}return new ye(s.map(n=>new ee(n)))})],["replace",new qe(t=>{if(t.length<2)throw new Error("replace() requires at least two arguments");let e=t[0],r=t[1];if(!(e instanceof ee&&r instanceof ee))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 Ve:s=t[2]:s=new Ve,!(s instanceof me||s instanceof Ve))throw new Error("replace() count argument must be a number or null");return new ee(TL(this.value,e.value,r.value,s.value))})]])},pe=class extends ar{type="BooleanValue"},OL=/[\x7f-\uffff]/g;function qk(t){return t.replace(OL,e=>"\\u"+e.charCodeAt(0).toString(16).padStart(4,"0"))}function fs(t,e={},r=0,s=!0){let{indent:n=null,ensureAscii:o=!1,separators:a=null,sortKeys:i=!1}=e,l,c;switch(a?[l,c]=a:n?(l=",",c=": "):(l=", ",c=": "),t.type){case"NullValue":return"null";case"UndefinedValue":return s?"null":"undefined";case"IntegerValue":case"FloatValue":case"BooleanValue":return JSON.stringify(t.value);case"StringValue":{let p=JSON.stringify(t.value);return o&&(p=qk(p)),p}case"ArrayValue":case"ObjectValue":{let p=n?" ".repeat(n):"",f=`
5
- `+p.repeat(r),_=f+p;if(t.type==="ArrayValue"){let m=t.value.map(w=>fs(w,e,r+1,s));return n?`[${_}${m.join(`${l}${_}`)}${f}]`:`[${m.join(l)}]`}else{let m=Array.from(t.value.entries());i&&(m=m.sort(([x],[k])=>x.localeCompare(k)));let w=m.map(([x,k])=>{let E=JSON.stringify(x);o&&(E=qk(E));let A=`${E}${c}${fs(k,e,r+1,s)}`;return n?`${_}${A}`:A});return n?`{${w.join(l)}${f}}`:`{${w.join(l)}}`}}default:throw new Error(`Cannot convert to JSON: ${t.type}`)}}var dt=class extends ar{type="ObjectValue";__bool__(){return new pe(this.value.size>0)}builtins=new Map([["get",new qe(([t,e])=>{if(!(t instanceof ee))throw new Error(`Object key must be a string: got ${t.type}`);return this.value.get(t.value)??e??new Ve})],["items",new qe(()=>this.items())],["keys",new qe(()=>this.keys())],["values",new qe(()=>this.values())],["dictsort",new qe(t=>{let e=new Map,r=t.filter(i=>i instanceof io?(e=i.value,!1):!0),s=r.at(0)??e.get("case_sensitive")??new pe(!1);if(!(s instanceof pe))throw new Error("case_sensitive must be a boolean");let n=r.at(1)??e.get("by")??new ee("key");if(!(n instanceof ee))throw new Error("by must be a string");if(!["key","value"].includes(n.value))throw new Error("by must be either 'key' or 'value'");let o=r.at(2)??e.get("reverse")??new pe(!1);if(!(o instanceof pe))throw new Error("reverse must be a boolean");let a=Array.from(this.value.entries()).map(([i,l])=>new ye([new ee(i),l])).sort((i,l)=>{let c=n.value==="key"?0:1,p=i.value[c],f=l.value[c],_=ld(p,f,s.value);return o.value?-_:_});return new ye(a)})]]);items(){return new ye(Array.from(this.value.entries()).map(([t,e])=>new ye([new ee(t),e])))}keys(){return new ye(Array.from(this.value.keys()).map(t=>new ee(t)))}values(){return new ye(Array.from(this.value.values()))}toString(){return fs(this,{},0,!1)}},io=class extends dt{type="KeywordArgumentsValue"},ye=class extends ar{type="ArrayValue";builtins=new Map([["length",new me(this.value.length)]]);__bool__(){return new pe(this.value.length>0)}toString(){return fs(this,{},0,!1)}},Wk=class extends ye{type="TupleValue"},qe=class extends ar{type="FunctionValue"},Ve=class extends ar{type="NullValue"},Ge=class extends ar{type="UndefinedValue"},ds=class{constructor(t){this.parent=t}variables=new Map([["namespace",new qe(t=>{if(t.length===0)return new dt(new Map);if(t.length!==1||!(t[0]instanceof dt))throw new Error("`namespace` expects either zero arguments or a single object argument");return t[0]})]]);tests=new Map([["boolean",t=>t.type==="BooleanValue"],["callable",t=>t instanceof qe],["odd",t=>{if(!(t instanceof me))throw new Error(`cannot odd on ${t.type}`);return t.value%2!==0}],["even",t=>{if(!(t instanceof me))throw new Error(`cannot even on ${t.type}`);return t.value%2===0}],["false",t=>t.type==="BooleanValue"&&!t.value],["true",t=>t.type==="BooleanValue"&&t.value],["none",t=>t.type==="NullValue"],["string",t=>t.type==="StringValue"],["number",t=>t instanceof me||t instanceof Ze],["integer",t=>t instanceof me],["iterable",t=>t.type==="ArrayValue"||t.type==="StringValue"],["mapping",t=>t instanceof dt],["sequence",t=>t instanceof ye||t instanceof dt||t instanceof ee],["lower",t=>{let e=t.value;return t.type==="StringValue"&&e===e.toLowerCase()}],["upper",t=>{let e=t.value;return t.type==="StringValue"&&e===e.toUpperCase()}],["none",t=>t.type==="NullValue"],["defined",t=>t.type!=="UndefinedValue"],["undefined",t=>t.type==="UndefinedValue"],["equalto",(t,e)=>t.value===e.value],["eq",(t,e)=>t.value===e.value]]);set(t,e){return this.declareVariable(t,Wl(e))}declareVariable(t,e){if(this.variables.has(t))throw new SyntaxError(`Variable already declared: ${t}`);return this.variables.set(t,e),e}setVariable(t,e){return this.variables.set(t,e),e}resolve(t){if(this.variables.has(t))return this;if(this.parent)return this.parent.resolve(t);throw new Error(`Unknown variable: ${t}`)}lookupVariable(t){try{return this.resolve(t).variables.get(t)??new Ge}catch{return new Ge}}};function IL(t){t.set("false",!1),t.set("true",!0),t.set("none",null),t.set("raise_exception",e=>{throw new Error(e)}),t.set("range",kL),t.set("strftime_now",AL),t.set("True",!0),t.set("False",!1),t.set("None",null)}function Vk(t,e){let r=e.split("."),s=t;for(let n of r)if(s instanceof dt)s=s.value.get(n)??new Ge;else if(s instanceof ye){let o=parseInt(n,10);if(!isNaN(o)&&o>=0&&o<s.value.length)s=s.value[o];else return new Ge}else return new Ge;return s}function ld(t,e,r=!1){if(t instanceof Ve&&e instanceof Ve)return 0;if(t instanceof Ve||e instanceof Ve)throw new Error(`Cannot compare ${t.type} with ${e.type}`);if(t instanceof Ge&&e instanceof Ge)return 0;if(t instanceof Ge||e instanceof Ge)throw new Error(`Cannot compare ${t.type} with ${e.type}`);let s=o=>o instanceof me||o instanceof Ze||o instanceof pe,n=o=>o instanceof pe?o.value?1:0:o.value;if(s(t)&&s(e)){let o=n(t),a=n(e);return o<a?-1:o>a?1:0}if(t.type!==e.type)throw new Error(`Cannot compare different types: ${t.type} and ${e.type}`);if(t.type==="StringValue"){let o=t.value,a=e.value;return r||(o=o.toLowerCase(),a=a.toLowerCase()),o<a?-1:o>a?1:0}else throw new Error(`Cannot compare type: ${t.type}`)}var CL=class{global;constructor(t){this.global=t??new ds}run(t){return this.evaluate(t,this.global)}evaluateBinaryExpression(t,e){let r=this.evaluate(t.left,e);switch(t.operator.value){case"and":return r.__bool__().value?this.evaluate(t.right,e):r;case"or":return r.__bool__().value?r:this.evaluate(t.right,e)}let s=this.evaluate(t.right,e);switch(t.operator.value){case"==":return new pe(r.value==s.value);case"!=":return new pe(r.value!=s.value)}if(r instanceof Ge||s instanceof Ge){if(s instanceof Ge&&["in","not in"].includes(t.operator.value))return new pe(t.operator.value==="not in");throw new Error(`Cannot perform operation ${t.operator.value} on undefined values`)}else{if(r instanceof Ve||s instanceof Ve)throw new Error("Cannot perform operation on null values");if(t.operator.value==="~")return new ee(r.value.toString()+s.value.toString());if((r instanceof me||r instanceof Ze)&&(s instanceof me||s instanceof Ze)){let n=r.value,o=s.value;switch(t.operator.value){case"+":case"-":case"*":{let a=t.operator.value==="+"?n+o:t.operator.value==="-"?n-o:n*o;return r instanceof Ze||s instanceof Ze?new Ze(a):new me(a)}case"/":return new Ze(n/o);case"%":{let a=n%o;return r instanceof Ze||s instanceof Ze?new Ze(a):new me(a)}case"<":return new pe(n<o);case">":return new pe(n>o);case">=":return new pe(n>=o);case"<=":return new pe(n<=o)}}else if(r instanceof ye&&s instanceof ye){if(t.operator.value==="+")return new ye(r.value.concat(s.value))}else if(s instanceof ye){let n=s.value.find(o=>o.value===r.value)!==void 0;switch(t.operator.value){case"in":return new pe(n);case"not in":return new pe(!n)}}}if((r instanceof ee||s instanceof ee)&&t.operator.value==="+")return new ee(r.value.toString()+s.value.toString());if(r instanceof ee&&s instanceof ee)switch(t.operator.value){case"in":return new pe(s.value.includes(r.value));case"not in":return new pe(!s.value.includes(r.value))}if(r instanceof ee&&s instanceof dt)switch(t.operator.value){case"in":return new pe(s.value.has(r.value));case"not in":return new pe(!s.value.has(r.value))}throw new SyntaxError(`Unknown operator "${t.operator.value}" between ${r.type} and ${s.type}`)}evaluateArguments(t,e){let r=[],s=new Map;for(let n of t)if(n.type==="SpreadExpression"){let o=n,a=this.evaluate(o.argument,e);if(!(a instanceof ye))throw new Error(`Cannot unpack non-iterable type: ${a.type}`);for(let i of a.value)r.push(i)}else if(n.type==="KeywordArgumentExpression"){let o=n;s.set(o.key.value,this.evaluate(o.value,e))}else{if(s.size>0)throw new Error("Positional arguments must come before keyword arguments");r.push(this.evaluate(n,e))}return[r,s]}applyFilter(t,e,r){if(e.type==="Identifier"){let s=e;if(s.value==="safe")return t;if(s.value==="tojson")return new ee(fs(t,{}));if(t instanceof ye)switch(s.value){case"list":return t;case"first":return t.value[0];case"last":return t.value[t.value.length-1];case"length":return new me(t.value.length);case"reverse":return new ye(t.value.slice().reverse());case"sort":return new ye(t.value.slice().sort((n,o)=>ld(n,o,!1)));case"join":return new ee(t.value.map(n=>n.value).join(""));case"string":return new ee(fs(t,{},0,!1));case"unique":{let n=new Set,o=[];for(let a of t.value)n.has(a.value)||(n.add(a.value),o.push(a));return new ye(o)}default:throw new Error(`Unknown ArrayValue filter: ${s.value}`)}else if(t instanceof ee)switch(s.value){case"length":case"upper":case"lower":case"title":case"capitalize":{let n=t.builtins.get(s.value);if(n instanceof qe)return n.value([],r);if(n instanceof me)return n;throw new Error(`Unknown StringValue filter: ${s.value}`)}case"trim":return new ee(t.value.trim());case"indent":return new ee(t.value.split(`
1
+ var QO=Object.defineProperty;var ls=(t=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(t,{get:(e,r)=>(typeof require<"u"?require:e)[r]}):t)(function(t){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+t+'" is not supported')});var Zs=(t,e)=>{for(var r in e)QO(t,r,{get:e[r],enumerable:!0})};import YO from"fs";import en from"path";import JO from"url";var ZO="4.0.0-next.8",id=typeof self<"u",tn=!jk(YO),Fk=!jk(en),Vl=id&&"caches"in self,eI=typeof globalThis.Deno<"u",kN=typeof globalThis.Bun<"u",Xl=eI&&Vl&&!tn,Bk=typeof process<"u",Uk=Bk&&process?.release?.name==="node"&&!Xl,ld=typeof window<"u"&&typeof window.document<"u",cd=id&&["DedicatedWorkerGlobalScope","ServiceWorkerGlobalScope","SharedWorkerGlobalScope"].includes(self.constructor?.name),tI=ld||cd||Xl,rI=Uk||typeof navigator<"u"&&"gpu"in navigator,sI=typeof navigator<"u"&&"ml"in navigator,nI=typeof crypto<"u"&&typeof crypto.getRandomValues=="function",oI=typeof chrome<"u"&&typeof chrome.runtime<"u"&&typeof chrome.runtime.id=="string",aI=typeof ServiceWorkerGlobalScope<"u"&&id&&self instanceof ServiceWorkerGlobalScope,iI=()=>{if(typeof navigator>"u")return!1;let t=navigator.userAgent,r=(navigator.vendor||"").indexOf("Apple")>-1,s=!t.match(/CriOS|FxiOS|EdgiOS|OPiOS|mercury|brave/i)&&!t.includes("Chrome")&&!t.includes("Android");return r&&s},lI=iI(),ie=Object.freeze({IS_BROWSER_ENV:ld,IS_WEBWORKER_ENV:cd,IS_WEB_ENV:tI,IS_SERVICE_WORKER_ENV:aI,IS_DENO_WEB_RUNTIME:Xl,IS_WEB_CACHE_AVAILABLE:Vl,IS_WEBGPU_AVAILABLE:rI,IS_WEBNN_AVAILABLE:sI,IS_SAFARI:lI,IS_PROCESS_AVAILABLE:Bk,IS_NODE_ENV:Uk,IS_FS_AVAILABLE:tn,IS_PATH_AVAILABLE:Fk,IS_CRYPTO_AVAILABLE:nI,IS_CHROME_AVAILABLE:oI}),ud=tn&&Fk,Hl="./";if(ud){let t=Object(import.meta).url;t?Hl=en.dirname(en.dirname(JO.fileURLToPath(t))):typeof __dirname<"u"&&(Hl=en.dirname(__dirname))}var cI=ud?en.join(Hl,"/.cache/"):null,Rk="/models/",uI=ud?en.join(Hl,Rk):Rk,pI=typeof globalThis.fetch=="function"?globalThis.fetch.bind(globalThis):void 0,Mt=Object.freeze({DEBUG:10,INFO:20,WARNING:30,ERROR:40,NONE:50}),Dk=Mt.WARNING,_e={version:ZO,backends:{onnx:{}},get logLevel(){return Dk},set logLevel(t){Dk=t,_e.backends.onnx?.setLogLevel?.(t)},allowRemoteModels:!0,remoteHost:"https://huggingface.co/",remotePathTemplate:"{model}/resolve/{revision}/",allowLocalModels:!(ld||cd||Xl),localModelPath:uI,useFS:tn,useBrowserCache:Vl,useFSCache:tn,cacheDir:cI,useCustomCache:!1,customCache:null,useWasmCache:Vl||tn,cacheKey:"transformers-cache",experimental_useCrossOriginStorage:!1,fetch:pI};function jk(t){return Object.keys(t).length===0}function gr(t,e){t&&t(e)}function Gk(t){return Number.isInteger(t)||typeof t=="bigint"}function pd(t){return t==null||t===-1}function dd(t){let e=[],r=t;for(;Array.isArray(r);)e.push(r.length),r=r[0];return e}function ht(...t){return Array.prototype.concat.apply([],t)}function qk(...t){return t.reduce((e,r)=>e.flatMap(s=>r.map(n=>[s,n])))}function rn(t,e){return Math.abs((t+e)%(2*e)-e)}function Ke(t,e){return Object.assign({},...e.map(r=>{if(t[r]!==void 0)return{[r]:t[r]}}))}function Wk(t,e){let r=0;for(let s of t)s===e&&++r;return r}var Z={error(...t){_e.logLevel<=Mt.ERROR&&console.error(...t)},warn(...t){_e.logLevel<=Mt.WARNING&&console.warn(...t)},info(...t){_e.logLevel<=Mt.INFO&&console.log(...t)},debug(...t){_e.logLevel<=Mt.DEBUG&&console.log(...t)},log(...t){this.info(...t)}};var dI=class{constructor(t){this.trie=this._build_trie(t)}_build_trie(t){let e=Object.create(null);for(let r of t){let s=e;for(let n=0;n<r.length;++n){let o=r[n];s=s[o]??=Object.create(null)}s.end=r}return e}split(t){let e=[],r=t.length,s=0,n=0;for(;n<r;){let o=this.trie,a=null,i=n;for(;i<r&&(o=o[t[i]]);)o.end&&(a=o.end),++i;a?(n>s&&e.push(t.slice(s,n)),e.push(a),n+=a.length,s=n):++n}return s<r&&e.push(t.slice(s)),e}},Vk=dI,fI=class{constructor(t){this.content=t.content,this.id=t.id,this.single_word=t.single_word??!1,this.lstrip=t.lstrip??!1,this.rstrip=t.rstrip??!1,this.special=t.special??!1,this.normalized=t.normalized??!this.special}},_I=fI,Zk=(()=>{let t=[...Array.from({length:94},(n,o)=>o+33),...Array.from({length:12},(n,o)=>o+161),...Array.from({length:82},(n,o)=>o+174)],e=t.slice(),r=0;for(let n=0;n<256;++n)t.includes(n)||(t.push(n),e.push(256+r),r+=1);let s=e.map(n=>String.fromCharCode(n));return Object.fromEntries(t.map((n,o)=>[n,s[o]]))})(),mI=t=>Object.fromEntries(Object.entries(t).map(([e,r])=>[r,e])),hI=mI(Zk),Hk=".,!?\u2026\u3002\uFF0C\u3001\u0964\u06D4\u060C",gI=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|[${Hk}])]+`,` ?[^\\s${Hk}]+`]]),Kl="\\p{P}\\u0021-\\u002F\\u003A-\\u0040\\u005B-\\u0060\\u007B-\\u007E",_d=t=>t.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"),Ql=(t,e=!0)=>{if(t.Regex!==void 0){let r=t.Regex.replace(/\\([#&~])/g,"$1");r=r.replace(/\\A/g,"^").replace(/\\z/g,"$").replace(/\\Z/g,"(?=\\r?\\n?$)");for(let[s,n]of gI)r=r.replaceAll(s,n);try{return new RegExp(r,"gu")}catch(s){if(!(s instanceof SyntaxError)||!s.message.toLowerCase().includes("invalid property name"))throw s;let n=!1,o=r.replace(/(\\[pP])\{([^}=]+)\}/g,(a,i,l)=>{try{return new RegExp(`\\p{${l}}`,"u"),`${i}{${l}}`}catch{return n=!0,`${i}{Script=${l}}`}});if(!n)throw s;try{return new RegExp(o,"gu")}catch{throw s}}}else if(t.String!==void 0){let r=wI(t.String);return new RegExp(e?r:`(${r})`,"gu")}else return console.warn("Unknown pattern type:",t),null},wI=t=>t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"),xI=(t,e,r)=>{let s=[],n=0;for(;n<t.length;){if(s.push(t[n]),(e.get(t[n])??r)!==r){++n;continue}for(;++n<t.length&&(e.get(t[n])??r)===r;)e.get(s.at(-1))!==r&&(s[s.length-1]+=t[n])}return s},yI=t=>t>=19968&&t<=40959||t>=13312&&t<=19903||t>=131072&&t<=173791||t>=173824&&t<=177983||t>=177984&&t<=178207||t>=178208&&t<=183983||t>=63744&&t<=64255||t>=194560&&t<=195103,bI=t=>Number.isInteger(t)||typeof t=="bigint",vI=t=>{let e=0;for(let r of t)++e;return e},kI=t=>eE(t.toLowerCase()),Wt=(...t)=>Array.prototype.concat.apply([],t),md=t=>new Map(Object.entries(t)),EI=(t,e)=>{let r=[],s=0;for(let n of t.matchAll(e)){let o=n[0];s<n.index&&r.push(t.slice(s,n.index)),o.length>0&&r.push(o),s=n.index+o.length}return s<t.length&&r.push(t.slice(s)),r},eE=t=>t.replace(/\p{M}/gu,""),Xk=(t,e,r=[])=>{if(!t||Array.isArray(t)||typeof t!="object")return`${e} must be a valid object`;for(let s of r)if(!(s in t))return`${e} must contain a "${s}" property`;return null},AI=t=>t.match(/\S+/g)||[],MI=class{constructor(){let t=function(...e){return t._call(...e)};return Object.setPrototypeOf(t,new.target.prototype)}},io=MI,SI=class extends io{constructor(t){super(),this.config=t}_call(t){return this.normalize(t)}},wr=SI,TI=class extends wr{tokenize_chinese_chars(t){let e=[];for(let r=0;r<t.length;++r){let s=t[r],n=s.charCodeAt(0);yI(n)?(e.push(" "),e.push(s),e.push(" ")):e.push(s)}return e.join("")}strip_accents(t){return t.normalize("NFD").replace(/\p{Mn}/gu,"")}is_control(t){switch(t){case" ":case`
2
+ `:case"\r":return!1;default:return/^\p{Cc}|\p{Cf}|\p{Co}|\p{Cs}$/u.test(t)}}clean_text(t){let e=[];for(let r of t){let s=r.charCodeAt(0);s===0||s===65533||this.is_control(r)||(/^\s$/.test(r)?e.push(" "):e.push(r))}return e.join("")}normalize(t){return this.config.clean_text&&(t=this.clean_text(t)),this.config.handle_chinese_chars&&(t=this.tokenize_chinese_chars(t)),this.config.lowercase?(t=t.toLowerCase(),this.config.strip_accents!==!1&&(t=this.strip_accents(t))):this.config.strip_accents&&(t=this.strip_accents(t)),t}},OI=TI,II=class extends wr{constructor(t){super(t),this.charsmap=t.precompiled_charsmap??null}normalize(t){return t=t.replace(/[\u0001-\u0008\u000B\u000E-\u001F\u007F\u008F\u009F]/gm,""),t=t.replace(/[\u0009\u000A\u000C\u000D\u00A0\u1680\u2000-\u200F\u2028\u2029\u202F\u205F\u2581\u3000\uFEFF\uFFFD]/gm," "),t.includes("\uFF5E")?t=t.split("\uFF5E").map(r=>r.normalize("NFKC")).join("\uFF5E"):t=t.normalize("NFKC"),t}},CI=II,LI=class extends wr{constructor(t){super(t),this.normalizers=(t.normalizers??[]).map(e=>tE(e))}normalize(t){return this.normalizers.reduce((e,r)=>r?r.normalize(e):e,t)}},PI=LI,zI=class extends wr{normalize(t){let e=Ql(this.config.pattern??{});return e===null?t:t.replaceAll(e,this.config.content??"")}},NI=zI,$I=class extends wr{constructor(){super(...arguments),this.form="NFC"}normalize(t){return t=t.normalize(this.form),t}},Yl=$I,RI=class extends Yl{constructor(){super(...arguments),this.form="NFC"}},DI=RI,FI=class extends Yl{constructor(){super(...arguments),this.form="NFD"}},BI=FI,UI=class extends Yl{constructor(){super(...arguments),this.form="NFKC"}},jI=UI,GI=class extends Yl{constructor(){super(...arguments),this.form="NFKD"}},qI=GI,WI=class extends wr{normalize(t){return this.config.strip_left&&this.config.strip_right?t=t.trim():(this.config.strip_left&&(t=t.trimStart()),this.config.strip_right&&(t=t.trimEnd())),t}},VI=WI,HI=class extends wr{normalize(t){return eE(t)}},XI=HI,KI=class extends wr{normalize(t){return t.toLowerCase()}},QI=KI,YI=class extends wr{normalize(t){return t=this.config.prepend+t,t}},JI=YI;function ZI(t){if(t===null)return null;switch(t.type){case"BertNormalizer":return new OI(t);case"Precompiled":return new CI(t);case"Sequence":return new PI(t);case"Replace":return new NI(t);case"NFC":return new DI(t);case"NFD":return new BI(t);case"NFKC":return new jI(t);case"NFKD":return new qI(t);case"Strip":return new VI(t);case"StripAccents":return new XI(t);case"Lowercase":return new QI(t);case"Prepend":return new JI(t);default:throw new Error(`Unknown Normalizer type: ${t.type}`)}}var tE=ZI,eC=class extends io{pre_tokenize(t,e){return(Array.isArray(t)?t.map(r=>this.pre_tokenize_text(r,e)):this.pre_tokenize_text(t,e)).flat()}_call(t,e){return this.pre_tokenize(t,e)}},Vt=eC,tC=class extends Vt{constructor(t){super(),this.config=t,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=/'s|'t|'re|'ve|'m|'ll|'d| ?\p{L}+| ?\p{N}+| ?[^\s\p{L}\p{N}]+|\s+(?!\S)|\s+/gu,this.byte_encoder=Zk,this.text_encoder=new TextEncoder}pre_tokenize_text(t,e){return this.add_prefix_space&&!t.startsWith(" ")&&(t=" "+t),(this.use_regex?t.match(this.pattern)||[]:[t]).map(s=>Array.from(this.text_encoder.encode(s),n=>this.byte_encoder[n]).join(""))}},rC=tC,sC=class extends Vt{pre_tokenize_text(t,e){return t.match(/\w+|[^\w\s]+/g)||[]}},nC=sC,oC=class extends Vt{constructor(t){super(),this.replacement=t.replacement??"\u2581",this.str_rep=t.str_rep||this.replacement,this.prepend_scheme=t.prepend_scheme??"always"}pre_tokenize_text(t,e){let{section_index:r=void 0}=e??{},s=t.replaceAll(" ",this.str_rep);return!s.startsWith(this.replacement)&&(this.prepend_scheme==="always"||this.prepend_scheme==="first"&&r===0)&&(s=this.str_rep+s),[s]}},aC=oC,iC=class extends Vt{constructor(t){super(),this.config=t,this.pattern=Ql(this.config.pattern??{},this.config.invert??!0)}pre_tokenize_text(t){return this.pattern===null?[]:this.config.invert?t.match(this.pattern)||[]:this.config.behavior?.toLowerCase()==="removed"?t.split(this.pattern).filter(e=>e):EI(t,this.pattern)}},lC=iC,cC=class extends Vt{constructor(t){super(),this.config=t,this.pattern=new RegExp(`[^${Kl}]+|[${Kl}]+`,"gu")}pre_tokenize_text(t){return t.match(this.pattern)||[]}},uC=cC,pC=class extends Vt{constructor(t){super(),this.config=t;let e=`[^\\d]+|\\d${this.config.individual_digits?"":"+"}`;this.pattern=new RegExp(e,"gu")}pre_tokenize_text(t){return t.match(this.pattern)||[]}},dC=pC,fC=class extends Vt{constructor(){super(),this.pattern=new RegExp(`[^\\s${Kl}]+|[${Kl}]`,"gu")}pre_tokenize_text(t,e){return t.trim().match(this.pattern)||[]}},_C=fC,mC=class extends Vt{constructor(t){super(),this.config=t,this.pattern=Ql(this.config.pattern??{}),this.content=this.config.content??""}pre_tokenize_text(t){return this.pattern===null?[t]:[t.replaceAll(this.pattern,this.config.content??"")]}},hC=mC,gC=class extends Vt{constructor(t){super(),this.tokenizers=(t.pretokenizers??[]).map(e=>rE(e))}pre_tokenize_text(t,e){return this.tokenizers.reduce((r,s)=>s?s.pre_tokenize(r,e):r,[t])}},wC=gC,xC=class extends Vt{pre_tokenize_text(t){return AI(t)}},yC=xC,bC=class extends Vt{constructor(t){super(),this.config=t,this._length=t.length}pre_tokenize_text(t){let e=[];for(let r=0;r<t.length;r+=this._length)e.push(t.slice(r,r+this._length));return e}},vC=bC;function kC(t){if(t===null)return null;switch(t.type){case"BertPreTokenizer":return new _C;case"Sequence":return new wC(t);case"Whitespace":return new nC;case"WhitespaceSplit":return new yC;case"Metaspace":return new aC(t);case"ByteLevel":return new rC(t);case"Split":return new lC(t);case"Punctuation":return new uC(t);case"Digits":return new dC(t);case"Replace":return new hC(t);case"FixedLength":return new vC(t);default:throw new Error(`Unknown PreTokenizer type: ${t.type}`)}}var rE=kC,EC=class extends io{constructor(t){super(),this.config=t,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(t){let e=this.encode(t);return this.fuse_unk&&(e=xI(e,this.tokens_to_ids,this.unk_token_id)),e}},Jl=EC,AC=class extends Jl{constructor(t){super(t),this.max_input_chars_per_word=100,this.tokens_to_ids=md(t.vocab),this.unk_token_id=this.tokens_to_ids.get(t.unk_token),this.unk_token=t.unk_token,this.max_input_chars_per_word=t.max_input_chars_per_word??100,this.vocab=new Array(this.tokens_to_ids.size);for(let[e,r]of this.tokens_to_ids)this.vocab[r]=e}encode(t){let e=[];for(let r of t){let s=[...r];if(s.length>this.max_input_chars_per_word){e.push(this.unk_token);continue}let n=!1,o=0,a=[];for(;o<s.length;){let i=s.length,l=null;for(;o<i;){let c=s.slice(o,i).join("");if(o>0&&(c=this.config.continuing_subword_prefix+c),this.tokens_to_ids.has(c)){l=c;break}--i}if(l===null){n=!0;break}a.push(l),o=i}n?e.push(this.unk_token):e.push(...a)}return e}},Kk=AC,Qk=class sE{constructor(e,r){this.is_leaf=e,this.children=r}static default(){return new sE(!1,new Map)}},MC=class{constructor(){this.root=Qk.default()}extend(t){for(let e of t)this.push(e)}push(t){let e=this.root;for(let r of t){let s=e.children.get(r);s===void 0&&(s=Qk.default(),e.children.set(r,s)),e=s}e.is_leaf=!0}*common_prefix_search(t){let e=this.root;if(e===void 0)return;let r="";for(let s of t){if(r+=s,e=e.children.get(s),e===void 0)return;e.is_leaf&&(yield r)}}},SC=MC,fd=class nE{constructor(e,r,s,n,o){this.token_id=e,this.node_id=r,this.pos=s,this.length=n,this.score=o,this.prev=null,this.backtrace_score=0}clone(){let e=new nE(this.token_id,this.node_id,this.pos,this.length,this.score);return e.prev=this.prev,e.backtrace_score=this.backtrace_score,e}},TC=class{constructor(t,e,r){this.chars=Array.from(t),this.len=this.chars.length,this.bos_token_id=e,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},()=>[]);let s=new fd(this.bos_token_id??0,0,0,0,0),n=new fd(this.eos_token_id??0,1,this.len,0,0);this.nodes.push(s.clone()),this.nodes.push(n.clone()),this.begin_nodes[this.len].push(n),this.end_nodes[0].push(s)}insert(t,e,r,s){let n=this.nodes.length,o=new fd(s,n,t,e,r);this.begin_nodes[t].push(o),this.end_nodes[t+e].push(o),this.nodes.push(o)}viterbi(){let t=this.len,e=0;for(;e<=t;){if(this.begin_nodes[e].length==0)return[];for(let a of this.begin_nodes[e]){a.prev=null;let i=0,l=null;for(let c of this.end_nodes[e]){let p=c.backtrace_score+a.score;(l===null||p>i)&&(l=c.clone(),i=p)}if(l!==null)a.prev=l,a.backtrace_score=i;else return[]}++e}let r=[],n=this.begin_nodes[t][0].prev;if(n===null)return[];let o=n.clone();for(;o.prev!==null;)r.push(o.clone()),o=o.clone().prev.clone();return r.reverse(),r}piece(t){return this.chars.slice(t.pos,t.pos+t.length).join("")}tokens(){return this.viterbi().map(e=>this.piece(e))}token_ids(){return this.viterbi().map(e=>e.token_id)}},OC=TC;function IC(t){if(t.length===0)throw new Error("Array must not be empty");let e=t[0],r=0;for(let s=1;s<t.length;++s)t[s]<e&&(e=t[s],r=s);return[e,r]}var CC=class extends Jl{constructor(t,e){super(t);let r=t.vocab.length;this.vocab=new Array(r),this.scores=new Array(r);for(let s=0;s<r;++s)[this.vocab[s],this.scores[s]]=t.vocab[s];this.unk_token_id=t.unk_id,this.unk_token=this.vocab[t.unk_id],this.tokens_to_ids=new Map(this.vocab.map((s,n)=>[s,n])),this.bos_token=" ",this.bos_token_id=this.tokens_to_ids.get(this.bos_token),this.eos_token=e,this.eos_token_id=this.tokens_to_ids.get(this.eos_token),this.unk_token=this.vocab[this.unk_token_id],this.min_score=IC(this.scores)[0],this.unk_score=this.min_score-10,this.scores[this.unk_token_id]=this.unk_score,this.trie=new SC,this.trie.extend(this.vocab),this.fuse_unk=!0}populate_nodes(t){let e=t.chars,r=1,s=0;for(;s<e.length;){let n=!1,o=[],a=e.slice(s).join(""),i=this.trie.common_prefix_search(a);for(let l of i){o.push(l);let c=this.tokens_to_ids.get(l),p=this.scores[c],d=vI(l);t.insert(s,d,p,c),!n&&d===r&&(n=!0)}n||t.insert(s,r,this.unk_score,this.unk_token_id),s+=r}}tokenize(t){let e=new OC(t,this.bos_token_id,this.eos_token_id);return this.populate_nodes(e),e.tokens()}encode(t){let e=[];for(let r of t){let s=this.tokenize(r);e.push(...s)}return e}},Yk=CC,LC=class{constructor(t=(r,s)=>r>s,e=1/0){this._heap=[],this._comparator=t,this._max_size=e}get size(){return this._heap.length}is_empty(){return this.size===0}peek(){return this._heap[0]}push(...t){return this.extend(t)}extend(t){for(let e of t)if(this.size<this._max_size)this._heap.push(e),this._sift_up();else{let r=this._smallest();this._comparator(e,this._heap[r])&&(this._heap[r]=e,this._sift_up_from(r))}return this.size}pop(){let t=this.peek(),e=this.size-1;return e>0&&this._swap(0,e),this._heap.pop(),this._sift_down(),t}replace(t){let e=this.peek();return this._heap[0]=t,this._sift_down(),e}_parent(t){return(t+1>>>1)-1}_left(t){return(t<<1)+1}_right(t){return t+1<<1}_greater(t,e){return this._comparator(this._heap[t],this._heap[e])}_swap(t,e){let r=this._heap[t];this._heap[t]=this._heap[e],this._heap[e]=r}_sift_up(){this._sift_up_from(this.size-1)}_sift_up_from(t){for(;t>0&&this._greater(t,this._parent(t));)this._swap(t,this._parent(t)),t=this._parent(t)}_sift_down(){let t=0;for(;this._left(t)<this.size&&this._greater(this._left(t),t)||this._right(t)<this.size&&this._greater(this._right(t),t);){let e=this._right(t)<this.size&&this._greater(this._right(t),this._left(t))?this._right(t):this._left(t);this._swap(t,e),t=e}}_smallest(){return 2**Math.floor(Math.log2(this.size))-1}},PC=LC,zC=class{constructor(t){this.capacity=t,this.cache=new Map}get(t){if(!this.cache.has(t))return;let e=this.cache.get(t);return this.cache.delete(t),this.cache.set(t,e),e}put(t,e){this.cache.has(t)&&this.cache.delete(t),this.cache.set(t,e),this.cache.size>this.capacity&&this.cache.delete(this.cache.keys().next().value)}clear(){this.cache.clear()}},NC=zC,$C=class extends Jl{constructor(t){super(t),this.tokens_to_ids=md(t.vocab),this.unk_token_id=this.tokens_to_ids.get(t.unk_token),this.unk_token=t.unk_token,this.vocab=new Array(this.tokens_to_ids.size);for(let[r,s]of this.tokens_to_ids)this.vocab[s]=r;let e=Array.isArray(t.merges[0]);this.merges=e?t.merges:t.merges.map(r=>r.split(" ",2)),this.bpe_ranks=new Map(this.merges.map((r,s)=>[JSON.stringify(r),s])),this.end_of_word_suffix=t.end_of_word_suffix,this.continuing_subword_suffix=t.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 NC(this.cache_capacity)}clear_cache(){this.cache.clear()}bpe(t){if(t.length===0)return[];let e=this.cache.get(t);if(e!==void 0)return e;let r=Array.from(t);this.end_of_word_suffix&&(r[r.length-1]+=this.end_of_word_suffix);let s=[];if(r.length>1){let n=new PC((i,l)=>i.score<l.score),o={token:r[0],bias:0,prev:null,next:null},a=o;for(let i=1;i<r.length;++i){let l={bias:i/r.length,token:r[i],prev:a,next:null};a.next=l,this.add_node(n,a),a=l}for(;!n.is_empty();){let i=n.pop();if(i.deleted||!i.next||i.next.deleted)continue;if(i.deleted=!0,i.next.deleted=!0,i.prev){let c={...i.prev};i.prev.deleted=!0,i.prev=c,c.prev?c.prev.next=c:o=c}let 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(n,l.prev)):o=l,l.next&&(l.next.prev=l,this.add_node(n,l))}for(let i=o;i!==null;i=i.next)s.push(i.token)}else s=r;if(this.continuing_subword_suffix)for(let n=0;n<s.length-1;++n)s[n]+=this.continuing_subword_suffix;return t.length<this.max_length_to_cache&&this.cache.put(t,s),s}add_node(t,e){let r=this.bpe_ranks.get(JSON.stringify([e.token,e.next.token]));r!==void 0&&(e.score=r+e.bias,t.push(e))}encode(t){let e=[];for(let r of t){if(this.ignore_merges&&this.tokens_to_ids.has(r)){e.push(r);continue}let s=this.bpe(r);for(let n of s)if(this.tokens_to_ids.has(n))e.push(n);else if(this.byte_fallback){let o=Array.from(this.text_encoder.encode(n)).map(a=>`<0x${a.toString(16).toUpperCase().padStart(2,"0")}>`);o.every(a=>this.tokens_to_ids.has(a))?e.push(...o):this.unk_token!=null&&e.push(this.unk_token)}else this.unk_token!=null&&e.push(this.unk_token)}return e}},Jk=$C,RC=class extends Jl{constructor(t,e){super(t);let r=t.vocab;this.tokens_to_ids=md(e.target_lang?r[e.target_lang]:r),this.bos_token=e.bos_token,this.bos_token_id=this.tokens_to_ids.get(this.bos_token),this.eos_token=e.eos_token,this.eos_token_id=this.tokens_to_ids.get(this.eos_token),this.pad_token=e.pad_token,this.pad_token_id=this.tokens_to_ids.get(this.pad_token),this.unk_token=e.unk_token,this.unk_token_id=this.tokens_to_ids.get(this.unk_token),this.vocab=new Array(this.tokens_to_ids.size);for(let[s,n]of this.tokens_to_ids)this.vocab[n]=s}encode(t){return t}},DC=RC;function FC(t,e){switch(t.type){case"WordPiece":return new Kk(t);case"Unigram":return new Yk(t,e.eos_token);case"BPE":return new Jk(t);default:if(t.vocab)return Array.isArray(t.vocab)?new Yk(t,e.eos_token):Object.hasOwn(t,"continuing_subword_prefix")&&Object.hasOwn(t,"unk_token")?Object.hasOwn(t,"merges")?new Jk(t):new Kk(t):new DC(t,{target_lang:e.target_lang,bos_token:e.bos_token,eos_token:e.eos_token,pad_token:e.pad_token,unk_token:e.unk_token});throw new Error(`Unknown TokenizerModel type: ${t?.type}`)}}var BC=FC,UC=class extends io{constructor(t){super(),this.config=t}_call(t,...e){return this.post_process(t,...e)}},lo=UC,jC=class extends lo{post_process(t,e=null,r=!0){let s=e===null?this.config.single:this.config.pair,n=[],o=[];for(let a of s)"SpecialToken"in a?r&&(n.push(a.SpecialToken.id),o.push(a.SpecialToken.type_id)):"Sequence"in a&&(a.Sequence.id==="A"?(n=Wt(n,t),o=Wt(o,new Array(t.length).fill(a.Sequence.type_id))):a.Sequence.id==="B"&&(n=Wt(n,e),o=Wt(o,new Array(e.length).fill(a.Sequence.type_id))));return{tokens:n,token_type_ids:o}}},GC=jC,qC=class extends lo{post_process(t,e=null){return{tokens:t,tokens_pair:e}}},WC=qC,VC=class extends lo{constructor(t){super(t),this.sep=t.sep,this.cls=t.cls}post_process(t,e=null,r=!0){r&&(t=Wt([this.cls[0]],t,[this.sep[0]]));let s=new Array(t.length).fill(0);if(e){let n=[],o=r?[this.sep[0]]:[];t=Wt(t,n,e,o),s=Wt(s,new Array(e.length+n.length+o.length).fill(1))}return{tokens:t,token_type_ids:s}}},HC=VC,XC=class extends lo{constructor(t){super(t),this.sep=t.sep,this.cls=t.cls}post_process(t,e,r=!0){r&&(t=Wt([this.cls[0]],t,[this.sep[0]]));let s=new Array(t.length).fill(0);if(e){let n=r?[this.sep[0]]:[],o=r?[this.sep[0]]:[];t=Wt(t,n,e,o),s=Wt(s,new Array(e.length+n.length+o.length).fill(1))}return{tokens:t,token_type_ids:s}}},KC=XC,QC=class extends lo{constructor(t){super(t),this.processors=(t.processors??[]).map(e=>oE(e))}post_process(t,e=null,r=!0){let s={tokens:t,tokens_pair:e};for(let n of this.processors)s=n.post_process(s.tokens,s.tokens_pair,r);return s}},YC=QC;function JC(t){if(t===null)return null;switch(t.type){case"TemplateProcessing":return new GC(t);case"ByteLevel":return new WC(t);case"BertProcessing":return new HC(t);case"RobertaProcessing":return new KC(t);case"Sequence":return new YC(t);default:throw new Error(`Unknown PostProcessor type: ${t.type}`)}}var oE=JC,ZC=class extends io{constructor(t){super(),this.config=t,this.added_tokens=[],this.end_of_word_suffix=null,this.trim_offsets="trim_offsets"in t?t.trim_offsets:!1}_call(t){return this.decode(t)}decode(t){return this.decode_chain(t).join("")}},$t=ZC,eL=class extends $t{constructor(t){super(t),this.byte_decoder=hI,this.text_decoder=new TextDecoder("utf-8",{fatal:!1,ignoreBOM:!0}),this.end_of_word_suffix=null}convert_tokens_to_string(t){let e=t.join(""),r=new Uint8Array([...e].map(s=>this.byte_decoder[s]));return this.text_decoder.decode(r)}decode_chain(t){let e=[],r=[];for(let s of t)this.added_tokens.find(n=>n.content===s)!==void 0?(r.length>0&&(e.push(this.convert_tokens_to_string(r)),r=[]),e.push(s)):r.push(s);return r.length>0&&e.push(this.convert_tokens_to_string(r)),e}},tL=eL,rL=class extends $t{constructor(t){super(t),this.cleanup=t.cleanup}decode_chain(t){return t.map((e,r)=>{if(r!==0){let s=this.config.prefix;s&&e.startsWith(s)?e=e.replace(s,""):e=" "+e}return this.cleanup&&(e=_d(e)),e})}},sL=rL,nL=class extends $t{constructor(t){super(t),this.replacement=t.replacement??"\u2581"}decode_chain(t){let e=[];for(let r=0;r<t.length;++r){let s=t[r].replaceAll(this.replacement," ");r==0&&s.startsWith(" ")&&(s=s.substring(1)),e.push(s)}return e}},oL=nL,aL=class extends $t{constructor(t){super(t),this.suffix=t.suffix??""}decode_chain(t){return t.map((e,r)=>e.replaceAll(this.suffix,r===t.length-1?"":" "))}},iL=aL,lL=class extends $t{constructor(t){super(t),this.pad_token=t.pad_token??"",this.word_delimiter_token=t.word_delimiter_token??"",this.cleanup=t.cleanup}convert_tokens_to_string(t){if(t.length===0)return"";let e=[t[0]];for(let n=1;n<t.length;++n)t[n]!==e.at(-1)&&e.push(t[n]);let s=e.filter(n=>n!==this.pad_token).join("");return this.cleanup&&(s=_d(s).replaceAll(this.word_delimiter_token," ").trim()),s}decode_chain(t){return[this.convert_tokens_to_string(t)]}},cL=lL,uL=class extends $t{constructor(t){super(t),this.decoders=(t.decoders??[]).map(e=>aE(e))}decode_chain(t){return this.decoders.reduce((e,r)=>r.decode_chain(e),t)}},pL=uL,dL=class extends $t{decode_chain(t){let e=Ql(this.config.pattern),r=this.config.content??"";return e===null?t:t.map(s=>s.replaceAll(e,r))}},fL=dL,_L=class extends $t{decode_chain(t){return[t.join("")]}},mL=_L,hL=class extends $t{constructor(t){super(t),this.content=t.content??"",this.start=t.start??0,this.stop=t.stop??0}decode_chain(t){return t.map(e=>{let r=0;for(let n=0;n<this.start&&e[n]===this.content;++n){r=n+1;continue}let s=e.length;for(let n=0;n<this.stop;++n){let o=e.length-n-1;if(e[o]===this.content){s=o;continue}else break}return e.slice(r,s)})}},gL=hL,wL=class extends $t{constructor(t){super(t),this.text_decoder=new TextDecoder}decode_chain(t){let e=[],r=[];for(let s of t){let n=null;if(s.length===6&&s.startsWith("<0x")&&s.endsWith(">")){let o=parseInt(s.slice(3,5),16);isNaN(o)||(n=o)}if(n!==null)r.push(n);else{if(r.length>0){let o=this.text_decoder.decode(Uint8Array.from(r));e.push(o),r=[]}e.push(s)}}if(r.length>0){let s=this.text_decoder.decode(Uint8Array.from(r));e.push(s),r=[]}return e}},xL=wL;function yL(t){if(t===null)return null;switch(t.type){case"ByteLevel":return new tL(t);case"WordPiece":return new sL(t);case"Metaspace":return new oL(t);case"BPEDecoder":return new iL(t);case"CTC":return new cL(t);case"Sequence":return new pL(t);case"Replace":return new fL(t);case"Fuse":return new mL(t);case"Strip":return new gL(t);case"ByteFallback":return new xL(t);default:throw new Error(`Unknown Decoder type: ${t.type}`)}}var aE=yL,bL=class{constructor(t,e){let r=Xk(t,"Tokenizer",["model","decoder","post_processor","pre_tokenizer","normalizer"]);if(r)throw new Error(r);let s=Xk(e,"Config");if(s)throw new Error(s);this.tokenizer=t,this.config=e,this.normalizer=tE(this.tokenizer.normalizer),this.pre_tokenizer=rE(this.tokenizer.pre_tokenizer),this.model=BC(this.tokenizer.model,this.config),this.post_processor=oE(this.tokenizer.post_processor),this.decoder=aE(this.tokenizer.decoder),this.special_tokens=[],this.all_special_ids=[],this.added_tokens=[];let n=[],o=[];this.added_tokens_map=new Map;for(let a of this.tokenizer.added_tokens){let i=new _I(a);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){let l=this.normalizer(i.content);o.push(l),this.added_tokens_map.set(l,i)}else n.push(i.content)}(this.config.additional_special_tokens??[]).forEach(a=>{this.special_tokens.includes(a)||this.special_tokens.push(a)}),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 Vk(n),this.splitter_normalized=new Vk(o),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(t,{text_pair:e=null,add_special_tokens:r=!0,return_token_type_ids:s=null}={}){let{tokens:n,token_type_ids:o}=this.tokenize_helper(t,{text_pair:e,add_special_tokens:r}),a=n.map(l=>this.added_tokens_map.get(l)?.id??this.model.tokens_to_ids.get(l)??this.model.unk_token_id),i={ids:a,tokens:n,attention_mask:new Array(a.length).fill(1)};return s&&o&&(i.token_type_ids=o),i}decode(t,e={}){if(!Array.isArray(t)||t.length===0||!bI(t[0]))throw Error("token_ids must be a non-empty array of integers.");let r=t.map(n=>this.model.vocab[Number(n)]??this.model.unk_token);e.skip_special_tokens&&(r=r.filter(n=>!this.special_tokens.includes(n)));let s=this.decoder?this.decoder(r):r.join(" ");return this.decoder&&this.decoder.end_of_word_suffix&&(s=s.replaceAll(this.decoder.end_of_word_suffix," "),e.skip_special_tokens&&(s=s.trim())),(e.clean_up_tokenization_spaces??this.clean_up_tokenization_spaces)&&(s=_d(s)),s}tokenize(t,{text_pair:e=null,add_special_tokens:r=!1}={}){return this.tokenize_helper(t,{text_pair:e,add_special_tokens:r}).tokens}encode_text(t){if(t===null)return null;let e=this.splitter_unnormalized.split(t);return e.forEach((r,s)=>{let n=this.added_tokens_map.get(r);n&&(n.lstrip&&s>0&&(e[s-1]=e[s-1].trimEnd()),n.rstrip&&s<e.length-1&&(e[s+1]=e[s+1].trimStart()))}),e.flatMap((r,s)=>{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=kI(r)),this.normalizer!==null&&(r=this.normalizer(r)),r.length===0)return[];let n=this.splitter_normalized.split(r);return n.forEach((o,a)=>{let i=this.added_tokens_map.get(o);i&&(i.lstrip&&a>0&&(n[a-1]=n[a-1].trimEnd()),i.rstrip&&a<n.length-1&&(n[a+1]=n[a+1].trimStart()))}),n.flatMap(o=>{if(o.length===0)return[];if(this.added_tokens_map.has(o))return[o];let a=this.pre_tokenizer!==null?this.pre_tokenizer(o,{section_index:s}):[o];return this.model(a)})})}tokenize_helper(t,{text_pair:e=null,add_special_tokens:r=!0}){let s=this.encode_text(t),n=this.encode_text(e||null);return this.post_processor?this.post_processor(s,n,r):{tokens:Wt(s??[],n??[])}}token_to_id(t){return this.model.tokens_to_ids.get(t)}id_to_token(t){return this.model.vocab[t]}get_added_tokens_decoder(){let t=new Map;for(let e of this.added_tokens)t.set(e.id,e);return t}get_vocab(t=!0){let e=new Map;for(let r=0;r<this.model.vocab.length;++r){let s=this.model.vocab[r];(t||!this.added_tokens_map.has(s))&&e.set(s,r)}return e}},iE=bL;var D=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"}),Rt=class{constructor(t,e){this.value=t,this.type=e}};function lE(t){return/\w/.test(t)}function co(t){return/[0-9]/.test(t)}function cE(t){return/\s/.test(t)}var vL=[["{%",D.OpenStatement],["%}",D.CloseStatement],["{{",D.OpenExpression],["}}",D.CloseExpression],["(",D.OpenParen],[")",D.CloseParen],["{",D.OpenCurlyBracket],["}",D.CloseCurlyBracket],["[",D.OpenSquareBracket],["]",D.CloseSquareBracket],[",",D.Comma],[".",D.Dot],[":",D.Colon],["|",D.Pipe],["<=",D.ComparisonBinaryOperator],[">=",D.ComparisonBinaryOperator],["==",D.ComparisonBinaryOperator],["!=",D.ComparisonBinaryOperator],["<",D.ComparisonBinaryOperator],[">",D.ComparisonBinaryOperator],["+",D.AdditiveBinaryOperator],["-",D.AdditiveBinaryOperator],["~",D.AdditiveBinaryOperator],["*",D.MultiplicativeBinaryOperator],["/",D.MultiplicativeBinaryOperator],["%",D.MultiplicativeBinaryOperator],["=",D.Equals]],kL=new Map([["n",`
3
+ `],["t"," "],["r","\r"],["b","\b"],["f","\f"],["v","\v"],["'","'"],['"','"'],["\\","\\"]]);function EL(t,e={}){return t.endsWith(`
4
+ `)&&(t=t.slice(0,-1)),e.lstrip_blocks&&(t=t.replace(/^[ \t]*({[#%-])/gm,"$1")),e.trim_blocks&&(t=t.replace(/([#%-]})\n/g,"$1")),t.replace(/{%\s*(end)?generation\s*%}/gs,"")}function AL(t,e={}){let r=[],s=EL(t,e),n=0,o=0,a=c=>{let p="";for(;c(s[n]);){if(s[n]==="\\"){if(++n,n>=s.length)throw new SyntaxError("Unexpected end of input");let d=s[n++],_=kL.get(d);if(_===void 0)throw new SyntaxError(`Unexpected escaped character: ${d}`);p+=_;continue}if(p+=s[n++],n>=s.length)throw new SyntaxError("Unexpected end of input")}return p},i=()=>{let c=r.at(-1);c&&c.type===D.Text&&(c.value=c.value.trimEnd(),c.value===""&&r.pop())},l=()=>{for(;n<s.length&&cE(s[n]);)++n};e:for(;n<s.length;){let c=r.at(-1)?.type;if(c===void 0||c===D.CloseStatement||c===D.CloseExpression||c===D.Comment){let d="";for(;n<s.length&&!(s[n]==="{"&&(s[n+1]==="%"||s[n+1]==="{"||s[n+1]==="#"));)d+=s[n++];if(d.length>0){r.push(new Rt(d,D.Text));continue}}if(s[n]==="{"&&s[n+1]==="#"){n+=2;let d=s[n]==="-";d&&++n;let _="";for(;s[n]!=="#"||s[n+1]!=="}";){if(n+2>=s.length)throw new SyntaxError("Missing end of comment tag");_+=s[n++]}let m=_.endsWith("-");m&&(_=_.slice(0,-1)),d&&i(),r.push(new Rt(_,D.Comment)),n+=2,m&&l();continue}if(s.slice(n,n+3)==="{%-"){i(),r.push(new Rt("{%",D.OpenStatement)),n+=3;continue}if(s.slice(n,n+3)==="{{-"){i(),r.push(new Rt("{{",D.OpenExpression)),o=0,n+=3;continue}if(a(cE),s.slice(n,n+3)==="-%}"){r.push(new Rt("%}",D.CloseStatement)),n+=3,l();continue}if(s.slice(n,n+3)==="-}}"){r.push(new Rt("}}",D.CloseExpression)),n+=3,l();continue}let p=s[n];if(p==="-"||p==="+"){let d=r.at(-1)?.type;if(d===D.Text||d===void 0)throw new SyntaxError(`Unexpected character: ${p}`);switch(d){case D.Identifier:case D.NumericLiteral:case D.StringLiteral:case D.CloseParen:case D.CloseSquareBracket:break;default:{++n;let _=a(co);r.push(new Rt(`${p}${_}`,_.length>0?D.NumericLiteral:D.UnaryOperator));continue}}}for(let[d,_]of vL){if(d==="}}"&&o>0)continue;if(s.slice(n,n+d.length)===d){r.push(new Rt(d,_)),_===D.OpenExpression?o=0:_===D.OpenCurlyBracket?++o:_===D.CloseCurlyBracket&&--o,n+=d.length;continue e}}if(p==="'"||p==='"'){++n;let d=a(_=>_!==p);r.push(new Rt(d,D.StringLiteral)),++n;continue}if(co(p)){let d=a(co);if(s[n]==="."&&co(s[n+1])){++n;let _=a(co);d=`${d}.${_}`}r.push(new Rt(d,D.NumericLiteral));continue}if(lE(p)){let d=a(lE);r.push(new Rt(d,D.Identifier));continue}throw new SyntaxError(`Unexpected character: ${p}`)}return r}var Xt=class{type="Statement"},ML=class extends Xt{constructor(t){super(),this.body=t}type="Program"},SL=class extends Xt{constructor(t,e,r){super(),this.test=t,this.body=e,this.alternate=r}type="If"},TL=class extends Xt{constructor(t,e,r,s){super(),this.loopvar=t,this.iterable=e,this.body=r,this.defaultBlock=s}type="For"},OL=class extends Xt{type="Break"},IL=class extends Xt{type="Continue"},CL=class extends Xt{constructor(t,e,r){super(),this.assignee=t,this.value=e,this.body=r}type="Set"},LL=class extends Xt{constructor(t,e,r){super(),this.name=t,this.args=e,this.body=r}type="Macro"},PL=class extends Xt{constructor(t){super(),this.value=t}type="Comment"},It=class extends Xt{type="Expression"},zL=class extends It{constructor(t,e,r){super(),this.object=t,this.property=e,this.computed=r}type="MemberExpression"},uE=class extends It{constructor(t,e){super(),this.callee=t,this.args=e}type="CallExpression"},sn=class extends It{constructor(t){super(),this.value=t}type="Identifier"},nn=class extends It{constructor(t){super(),this.value=t}type="Literal"},NL=class extends nn{type="IntegerLiteral"},$L=class extends nn{type="FloatLiteral"},pE=class extends nn{type="StringLiteral"},RL=class extends nn{type="ArrayLiteral"},dE=class extends nn{type="TupleLiteral"},DL=class extends nn{type="ObjectLiteral"},uo=class extends It{constructor(t,e,r){super(),this.operator=t,this.left=e,this.right=r}type="BinaryExpression"},FL=class extends It{constructor(t,e){super(),this.operand=t,this.filter=e}type="FilterExpression"},BL=class extends Xt{constructor(t,e){super(),this.filter=t,this.body=e}type="FilterStatement"},UL=class extends It{constructor(t,e){super(),this.lhs=t,this.test=e}type="SelectExpression"},jL=class extends It{constructor(t,e,r){super(),this.operand=t,this.negate=e,this.test=r}type="TestExpression"},GL=class extends It{constructor(t,e){super(),this.operator=t,this.argument=e}type="UnaryExpression"},qL=class extends It{constructor(t=void 0,e=void 0,r=void 0){super(),this.start=t,this.stop=e,this.step=r}type="SliceExpression"},WL=class extends It{constructor(t,e){super(),this.key=t,this.value=e}type="KeywordArgumentExpression"},VL=class extends It{constructor(t){super(),this.argument=t}type="SpreadExpression"},HL=class extends Xt{constructor(t,e,r){super(),this.call=t,this.callerArgs=e,this.body=r}type="CallStatement"},XL=class extends It{constructor(t,e,r){super(),this.condition=t,this.trueExpr=e,this.falseExpr=r}type="Ternary"};function KL(t){let e=new ML([]),r=0;function s(P,N){let F=t[r++];if(!F||F.type!==P)throw new Error(`Parser Error: ${N}. ${F.type} !== ${P}.`);return F}function n(P){if(!l(P))throw new SyntaxError(`Expected ${P}`);++r}function o(){switch(t[r].type){case D.Comment:return new PL(t[r++].value);case D.Text:return c();case D.OpenStatement:return p();case D.OpenExpression:return d();default:throw new SyntaxError(`Unexpected token type: ${t[r].type}`)}}function a(...P){return r+P.length<=t.length&&P.every((N,F)=>N===t[r+F].type)}function i(...P){return t[r]?.type===D.OpenStatement&&t[r+1]?.type===D.Identifier&&P.includes(t[r+1]?.value)}function l(...P){return r+P.length<=t.length&&P.every((N,F)=>t[r+F].type==="Identifier"&&N===t[r+F].value)}function c(){return new pE(s(D.Text,"Expected text token").value)}function p(){if(s(D.OpenStatement,"Expected opening statement token"),t[r].type!==D.Identifier)throw new SyntaxError(`Unknown statement, got ${t[r].type}`);let P=t[r].value,N;switch(P){case"set":++r,N=_();break;case"if":++r,N=m(),s(D.OpenStatement,"Expected {% token"),n("endif"),s(D.CloseStatement,"Expected %} token");break;case"macro":++r,N=w(),s(D.OpenStatement,"Expected {% token"),n("endmacro"),s(D.CloseStatement,"Expected %} token");break;case"for":++r,N=E(),s(D.OpenStatement,"Expected {% token"),n("endfor"),s(D.CloseStatement,"Expected %} token");break;case"call":{++r;let F=null;a(D.OpenParen)&&(F=B());let J=ae();if(J.type!=="Identifier")throw new SyntaxError("Expected identifier following call statement");let xe=B();s(D.CloseStatement,"Expected closing statement token");let ue=[];for(;!i("endcall");)ue.push(o());s(D.OpenStatement,"Expected '{%'"),n("endcall"),s(D.CloseStatement,"Expected closing statement token");let qe=new uE(J,xe);N=new HL(qe,F,ue);break}case"break":++r,s(D.CloseStatement,"Expected closing statement token"),N=new OL;break;case"continue":++r,s(D.CloseStatement,"Expected closing statement token"),N=new IL;break;case"filter":{++r;let F=ae();F instanceof sn&&a(D.OpenParen)&&(F=X(F)),s(D.CloseStatement,"Expected closing statement token");let J=[];for(;!i("endfilter");)J.push(o());s(D.OpenStatement,"Expected '{%'"),n("endfilter"),s(D.CloseStatement,"Expected '%}'"),N=new BL(F,J);break}default:throw new SyntaxError(`Unknown statement type: ${P}`)}return N}function d(){s(D.OpenExpression,"Expected opening expression token");let P=k();return s(D.CloseExpression,"Expected closing expression token"),P}function _(){let P=x(),N=null,F=[];if(a(D.Equals))++r,N=x();else{for(s(D.CloseStatement,"Expected %} token");!i("endset");)F.push(o());s(D.OpenStatement,"Expected {% token"),n("endset")}return s(D.CloseStatement,"Expected closing statement token"),new CL(P,N,F)}function m(){let P=k();s(D.CloseStatement,"Expected closing statement token");let N=[],F=[];for(;!i("elif","else","endif");)N.push(o());if(i("elif")){++r,++r;let J=m();F.push(J)}else if(i("else"))for(++r,++r,s(D.CloseStatement,"Expected closing statement token");!i("endif");)F.push(o());return new SL(P,N,F)}function w(){let P=ae();if(P.type!=="Identifier")throw new SyntaxError("Expected identifier following macro statement");let N=B();s(D.CloseStatement,"Expected closing statement token");let F=[];for(;!i("endmacro");)F.push(o());return new LL(P,N,F)}function x(P=!1){let N=P?ae:k,F=[N()],J=a(D.Comma);for(;J&&(++r,F.push(N()),!!a(D.Comma)););return J?new dE(F):F[0]}function E(){let P=x(!0);if(!(P instanceof sn||P instanceof dE))throw new SyntaxError(`Expected identifier/tuple for the loop variable, got ${P.type} instead`);if(!l("in"))throw new SyntaxError("Expected `in` keyword following loop variable");++r;let N=k();s(D.CloseStatement,"Expected closing statement token");let F=[];for(;!i("endfor","else");)F.push(o());let J=[];if(i("else"))for(++r,++r,s(D.CloseStatement,"Expected closing statement token");!i("endfor");)J.push(o());return new TL(P,N,F,J)}function k(){return A()}function A(){let P=T();if(l("if")){++r;let N=T();if(l("else")){++r;let F=A();return new XL(N,P,F)}else return new UL(P,N)}return P}function T(){let P=S();for(;l("or");){let N=t[r];++r;let F=S();P=new uo(N,P,F)}return P}function S(){let P=L();for(;l("and");){let N=t[r];++r;let F=L();P=new uo(N,P,F)}return P}function L(){let P;for(;l("not");){let N=t[r];++r;let F=L();P=new GL(N,F)}return P??O()}function O(){let P=v();for(;;){let N;if(l("not","in"))N=new Rt("not in",D.Identifier),r+=2;else if(l("in"))N=t[r++];else if(a(D.ComparisonBinaryOperator))N=t[r++];else break;let F=v();P=new uo(N,P,F)}return P}function v(){let P=R();for(;a(D.AdditiveBinaryOperator);){let N=t[r];++r;let F=R();P=new uo(N,P,F)}return P}function W(){let P=Q(ae());return a(D.OpenParen)?X(P):P}function X(P){let N=new uE(P,B());return N=Q(N),a(D.OpenParen)&&(N=X(N)),N}function B(){s(D.OpenParen,"Expected opening parenthesis for arguments list");let P=H();return s(D.CloseParen,"Expected closing parenthesis for arguments list"),P}function H(){let P=[];for(;!a(D.CloseParen);){let N;if(t[r].type===D.MultiplicativeBinaryOperator&&t[r].value==="*"){++r;let F=k();N=new VL(F)}else if(N=k(),a(D.Equals)){if(++r,!(N instanceof sn))throw new SyntaxError("Expected identifier for keyword argument");let F=k();N=new WL(N,F)}P.push(N),a(D.Comma)&&++r}return P}function G(){let P=[],N=!1;for(;!a(D.CloseSquareBracket);)a(D.Colon)?(P.push(void 0),++r,N=!0):(P.push(k()),a(D.Colon)&&(++r,N=!0));if(P.length===0)throw new SyntaxError("Expected at least one argument for member/slice expression");if(N){if(P.length>3)throw new SyntaxError("Expected 0-3 arguments for slice expression");return new qL(...P)}return P[0]}function Q(P){for(;a(D.Dot)||a(D.OpenSquareBracket);){let N=t[r];++r;let F,J=N.type===D.OpenSquareBracket;if(J)F=G(),s(D.CloseSquareBracket,"Expected closing square bracket");else if(F=ae(),F.type!=="Identifier")throw new SyntaxError("Expected identifier following dot operator");P=new zL(P,F,J)}return P}function R(){let P=C();for(;a(D.MultiplicativeBinaryOperator);){let N=t[r++],F=C();P=new uo(N,P,F)}return P}function C(){let P=te();for(;l("is");){++r;let N=l("not");N&&++r;let F=ae();if(!(F instanceof sn))throw new SyntaxError("Expected identifier for the test");P=new jL(P,N,F)}return P}function te(){let P=W();for(;a(D.Pipe);){++r;let N=ae();if(!(N instanceof sn))throw new SyntaxError("Expected identifier for the filter");a(D.OpenParen)&&(N=X(N)),P=new FL(P,N)}return P}function ae(){let P=t[r++];switch(P.type){case D.NumericLiteral:{let N=P.value;return N.includes(".")?new $L(Number(N)):new NL(Number(N))}case D.StringLiteral:{let N=P.value;for(;a(D.StringLiteral);)N+=t[r++].value;return new pE(N)}case D.Identifier:return new sn(P.value);case D.OpenParen:{let N=x();return s(D.CloseParen,"Expected closing parenthesis, got ${tokens[current].type} instead."),N}case D.OpenSquareBracket:{let N=[];for(;!a(D.CloseSquareBracket);)N.push(k()),a(D.Comma)&&++r;return++r,new RL(N)}case D.OpenCurlyBracket:{let N=new Map;for(;!a(D.CloseCurlyBracket);){let F=k();s(D.Colon,"Expected colon between key and value in object literal");let J=k();N.set(F,J),a(D.Comma)&&++r}return++r,new DL(N)}default:throw new SyntaxError(`Unexpected token: ${P.type}`)}}for(;r<t.length;)e.body.push(o());return e}function QL(t,e,r=1){if(e===void 0&&(e=t,t=0),r===0)throw new Error("range() step must not be zero");let s=[];if(r>0)for(let n=t;n<e;n+=r)s.push(n);else for(let n=t;n>e;n+=r)s.push(n);return s}function fE(t,e,r,s=1){let n=Math.sign(s);n>=0?(e=(e??=0)<0?Math.max(t.length+e,0):Math.min(e,t.length),r=(r??=t.length)<0?Math.max(t.length+r,0):Math.min(r,t.length)):(e=(e??=t.length-1)<0?Math.max(t.length+e,-1):Math.min(e,t.length-1),r=(r??=-1)<-1?Math.max(t.length+r,-1):Math.min(r,t.length-1));let o=[];for(let a=e;n*a<n*r;a+=s)o.push(t[a]);return o}function YL(t){return t.replace(/\b\w/g,e=>e.toUpperCase())}function JL(t){return ZL(new Date,t)}function ZL(t,e){let r=new Intl.DateTimeFormat(void 0,{month:"long"}),s=new Intl.DateTimeFormat(void 0,{month:"short"}),n=o=>o<10?"0"+o:o.toString();return e.replace(/%[YmdbBHM%]/g,o=>{switch(o){case"%Y":return t.getFullYear().toString();case"%m":return n(t.getMonth()+1);case"%d":return n(t.getDate());case"%b":return s.format(t);case"%B":return r.format(t);case"%H":return n(t.getHours());case"%M":return n(t.getMinutes());case"%%":return"%";default:return o}})}function eP(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function tP(t,e,r,s){if(s===0)return t;let n=s==null||s<0?1/0:s,o=e.length===0?new RegExp("(?=)","gu"):new RegExp(eP(e),"gu");return t.replaceAll(o,a=>n>0?(--n,r):a)}var _E=class extends Error{},mE=class extends Error{},nr=class{type="RuntimeValue";value;builtins=new Map;constructor(t=void 0){this.value=t}__bool__(){return new pe(!!this.value)}toString(){return String(this.value)}},me=class extends nr{type="IntegerValue"},Ye=class extends nr{type="FloatValue";toString(){return this.value%1===0?this.value.toFixed(1):this.value.toString()}},ee=class extends nr{type="StringValue";builtins=new Map([["upper",new Ge(()=>new ee(this.value.toUpperCase()))],["lower",new Ge(()=>new ee(this.value.toLowerCase()))],["strip",new Ge(()=>new ee(this.value.trim()))],["title",new Ge(()=>new ee(YL(this.value)))],["capitalize",new Ge(()=>new ee(this.value.charAt(0).toUpperCase()+this.value.slice(1)))],["length",new me(this.value.length)],["rstrip",new Ge(()=>new ee(this.value.trimEnd()))],["lstrip",new Ge(()=>new ee(this.value.trimStart()))],["startswith",new Ge(t=>{if(t.length===0)throw new Error("startswith() requires at least one argument");let e=t[0];if(e instanceof ee)return new pe(this.value.startsWith(e.value));if(e instanceof ye){for(let r of e.value){if(!(r instanceof ee))throw new Error("startswith() tuple elements must be strings");if(this.value.startsWith(r.value))return new pe(!0)}return new pe(!1)}throw new Error("startswith() argument must be a string or tuple of strings")})],["endswith",new Ge(t=>{if(t.length===0)throw new Error("endswith() requires at least one argument");let e=t[0];if(e instanceof ee)return new pe(this.value.endsWith(e.value));if(e instanceof ye){for(let r of e.value){if(!(r instanceof ee))throw new Error("endswith() tuple elements must be strings");if(this.value.endsWith(r.value))return new pe(!0)}return new pe(!1)}throw new Error("endswith() argument must be a string or tuple of strings")})],["split",new Ge(t=>{let e=t[0]??new We;if(!(e instanceof ee||e instanceof We))throw new Error("sep argument must be a string or null");let r=t[1]??new me(-1);if(!(r instanceof me))throw new Error("maxsplit argument must be a number");let s=[];if(e instanceof We){let n=this.value.trimStart();for(let{0:o,index:a}of n.matchAll(/\S+/g)){if(r.value!==-1&&s.length>=r.value&&a!==void 0){s.push(o+n.slice(a+o.length));break}s.push(o)}}else{if(e.value==="")throw new Error("empty separator");s=this.value.split(e.value),r.value!==-1&&s.length>r.value&&s.push(s.splice(r.value).join(e.value))}return new ye(s.map(n=>new ee(n)))})],["replace",new Ge(t=>{if(t.length<2)throw new Error("replace() requires at least two arguments");let e=t[0],r=t[1];if(!(e instanceof ee&&r instanceof ee))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 We:s=t[2]:s=new We,!(s instanceof me||s instanceof We))throw new Error("replace() count argument must be a number or null");return new ee(tP(this.value,e.value,r.value,s.value))})]])},pe=class extends nr{type="BooleanValue"},rP=/[\x7f-\uffff]/g;function hE(t){return t.replace(rP,e=>"\\u"+e.charCodeAt(0).toString(16).padStart(4,"0"))}function us(t,e={},r=0,s=!0){let{indent:n=null,ensureAscii:o=!1,separators:a=null,sortKeys:i=!1}=e,l,c;switch(a?[l,c]=a:n?(l=",",c=": "):(l=", ",c=": "),t.type){case"NullValue":return"null";case"UndefinedValue":return s?"null":"undefined";case"IntegerValue":case"FloatValue":case"BooleanValue":return JSON.stringify(t.value);case"StringValue":{let p=JSON.stringify(t.value);return o&&(p=hE(p)),p}case"ArrayValue":case"ObjectValue":{let p=n?" ".repeat(n):"",d=`
5
+ `+p.repeat(r),_=d+p;if(t.type==="ArrayValue"){let m=t.value.map(w=>us(w,e,r+1,s));return n?`[${_}${m.join(`${l}${_}`)}${d}]`:`[${m.join(l)}]`}else{let m=Array.from(t.value.entries());i&&(m=m.sort(([x],[E])=>x.localeCompare(E)));let w=m.map(([x,E])=>{let k=JSON.stringify(x);o&&(k=hE(k));let A=`${k}${c}${us(E,e,r+1,s)}`;return n?`${_}${A}`:A});return n?`{${w.join(l)}${d}}`:`{${w.join(l)}}`}}default:throw new Error(`Cannot convert to JSON: ${t.type}`)}}var ct=class extends nr{type="ObjectValue";__bool__(){return new pe(this.value.size>0)}builtins=new Map([["get",new Ge(([t,e])=>{if(!(t instanceof ee))throw new Error(`Object key must be a string: got ${t.type}`);return this.value.get(t.value)??e??new We})],["items",new Ge(()=>this.items())],["keys",new Ge(()=>this.keys())],["values",new Ge(()=>this.values())],["dictsort",new Ge(t=>{let e=new Map,r=t.filter(i=>i instanceof po?(e=i.value,!1):!0),s=r.at(0)??e.get("case_sensitive")??new pe(!1);if(!(s instanceof pe))throw new Error("case_sensitive must be a boolean");let n=r.at(1)??e.get("by")??new ee("key");if(!(n instanceof ee))throw new Error("by must be a string");if(!["key","value"].includes(n.value))throw new Error("by must be either 'key' or 'value'");let o=r.at(2)??e.get("reverse")??new pe(!1);if(!(o instanceof pe))throw new Error("reverse must be a boolean");let a=Array.from(this.value.entries()).map(([i,l])=>new ye([new ee(i),l])).sort((i,l)=>{let c=n.value==="key"?0:1,p=i.value[c],d=l.value[c],_=hd(p,d,s.value);return o.value?-_:_});return new ye(a)})]]);items(){return new ye(Array.from(this.value.entries()).map(([t,e])=>new ye([new ee(t),e])))}keys(){return new ye(Array.from(this.value.keys()).map(t=>new ee(t)))}values(){return new ye(Array.from(this.value.values()))}toString(){return us(this,{},0,!1)}},po=class extends ct{type="KeywordArgumentsValue"},ye=class extends nr{type="ArrayValue";builtins=new Map([["length",new me(this.value.length)]]);__bool__(){return new pe(this.value.length>0)}toString(){return us(this,{},0,!1)}},gE=class extends ye{type="TupleValue"},Ge=class extends nr{type="FunctionValue"},We=class extends nr{type="NullValue"},je=class extends nr{type="UndefinedValue"},cs=class{constructor(t){this.parent=t}variables=new Map([["namespace",new Ge(t=>{if(t.length===0)return new ct(new Map);if(t.length!==1||!(t[0]instanceof ct))throw new Error("`namespace` expects either zero arguments or a single object argument");return t[0]})]]);tests=new Map([["boolean",t=>t.type==="BooleanValue"],["callable",t=>t instanceof Ge],["odd",t=>{if(!(t instanceof me))throw new Error(`cannot odd on ${t.type}`);return t.value%2!==0}],["even",t=>{if(!(t instanceof me))throw new Error(`cannot even on ${t.type}`);return t.value%2===0}],["false",t=>t.type==="BooleanValue"&&!t.value],["true",t=>t.type==="BooleanValue"&&t.value],["none",t=>t.type==="NullValue"],["string",t=>t.type==="StringValue"],["number",t=>t instanceof me||t instanceof Ye],["integer",t=>t instanceof me],["iterable",t=>t.type==="ArrayValue"||t.type==="StringValue"],["mapping",t=>t instanceof ct],["sequence",t=>t instanceof ye||t instanceof ct||t instanceof ee],["lower",t=>{let e=t.value;return t.type==="StringValue"&&e===e.toLowerCase()}],["upper",t=>{let e=t.value;return t.type==="StringValue"&&e===e.toUpperCase()}],["none",t=>t.type==="NullValue"],["defined",t=>t.type!=="UndefinedValue"],["undefined",t=>t.type==="UndefinedValue"],["equalto",(t,e)=>t.value===e.value],["eq",(t,e)=>t.value===e.value]]);set(t,e){return this.declareVariable(t,Zl(e))}declareVariable(t,e){if(this.variables.has(t))throw new SyntaxError(`Variable already declared: ${t}`);return this.variables.set(t,e),e}setVariable(t,e){return this.variables.set(t,e),e}resolve(t){if(this.variables.has(t))return this;if(this.parent)return this.parent.resolve(t);throw new Error(`Unknown variable: ${t}`)}lookupVariable(t){try{return this.resolve(t).variables.get(t)??new je}catch{return new je}}};function sP(t){t.set("false",!1),t.set("true",!0),t.set("none",null),t.set("raise_exception",e=>{throw new Error(e)}),t.set("range",QL),t.set("strftime_now",JL),t.set("True",!0),t.set("False",!1),t.set("None",null)}function wE(t,e){let r=e.split("."),s=t;for(let n of r)if(s instanceof ct)s=s.value.get(n)??new je;else if(s instanceof ye){let o=parseInt(n,10);if(!isNaN(o)&&o>=0&&o<s.value.length)s=s.value[o];else return new je}else return new je;return s}function hd(t,e,r=!1){if(t instanceof We&&e instanceof We)return 0;if(t instanceof We||e instanceof We)throw new Error(`Cannot compare ${t.type} with ${e.type}`);if(t instanceof je&&e instanceof je)return 0;if(t instanceof je||e instanceof je)throw new Error(`Cannot compare ${t.type} with ${e.type}`);let s=o=>o instanceof me||o instanceof Ye||o instanceof pe,n=o=>o instanceof pe?o.value?1:0:o.value;if(s(t)&&s(e)){let o=n(t),a=n(e);return o<a?-1:o>a?1:0}if(t.type!==e.type)throw new Error(`Cannot compare different types: ${t.type} and ${e.type}`);if(t.type==="StringValue"){let o=t.value,a=e.value;return r||(o=o.toLowerCase(),a=a.toLowerCase()),o<a?-1:o>a?1:0}else throw new Error(`Cannot compare type: ${t.type}`)}var nP=class{global;constructor(t){this.global=t??new cs}run(t){return this.evaluate(t,this.global)}evaluateBinaryExpression(t,e){let r=this.evaluate(t.left,e);switch(t.operator.value){case"and":return r.__bool__().value?this.evaluate(t.right,e):r;case"or":return r.__bool__().value?r:this.evaluate(t.right,e)}let s=this.evaluate(t.right,e);switch(t.operator.value){case"==":return new pe(r.value==s.value);case"!=":return new pe(r.value!=s.value)}if(r instanceof je||s instanceof je){if(s instanceof je&&["in","not in"].includes(t.operator.value))return new pe(t.operator.value==="not in");throw new Error(`Cannot perform operation ${t.operator.value} on undefined values`)}else{if(r instanceof We||s instanceof We)throw new Error("Cannot perform operation on null values");if(t.operator.value==="~")return new ee(r.value.toString()+s.value.toString());if((r instanceof me||r instanceof Ye)&&(s instanceof me||s instanceof Ye)){let n=r.value,o=s.value;switch(t.operator.value){case"+":case"-":case"*":{let a=t.operator.value==="+"?n+o:t.operator.value==="-"?n-o:n*o;return r instanceof Ye||s instanceof Ye?new Ye(a):new me(a)}case"/":return new Ye(n/o);case"%":{let a=n%o;return r instanceof Ye||s instanceof Ye?new Ye(a):new me(a)}case"<":return new pe(n<o);case">":return new pe(n>o);case">=":return new pe(n>=o);case"<=":return new pe(n<=o)}}else if(r instanceof ye&&s instanceof ye){if(t.operator.value==="+")return new ye(r.value.concat(s.value))}else if(s instanceof ye){let n=s.value.find(o=>o.value===r.value)!==void 0;switch(t.operator.value){case"in":return new pe(n);case"not in":return new pe(!n)}}}if((r instanceof ee||s instanceof ee)&&t.operator.value==="+")return new ee(r.value.toString()+s.value.toString());if(r instanceof ee&&s instanceof ee)switch(t.operator.value){case"in":return new pe(s.value.includes(r.value));case"not in":return new pe(!s.value.includes(r.value))}if(r instanceof ee&&s instanceof ct)switch(t.operator.value){case"in":return new pe(s.value.has(r.value));case"not in":return new pe(!s.value.has(r.value))}throw new SyntaxError(`Unknown operator "${t.operator.value}" between ${r.type} and ${s.type}`)}evaluateArguments(t,e){let r=[],s=new Map;for(let n of t)if(n.type==="SpreadExpression"){let o=n,a=this.evaluate(o.argument,e);if(!(a instanceof ye))throw new Error(`Cannot unpack non-iterable type: ${a.type}`);for(let i of a.value)r.push(i)}else if(n.type==="KeywordArgumentExpression"){let o=n;s.set(o.key.value,this.evaluate(o.value,e))}else{if(s.size>0)throw new Error("Positional arguments must come before keyword arguments");r.push(this.evaluate(n,e))}return[r,s]}applyFilter(t,e,r){if(e.type==="Identifier"){let s=e;if(s.value==="safe")return t;if(s.value==="tojson")return new ee(us(t,{}));if(t instanceof ye)switch(s.value){case"list":return t;case"first":return t.value[0];case"last":return t.value[t.value.length-1];case"length":return new me(t.value.length);case"reverse":return new ye(t.value.slice().reverse());case"sort":return new ye(t.value.slice().sort((n,o)=>hd(n,o,!1)));case"join":return new ee(t.value.map(n=>n.value).join(""));case"string":return new ee(us(t,{},0,!1));case"unique":{let n=new Set,o=[];for(let a of t.value)n.has(a.value)||(n.add(a.value),o.push(a));return new ye(o)}default:throw new Error(`Unknown ArrayValue filter: ${s.value}`)}else if(t instanceof ee)switch(s.value){case"length":case"upper":case"lower":case"title":case"capitalize":{let n=t.builtins.get(s.value);if(n instanceof Ge)return n.value([],r);if(n instanceof me)return n;throw new Error(`Unknown StringValue filter: ${s.value}`)}case"trim":return new ee(t.value.trim());case"indent":return new ee(t.value.split(`
6
6
  `).map((n,o)=>o===0||n.length===0?n:" "+n).join(`
7
- `));case"join":case"string":return t;case"int":{let n=parseInt(t.value,10);return new me(isNaN(n)?0:n)}case"float":{let n=parseFloat(t.value);return new Ze(isNaN(n)?0:n)}default:throw new Error(`Unknown StringValue filter: ${s.value}`)}else if(t instanceof me||t instanceof Ze)switch(s.value){case"abs":return t instanceof me?new me(Math.abs(t.value)):new Ze(Math.abs(t.value));case"int":return new me(Math.floor(t.value));case"float":return new Ze(t.value);case"string":return new ee(t.toString());default:throw new Error(`Unknown NumericValue filter: ${s.value}`)}else if(t instanceof dt)switch(s.value){case"items":return new ye(Array.from(t.value.entries()).map(([n,o])=>new ye([new ee(n),o])));case"length":return new me(t.value.size);default:{let n=t.builtins.get(s.value);if(n)return n instanceof qe?n.value([],r):n;throw new Error(`Unknown ObjectValue filter: ${s.value}`)}}else if(t instanceof pe)switch(s.value){case"bool":return new pe(t.value);case"int":return new me(t.value?1:0);case"float":return new Ze(t.value?1:0);case"string":return new ee(t.value?"true":"false");default:throw new Error(`Unknown BooleanValue filter: ${s.value}`)}throw new Error(`Cannot apply filter "${s.value}" to type: ${t.type}`)}else if(e.type==="CallExpression"){let s=e;if(s.callee.type!=="Identifier")throw new Error(`Unknown filter: ${s.callee.type}`);let n=s.callee.value;if(n==="tojson"){let[,o]=this.evaluateArguments(s.args,r),a=o.get("indent")??new Ve;if(!(a instanceof me||a instanceof Ve))throw new Error("If set, indent must be a number");let i=o.get("ensure_ascii")??new pe(!1);if(!(i instanceof pe))throw new Error("If set, ensure_ascii must be a boolean");let l=o.get("sort_keys")??new pe(!1);if(!(l instanceof pe))throw new Error("If set, sort_keys must be a boolean");let c=o.get("separators")??new Ve,p=null;if(c instanceof ye||c instanceof Wk){if(c.value.length!==2)throw new Error("separators must be a tuple of two strings");let[f,_]=c.value;if(!(f instanceof ee)||!(_ instanceof ee))throw new Error("separators must be a tuple of two strings");p=[f.value,_.value]}else if(!(c instanceof Ve))throw new Error("If set, separators must be a tuple of two strings");return new ee(fs(t,{indent:a.value,ensureAscii:i.value,sortKeys:l.value,separators:p}))}else if(n==="join"){let o;if(t instanceof ee)o=Array.from(t.value);else if(t instanceof ye)o=t.value.map(c=>c.value);else throw new Error(`Cannot apply filter "${n}" to type: ${t.type}`);let[a,i]=this.evaluateArguments(s.args,r),l=a.at(0)??i.get("separator")??new ee("");if(!(l instanceof ee))throw new Error("separator must be a string");return new ee(o.join(l.value))}else if(n==="int"||n==="float"){let[o,a]=this.evaluateArguments(s.args,r),i=o.at(0)??a.get("default")??(n==="int"?new me(0):new Ze(0));if(t instanceof ee){let l=n==="int"?parseInt(t.value,10):parseFloat(t.value);return isNaN(l)?i:n==="int"?new me(l):new Ze(l)}else{if(t instanceof me||t instanceof Ze)return t;if(t instanceof pe)return n==="int"?new me(t.value?1:0):new Ze(t.value?1:0);throw new Error(`Cannot apply filter "${n}" to type: ${t.type}`)}}else if(n==="default"){let[o,a]=this.evaluateArguments(s.args,r),i=o[0]??new ee(""),l=o[1]??a.get("boolean")??new pe(!1);if(!(l instanceof pe))throw new Error("`default` filter flag must be a boolean");return t instanceof Ge||l.value&&!t.__bool__().value?i:t}if(t instanceof ye){switch(n){case"sort":{let[o,a]=this.evaluateArguments(s.args,r),i=o.at(0)??a.get("reverse")??new pe(!1);if(!(i instanceof pe))throw new Error("reverse must be a boolean");let l=o.at(1)??a.get("case_sensitive")??new pe(!1);if(!(l instanceof pe))throw new Error("case_sensitive must be a boolean");let c=o.at(2)??a.get("attribute")??new Ve;if(!(c instanceof ee||c instanceof me||c instanceof Ve))throw new Error("attribute must be a string, integer, or null");let p=f=>{if(c instanceof Ve)return f;let _=c instanceof me?String(c.value):c.value;return Vk(f,_)};return new ye(t.value.slice().sort((f,_)=>{let m=p(f),w=p(_),x=ld(m,w,l.value);return i.value?-x:x}))}case"selectattr":case"rejectattr":{let o=n==="selectattr";if(t.value.some(f=>!(f instanceof dt)))throw new Error(`\`${n}\` can only be applied to array of objects`);if(s.args.some(f=>f.type!=="StringLiteral"))throw new Error(`arguments of \`${n}\` must be strings`);let[a,i,l]=s.args.map(f=>this.evaluate(f,r)),c;if(i){let f=r.tests.get(i.value);if(!f)throw new Error(`Unknown test: ${i.value}`);c=f}else c=(...f)=>f[0].__bool__().value;let p=t.value.filter(f=>{let _=f.value.get(a.value),m=_?c(_,l):!1;return o?m:!m});return new ye(p)}case"map":{let[,o]=this.evaluateArguments(s.args,r);if(o.has("attribute")){let a=o.get("attribute");if(!(a instanceof ee))throw new Error("attribute must be a string");let i=o.get("default"),l=t.value.map(c=>{if(!(c instanceof dt))throw new Error("items in map must be an object");let p=Vk(c,a.value);return p instanceof Ge?i??new Ge:p});return new ye(l)}else throw new Error("`map` expressions without `attribute` set are not currently supported.")}}throw new Error(`Unknown ArrayValue filter: ${n}`)}else if(t instanceof ee){switch(n){case"indent":{let[o,a]=this.evaluateArguments(s.args,r),i=o.at(0)??a.get("width")??new me(4);if(!(i instanceof me))throw new Error("width must be a number");let l=o.at(1)??a.get("first")??new pe(!1),c=o.at(2)??a.get("blank")??new pe(!1),p=t.value.split(`
8
- `),f=" ".repeat(i.value),_=p.map((m,w)=>!l.value&&w===0||!c.value&&m.length===0?m:f+m);return new ee(_.join(`
9
- `))}case"replace":{let o=t.builtins.get("replace");if(!(o instanceof qe))throw new Error("replace filter not available");let[a,i]=this.evaluateArguments(s.args,r);return o.value([...a,new io(i)],r)}}throw new Error(`Unknown StringValue filter: ${n}`)}else if(t instanceof dt){let o=t.builtins.get(n);if(o&&o instanceof qe){let[a,i]=this.evaluateArguments(s.args,r);return i.size>0&&a.push(new io(i)),o.value(a,r)}throw new Error(`Unknown ObjectValue filter: ${n}`)}else throw new Error(`Cannot apply filter "${n}" to type: ${t.type}`)}throw new Error(`Unknown filter: ${e.type}`)}evaluateFilterExpression(t,e){let r=this.evaluate(t.operand,e);return this.applyFilter(r,t.filter,e)}evaluateTestExpression(t,e){let r=this.evaluate(t.operand,e),s=e.tests.get(t.test.value);if(!s)throw new Error(`Unknown test: ${t.test.value}`);let n=s(r);return new pe(t.negate?!n:n)}evaluateSelectExpression(t,e){return this.evaluate(t.test,e).__bool__().value?this.evaluate(t.lhs,e):new Ge}evaluateUnaryExpression(t,e){let r=this.evaluate(t.argument,e);if(t.operator.value==="not")return new pe(!r.value);throw new SyntaxError(`Unknown operator: ${t.operator.value}`)}evaluateTernaryExpression(t,e){return this.evaluate(t.condition,e).__bool__().value?this.evaluate(t.trueExpr,e):this.evaluate(t.falseExpr,e)}evalProgram(t,e){return this.evaluateBlock(t.body,e)}evaluateBlock(t,e){let r="";for(let s of t){let n=this.evaluate(s,e);n.type!=="NullValue"&&n.type!=="UndefinedValue"&&(r+=n.toString())}return new ee(r)}evaluateIdentifier(t,e){return e.lookupVariable(t.value)}evaluateCallExpression(t,e){let[r,s]=this.evaluateArguments(t.args,e);s.size>0&&r.push(new io(s));let n=this.evaluate(t.callee,e);if(n.type!=="FunctionValue")throw new Error(`Cannot call something that is not a function: got ${n.type}`);return n.value(r,e)}evaluateSliceExpression(t,e,r){if(!(t instanceof ye||t instanceof ee))throw new Error("Slice object must be an array or string");let s=this.evaluate(e.start,r),n=this.evaluate(e.stop,r),o=this.evaluate(e.step,r);if(!(s instanceof me||s instanceof Ge))throw new Error("Slice start must be numeric or undefined");if(!(n instanceof me||n instanceof Ge))throw new Error("Slice stop must be numeric or undefined");if(!(o instanceof me||o instanceof Ge))throw new Error("Slice step must be numeric or undefined");return t instanceof ye?new ye(Uk(t.value,s.value,n.value,o.value)):new ee(Uk(Array.from(t.value),s.value,n.value,o.value).join(""))}evaluateMemberExpression(t,e){let r=this.evaluate(t.object,e),s;if(t.computed){if(t.property.type==="SliceExpression")return this.evaluateSliceExpression(r,t.property,e);s=this.evaluate(t.property,e)}else s=new ee(t.property.value);let n;if(r instanceof dt){if(!(s instanceof ee))throw new Error(`Cannot access property with non-string: got ${s.type}`);n=r.value.get(s.value)??r.builtins.get(s.value)}else if(r instanceof ye||r instanceof ee)if(s instanceof me)n=r.value.at(s.value),r instanceof ee&&(n=new ee(r.value.at(s.value)));else if(s instanceof ee)n=r.builtins.get(s.value);else throw new Error(`Cannot access property with non-string/non-number: got ${s.type}`);else{if(!(s instanceof ee))throw new Error(`Cannot access property with non-string: got ${s.type}`);n=r.builtins.get(s.value)}return n instanceof ar?n:new Ge}evaluateSet(t,e){let r=t.value?this.evaluate(t.value,e):this.evaluateBlock(t.body,e);if(t.assignee.type==="Identifier"){let s=t.assignee.value;e.setVariable(s,r)}else if(t.assignee.type==="TupleLiteral"){let s=t.assignee;if(!(r instanceof ye))throw new Error(`Cannot unpack non-iterable type in set: ${r.type}`);let n=r.value;if(n.length!==s.value.length)throw new Error(`Too ${s.value.length>n.length?"few":"many"} items to unpack in set`);for(let o=0;o<s.value.length;++o){let a=s.value[o];if(a.type!=="Identifier")throw new Error(`Cannot unpack to non-identifier in set: ${a.type}`);e.setVariable(a.value,n[o])}}else if(t.assignee.type==="MemberExpression"){let s=t.assignee,n=this.evaluate(s.object,e);if(!(n instanceof dt))throw new Error("Cannot assign to member of non-object");if(s.property.type!=="Identifier")throw new Error("Cannot assign to member with non-identifier property");n.value.set(s.property.value,r)}else throw new Error(`Invalid LHS inside assignment expression: ${JSON.stringify(t.assignee)}`);return new Ve}evaluateIf(t,e){let r=this.evaluate(t.test,e);return this.evaluateBlock(r.__bool__().value?t.body:t.alternate,e)}evaluateFor(t,e){let r=new ds(e),s,n;if(t.iterable.type==="SelectExpression"){let c=t.iterable;n=this.evaluate(c.lhs,r),s=c.test}else n=this.evaluate(t.iterable,r);if(!(n instanceof ye||n instanceof dt))throw new Error(`Expected iterable or object type in for loop: got ${n.type}`);n instanceof dt&&(n=n.keys());let o=[],a=[];for(let c=0;c<n.value.length;++c){let p=new ds(r),f=n.value[c],_;if(t.loopvar.type==="Identifier")_=m=>m.setVariable(t.loopvar.value,f);else if(t.loopvar.type==="TupleLiteral"){let m=t.loopvar;if(f.type!=="ArrayValue")throw new Error(`Cannot unpack non-iterable type: ${f.type}`);let w=f;if(m.value.length!==w.value.length)throw new Error(`Too ${m.value.length>w.value.length?"few":"many"} items to unpack`);_=x=>{for(let k=0;k<m.value.length;++k){if(m.value[k].type!=="Identifier")throw new Error(`Cannot unpack non-identifier type: ${m.value[k].type}`);x.setVariable(m.value[k].value,w.value[k])}}}else throw new Error(`Invalid loop variable(s): ${t.loopvar.type}`);s&&(_(p),!this.evaluate(s,p).__bool__().value)||(o.push(f),a.push(_))}let i="",l=!0;for(let c=0;c<o.length;++c){let p=new Map([["index",new me(c+1)],["index0",new me(c)],["revindex",new me(o.length-c)],["revindex0",new me(o.length-c-1)],["first",new pe(c===0)],["last",new pe(c===o.length-1)],["length",new me(o.length)],["previtem",c>0?o[c-1]:new Ge],["nextitem",c<o.length-1?o[c+1]:new Ge]]);r.setVariable("loop",new dt(p)),a[c](r);try{let f=this.evaluateBlock(t.body,r);i+=f.value}catch(f){if(f instanceof Gk)continue;if(f instanceof jk)break;throw f}l=!1}if(l){let c=this.evaluateBlock(t.defaultBlock,r);i+=c.value}return new ee(i)}evaluateMacro(t,e){return e.setVariable(t.name.value,new qe((r,s)=>{let n=new ds(s);r=r.slice();let o;r.at(-1)?.type==="KeywordArgumentsValue"&&(o=r.pop());for(let a=0;a<t.args.length;++a){let i=t.args[a],l=r[a];if(i.type==="Identifier"){let c=i;if(!l)throw new Error(`Missing positional argument: ${c.value}`);n.setVariable(c.value,l)}else if(i.type==="KeywordArgumentExpression"){let c=i,p=l??o?.value.get(c.key.value)??this.evaluate(c.value,n);n.setVariable(c.key.value,p)}else throw new Error(`Unknown argument type: ${i.type}`)}return this.evaluateBlock(t.body,n)})),new Ve}evaluateCallStatement(t,e){let r=new qe((i,l)=>{let c=new ds(l);if(t.callerArgs)for(let p=0;p<t.callerArgs.length;++p){let f=t.callerArgs[p];if(f.type!=="Identifier")throw new Error(`Caller parameter must be an identifier, got ${f.type}`);c.setVariable(f.value,i[p]??new Ge)}return this.evaluateBlock(t.body,c)}),[s,n]=this.evaluateArguments(t.call.args,e);s.push(new io(n));let o=this.evaluate(t.call.callee,e);if(o.type!=="FunctionValue")throw new Error(`Cannot call something that is not a function: got ${o.type}`);let a=new ds(e);return a.setVariable("caller",r),o.value(s,a)}evaluateFilterStatement(t,e){let r=this.evaluateBlock(t.body,e);return this.applyFilter(r,t.filter,e)}evaluate(t,e){if(!t)return new Ge;switch(t.type){case"Program":return this.evalProgram(t,e);case"Set":return this.evaluateSet(t,e);case"If":return this.evaluateIf(t,e);case"For":return this.evaluateFor(t,e);case"Macro":return this.evaluateMacro(t,e);case"CallStatement":return this.evaluateCallStatement(t,e);case"Break":throw new jk;case"Continue":throw new Gk;case"IntegerLiteral":return new me(t.value);case"FloatLiteral":return new Ze(t.value);case"StringLiteral":return new ee(t.value);case"ArrayLiteral":return new ye(t.value.map(r=>this.evaluate(r,e)));case"TupleLiteral":return new Wk(t.value.map(r=>this.evaluate(r,e)));case"ObjectLiteral":{let r=new Map;for(let[s,n]of t.value){let o=this.evaluate(s,e);if(!(o instanceof ee))throw new Error(`Object keys must be strings: got ${o.type}`);r.set(o.value,this.evaluate(n,e))}return new dt(r)}case"Identifier":return this.evaluateIdentifier(t,e);case"CallExpression":return this.evaluateCallExpression(t,e);case"MemberExpression":return this.evaluateMemberExpression(t,e);case"UnaryExpression":return this.evaluateUnaryExpression(t,e);case"BinaryExpression":return this.evaluateBinaryExpression(t,e);case"FilterExpression":return this.evaluateFilterExpression(t,e);case"FilterStatement":return this.evaluateFilterStatement(t,e);case"TestExpression":return this.evaluateTestExpression(t,e);case"SelectExpression":return this.evaluateSelectExpression(t,e);case"Ternary":return this.evaluateTernaryExpression(t,e);case"Comment":return new Ve;default:throw new SyntaxError(`Unknown node type: ${t.type}`)}}};function Wl(t){switch(typeof t){case"number":return Number.isInteger(t)?new me(t):new Ze(t);case"string":return new ee(t);case"boolean":return new pe(t);case"undefined":return new Ge;case"object":return t===null?new Ve:Array.isArray(t)?new ye(t.map(Wl)):new dt(new Map(Object.entries(t).map(([e,r])=>[e,Wl(r)])));case"function":return new qe((e,r)=>{let s=t(...e.map(n=>n.value))??null;return Wl(s)});default:throw new Error(`Cannot convert to runtime value: ${t}`)}}var it=`
10
- `,LL="{%- ",PL=" -%}";function zL(t){switch(t.operator.type){case"MultiplicativeBinaryOperator":return 4;case"AdditiveBinaryOperator":return 3;case"ComparisonBinaryOperator":return 2;case"Identifier":return t.operator.value==="and"?1:t.operator.value==="in"||t.operator.value==="not in"?2:0}return 0}function NL(t,e=" "){let r=typeof e=="number"?" ".repeat(e):e;return Qt(t.body,0,r).replace(/\n$/,"")}function xt(...t){return LL+t.join(" ")+PL}function Qt(t,e,r){return t.map(s=>$L(s,e,r)).join(it)}function $L(t,e,r){let s=r.repeat(e);switch(t.type){case"Program":return Qt(t.body,e,r);case"If":return RL(t,e,r);case"For":return DL(t,e,r);case"Set":return FL(t,e,r);case"Macro":return BL(t,e,r);case"Break":return s+xt("break");case"Continue":return s+xt("continue");case"CallStatement":return UL(t,e,r);case"FilterStatement":return jL(t,e,r);case"Comment":return s+"{# "+t.value+" #}";default:return s+"{{- "+ke(t)+" -}}"}}function RL(t,e,r){let s=r.repeat(e),n=[],o=t;for(;o&&(n.push({test:o.test,body:o.body}),o.alternate.length===1&&o.alternate[0].type==="If");)o=o.alternate[0];let a=s+xt("if",ke(n[0].test))+it+Qt(n[0].body,e+1,r);for(let i=1;i<n.length;++i)a+=it+s+xt("elif",ke(n[i].test))+it+Qt(n[i].body,e+1,r);return o&&o.alternate.length>0&&(a+=it+s+xt("else")+it+Qt(o.alternate,e+1,r)),a+=it+s+xt("endif"),a}function DL(t,e,r){let s=r.repeat(e),n="";if(t.iterable.type==="SelectExpression"){let a=t.iterable;n=`${ke(a.lhs)} if ${ke(a.test)}`}else n=ke(t.iterable);let o=s+xt("for",ke(t.loopvar),"in",n)+it+Qt(t.body,e+1,r);return t.defaultBlock.length>0&&(o+=it+s+xt("else")+it+Qt(t.defaultBlock,e+1,r)),o+=it+s+xt("endfor"),o}function FL(t,e,r){let s=r.repeat(e),n=ke(t.assignee),o=t.value?ke(t.value):"",a=s+xt("set",`${n}${t.value?" = "+o:""}`);return t.body.length===0?a:a+it+Qt(t.body,e+1,r)+it+s+xt("endset")}function BL(t,e,r){let s=r.repeat(e),n=t.args.map(ke).join(", ");return s+xt("macro",`${t.name.value}(${n})`)+it+Qt(t.body,e+1,r)+it+s+xt("endmacro")}function UL(t,e,r){let s=r.repeat(e),n=t.callerArgs&&t.callerArgs.length>0?`(${t.callerArgs.map(ke).join(", ")})`:"",o=ke(t.call),a=s+xt(`call${n}`,o)+it;return a+=Qt(t.body,e+1,r)+it,a+=s+xt("endcall"),a}function jL(t,e,r){let s=r.repeat(e),n=t.filter.type==="Identifier"?t.filter.value:ke(t.filter),o=s+xt("filter",n)+it;return o+=Qt(t.body,e+1,r)+it,o+=s+xt("endfilter"),o}function ke(t,e=-1){switch(t.type){case"SpreadExpression":return`*${ke(t.argument)}`;case"Identifier":return t.value;case"IntegerLiteral":return`${t.value}`;case"FloatLiteral":return`${t.value}`;case"StringLiteral":return JSON.stringify(t.value);case"BinaryExpression":{let r=t,s=zL(r),n=ke(r.left,s),o=ke(r.right,s+1),a=`${n} ${r.operator.value} ${o}`;return s<e?`(${a})`:a}case"UnaryExpression":{let r=t;return r.operator.value+(r.operator.value==="not"?" ":"")+ke(r.argument,1/0)}case"CallExpression":{let r=t,s=r.args.map(ke).join(", ");return`${ke(r.callee)}(${s})`}case"MemberExpression":{let r=t,s=ke(r.object);["Identifier","MemberExpression","CallExpression","StringLiteral","IntegerLiteral","FloatLiteral","ArrayLiteral","TupleLiteral","ObjectLiteral"].includes(r.object.type)||(s=`(${s})`);let n=ke(r.property);return!r.computed&&r.property.type!=="Identifier"&&(n=`(${n})`),r.computed?`${s}[${n}]`:`${s}.${n}`}case"FilterExpression":{let r=t,s=ke(r.operand,1/0);return r.filter.type==="CallExpression"?`${s} | ${ke(r.filter)}`:`${s} | ${r.filter.value}`}case"SelectExpression":{let r=t;return`${ke(r.lhs)} if ${ke(r.test)}`}case"TestExpression":{let r=t;return`${ke(r.operand)} is${r.negate?" not":""} ${r.test.value}`}case"ArrayLiteral":case"TupleLiteral":{let r=t.value.map(ke),s=t.type==="ArrayLiteral"?"[]":"()";return`${s[0]}${r.join(", ")}${s[1]}`}case"ObjectLiteral":return`{${Array.from(t.value.entries()).map(([s,n])=>`${ke(s)}: ${ke(n)}`).join(", ")}}`;case"SliceExpression":{let r=t,s=r.start?ke(r.start):"",n=r.stop?ke(r.stop):"",o=r.step?`:${ke(r.step)}`:"";return`${s}:${n}${o}`}case"KeywordArgumentExpression":{let r=t;return`${r.key.value}=${ke(r.value)}`}case"Ternary":{let r=t,s=`${ke(r.trueExpr)} if ${ke(r.condition,0)} else ${ke(r.falseExpr)}`;return e>-1?`(${s})`:s}default:throw new Error(`Unknown expression type: ${t.type}`)}}var Hk=class{parsed;constructor(t){let e=JC(t,{lstrip_blocks:!0,trim_blocks:!0});this.parsed=vL(e)}render(t){let e=new ds;if(IL(e),t)for(let[n,o]of Object.entries(t))e.set(n,o);return new CL(e).run(this.parsed).value}format(t){return NL(this.parsed,t?.indent||" ")}};var rt=class{constructor(){let t=function(...e){return t._call(...e)};return Object.setPrototypeOf(t,new.target.prototype)}_call(...t){throw Error("Must implement _call method in subclass")}};import sn from"fs";var GL={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"},Ir=class t{constructor(e){if(this.filePath=e,this.headers=new Headers,this.exists=sn.existsSync(e),this.exists){this.status=200,this.statusText="OK";let r=sn.statSync(e);this.headers.set("content-length",r.size.toString()),this.updateContentType();let s=sn.createReadStream(e);this.body=new ReadableStream({start(n){s.on("data",o=>n.enqueue(o)),s.on("end",()=>n.close()),s.on("error",o=>n.error(o))},cancel(){s.destroy()}})}else this.status=404,this.statusText="Not Found",this.body=null}updateContentType(){let e=this.filePath.toString().split(".").pop().toLowerCase();this.headers.set("content-type",GL[e]??"application/octet-stream")}clone(){let e=new t(this.filePath);return e.exists=this.exists,e.status=this.status,e.statusText=this.statusText,e.headers=new Headers(this.headers),e}async arrayBuffer(){return(await sn.promises.readFile(this.filePath)).buffer}async blob(){let e=await sn.promises.readFile(this.filePath);return new Blob([e],{type:this.headers.get("content-type")})}async text(){return await sn.promises.readFile(this.filePath,"utf8")}async json(){return JSON.parse(await this.text())}};import lo from"fs";import Vl from"path";var nn=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(ie.IS_CRYPTO_AVAILABLE){let i=new Uint32Array(1);crypto.getRandomValues(i),e=i[0]}else e=Date.now()>>>0;let r=this._mt,s=(i,l)=>Math.imul(i,l)>>>0,n=[];for(let i=e||0;i>0;i=Math.floor(i/4294967296))n.push(i&4294967295);n.length||n.push(0),r[0]=19650218;for(let i=1;i<624;++i)r[i]=s(1812433253,r[i-1]^r[i-1]>>>30)+i>>>0;let o=1,a=0;for(let i=Math.max(624,n.length);i>0;--i,++o,++a)o>=624&&(r[0]=r[623],o=1),a>=n.length&&(a=0),r[o]=(r[o]^s(r[o-1]^r[o-1]>>>30,1664525))+n[a]+a>>>0;for(let i=623;i>0;--i,++o)o>=624&&(r[0]=r[623],o=1),r[o]=(r[o]^s(r[o-1]^r[o-1]>>>30,1566083941))-o>>>0;r[0]=2147483648,this._idx=624,this._gauss_next=null}_int32(){let e=this._mt;if(this._idx>=624){for(let s=0;s<624;++s){let n=e[s]&2147483648|e[(s+1)%624]&2147483647;e[s]=(e[(s+397)%624]^n>>>1^(n&1?2567483615:0))>>>0}this._idx=0}let r=e[this._idx++];return r^=r>>>11,r^=r<<7&2636928640,r^=r<<15&4022730752,r^=r>>>18,r>>>0}random(){return((this._int32()>>>5)*67108864+(this._int32()>>>6))/9007199254740992}gauss(e=0,r=1){let s=this._gauss_next;if(this._gauss_next=null,s===null){let n=this.random()*2*Math.PI,o=Math.sqrt(-2*Math.log(1-this.random()));s=Math.cos(n)*o,this._gauss_next=Math.sin(n)*o}return e+s*r}shuffle(e){for(let r=e.length-1;r>0;--r){let s=32-Math.clz32(r+1),n=this._int32()>>>32-s;for(;n>r;)n=this._int32()>>>32-s;let o=e[r];e[r]=e[n],e[n]=o}}choices(e,r){return e[Xk(this._random_fn,r)]}};function Xk(t,e){let r=0;for(let n=0;n<e.length;++n)r+=e[n];let s=t()*r;for(let n=0;n<e.length;++n)if(s-=e[n],s<0)return n;return e.length-1}var ir=new nn,_s=Object.freeze({Random:nn,seed:ir.seed.bind(ir),random:ir.random.bind(ir),gauss:ir.gauss.bind(ir),shuffle:ir.shuffle.bind(ir),choices:ir.choices.bind(ir)}),Kk=t=>Xk(_s.random,t);var qL=new nn,on=class{constructor(e){this.path=e}async match(e){let r=Vl.join(this.path,e),s=new Ir(r);if(s.exists)return s}async put(e,r,s=void 0){let n=Vl.join(this.path,e),o=ie.IS_PROCESS_AVAILABLE?process.pid:Date.now(),a=qL._int32().toString(36),i=n+`.tmp.${o}.${a}`;try{let l=r.headers.get("Content-Length"),c=parseInt(l??"0"),p=0;await lo.promises.mkdir(Vl.dirname(n),{recursive:!0});let f=lo.createWriteStream(i),_=r.body.getReader();for(;;){let{done:m,value:w}=await _.read();if(m)break;await new Promise((k,E)=>{f.write(w,A=>{if(A){E(A);return}k()})}),p+=w.length;let x=c?p/c*100:0;s?.({progress:x,loaded:p,total:c})}await new Promise((m,w)=>{f.close(x=>x?w(x):m())}),await lo.promises.rename(i,n)}catch(l){try{await lo.promises.unlink(i)}catch{}throw l}}async delete(e){let r=Vl.join(this.path,e);try{return await lo.promises.unlink(r),!0}catch{return!1}}};var Qk={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"},Hl=100,Yk=/^(\b[\w\-.]+\b\/)?\b[\w\-.]{1,96}\b$/;function co(...t){return t=t.map((e,r)=>(r&&(e=e.replace(new RegExp("^/"),"")),r!==t.length-1&&(e=e.replace(new RegExp("/$"),"")),e)),t.join("/")}function Cr(t,e=null,r=null){let s;try{s=new URL(t)}catch{return!1}return!(e&&!e.includes(s.protocol)||r&&!r.includes(s.hostname))}function Jk(t){return!(!Yk.test(t)||t.includes("..")||t.includes("--")||t.endsWith(".git")||t.endsWith(".ipynb"))}function Zk(t,e,r){if(!r)return null;let s=Qk[t]??`Error (${t}) occurred while trying to load file`;throw Error(`${s}: "${e}".`)}async function eE(t,e,r){let s=t.headers.get("Content-Length"),n=s?parseInt(s,10):r??0;s===null&&!r&&Z.warn("Unable to determine content-length from response headers. Will expand buffer when needed.");let o=new Uint8Array(n),a=0,i=t.body.getReader();async function l(){let{done:c,value:p}=await i.read();if(c)return;let f=a+p.length;if(f>n){n=f;let m=new Uint8Array(n);m.set(o),o=m}o.set(p,a),a=f;let _=a/n*100;return e({progress:_,loaded:a,total:n}),l()}return await l(),o}function cd(t){return Cr(t,["blob:"])}function ud(t){let e;if(typeof location<"u"&&location.href)e=location.href;else if(typeof import.meta<"u"&&import.meta.url)e=import.meta.url;else return t;return new URL(t,e).href}var rE="SHA-256",WL="experimental_transformers-hash-cache",tE=t=>({algorithm:rE,value:t}),uo=class{#t=null;_getHashCache=()=>(this.#t??=caches.open(WL),this.#t);static isAvailable=()=>typeof navigator<"u"&&"crossOriginStorage"in navigator;match=async e=>{let r=await this._getFileHash(e);if(r)try{let[s]=await navigator.crossOriginStorage.requestFileHandles([tE(r)]),n=await s.getFile();return new Response(n,{headers:{"Content-Length":String(n.size)}})}catch{return}};put=async(e,r)=>{let s=await this._getFileHash(e);if(s){let n=await r.blob();await this._storeBlobInCOS(n,s)}else this._processAndStore(e,r.body)};_storeBlobInCOS=async(e,r)=>{let[s]=await navigator.crossOriginStorage.requestFileHandles([tE(r)],{create:!0}),n=await s.createWritable();await n.write(e),await n.close()};_processAndStore=async(e,r)=>{try{let s=[];for await(let a of r)s.push(a);let n=new Blob(s),o=await this._getBlobHash(n);await this._storeBlobInCOS(n,o);try{await(await this._getHashCache()).put(e,new Response(o))}catch{}}catch{}};delete=async e=>{try{return await(await this._getHashCache()).delete(e)}catch{return!1}};_getFileHash=async e=>{try{let r=await this._getHashCache(),s=await r.match(e);if(s)return s.text();let n=await this._getLfsFileHash(e);return n?(await r.put(e,new Response(n)),n):null}catch{return null}};_getLfsFileHash=async e=>{if(!e.includes("/resolve/"))return null;let r=e.replace("/resolve/","/raw/");try{let n=(await fetch(r).then(o=>o.text())).match(/^oid sha256:([0-9a-f]+)$/m);return n?n[1]:null}catch{return null}};_getBlobHash=async e=>{let r=await e.arrayBuffer(),s=await crypto.subtle.digest(rE,r);return Array.from(new Uint8Array(s)).map(o=>o.toString(16).padStart(2,"0")).join("")}};async function Jt(t=null){let e=null;if(_e.useCustomCache){if(!_e.customCache)throw Error("`env.useCustomCache=true`, but `env.customCache` is not defined.");if(!_e.customCache.match||!_e.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");e=_e.customCache}if(!e&&_e.experimental_useCrossOriginStorage&&uo.isAvailable()&&(e=new uo),!e&&_e.useBrowserCache){if(typeof caches>"u")throw Error("Browser cache is not available in this environment.");try{e=await caches.open(_e.cacheKey)}catch(r){Z.warn("An error occurred while opening the browser cache:",r)}}if(!e&&_e.useFSCache){if(!ie.IS_FS_AVAILABLE)throw Error("File System Cache is not available in this environment.");e=new on(t??_e.cacheDir)}return e}async function sE(t,...e){for(let r of e)try{let s=await t.match(r);if(s)return s}catch{continue}}var Xl=class{#t;#e;constructor(e){this.#t=e,this.#e=new Map}get(e){if(!this.#e.has(e))return;let r=this.#e.get(e);return this.#e.delete(e),this.#e.set(e,r),r}put(e,r){this.#e.has(e)&&this.#e.delete(e),this.#e.set(e,r),this.#e.size>this.#t&&this.#e.delete(this.#e.keys().next().value)}delete(e){return this.#e.delete(e)}clear(){this.#e.clear()}};var VL=100,pd=new Xl(VL);function Kl(t,e){let r=pd.get(t);if(r!==void 0)return r;let s=e().then(n=>n,n=>(pd.delete(t),Promise.reject(n)));return pd.put(t,s),s}async function HL(t){if(!Cr(t,["http:","https:"]))return null;let e=dd(t);return e.set("Range","bytes=0-0"),_e.fetch(t,{method:"GET",headers:e,cache:"no-store"})}function lr(t,e,r={}){let s=JSON.stringify([t,e,r?.revision,r?.cache_dir,r?.local_files_only]);return Kl(s,()=>XL(t,e,r))}async function XL(t,e,r){let s=await Jt(r?.cache_dir),{localPath:n,remoteURL:o,proposedCacheKey:a,validModelId:i}=Pr(t,e,r,s),l=await zr(s,n,a);if(l!==void 0&&typeof l!="string"){let c=l.headers.get("content-length"),p=l.headers.get("content-type");return{exists:!0,size:c?parseInt(c,10):void 0,contentType:p||void 0,fromCache:!0}}if(_e.allowLocalModels&&!Cr(n,["http:","https:"]))try{let p=await Lr(n);if(typeof p!="string"&&p.status!==404){let f=p.headers.get("content-length"),_=p.headers.get("content-type");return{exists:!0,size:f?parseInt(f,10):void 0,contentType:_||void 0,fromCache:!1}}}catch{}if(_e.allowRemoteModels&&!r.local_files_only&&i)try{let c=await HL(o);if(c&&c.status>=200&&c.status<300){let p,f=c.headers.get("content-type");if(c.status===206){let _=c.headers.get("content-range");if(_){let m=_.match(/bytes \d+-\d+\/(\d+)/);m&&(p=parseInt(m[1],10))}}else if(c.status===200)try{await c.body?.cancel()}catch{}if(p===void 0){let _=c.headers.get("content-length");p=_?parseInt(_,10):void 0}return{exists:!0,size:p,contentType:f||void 0,fromCache:!1}}}catch(c){Z.warn(`Unable to fetch file metadata for "${o}": ${c}`)}return{exists:!1,fromCache:!1}}async function Lr(t){return _e.useFS&&!Cr(t,["http:","https:","blob:"])?new Ir(t instanceof URL?t.protocol==="file:"?t.pathname:t.toString():t):_e.fetch(t,{headers:dd(t)})}function dd(t){let e=typeof process<"u"&&process?.release?.name==="node",r=new Headers;if(e){let s=!!process.env?.TESTING_REMOTELY,n=_e.version;if(r.set("User-Agent",`transformers.js/${n}; is_ci/${s};`),Cr(t,["http:","https:"],["huggingface.co","hf.co"])){let a=process.env?.HF_TOKEN??process.env?.HF_ACCESS_TOKEN;a&&r.set("Authorization",`Bearer ${a}`)}}return r}function Pr(t,e,r={},s=null){let n=r.revision??"main",o=co(t,e),a=Jk(t),i=a?co(_e.localModelPath,o):o,l=co(_e.remoteHost,_e.remotePathTemplate.replaceAll("{model}",t).replaceAll("{revision}",encodeURIComponent(n)),e),c=s instanceof on?n==="main"?o:co(t,n,e):l;return{requestURL:o,localPath:i,remoteURL:l,proposedCacheKey:c,validModelId:a}}async function zr(t,e,r){if(t)return await sE(t,e,r)}async function KL(t,e,r,s,n,o,a={}){if(await r.match(s)===void 0)if(o)typeof n!="string"&&await r.put(s,new Response(o,{headers:n.headers})).catch(i=>{Z.warn(`Unable to add response to browser cache: ${i}.`)});else{let i=a.progress_callback?l=>xr(a.progress_callback,{status:"progress",name:t,file:e,...l}):void 0;await r.put(s,n,i)}}async function QL(t,e,r=!0,s={},n=!1,o=null){let{requestURL:a,localPath:i,remoteURL:l,proposedCacheKey:c,validModelId:p}=Pr(t,e,s,o),f,_=!1,m;m=await zr(o,i,c);let w=m!==void 0;if(!w){if(_e.allowLocalModels)if(Cr(a,["http:","https:"])){if(s.local_files_only)throw new Error(`\`local_files_only=true\`, but attempted to load a remote file from: ${a}.`);if(!_e.allowRemoteModels)throw new Error(`\`env.allowRemoteModels=false\`, but attempted to load a remote file from: ${a}.`)}else try{m=await Lr(i),f=i}catch(A){Z.warn(`Unable to load from local path "${i}": "${A}"`)}if(m===void 0||typeof m!="string"&&m.status===404){if(s.local_files_only||!_e.allowRemoteModels){if(r)throw Error(`\`local_files_only=true\` or \`env.allowRemoteModels=false\` and file was not found locally at "${i}".`);return null}if(!p)throw Error(`Local file missing at "${i}" and download aborted due to invalid model ID "${t}".`);if(m=await Lr(l),m.status!==200)return Zk(m.status,l,r);f=c}_=o&&typeof Response<"u"&&m instanceof Response&&m.status===200}xr(s.progress_callback,{status:"download",name:t,file:e});let x;if(!(ie.IS_NODE_ENV&&n)){let E;if(typeof m!="string")if(!s.progress_callback)E=new Uint8Array(await m.arrayBuffer());else if(w&&typeof navigator<"u"&&/firefox/i.test(navigator.userAgent))E=new Uint8Array(await m.arrayBuffer()),xr(s.progress_callback,{status:"progress",name:t,file:e,progress:100,loaded:E.length,total:E.length});else{let A,T=m.headers.get("content-length");if(T)A=parseInt(T,10);else try{let S=await lr(t,e,s);S.size&&(A=S.size)}catch{}E=await eE(m,S=>{xr(s.progress_callback,{status:"progress",name:t,file:e,...S})},A)}x=E}if(_&&f&&typeof m!="string"&&await KL(t,e,o,f,m,x,s),xr(s.progress_callback,{status:"done",name:t,file:e}),x){if(!ie.IS_NODE_ENV&&n)throw new Error("Cannot return path in a browser environment.");return x}if(m instanceof Ir)return m.filePath;let k=await o?.match(f);if(k instanceof Ir)return k.filePath;if(k instanceof Response)return new Uint8Array(await k.arrayBuffer());if(typeof k=="string")return k;throw new Error("Unable to get model file path or buffer.")}async function po(t,e,r=!0,s={},n=!1){if(!_e.allowLocalModels){if(s.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(!_e.allowRemoteModels)throw Error("Invalid configuration detected: both local and remote models are disabled. Fix by setting `env.allowLocalModels` or `env.allowRemoteModels` to `true`.")}xr(s.progress_callback,{status:"initiate",name:t,file:e});let o=await Jt(s?.cache_dir);return await QL(t,e,r,s,n,o)}async function fd(t,e,r=!0,s={}){let n=await po(t,e,r,s,!1);return n===null?null:new TextDecoder("utf-8").decode(n)}async function ft(t,e,r=!0,s={}){let n=await fd(t,e,r,s);return n===null?{}:JSON.parse(n)}function oE(t,[e,r,s],[n,o],a="bilinear",i=!1){let l=o/s,c=n/r,p=new t.constructor(n*o*e),f=r*s,_=n*o;for(let m=0;m<n;++m)for(let w=0;w<o;++w){let x=m*o+w,k=(w+.5)/l-.5,E=(m+.5)/c-.5,A=Math.floor(k),T=Math.floor(E),S=Math.min(A+1,s-1),P=Math.min(T+1,r-1);A=Math.max(A,0),T=Math.max(T,0);let O=k-A,v=E-T,j=(1-O)*(1-v),H=O*(1-v),B=(1-O)*v,V=O*v,q=T*s,Q=P*s,F=q+A,C=q+S,te=Q+A,le=Q+S;for(let L=0;L<e;++L){let z=L*f;p[L*_+x]=j*t[z+F]+H*t[z+C]+B*t[z+te]+V*t[z+le]}}return p}function aE(t,e,r){let s=new Array(r.length),n=new Array(r.length);for(let i=r.length-1,l=1;i>=0;--i)n[i]=l,s[i]=e[r[i]],l*=s[i];let o=r.map((i,l)=>n[r.indexOf(l)]),a=new t.constructor(t.length);for(let i=0;i<t.length;++i){let l=0;for(let c=e.length-1,p=i;c>=0;--c)l+=p%e[c]*o[c],p=Math.floor(p/e[c]);a[l]=t[i]}return[a,s]}function $e(t){let e=Ce(t)[0],r=t.map(o=>Math.exp(o-e)),s=r.reduce((o,a)=>o+a,0);return r.map(o=>o/s)}function md(t){let e=Ce(t)[0],r=0;for(let o=0;o<t.length;++o)r+=Math.exp(t[o]-e);let s=Math.log(r);return t.map(o=>o-e-s)}function iE(t,e){let r=0;for(let s=0;s<t.length;++s)r+=t[s]*e[s];return r}function YL(t,e){let r=iE(t,e),s=nE(t),n=nE(e);return r/(s*n)}function nE(t){return Math.sqrt(t.reduce((e,r)=>e+r*r,0))}function fo(t){if(t.length===0)throw Error("Array must not be empty");let e=t[0],r=0;for(let s=1;s<t.length;++s)t[s]<e&&(e=t[s],r=s);return[e,r]}function Ce(t){if(t.length===0)throw Error("Array must not be empty");let e=t[0],r=0;for(let s=1;s<t.length;++s)t[s]>e&&(e=t[s],r=s);return[e,r]}function lE(t){return t>0&&(t&t-1)===0}var Ql=class{constructor(e){if(this.size=e|0,this.size<=1||!lE(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 s=0;s<this.table.length;s+=2){let n=Math.PI*s/this.size;this.table[s]=Math.cos(n),this.table[s+1]=-Math.sin(n)}let r=0;for(let s=1;this.size>s;s<<=1)++r;this._width=r%2===0?r-1:r,this._bitrev=new Int32Array(1<<this._width);for(let s=0;s<this._bitrev.length;++s){this._bitrev[s]=0;for(let n=0;n<this._width;n+=2){let o=this._width-n-2;this._bitrev[s]|=(s>>>n&3)<<o}}}createComplexArray(){return new Float64Array(this._csize)}fromComplexArray(e,r){let s=r||new Array(e.length>>>1);for(let n=0;n<e.length;n+=2)s[n>>>1]=e[n];return s}toComplexArray(e,r){let s=r||this.createComplexArray();for(let n=0;n<s.length;n+=2)s[n]=e[n>>>1],s[n+1]=0;return s}transform(e,r){if(e===r)throw new Error("Input and output buffers must be different");this._transform4(e,r,1)}realTransform(e,r){if(e===r)throw new Error("Input and output buffers must be different");this._realTransform4(e,r,1)}inverseTransform(e,r){if(e===r)throw new Error("Input and output buffers must be different");this._transform4(e,r,-1);for(let s=0;s<e.length;++s)e[s]/=this.size}_transform4(e,r,s){let n=this._csize,a=1<<this._width,i=n/a<<1,l,c,p=this._bitrev;if(i===4)for(l=0,c=0;l<n;l+=i,++c){let _=p[c];this._singleTransform2(r,e,l,_,a)}else for(l=0,c=0;l<n;l+=i,++c){let _=p[c];this._singleTransform4(r,e,l,_,a,s)}let f=this.table;for(a>>=2;a>=2;a>>=2){i=n/a<<1;let _=i>>>2;for(l=0;l<n;l+=i){let m=l+_-1;for(let w=l,x=0;w<m;w+=2,x+=a){let k=w,E=k+_,A=E+_,T=A+_,S=e[k],P=e[k+1],O=e[E],v=e[E+1],j=e[A],H=e[A+1],B=e[T],V=e[T+1],q=f[x],Q=s*f[x+1],F=O*q-v*Q,C=O*Q+v*q,te=f[2*x],le=s*f[2*x+1],L=j*te-H*le,z=j*le+H*te,R=f[3*x],J=s*f[3*x+1],Ie=B*R-V*J,ae=B*J+V*R,Ue=S+L,Je=P+z,tt=S-L,nt=P-z,at=F+Ie,Se=C+ae,xe=s*(F-Ie),We=s*(C-ae);e[k]=Ue+at,e[k+1]=Je+Se,e[E]=tt+We,e[E+1]=nt-xe,e[A]=Ue-at,e[A+1]=Je-Se,e[T]=tt-We,e[T+1]=nt+xe}}}}_singleTransform2(e,r,s,n,o){let a=e[n],i=e[n+1],l=e[n+o],c=e[n+o+1];r[s]=a+l,r[s+1]=i+c,r[s+2]=a-l,r[s+3]=i-c}_singleTransform4(e,r,s,n,o,a){let i=o*2,l=o*3,c=e[n],p=e[n+1],f=e[n+o],_=e[n+o+1],m=e[n+i],w=e[n+i+1],x=e[n+l],k=e[n+l+1],E=c+m,A=p+w,T=c-m,S=p-w,P=f+x,O=_+k,v=a*(f-x),j=a*(_-k);r[s]=E+P,r[s+1]=A+O,r[s+2]=T+j,r[s+3]=S-v,r[s+4]=E-P,r[s+5]=A-O,r[s+6]=T-j,r[s+7]=S+v}_realTransform4(e,r,s){let n=this._csize,a=1<<this._width,i=n/a<<1,l,c,p=this._bitrev;if(i===4)for(l=0,c=0;l<n;l+=i,++c){let m=p[c];this._singleRealTransform2(r,e,l,m>>>1,a>>>1)}else for(l=0,c=0;l<n;l+=i,++c){let m=p[c];this._singleRealTransform4(r,e,l,m>>>1,a>>>1,s)}let f=this.table;for(a>>=2;a>=2;a>>=2){i=n/a<<1;let m=i>>>1,w=m>>>1,x=w>>>1;for(l=0;l<n;l+=i)for(let k=0,E=0;k<=x;k+=2,E+=a){let A=l+k,T=A+w,S=T+w,P=S+w,O=e[A],v=e[A+1],j=e[T],H=e[T+1],B=e[S],V=e[S+1],q=e[P],Q=e[P+1],F=O,C=v,te=f[E],le=s*f[E+1],L=j*te-H*le,z=j*le+H*te,R=f[2*E],J=s*f[2*E+1],Ie=B*R-V*J,ae=B*J+V*R,Ue=f[3*E],Je=s*f[3*E+1],tt=q*Ue-Q*Je,nt=q*Je+Q*Ue,at=F+Ie,Se=C+ae,xe=F-Ie,We=C-ae,St=L+tt,ve=z+nt,De=s*(L-tt),Sr=s*(z-nt);if(e[A]=at+St,e[A+1]=Se+ve,e[T]=xe+Sr,e[T+1]=We-De,k===0){e[S]=at-St,e[S+1]=Se-ve;continue}if(k===x)continue;let is=l+w-k,Tt=l+m-k;e[is]=xe-s*Sr,e[is+1]=-We-s*De,e[Tt]=at-s*St,e[Tt+1]=-Se+s*ve}}let _=n>>>1;for(let m=2;m<_;m+=2)e[n-m]=e[m],e[n-m+1]=-e[m+1]}_singleRealTransform2(e,r,s,n,o){let a=e[n],i=e[n+o];r[s]=a+i,r[s+1]=0,r[s+2]=a-i,r[s+3]=0}_singleRealTransform4(e,r,s,n,o,a){let i=o*2,l=o*3,c=e[n],p=e[n+o],f=e[n+i],_=e[n+l],m=c+f,w=c-f,x=p+_,k=a*(p-_);r[s]=m+x,r[s+1]=0,r[s+2]=w,r[s+3]=-k,r[s+4]=m-x,r[s+5]=0,r[s+6]=w,r[s+7]=k}},_d=class{constructor(e){let r=2*(e-1),s=2*(2*e-1),n=2**Math.ceil(Math.log2(s));this.bufferSize=n,this._a=r;let o=new Float64Array(s),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);let i=-2*Math.PI/e,l=Math.cos(i),c=Math.sin(i);for(let p=0;p<s>>1;++p){let f=(p+1-e)**2/2,_=Math.sqrt(l**2+c**2)**f,m=f*Math.atan2(c,l),w=2*p;o[w]=_*Math.cos(m),o[w+1]=_*Math.sin(m),a[w]=o[w],a[w+1]=-o[w+1]}this._slicedChirpBuffer=o.subarray(r,s),this._f=new Ql(n>>1),this._f.transform(this._chirpBuffer,a)}_transform(e,r,s){let n=this._buffer1,o=this._buffer2,a=this._outBuffer1,i=this._outBuffer2,l=this._chirpBuffer,c=this._slicedChirpBuffer,p=this._a;if(s)for(let f=0;f<c.length;f+=2){let _=f+1,m=f>>1,w=r[m];n[f]=w*c[f],n[_]=w*c[_]}else for(let f=0;f<c.length;f+=2){let _=f+1;n[f]=r[f]*c[f]-r[_]*c[_],n[_]=r[f]*c[_]+r[_]*c[f]}this._f.transform(a,n);for(let f=0;f<l.length;f+=2){let _=f+1;o[f]=a[f]*l[f]-a[_]*l[_],o[_]=a[f]*l[_]+a[_]*l[f]}this._f.inverseTransform(i,o);for(let f=0;f<i.length;f+=2){let _=i[f+p],m=i[f+p+1],w=c[f],x=c[f+1];e[f]=_*w-m*x,e[f+1]=_*x+m*w}}transform(e,r){this._transform(e,r,!1)}realTransform(e,r){this._transform(e,r,!0)}},Yl=class{constructor(e){this.fft_length=e,this.isPowerOfTwo=lE(e),this.isPowerOfTwo?(this.fft=new Ql(e),this.outputBufferSize=2*e):(this.fft=new _d(e),this.outputBufferSize=this.fft.bufferSize)}realTransform(e,r){this.fft.realTransform(e,r)}transform(e,r){this.fft.transform(e,r)}};function cE(t,e){if(e%2===0||e<=0)throw new Error("Window size must be a positive odd number");let r=new t.constructor(t.length),s=new t.constructor(e),n=Math.floor(e/2);for(let o=0;o<t.length;++o){let a=0;for(let i=-n;i<=n;++i){let l=o+i;l<0?l=Math.abs(l):l>=t.length&&(l=2*(t.length-1)-l),s[a++]=t[l]}s.sort(),r[o]=s[n]}return r}function ms(t,e){let r=Math.pow(10,e);return Math.round(t*r)/r}function uE(t){let e=Math.round(t);return Math.abs(t)%1===.5?e%2===0?e:e-1:e}function pE(t){let e=t.length,r=t[0].length,s=[e+1,r+1],n=Array.from({length:s[0]},()=>Array(s[1]).fill(1/0));n[0][0]=0;let o=Array.from({length:s[0]},()=>Array(s[1]).fill(-1));for(let p=1;p<s[1];++p)for(let f=1;f<s[0];++f){let _=n[f-1][p-1],m=n[f-1][p],w=n[f][p-1],x,k;_<m&&_<w?(x=_,k=0):m<_&&m<w?(x=m,k=1):(x=w,k=2),n[f][p]=t[f-1][p-1]+x,o[f][p]=k}for(let p=0;p<s[1];++p)o[0][p]=2;for(let p=0;p<s[0];++p)o[p][0]=1;let a=e,i=r,l=[],c=[];for(;a>0||i>0;)switch(l.push(a-1),c.push(i-1),o[a][i]){case 0:--a,--i;break;case 1:--a;break;case 2:--i;break;default:throw new Error(`Internal error in dynamic time warping. Unexpected trace[${a}, ${i}]. Please file a bug report.`)}return l.reverse(),c.reverse(),[l,c]}var dE=(function(){let t=null;return function(e){if(!t){t=new Float32Array(65536);let o=new ArrayBuffer(4),a=new Uint32Array(o),i=new Float32Array(o);for(let l=0;l<t.length;++l){let c=0,p=(l&32768)<<16,f=(l&31744)>>10,_=l&1023;if(f===31)c=p|2139095040|_<<13;else if(f===0)if(_===0)c=p;else{let m=113;for(;(_&1024)===0;)_<<=1,--m;_&=-1025,c=p|m<<23|_<<13}else c=p|f+112<<23|_<<13;a[0]=c,t[l]=i[0]}}let r=e.length,s=t,n=new Float32Array(r);for(let o=0;o<r;++o)n[o]=s[e[o]];return n}})();import*as SP from"onnxruntime-node";var of={};Ys(of,{InferenceSession:()=>qd,TRACE:()=>ac,TRACE_EVENT_BEGIN:()=>Fr,TRACE_EVENT_END:()=>Br,TRACE_FUNC_BEGIN:()=>bs,TRACE_FUNC_END:()=>vs,Tensor:()=>Zt,default:()=>MP,env:()=>He,registerBackend:()=>ys});var jd=Object.defineProperty,JL=Object.getOwnPropertyDescriptor,ZL=Object.getOwnPropertyNames,eP=Object.prototype.hasOwnProperty,tP=(t=>typeof ps<"u"?ps:typeof Proxy<"u"?new Proxy(t,{get:(e,r)=>(typeof ps<"u"?ps:e)[r]}):t)(function(t){if(typeof ps<"u")return ps.apply(this,arguments);throw Error('Dynamic require of "'+t+'" is not supported')}),be=(t,e)=>()=>(t&&(e=t(t=0)),e),bo=(t,e)=>{for(var r in e)jd(t,r,{get:e[r],enumerable:!0})},rP=(t,e,r,s)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of ZL(e))!eP.call(t,n)&&n!==r&&jd(t,n,{get:()=>e[n],enumerable:!(s=JL(e,n))||s.enumerable});return t},oc=t=>rP(jd({},"__esModule",{value:!0}),t),_o,Nr,ys,fE,BE,UE=be(()=>{"use strict";_o=new Map,Nr=[],ys=(t,e,r)=>{if(e&&typeof e.init=="function"&&typeof e.createInferenceSessionHandler=="function"){let s=_o.get(t);if(s===void 0)_o.set(t,{backend:e,priority:r});else{if(s.priority>r)return;if(s.priority===r&&s.backend!==e)throw new Error(`cannot register backend "${t}" using priority ${r}`)}if(r>=0){let n=Nr.indexOf(t);n!==-1&&Nr.splice(n,1);for(let o=0;o<Nr.length;o++)if(_o.get(Nr[o]).priority<=r){Nr.splice(o,0,t);return}Nr.push(t)}return}throw new TypeError("not a valid backend")},fE=async t=>{let e=_o.get(t);if(!e)return"backend not found.";if(e.initialized)return e.backend;if(e.aborted)return e.error;{let r=!!e.initPromise;try{return r||(e.initPromise=e.backend.init(t)),await e.initPromise,e.initialized=!0,e.backend}catch(s){return r||(e.error=`${s}`,e.aborted=!0),e.error}finally{delete e.initPromise}}},BE=async t=>{let e=t.executionProviders||[],r=e.map(l=>typeof l=="string"?l:l.name),s=r.length===0?Nr:r,n,o=[],a=new Set;for(let l of s){let c=await fE(l);typeof c=="string"?o.push({name:l,err:c}):(n||(n=c),n===c&&a.add(l))}if(!n)throw new Error(`no available backend found. ERR: ${o.map(l=>`[${l.name}] ${l.err}`).join(", ")}`);for(let{name:l,err:c}of o)r.includes(l)&&console.warn(`removing requested execution provider "${l}" from session options because it is not available: ${c}`);let i=e.filter(l=>a.has(typeof l=="string"?l:l.name));return[n,new Proxy(t,{get:(l,c)=>c==="executionProviders"?i:Reflect.get(l,c)})]}}),sP=be(()=>{"use strict";UE()}),jE,nP=be(()=>{"use strict";jE="1.24.0-dev.20251116-b39e144322"}),hd,_t,GE=be(()=>{"use strict";nP(),hd="warning",_t={wasm:{},webgl:{},webgpu:{},versions:{common:jE},set logLevel(t){if(t!==void 0){if(typeof t!="string"||["verbose","info","warning","error","fatal"].indexOf(t)===-1)throw new Error(`Unsupported logging level: ${t}`);hd=t}},get logLevel(){return hd}},Object.defineProperty(_t,"logLevel",{enumerable:!0})}),He,oP=be(()=>{"use strict";GE(),He=_t}),qE,WE,aP=be(()=>{"use strict";qE=(t,e)=>{let r=typeof document<"u"?document.createElement("canvas"):new OffscreenCanvas(1,1);r.width=t.dims[3],r.height=t.dims[2];let s=r.getContext("2d");if(s!=null){let n,o;e?.tensorLayout!==void 0&&e.tensorLayout==="NHWC"?(n=t.dims[2],o=t.dims[3]):(n=t.dims[3],o=t.dims[2]);let a=e?.format!==void 0?e.format:"RGB",i=e?.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 p=o*n,f=0,_=p,m=p*2,w=-1;a==="RGBA"?(f=0,_=p,m=p*2,w=p*3):a==="RGB"?(f=0,_=p,m=p*2):a==="RBG"&&(f=0,m=p,_=p*2);for(let x=0;x<o;x++)for(let k=0;k<n;k++){let E=(t.data[f++]-c[0])*l[0],A=(t.data[_++]-c[1])*l[1],T=(t.data[m++]-c[2])*l[2],S=w===-1?255:(t.data[w++]-c[3])*l[3];s.fillStyle="rgba("+E+","+A+","+T+","+S+")",s.fillRect(k,x,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")},WE=(t,e)=>{let r=typeof document<"u"?document.createElement("canvas").getContext("2d"):new OffscreenCanvas(1,1).getContext("2d"),s;if(r!=null){let n,o,a;e?.tensorLayout!==void 0&&e.tensorLayout==="NHWC"?(n=t.dims[2],o=t.dims[1],a=t.dims[3]):(n=t.dims[3],o=t.dims[2],a=t.dims[1]);let i=e!==void 0&&e.format!==void 0?e.format:"RGB",l=e?.norm,c,p;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?p=[0,0,0,0]:typeof l.bias=="number"?p=[l.bias,l.bias,l.bias,l.bias]:(p=[l.bias[0],l.bias[1],l.bias[2],0],l.bias[3]!==void 0&&(p[3]=l.bias[3]));let f=o*n;if(e!==void 0&&(e.format!==void 0&&a===4&&e.format!=="RGBA"||a===3&&e.format!=="RGB"&&e.format!=="BGR"))throw new Error("Tensor format doesn't match input tensor dims");let _=4,m=0,w=1,x=2,k=3,E=0,A=f,T=f*2,S=-1;i==="RGBA"?(E=0,A=f,T=f*2,S=f*3):i==="RGB"?(E=0,A=f,T=f*2):i==="RBG"&&(E=0,T=f,A=f*2),s=r.createImageData(n,o);for(let P=0;P<o*n;m+=_,w+=_,x+=_,k+=_,P++)s.data[m]=(t.data[E++]-p[0])*c[0],s.data[w]=(t.data[A++]-p[1])*c[1],s.data[x]=(t.data[T++]-p[2])*c[2],s.data[k]=S===-1?255:(t.data[S++]-p[3])*c[3]}else throw new Error("Can not access image data");return s}}),Jl,VE,HE,XE,KE,QE,iP=be(()=>{"use strict";Gd(),Jl=(t,e)=>{if(t===void 0)throw new Error("Image buffer must be defined");if(e.height===void 0||e.width===void 0)throw new Error("Image height and width must be defined");if(e.tensorLayout==="NHWC")throw new Error("NHWC Tensor layout is not supported yet");let{height:r,width:s}=e,n=e.norm??{mean:255,bias:0},o,a;typeof n.mean=="number"?o=[n.mean,n.mean,n.mean,n.mean]:o=[n.mean[0],n.mean[1],n.mean[2],n.mean[3]??255],typeof n.bias=="number"?a=[n.bias,n.bias,n.bias,n.bias]:a=[n.bias[0],n.bias[1],n.bias[2],n.bias[3]??0];let i=e.format!==void 0?e.format:"RGBA",l=e.tensorFormat!==void 0&&e.tensorFormat!==void 0?e.tensorFormat:"RGB",c=r*s,p=l==="RGBA"?new Float32Array(c*4):new Float32Array(c*3),f=4,_=0,m=1,w=2,x=3,k=0,E=c,A=c*2,T=-1;i==="RGB"&&(f=3,_=0,m=1,w=2,x=-1),l==="RGBA"?T=c*3:l==="RBG"?(k=0,A=c,E=c*2):l==="BGR"&&(A=0,E=c,k=c*2);for(let S=0;S<c;S++,_+=f,w+=f,m+=f,x+=f)p[k++]=(t[_]+a[0])/o[0],p[E++]=(t[m]+a[1])/o[1],p[A++]=(t[w]+a[2])/o[2],T!==-1&&x!==-1&&(p[T++]=(t[x]+a[3])/o[3]);return l==="RGBA"?new Nt("float32",p,[1,4,r,s]):new Nt("float32",p,[1,3,r,s])},VE=async(t,e)=>{let r=typeof HTMLImageElement<"u"&&t instanceof HTMLImageElement,s=typeof ImageData<"u"&&t instanceof ImageData,n=typeof ImageBitmap<"u"&&t instanceof ImageBitmap,o=typeof t=="string",a,i=e??{},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=p=>typeof HTMLCanvasElement<"u"&&p instanceof HTMLCanvasElement||p instanceof OffscreenCanvas?p.getContext("2d"):null;if(r){let p=l();p.width=t.width,p.height=t.height;let f=c(p);if(f!=null){let _=t.height,m=t.width;if(e!==void 0&&e.resizedHeight!==void 0&&e.resizedWidth!==void 0&&(_=e.resizedHeight,m=e.resizedWidth),e!==void 0){if(i=e,e.tensorFormat!==void 0)throw new Error("Image input config format must be RGBA for HTMLImageElement");i.tensorFormat="RGBA",i.height=_,i.width=m}else i.tensorFormat="RGBA",i.height=_,i.width=m;f.drawImage(t,0,0),a=f.getImageData(0,0,m,_).data}else throw new Error("Can not access image data")}else if(s){let p,f;if(e!==void 0&&e.resizedWidth!==void 0&&e.resizedHeight!==void 0?(p=e.resizedHeight,f=e.resizedWidth):(p=t.height,f=t.width),e!==void 0&&(i=e),i.format="RGBA",i.height=p,i.width=f,e!==void 0){let _=l();_.width=f,_.height=p;let m=c(_);if(m!=null)m.putImageData(t,0,0),a=m.getImageData(0,0,f,p).data;else throw new Error("Can not access image data")}else a=t.data}else if(n){if(e===void 0)throw new Error("Please provide image config with format for Imagebitmap");let p=l();p.width=t.width,p.height=t.height;let f=c(p);if(f!=null){let _=t.height,m=t.width;return f.drawImage(t,0,0,m,_),a=f.getImageData(0,0,m,_).data,i.height=_,i.width=m,Jl(a,i)}else throw new Error("Can not access image data")}else{if(o)return new Promise((p,f)=>{let _=l(),m=c(_);if(!t||!m)return f();let w=new Image;w.crossOrigin="Anonymous",w.src=t,w.onload=()=>{_.width=w.width,_.height=w.height,m.drawImage(w,0,0,_.width,_.height);let x=m.getImageData(0,0,_.width,_.height);i.height=_.height,i.width=_.width,p(Jl(x.data,i))}});throw new Error("Input data provided is not supported - aborted tensor creation")}if(a!==void 0)return Jl(a,i);throw new Error("Input data provided is not supported - aborted tensor creation")},HE=(t,e)=>{let{width:r,height:s,download:n,dispose:o}=e,a=[1,s,r,4];return new Nt({location:"texture",type:"float32",texture:t,dims:a,download:n,dispose:o})},XE=(t,e)=>{let{dataType:r,dims:s,download:n,dispose:o}=e;return new Nt({location:"gpu-buffer",type:r??"float32",gpuBuffer:t,dims:s,download:n,dispose:o})},KE=(t,e)=>{let{dataType:r,dims:s,download:n,dispose:o}=e;return new Nt({location:"ml-tensor",type:r??"float32",mlTensor:t,dims:s,download:n,dispose:o})},QE=(t,e,r)=>new Nt({location:"cpu-pinned",type:t,data:e,dims:r??[e.length]})}),ws,xo,gd,YE,lP=be(()=>{"use strict";ws=new Map([["float32",Float32Array],["uint8",Uint8Array],["int8",Int8Array],["uint16",Uint16Array],["int16",Int16Array],["int32",Int32Array],["bool",Uint8Array],["float64",Float64Array],["uint32",Uint32Array],["int4",Uint8Array],["uint4",Uint8Array]]),xo=new Map([[Float32Array,"float32"],[Uint8Array,"uint8"],[Int8Array,"int8"],[Uint16Array,"uint16"],[Int16Array,"int16"],[Int32Array,"int32"],[Float64Array,"float64"],[Uint32Array,"uint32"]]),gd=!1,YE=()=>{if(!gd){gd=!0;let t=typeof BigInt64Array<"u"&&BigInt64Array.from,e=typeof BigUint64Array<"u"&&BigUint64Array.from,r=globalThis.Float16Array,s=typeof r<"u"&&r.from;t&&(ws.set("int64",BigInt64Array),xo.set(BigInt64Array,"int64")),e&&(ws.set("uint64",BigUint64Array),xo.set(BigUint64Array,"uint64")),s?(ws.set("float16",r),xo.set(r,"float16")):ws.set("float16",Uint16Array)}}}),JE,ZE,cP=be(()=>{"use strict";Gd(),JE=t=>{let e=1;for(let r=0;r<t.length;r++){let s=t[r];if(typeof s!="number"||!Number.isSafeInteger(s))throw new TypeError(`dims[${r}] must be an integer, got: ${s}`);if(s<0)throw new RangeError(`dims[${r}] must be a non-negative integer, got: ${s}`);e*=s}return e},ZE=(t,e)=>{switch(t.location){case"cpu":return new Nt(t.type,t.data,e);case"cpu-pinned":return new Nt({location:"cpu-pinned",data:t.data,type:t.type,dims:e});case"texture":return new Nt({location:"texture",texture:t.texture,type:t.type,dims:e});case"gpu-buffer":return new Nt({location:"gpu-buffer",gpuBuffer:t.gpuBuffer,type:t.type,dims:e});case"ml-tensor":return new Nt({location:"ml-tensor",mlTensor:t.mlTensor,type:t.type,dims:e});default:throw new Error(`tensorReshape: tensor location ${t.location} is not supported`)}}}),Nt,Gd=be(()=>{"use strict";aP(),iP(),lP(),cP(),Nt=class{constructor(t,e,r){YE();let s,n;if(typeof t=="object"&&"location"in t)switch(this.dataLocation=t.location,s=t.type,n=t.dims,t.location){case"cpu-pinned":{let a=ws.get(s);if(!a)throw new TypeError(`unsupported type "${s}" to create tensor from pinned buffer`);if(!(t.data instanceof a))throw new TypeError(`buffer should be of type ${a.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 a,i;if(typeof t=="string")if(s=t,i=r,t==="string"){if(!Array.isArray(e))throw new TypeError("A string tensor's data must be a string array.");a=e}else{let l=ws.get(t);if(l===void 0)throw new TypeError(`Unsupported tensor type: ${t}.`);if(Array.isArray(e)){if(t==="float16"&&l===Uint16Array||t==="uint4"||t==="int4")throw new TypeError(`Creating a ${t} tensor from number array is not supported. Please use ${l.name} as data.`);t==="uint64"||t==="int64"?a=l.from(e,BigInt):a=l.from(e)}else if(e instanceof l)a=e;else if(e instanceof Uint8ClampedArray)if(t==="uint8")a=Uint8Array.from(e);else throw new TypeError("A Uint8ClampedArray tensor's data must be type of uint8");else if(t==="float16"&&e instanceof Uint16Array&&l!==Uint16Array)a=new globalThis.Float16Array(e.buffer,e.byteOffset,e.length);else throw new TypeError(`A ${s} tensor's data must be type of ${l}`)}else if(i=e,Array.isArray(t)){if(t.length===0)throw new TypeError("Tensor type cannot be inferred from an empty array.");let l=typeof t[0];if(l==="string")s="string",a=t;else if(l==="boolean")s="bool",a=Uint8Array.from(t);else throw new TypeError(`Invalid element type of data array: ${l}.`)}else if(t instanceof Uint8ClampedArray)s="uint8",a=Uint8Array.from(t);else{let l=xo.get(t.constructor);if(l===void 0)throw new TypeError(`Unsupported type for tensor data: ${t.constructor}.`);s=l,a=t}if(i===void 0)i=[a.length];else if(!Array.isArray(i))throw new TypeError("A tensor's dims must be a number array");n=i,this.cpuData=a,this.dataLocation="cpu"}let o=JE(n);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=n,this.size=o}static async fromImage(t,e){return VE(t,e)}static fromTexture(t,e){return HE(t,e)}static fromGpuBuffer(t,e){return XE(t,e)}static fromMLTensor(t,e){return KE(t,e)}static fromPinnedBuffer(t,e,r){return QE(t,e,r)}toDataURL(t){return qE(this,t)}toImageData(t){return WE(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;let e=await this.downloader();return this.downloader=void 0,this.dataLocation="cpu",this.cpuData=e,t&&this.disposer&&(this.disposer(),this.disposer=void 0),e}finally{this.isDownloading=!1}}default:throw new Error(`cannot get data from location: ${this.dataLocation}`)}}dispose(){if(this.isDownloading)throw new Error("The current tensor is being downloaded.");this.disposer&&(this.disposer(),this.disposer=void 0),this.cpuData=void 0,this.gpuTextureData=void 0,this.gpuBufferData=void 0,this.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 ZE(this,t)}}}),Zt,eA=be(()=>{"use strict";Gd(),Zt=Nt}),ac,wd,bs,vs,Fr,Br,tA=be(()=>{"use strict";GE(),ac=(t,e)=>{(typeof _t.trace>"u"?!_t.wasm.trace:!_t.trace)||console.timeStamp(`${t}::ORT::${e}`)},wd=(t,e)=>{let r=new Error().stack?.split(/\r\n|\r|\n/g)||[],s=!1;for(let n=0;n<r.length;n++){if(s&&!r[n].includes("TRACE_FUNC")){let o=`FUNC_${t}::${r[n].trim().split(" ")[1]}`;e&&(o+=`::${e}`),ac("CPU",o);return}r[n].includes("TRACE_FUNC")&&(s=!0)}},bs=t=>{(typeof _t.trace>"u"?!_t.wasm.trace:!_t.trace)||wd("BEGIN",t)},vs=t=>{(typeof _t.trace>"u"?!_t.wasm.trace:!_t.trace)||wd("END",t)},Fr=t=>{(typeof _t.trace>"u"?!_t.wasm.trace:!_t.trace)||console.time(`ORT::${t}`)},Br=t=>{(typeof _t.trace>"u"?!_t.wasm.trace:!_t.trace)||console.timeEnd(`ORT::${t}`)}}),rA,uP=be(()=>{"use strict";UE(),eA(),tA(),rA=class sA{constructor(e){this.handler=e}async run(e,r,s){bs(),Fr("InferenceSession.run");let n={},o={};if(typeof e!="object"||e===null||e instanceof Zt||Array.isArray(e))throw new TypeError("'feeds' must be an object that use input names as keys and OnnxValue as corresponding values.");let a=!0;if(typeof r=="object"){if(r===null)throw new TypeError("Unexpected argument[1]: cannot be null.");if(r instanceof Zt)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.");a=!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}.`);n[c]=null}if(typeof s=="object"&&s!==null)o=s;else if(typeof s<"u")throw new TypeError("'options' must be an object.")}else{let c=!1,p=Object.getOwnPropertyNames(r);for(let f of this.outputNames)if(p.indexOf(f)!==-1){let _=r[f];(_===null||_ instanceof Zt)&&(c=!0,a=!1,n[f]=_)}if(c){if(typeof s=="object"&&s!==null)o=s;else if(typeof s<"u")throw new TypeError("'options' must be an object.")}else o=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 e[c]>"u")throw new Error(`input '${c}' is missing in 'feeds'.`);if(a)for(let c of this.outputNames)n[c]=null;let i=await this.handler.run(e,n,o),l={};for(let c in i)if(Object.hasOwnProperty.call(i,c)){let p=i[c];p instanceof Zt?l[c]=p:l[c]=new Zt(p.type,p.data,p.dims)}return Br("InferenceSession.run"),vs(),l}async release(){return this.handler.dispose()}static async create(e,r,s,n){bs(),Fr("InferenceSession.create");let o,a={};if(typeof e=="string"){if(o=e,typeof r=="object"&&r!==null)a=r;else if(typeof r<"u")throw new TypeError("'options' must be an object.")}else if(e instanceof Uint8Array){if(o=e,typeof r=="object"&&r!==null)a=r;else if(typeof r<"u")throw new TypeError("'options' must be an object.")}else if(e instanceof ArrayBuffer||typeof SharedArrayBuffer<"u"&&e instanceof SharedArrayBuffer){let p=e,f=0,_=e.byteLength;if(typeof r=="object"&&r!==null)a=r;else if(typeof r=="number"){if(f=r,!Number.isSafeInteger(f))throw new RangeError("'byteOffset' must be an integer.");if(f<0||f>=p.byteLength)throw new RangeError(`'byteOffset' is out of range [0, ${p.byteLength}).`);if(_=e.byteLength-f,typeof s=="number"){if(_=s,!Number.isSafeInteger(_))throw new RangeError("'byteLength' must be an integer.");if(_<=0||f+_>p.byteLength)throw new RangeError(`'byteLength' is out of range (0, ${p.byteLength-f}].`);if(typeof n=="object"&&n!==null)a=n;else if(typeof n<"u")throw new TypeError("'options' must be an object.")}else if(typeof s<"u")throw new TypeError("'byteLength' must be a number.")}else if(typeof r<"u")throw new TypeError("'options' must be an object.");o=new Uint8Array(p,f,_)}else throw new TypeError("Unexpected argument[0]: must be 'path' or 'buffer'.");let[i,l]=await BE(a),c=await i.createInferenceSessionHandler(o,l);return Br("InferenceSession.create"),vs(),new sA(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}}}),qd,pP=be(()=>{"use strict";uP(),qd=rA}),dP=be(()=>{"use strict"}),fP=be(()=>{"use strict"}),_P=be(()=>{"use strict"}),mP=be(()=>{"use strict"}),nA={};bo(nA,{InferenceSession:()=>qd,TRACE:()=>ac,TRACE_EVENT_BEGIN:()=>Fr,TRACE_EVENT_END:()=>Br,TRACE_FUNC_BEGIN:()=>bs,TRACE_FUNC_END:()=>vs,Tensor:()=>Zt,env:()=>He,registerBackend:()=>ys});var ks=be(()=>{"use strict";sP(),oP(),pP(),eA(),dP(),fP(),tA(),_P(),mP()}),Wd=be(()=>{"use strict"}),oA={};bo(oA,{default:()=>aA});var xd,yd,aA,hP=be(()=>{"use strict";bA(),Es(),Vd(),xd="ort-wasm-proxy-worker",yd=globalThis.self?.name===xd,yd&&(self.onmessage=t=>{let{type:e,in:r}=t.data;try{switch(e){case"init-wasm":Hd(r.wasm).then(()=>{Jd(r).then(()=>{postMessage({type:e})},s=>{postMessage({type:e,err:s})})},s=>{postMessage({type:e,err:s})});break;case"init-ep":{let{epName:s,env:n}=r;Zd(n,s).then(()=>{postMessage({type:e})},o=>{postMessage({type:e,err:o})});break}case"copy-from":{let{buffer:s}=r,n=cc(s);postMessage({type:e,out:n});break}case"create":{let{model:s,options:n}=r;ef(s,n).then(o=>{postMessage({type:e,out:o})},o=>{postMessage({type:e,err:o})});break}case"release":tf(r),postMessage({type:e});break;case"run":{let{sessionId:s,inputIndices:n,inputs:o,outputIndices:a,options:i}=r;rf(s,n,o,a,new Array(a.length).fill(null),i).then(l=>{l.some(c=>c[3]!=="cpu")?postMessage({type:e,err:"Proxy does not support non-cpu tensor location."}):postMessage({type:e,out:l},nf([...o,...l]))},l=>{postMessage({type:e,err:l})});break}case"end-profiling":sf(r),postMessage({type:e});break;default:}}catch(s){postMessage({type:e,err:s})}}),aA=yd?null:t=>new Worker(t??Pt,{type:"module",name:xd})}),iA={};bo(iA,{default:()=>lA});async function _E(t={}){var e=t,r=!!globalThis.window,s=!!globalThis.WorkerGlobalScope,n=s&&self.name?.startsWith("em-pthread");e.mountExternalData=(u,d)=>{u.startsWith("./")&&(u=u.substring(2)),(e.Uc||(e.Uc=new Map)).set(u,d)},e.unmountExternalData=()=>{delete e.Uc},globalThis.SharedArrayBuffer??new WebAssembly.Memory({initial:0,maximum:0,Be:!0}).buffer.constructor;let o=()=>{let u=d=>(...h)=>{let g=nr;return h=d(...h),nr!=g?new Promise((b,M)=>{Np={resolve:b,reject:M}}):h};(()=>{for(let d of["_OrtAppendExecutionProvider","_OrtCreateSession","_OrtRun","_OrtRunWithBinding","_OrtBindInput"])e[d]=u(e[d])})(),typeof jsepRunAsync<"u"&&(e._OrtRun=jsepRunAsync(e._OrtRun),e._OrtRunWithBinding=jsepRunAsync(e._OrtRunWithBinding)),o=void 0};e.asyncInit=()=>{o?.()};var a,i,l=(u,d)=>{throw d},c=import.meta.url,p="";if(r||s){try{p=new URL(".",c).href}catch{}s&&(i=u=>{var d=new XMLHttpRequest;return d.open("GET",u,!1),d.responseType="arraybuffer",d.send(null),new Uint8Array(d.response)}),a=async u=>{if(O(u))return new Promise((h,g)=>{var b=new XMLHttpRequest;b.open("GET",u,!0),b.responseType="arraybuffer",b.onload=()=>{b.status==200||b.status==0&&b.response?h(b.response):g(b.status)},b.onerror=g,b.send(null)});var d=await fetch(u,{credentials:"same-origin"});if(d.ok)return d.arrayBuffer();throw Error(d.status+" : "+d.url)}}var f,_,m,w,x,k,E=console.log.bind(console),A=console.error.bind(console),T=E,S=A,P=!1,O=u=>u.startsWith("file://");function v(){Tr.buffer!=B.buffer&&Ie()}if(n){let u=function(d){try{var h=d.data,g=h.Oc;if(g==="load"){let b=[];self.onmessage=M=>b.push(M),k=()=>{postMessage({Oc:"loaded"});for(let M of b)u(M);self.onmessage=u};for(let M of h.de)e[M]&&!e[M].proxy||(e[M]=(...I)=>{postMessage({Oc:"callHandler",ce:M,args:I})},M=="print"&&(T=e[M]),M=="printErr"&&(S=e[M]));Tr=h.je,Ie(),_=h.ke,tt(),Rl()}else if(g==="run"){(function(b){var M=(v(),C)[b+52>>>2>>>0];b=(v(),C)[b+56>>>2>>>0],bv(M,M-b),ce(M)})(h.Nc),Hp(h.Nc,0,0,1,0,0),l1(),Lp(h.Nc),H||(sv(),H=!0);try{kM(h.he,h.Wc)}catch(b){if(b!="unwind")throw b}}else h.target!=="setimmediate"&&(g==="checkMailbox"?H&&Ol():g&&(S(`worker: received unknown command ${g}`),S(h)))}catch(b){throw hv(),b}};var j=u,H=!1;self.onunhandledrejection=d=>{throw d.reason||d},self.onmessage=u}var B,V,q,Q,F,C,te,le,L,z,R,J=!1;function Ie(){var u=Tr.buffer;e.HEAP8=B=new Int8Array(u),q=new Int16Array(u),e.HEAPU8=V=new Uint8Array(u),Q=new Uint16Array(u),e.HEAP32=F=new Int32Array(u),e.HEAPU32=C=new Uint32Array(u),te=new Float32Array(u),le=new Float64Array(u),L=new BigInt64Array(u),z=new BigUint64Array(u)}function ae(){J=!0,n?k():wr._b()}function Ue(u){throw S(u="Aborted("+u+")"),P=!0,u=new WebAssembly.RuntimeError(u+". Build with -sASSERTIONS for more info."),x?.(u),u}function Je(){return{a:{f:EM,J:AM,k:MM,p:SM,l:TM,ta:OM,b:IM,ca:CM,Ka:_1,s:LM,da:w1,_a:x1,Ga:y1,Ia:b1,$a:v1,Ya:k1,Ra:E1,Xa:A1,pa:M1,Ha:S1,Yb:T1,Za:O1,Fa:I1,eb:PM,Da:NM,Tb:$M,Rb:DM,Ca:BM,M:UM,I:jM,Sb:GM,ka:QM,Ub:YM,Ua:JM,Wb:eS,La:tS,Pb:rS,la:sS,Ta:Lp,bb:nS,U:lS,n:fS,c:Ip,sb:_S,w:mS,L:hS,z:gS,j:wS,o:D1,tb:xS,G:yS,T:bS,h:vS,u:kS,m:ES,i:AS,Oa:MS,Pa:SS,Qa:TS,Ma:j1,Na:G1,Qb:q1,fb:IS,db:PS,Y:zS,rb:NS,ma:$S,cb:CS,gb:RS,ab:DS,Xb:FS,N:OS,hb:BS,X:US,Vb:jS,ob:YS,C:JS,sa:ZS,ra:eT,qb:tT,W:rT,v:sT,nb:nT,mb:oT,lb:aT,pb:iT,kb:lT,jb:cT,ib:uT,Va:Q1,Wa:Y1,Ja:Tt,ea:J1,oa:Z1,Sa:ev,na:tv,Db:yO,xa:dO,Eb:xO,ya:pO,F:tO,e:jT,r:BT,x:FT,D:JT,Ib:lO,ba:aO,B:qT,za:cO,$:fO,ha:iO,Fb:gO,Gb:hO,Ba:rO,Aa:oO,Jb:sO,wa:wO,aa:uO,d:GT,A:WT,q:UT,Cb:bO,t:HT,y:ZT,H:VT,E:XT,K:eO,S:_O,ja:YT,_:mO,Kb:QT,Lb:KT,P:nO,g:dT,a:Tr,Ob:Sr,Hb:fT,ia:_T,O:mT,qa:hT,Mb:gT,Q:wT,zb:xT,Ab:yT,ua:bT,fa:vT,R:kT,Ea:ET,va:AT,Z:MT,xb:ST,Zb:TT,V:OT,Bb:IT,ub:CT,vb:PT,wb:zT,ga:NT,yb:$T,Nb:RT}}}async function tt(){function u(g,b){var M=wr=g.exports;g={};for(let[I,N]of Object.entries(M))typeof N=="function"?(M=oS(N),g[I]=M):g[I]=N;return wr=g,wr=(function(){var I=wr,N=Y=>Te=>Y(Te)>>>0,U=Y=>()=>Y()>>>0;return(I=Object.assign({},I)).$b=N(I.$b),I.Cc=U(I.Cc),I.Ec=N(I.Ec),I.rd=(Y=>(Te,Ne)=>Y(Te,Ne)>>>0)(I.rd),I.wd=N(I.wd),I.xd=U(I.xd),I.Bd=N(I.Bd),I})(),a1.push(wr.id),rv=(g=wr).$b,sv=g.ac,e._OrtInit=g.bc,e._OrtGetLastError=g.cc,e._OrtCreateSessionOptions=g.dc,e._OrtAppendExecutionProvider=g.ec,e._OrtAddFreeDimensionOverride=g.fc,e._OrtAddSessionConfigEntry=g.gc,e._OrtReleaseSessionOptions=g.hc,e._OrtCreateSession=g.ic,e._OrtReleaseSession=g.jc,e._OrtGetInputOutputCount=g.kc,e._OrtGetInputOutputMetadata=g.lc,e._OrtFree=g.mc,e._OrtCreateTensor=g.nc,e._OrtGetTensorData=g.oc,e._OrtReleaseTensor=g.pc,e._OrtCreateRunOptions=g.qc,e._OrtAddRunConfigEntry=g.rc,e._OrtReleaseRunOptions=g.sc,e._OrtCreateBinding=g.tc,e._OrtBindInput=g.uc,e._OrtBindOutput=g.vc,e._OrtClearBoundOutputs=g.wc,e._OrtReleaseBinding=g.xc,e._OrtRunWithBinding=g.yc,e._OrtRun=g.zc,e._OrtEndProfiling=g.Ac,Up=e._OrtGetWebGpuDevice=g.Bc,Nl=g.Cc,Ht=e._free=g.Dc,Qs=e._malloc=g.Ec,nv=e._wgpuBufferRelease=g.Fc,ov=e._wgpuCreateInstance=g.Gc,av=g.Hc,iv=g.Ic,lv=g.Jc,cv=g.Kc,uv=g.Lc,pv=g.Pc,dv=g.Zc,fv=g._c,_v=g.$c,jp=g.bd,Gp=g.cd,qp=g.dd,Wp=g.ed,to=g.fd,Vp=g.gd,mv=g.hd,Hp=g.kd,hv=g.ld,gv=g.md,wv=g.nd,Xp=g.od,xv=g.pd,yv=g.qd,Kp=g.rd,ge=g.sd,ro=g.td,bv=g.ud,ce=g.vd,$l=g.wd,ue=g.xd,vv=g.yd,Qp=g.zd,kv=g.Ad,Ev=g.Bd,Av=g.Cd,Yp=g.Dd,Mv=g.Ed,Sv=g.Fd,Tv=g.Gd,Ov=g.Hd,Iv=g.Id,Cv=g.Jd,Lv=g.Kd,Pv=g.Ld,zv=g.Md,Nv=g.Nd,$v=g.Od,Rv=g.Pd,Dv=g.Qd,Fv=g.Rd,Bv=g.Td,Uv=g.Ud,jv=g.Vd,Gv=g.Wd,qv=g.Yd,Wv=g.Zd,Vv=g._d,Hv=g.$d,Xv=g.ae,Kv=g.be,Qv=g.pe,Yv=g.qe,Jv=g.re,Zv=g.se,ek=g.te,tk=g.ue,rk=g.ve,sk=g.we,nk=g.xe,ok=g.ye,ak=g.ze,ik=g.Xe,lk=g.Ye,ck=g.Ze,uk=g._e,_=b,wr}var d,h=Je();return e.instantiateWasm?new Promise(g=>{e.instantiateWasm(h,(b,M)=>{g(u(b,M))})}):n?u(new WebAssembly.Instance(_,Je()),_):(R??=e.locateFile?e.locateFile?e.locateFile("ort-wasm-simd-threaded.asyncify.wasm",p):p+"ort-wasm-simd-threaded.asyncify.wasm":new URL("ort-wasm-simd-threaded.asyncify.wasm",import.meta.url).href,d=await(async function(g){var b=R;if(!f&&!O(b))try{var M=fetch(b,{credentials:"same-origin"});return await WebAssembly.instantiateStreaming(M,g)}catch(I){S(`wasm streaming compile failed: ${I}`),S("falling back to ArrayBuffer instantiation")}return(async function(I,N){try{var U=await(async function(Y){if(!f)try{var Te=await a(Y);return new Uint8Array(Te)}catch{}if(Y==R&&f)Y=new Uint8Array(f);else{if(!i)throw"both async and sync fetching of the wasm failed";Y=i(Y)}return Y})(I);return await WebAssembly.instantiate(U,N)}catch(Y){S(`failed to asynchronously prepare wasm: ${Y}`),Ue(Y)}})(b,g)})(h),u(d.instance,d.module))}class nt{name="ExitStatus";constructor(d){this.message=`Program terminated with exit(${d})`,this.status=d}}var at=u=>{u.terminate(),u.onmessage=()=>{}},Se=[],xe=0,We=null,St=u=>{ot.length==0&&(u1(),c1(ot[0]));var d=ot.pop();if(!d)return 6;Jn.push(d),ls[u.Nc]=d,d.Nc=u.Nc;var h={Oc:"run",he:u.ge,Wc:u.Wc,Nc:u.Nc};return d.postMessage(h,u.Yc),0},ve=0,De=(u,d,...h)=>{var g,b=16*h.length,M=ue(),I=$l(b),N=I>>>3;for(g of h)typeof g=="bigint"?((v(),L)[N++>>>0]=1n,(v(),L)[N++>>>0]=g):((v(),L)[N++>>>0]=0n,(v(),le)[N++>>>0]=g);return u=gv(u,0,b,I,d),ce(M),u};function Sr(u){if(n)return De(0,1,u);if(m=u,!(0<ve)){for(var d of Jn)at(d);for(d of ot)at(d);ot=[],Jn=[],ls={},P=!0}l(0,new nt(u))}function is(u){if(n)return De(1,0,u);Tt(u)}var Tt=u=>{if(m=u,n)throw is(u),"unwind";Sr(u)},ot=[],Jn=[],a1=[],ls={},i1=u=>{var d=u.Nc;delete ls[d],ot.push(u),Jn.splice(Jn.indexOf(u),1),u.Nc=0,wv(d)};function l1(){a1.forEach(u=>u())}var c1=u=>new Promise(d=>{u.onmessage=b=>{var M=b.data;if(b=M.Oc,M.Vc&&M.Vc!=Nl()){var I=ls[M.Vc];I?I.postMessage(M,M.Yc):S(`Internal error! Worker sent a message "${b}" to target pthread ${M.Vc}, but that thread no longer exists!`)}else b==="checkMailbox"?Ol():b==="spawnThread"?St(M):b==="cleanupThread"?At(()=>{i1(ls[M.ie])}):b==="loaded"?(u.loaded=!0,d(u)):M.target==="setimmediate"?u.postMessage(M):b==="uncaughtException"?u.onerror(M.error):b==="callHandler"?e[M.ce](...M.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 h,g=[];for(h of[])e.propertyIsEnumerable(h)&&g.push(h);u.postMessage({Oc:"load",de:g,je:Tr,ke:_})});function u1(){var u=new Worker((()=>{let d=URL;return import.meta.url>"file:"&&import.meta.url<"file;"?new d("ort.webgpu.bundle.min.mjs",import.meta.url):new URL(import.meta.url)})(),{type:"module",workerData:"em-pthread",name:"em-pthread"});ot.push(u)}var Tr,kM=(u,d)=>{ve=0,u=Yp(u,d),0<ve?m=u:Xp(u)},Sl=[],Tl=0,Et=u=>-9007199254740992>u||9007199254740992<u?NaN:Number(u);function EM(u){var d=new Mp(u>>>=0);return(v(),B)[d.Qc+12>>>0]==0&&(p1(d,!0),Tl--),d1(d,!1),Sl.push(d),Ev(u)}var Vs=0,AM=()=>{ge(0,0);var u=Sl.pop();vv(u.Xc),Vs=0};function p1(u,d){d=d?1:0,(v(),B)[u.Qc+12>>>0]=d}function d1(u,d){d=d?1:0,(v(),B)[u.Qc+13>>>0]=d}class Mp{constructor(d){this.Xc=d,this.Qc=d-24}}var Sp=u=>{var d=Vs;if(!d)return ro(0),0;var h=new Mp(d);(v(),C)[h.Qc+16>>>2>>>0]=d;var g=(v(),C)[h.Qc+4>>>2>>>0];if(!g)return ro(0),d;for(var b of u){if(b===0||b===g)break;if(kv(b,g,h.Qc+16))return ro(b),d}return ro(g),d};function MM(){return Sp([])}function SM(u){return Sp([u>>>0])}function TM(u,d,h,g){return Sp([u>>>0,d>>>0,h>>>0,g>>>0])}var OM=()=>{var u=Sl.pop();u||Ue("no exception to throw");var d=u.Xc;throw(v(),B)[u.Qc+13>>>0]==0&&(Sl.push(u),d1(u,!0),p1(u,!1),Tl++),Qp(d),Vs=d};function IM(u,d,h){var g=new Mp(u>>>=0);throw d>>>=0,h>>>=0,(v(),C)[g.Qc+16>>>2>>>0]=0,(v(),C)[g.Qc+4>>>2>>>0]=d,(v(),C)[g.Qc+8>>>2>>>0]=h,Qp(u),Tl++,Vs=u}var CM=()=>Tl;function f1(u,d,h,g){return n?De(2,1,u,d,h,g):_1(u,d,h,g)}function _1(u,d,h,g){if(u>>>=0,d>>>=0,h>>>=0,g>>>=0,!globalThis.SharedArrayBuffer)return 6;var b=[];return n&&b.length===0?f1(u,d,h,g):(u={ge:h,Nc:u,Wc:g,Yc:b},n?(u.Oc="spawnThread",postMessage(u,b),0):St(u))}function LM(u){throw Vs||=u>>>0,Vs}var m1=globalThis.TextDecoder&&new TextDecoder,h1=(u,d,h,g)=>{if(h=d+h,g)return h;for(;u[d]&&!(d>=h);)++d;return d},g1=(u,d=0,h,g)=>{if(16<(h=h1(u,d>>>=0,h,g))-d&&u.buffer&&m1)return m1.decode(u.buffer instanceof ArrayBuffer?u.subarray(d,h):u.slice(d,h));for(g="";d<h;){var b=u[d++];if(128&b){var M=63&u[d++];if((224&b)==192)g+=String.fromCharCode((31&b)<<6|M);else{var I=63&u[d++];65536>(b=(240&b)==224?(15&b)<<12|M<<6|I:(7&b)<<18|M<<12|I<<6|63&u[d++])?g+=String.fromCharCode(b):(b-=65536,g+=String.fromCharCode(55296|b>>10,56320|1023&b))}}else g+=String.fromCharCode(b)}return g},Hs=(u,d,h)=>(u>>>=0)?g1((v(),V),u,d,h):"";function w1(u,d,h){return n?De(3,1,u,d,h):0}function x1(u,d){if(n)return De(4,1,u,d)}function y1(u,d){if(n)return De(5,1,u,d)}function b1(u,d,h){if(n)return De(6,1,u,d,h)}function v1(u,d,h){return n?De(7,1,u,d,h):0}function k1(u,d){if(n)return De(8,1,u,d)}function E1(u,d,h){if(n)return De(9,1,u,d,h)}function A1(u,d,h,g){if(n)return De(10,1,u,d,h,g)}function M1(u,d,h,g){if(n)return De(11,1,u,d,h,g)}function S1(u,d,h,g){if(n)return De(12,1,u,d,h,g)}function T1(u){if(n)return De(13,1,u)}function O1(u,d){if(n)return De(14,1,u,d)}function I1(u,d,h){if(n)return De(15,1,u,d,h)}var PM=()=>Ue(""),sr=u=>{u>>>=0;for(var d="";;){var h=(v(),V)[u++>>>0];if(!h)return d;d+=String.fromCharCode(h)}},Tp={},Op={},zM={},Xs=class extends Error{constructor(u){super(u),this.name="BindingError"}};function fr(u,d,h={}){return(function(g,b,M={}){var I=b.name;if(!g)throw new Xs(`type "${I}" must have a positive integer typeid pointer`);if(Op.hasOwnProperty(g)){if(M.ee)return;throw new Xs(`Cannot register type '${I}' twice`)}Op[g]=b,delete zM[g],Tp.hasOwnProperty(g)&&(b=Tp[g],delete Tp[g],b.forEach(N=>N()))})(u,d,h)}var C1=(u,d,h)=>{switch(d){case 1:return h?g=>(v(),B)[g>>>0]:g=>(v(),V)[g>>>0];case 2:return h?g=>(v(),q)[g>>>1>>>0]:g=>(v(),Q)[g>>>1>>>0];case 4:return h?g=>(v(),F)[g>>>2>>>0]:g=>(v(),C)[g>>>2>>>0];case 8:return h?g=>(v(),L)[g>>>3>>>0]:g=>(v(),z)[g>>>3>>>0];default:throw new TypeError(`invalid integer width (${d}): ${u}`)}};function NM(u,d,h,g,b){u>>>=0,h>>>=0,d=sr(d>>>0);let M=I=>I;if(g=g===0n){let I=8*h;M=N=>BigInt.asUintN(I,N),b=M(b)}fr(u,{name:d,Mc:M,Sc:(I,N)=>(typeof N=="number"&&(N=BigInt(N)),N),Rc:C1(d,h,!g),Tc:null})}function $M(u,d,h,g){fr(u>>>=0,{name:d=sr(d>>>0),Mc:function(b){return!!b},Sc:function(b,M){return M?h:g},Rc:function(b){return this.Mc((v(),V)[b>>>0])},Tc:null})}var L1=[],cs=[0,1,,1,null,1,!0,1,!1,1];function Ip(u){9<(u>>>=0)&&--cs[u+1]==0&&(cs[u]=void 0,L1.push(u))}var Rt=u=>{if(!u)throw new Xs(`Cannot use deleted val. handle = ${u}`);return cs[u]},Vt=u=>{switch(u){case void 0:return 2;case null:return 4;case!0:return 6;case!1:return 8;default:let d=L1.pop()||cs.length;return cs[d]=u,cs[d+1]=1,d}};function Cp(u){return this.Mc((v(),C)[u>>>2>>>0])}var RM={name:"emscripten::val",Mc:u=>{var d=Rt(u);return Ip(u),d},Sc:(u,d)=>Vt(d),Rc:Cp,Tc:null};function DM(u){return fr(u>>>0,RM)}var FM=(u,d)=>{switch(d){case 4:return function(h){return this.Mc((v(),te)[h>>>2>>>0])};case 8:return function(h){return this.Mc((v(),le)[h>>>3>>>0])};default:throw new TypeError(`invalid float width (${d}): ${u}`)}};function BM(u,d,h){h>>>=0,fr(u>>>=0,{name:d=sr(d>>>0),Mc:g=>g,Sc:(g,b)=>b,Rc:FM(d,h),Tc:null})}function UM(u,d,h,g,b){u>>>=0,h>>>=0,d=sr(d>>>0);let M=N=>N;if(g===0){var I=32-8*h;M=N=>N<<I>>>I,b=M(b)}fr(u,{name:d,Mc:M,Sc:(N,U)=>U,Rc:C1(d,h,g!==0),Tc:null})}function jM(u,d,h){function g(M){var I=(v(),C)[M>>>2>>>0];return M=(v(),C)[M+4>>>2>>>0],new b((v(),B).buffer,M,I)}var b=[Int8Array,Uint8Array,Int16Array,Uint16Array,Int32Array,Uint32Array,Float32Array,Float64Array,BigInt64Array,BigUint64Array][d];fr(u>>>=0,{name:h=sr(h>>>0),Mc:g,Rc:g},{ee:!0})}var _r=(u,d,h)=>{var g=(v(),V);if(d>>>=0,0<h){var b=d;h=d+h-1;for(var M=0;M<u.length;++M){var I=u.codePointAt(M);if(127>=I){if(d>=h)break;g[d++>>>0]=I}else if(2047>=I){if(d+1>=h)break;g[d++>>>0]=192|I>>6,g[d++>>>0]=128|63&I}else if(65535>=I){if(d+2>=h)break;g[d++>>>0]=224|I>>12,g[d++>>>0]=128|I>>6&63,g[d++>>>0]=128|63&I}else{if(d+3>=h)break;g[d++>>>0]=240|I>>18,g[d++>>>0]=128|I>>12&63,g[d++>>>0]=128|I>>6&63,g[d++>>>0]=128|63&I,M++}}g[d>>>0]=0,u=d-b}else u=0;return u},mr=u=>{for(var d=0,h=0;h<u.length;++h){var g=u.charCodeAt(h);127>=g?d++:2047>=g?d+=2:55296<=g&&57343>=g?(d+=4,++h):d+=3}return d};function GM(u,d){fr(u>>>=0,{name:d=sr(d>>>0),Mc(h){var g=(v(),C)[h>>>2>>>0];return g=Hs(h+4,g,!0),Ht(h),g},Sc(h,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 Xs("Cannot pass non-string to std::string");var M=b?mr(g):g.length,I=Qs(4+M+1),N=I+4;return(v(),C)[I>>>2>>>0]=M,b?_r(g,N,M+1):(v(),V).set(g,N>>>0),h!==null&&h.push(Ht,I),I},Rc:Cp,Tc(h){Ht(h)}})}var P1=globalThis.TextDecoder?new TextDecoder("utf-16le"):void 0,qM=(u,d,h)=>{if(u>>>=1,16<(d=h1((v(),Q),u,d/2,h))-u&&P1)return P1.decode((v(),Q).slice(u,d));for(h="";u<d;++u){var g=(v(),Q)[u>>>0];h+=String.fromCharCode(g)}return h},WM=(u,d,h)=>{if(h??=2147483647,2>h)return 0;var g=d;h=(h-=2)<2*u.length?h/2:u.length;for(var b=0;b<h;++b){var M=u.charCodeAt(b);(v(),q)[d>>>1>>>0]=M,d+=2}return(v(),q)[d>>>1>>>0]=0,d-g},VM=u=>2*u.length,HM=(u,d,h)=>{var g="";u>>>=2;for(var b=0;!(b>=d/4);b++){var M=(v(),C)[u+b>>>0];if(!M&&!h)break;g+=String.fromCodePoint(M)}return g},XM=(u,d,h)=>{if(d>>>=0,h??=2147483647,4>h)return 0;var g=d;h=g+h-4;for(var b=0;b<u.length;++b){var M=u.codePointAt(b);if(65535<M&&b++,(v(),F)[d>>>2>>>0]=M,(d+=4)+4>h)break}return(v(),F)[d>>>2>>>0]=0,d-g},KM=u=>{for(var d=0,h=0;h<u.length;++h)65535<u.codePointAt(h)&&h++,d+=4;return d};function QM(u,d,h){if(u>>>=0,d>>>=0,h=sr(h>>>=0),d===2)var g=qM,b=WM,M=VM;else g=HM,b=XM,M=KM;fr(u,{name:h,Mc:I=>{var N=(v(),C)[I>>>2>>>0];return N=g(I+4,N*d,!0),Ht(I),N},Sc:(I,N)=>{if(typeof N!="string")throw new Xs(`Cannot pass non-string to C++ string type ${h}`);var U=M(N),Y=Qs(4+U+d);return(v(),C)[Y>>>2>>>0]=U/d,b(N,Y+4,U+d),I!==null&&I.push(Ht,Y),Y},Rc:Cp,Tc(I){Ht(I)}})}function YM(u,d){fr(u>>>=0,{fe:!0,name:d=sr(d>>>0),Mc:()=>{},Sc:()=>{}})}function JM(u){Hp(u>>>0,!s,1,!r,131072,!1),l1()}var At=u=>{if(!P)try{if(u(),!(0<ve))try{n?Nl()&&Xp(m):Tt(m)}catch(d){d instanceof nt||d=="unwind"||l(0,d)}}catch(d){d instanceof nt||d=="unwind"||l(0,d)}},ZM=!Atomics.waitAsync||globalThis.navigator?.userAgent&&91>Number((navigator.userAgent.match(/Chrom(e|ium)\/([0-9]+)\./)||[])[2]);function Lp(u){u>>>=0,ZM||(Atomics.waitAsync((v(),F),u>>>2,u).value.then(Ol),u+=128,Atomics.store((v(),F),u>>>2,1))}var Ol=()=>At(()=>{var u=Nl();u&&(Lp(u),yv())});function eS(u,d){(u>>>=0)==d>>>0?setTimeout(Ol):n?postMessage({Vc:u,Oc:"checkMailbox"}):(u=ls[u])&&u.postMessage({Oc:"checkMailbox"})}var Pp=[];function tS(u,d,h,g,b){for(d>>>=0,b>>>=0,Pp.length=0,h=b>>>3,g=b+g>>>3;h<g;){var M;M=(v(),L)[h++>>>0]?(v(),L)[h++>>>0]:(v(),le)[h++>>>0],Pp.push(M)}return(d?Jp[d]:DT[u])(...Pp)}var rS=()=>{ve=0};function sS(u){u>>>=0,n?postMessage({Oc:"cleanupThread",ie:u}):i1(ls[u])}function nS(u){}var Il=u=>{try{u()}catch(d){Ue(d)}};function oS(u){var d=(...h)=>{Cl.push(u);try{return u(...h)}finally{P||(Cl.pop(),nr&&Or===1&&Cl.length===0&&(Or=0,ve+=1,Il(lk),typeof Fibers<"u"&&Fibers.De()))}};return $1.set(u,d),d}var Or=0,nr=null,z1=0,Cl=[],zp=new Map,N1=new Map,$1=new Map,aS=0,Np=null,iS=[],R1=u=>(function(d){if(!P){if(Or===0){var h=!1,g=!1;d((b=0)=>{if(!P&&(z1=b,h=!0,g)){Or=2,Il(()=>ck(nr)),typeof MainLoop<"u"&&MainLoop.Xd&&MainLoop.resume(),b=!1;try{var M=(function(){var U=(v(),F)[nr+8>>>2>>>0];return U=N1.get(U),U=$1.get(U),--ve,U()})()}catch(U){M=U,b=!0}var I=!1;if(!nr){var N=Np;N&&(Np=null,(b?N.reject:N.resolve)(M),I=!0)}if(b&&!I)throw M}}),g=!0,h||(Or=1,nr=(function(){var b=Qs(65548),M=b+12;if((v(),C)[b>>>2>>>0]=M,(v(),C)[b+4>>>2>>>0]=M+65536,M=Cl[0],!zp.has(M)){var I=aS++;zp.set(M,I),N1.set(I,M)}return M=zp.get(M),(v(),F)[b+8>>>2>>>0]=M,b})(),typeof MainLoop<"u"&&MainLoop.Xd&&MainLoop.pause(),Il(()=>ik(nr)))}else Or===2?(Or=0,Il(uk),Ht(nr),nr=null,iS.forEach(At)):Ue(`invalid state: ${Or}`);return z1}})(d=>{u().then(d)});function lS(u){return u>>>=0,R1(async()=>{var d=await Rt(u);return Vt(d)})}var $p=[],cS=u=>{var d=$p.length;return $p.push(u),d},uS=(u,d)=>{for(var h=Array(u),g=0;g<u;++g){var b=g,M=(v(),C)[d+4*g>>>2>>>0],I=Op[M];if(I===void 0)throw u=`parameter ${g}`,M=rv(M),d=sr(M),Ht(M),new Xs(`${u} has unknown type ${d}`);h[b]=I}return h},pS=(u,d,h)=>{var g=[];return u=u(g,h),g.length&&((v(),C)[d>>>2>>>0]=Vt(g)),u},dS={},Ll=u=>{var d=dS[u];return d===void 0?sr(u):d};function fS(u,d,h){var[g,...b]=uS(u,d>>>0);d=g.Sc.bind(g);var M=b.map(U=>U.Rc.bind(U));u--;var I={toValue:Rt};switch(u=M.map((U,Y)=>{var Te=`argFromPtr${Y}`;return I[Te]=U,`${Te}(args${Y?"+"+8*Y:""})`}),h){case 0:var N="toValue(handle)";break;case 2:N="new (toValue(handle))";break;case 3:N="";break;case 1:I.getStringOrSymbol=Ll,N="toValue(handle)[getStringOrSymbol(methodName)]"}return N+=`(${u})`,g.fe||(I.toReturnWire=d,I.emval_returnValue=pS,N=`return emval_returnValue(toReturnWire, destructorsRef, ${N})`),N=`return function (handle, methodName, destructorsRef, args) {
11
- ${N}
12
- }`,h=new Function(Object.keys(I),N)(...Object.values(I)),N=`methodCaller<(${b.map(U=>U.name)}) => ${g.name}>`,cS(Object.defineProperty(h,"name",{value:N}))}function _S(u,d){return d>>>=0,(u=Rt(u>>>0))==Rt(d)}function mS(u){return(u>>>=0)?(u=Ll(u),Vt(globalThis[u])):Vt(globalThis)}function hS(u){return u=Ll(u>>>0),Vt(e[u])}function gS(u,d){return d>>>=0,u=Rt(u>>>0),d=Rt(d),Vt(u[d])}function wS(u){9<(u>>>=0)&&(cs[u+1]+=1)}function D1(u,d,h,g,b){return $p[u>>>0](d>>>0,h>>>0,g>>>0,b>>>0)}function xS(u,d,h,g,b){return D1(u>>>0,d>>>0,h>>>0,g>>>0,b>>>0)}function yS(){return Vt([])}function bS(u){u=Rt(u>>>0);for(var d=Array(u.length),h=0;h<u.length;h++)d[h]=u[h];return Vt(d)}function vS(u){return Vt(Ll(u>>>0))}function kS(){return Vt({})}function ES(u){for(var d=Rt(u>>>=0);d.length;){var h=d.pop();d.pop()(h)}Ip(u)}function AS(u,d,h){d>>>=0,h>>>=0,u=Rt(u>>>0),d=Rt(d),h=Rt(h),u[d]=h}function MS(u,d){u=Et(u),d>>>=0,u=new Date(1e3*u),(v(),F)[d>>>2>>>0]=u.getUTCSeconds(),(v(),F)[d+4>>>2>>>0]=u.getUTCMinutes(),(v(),F)[d+8>>>2>>>0]=u.getUTCHours(),(v(),F)[d+12>>>2>>>0]=u.getUTCDate(),(v(),F)[d+16>>>2>>>0]=u.getUTCMonth(),(v(),F)[d+20>>>2>>>0]=u.getUTCFullYear()-1900,(v(),F)[d+24>>>2>>>0]=u.getUTCDay(),u=(u.getTime()-Date.UTC(u.getUTCFullYear(),0,1,0,0,0,0))/864e5|0,(v(),F)[d+28>>>2>>>0]=u}var F1=u=>u%4==0&&(u%100!=0||u%400==0),B1=[0,31,60,91,121,152,182,213,244,274,305,335],U1=[0,31,59,90,120,151,181,212,243,273,304,334];function SS(u,d){u=Et(u),d>>>=0,u=new Date(1e3*u),(v(),F)[d>>>2>>>0]=u.getSeconds(),(v(),F)[d+4>>>2>>>0]=u.getMinutes(),(v(),F)[d+8>>>2>>>0]=u.getHours(),(v(),F)[d+12>>>2>>>0]=u.getDate(),(v(),F)[d+16>>>2>>>0]=u.getMonth(),(v(),F)[d+20>>>2>>>0]=u.getFullYear()-1900,(v(),F)[d+24>>>2>>>0]=u.getDay();var h=(F1(u.getFullYear())?B1:U1)[u.getMonth()]+u.getDate()-1|0;(v(),F)[d+28>>>2>>>0]=h,(v(),F)[d+36>>>2>>>0]=-60*u.getTimezoneOffset(),h=new Date(u.getFullYear(),6,1).getTimezoneOffset();var g=new Date(u.getFullYear(),0,1).getTimezoneOffset();u=0|(h!=g&&u.getTimezoneOffset()==Math.min(g,h)),(v(),F)[d+32>>>2>>>0]=u}function TS(u){u>>>=0;var d=new Date((v(),F)[u+20>>>2>>>0]+1900,(v(),F)[u+16>>>2>>>0],(v(),F)[u+12>>>2>>>0],(v(),F)[u+8>>>2>>>0],(v(),F)[u+4>>>2>>>0],(v(),F)[u>>>2>>>0],0),h=(v(),F)[u+32>>>2>>>0],g=d.getTimezoneOffset(),b=new Date(d.getFullYear(),6,1).getTimezoneOffset(),M=new Date(d.getFullYear(),0,1).getTimezoneOffset(),I=Math.min(M,b);return 0>h?(v(),F)[u+32>>>2>>>0]=+(b!=M&&I==g):0<h!=(I==g)&&(b=Math.max(M,b),d.setTime(d.getTime()+6e4*((0<h?I:b)-g))),(v(),F)[u+24>>>2>>>0]=d.getDay(),h=(F1(d.getFullYear())?B1:U1)[d.getMonth()]+d.getDate()-1|0,(v(),F)[u+28>>>2>>>0]=h,(v(),F)[u>>>2>>>0]=d.getSeconds(),(v(),F)[u+4>>>2>>>0]=d.getMinutes(),(v(),F)[u+8>>>2>>>0]=d.getHours(),(v(),F)[u+12>>>2>>>0]=d.getDate(),(v(),F)[u+16>>>2>>>0]=d.getMonth(),(v(),F)[u+20>>>2>>>0]=d.getYear(),u=d.getTime(),BigInt(isNaN(u)?-1:u/1e3)}function j1(u,d,h,g,b,M,I){return n?De(16,1,u,d,h,g,b,M,I):-52}function G1(u,d,h,g,b,M){if(n)return De(17,1,u,d,h,g,b,M)}var Zn={},OS=()=>performance.timeOrigin+performance.now();function q1(u,d){if(n)return De(18,1,u,d);if(Zn[u]&&(clearTimeout(Zn[u].id),delete Zn[u]),!d)return 0;var h=setTimeout(()=>{delete Zn[u],At(()=>xv(u,performance.timeOrigin+performance.now()))},d);return Zn[u]={id:h,Ce:d},0}function IS(u,d,h,g){u>>>=0,d>>>=0,h>>>=0,g>>>=0;var b=new Date().getFullYear(),M=new Date(b,0,1).getTimezoneOffset();b=new Date(b,6,1).getTimezoneOffset();var I=Math.max(M,b);(v(),C)[u>>>2>>>0]=60*I,(v(),F)[d>>>2>>>0]=+(M!=b),u=(d=N=>{var U=Math.abs(N);return`UTC${0<=N?"-":"+"}${String(Math.floor(U/60)).padStart(2,"0")}${String(U%60).padStart(2,"0")}`})(M),d=d(b),b<M?(_r(u,h,17),_r(d,g,17)):(_r(u,g,17),_r(d,h,17))}var CS=()=>Date.now(),LS=1;function PS(u,d,h){if(h>>>=0,!(0<=u&&3>=u))return 28;if(u===0)u=Date.now();else{if(!LS)return 52;u=performance.timeOrigin+performance.now()}return u=Math.round(1e6*u),(v(),L)[h>>>3>>>0]=BigInt(u),0}var Rp=[],W1=(u,d)=>{Rp.length=0;for(var h;h=(v(),V)[u++>>>0];){var g=h!=105;d+=(g&=h!=112)&&d%8?4:0,Rp.push(h==112?(v(),C)[d>>>2>>>0]:h==106?(v(),L)[d>>>3>>>0]:h==105?(v(),F)[d>>>2>>>0]:(v(),le)[d>>>3>>>0]),d+=g?8:4}return Rp};function zS(u,d,h){return u>>>=0,d=W1(d>>>0,h>>>0),Jp[u](...d)}function NS(u,d,h){return u>>>=0,d=W1(d>>>0,h>>>0),Jp[u](...d)}var $S=()=>{};function RS(u,d){return S(Hs(u>>>0,d>>>0))}var DS=()=>{throw ve+=1,"unwind"};function FS(){return 4294901760}var BS=()=>1,US=()=>navigator.hardwareConcurrency;function jS(u){u>>>=0;var d=(v(),V).length;if(u<=d||4294901760<u)return!1;for(var h=1;4>=h;h*=2){var g=d*(1+.2/h);g=Math.min(g,u+100663296);e:{g=(Math.min(4294901760,65536*Math.ceil(Math.max(u,g)/65536))-Tr.buffer.byteLength+65535)/65536|0;try{Tr.grow(g),Ie();var b=1;break e}catch{}b=void 0}if(b)return!0}return!1}var or=u=>{var d=mr(u)+1,h=$l(d);return _r(u,h,d),h},Dp=(u,d)=>{(v(),C)[u>>>2>>>0]=d;var h=(v(),C)[u>>>2>>>0];(v(),C)[u+4>>>2>>>0]=(d-h)/4294967296},eo=u=>(v(),C)[u>>>2>>>0]+4294967296*(v(),F)[u+4>>>2>>>0],gt=[],GS=(u,d)=>{gt[u>>>0]=d},hr=[],Pl=[],Ks=(u,d)=>{Pl[u]=new Promise(h=>d.finally(()=>h(u)))},se=u=>{if(u)return gt[u>>>0]},qS=(u,d)=>{for(u=(v(),C)[u>>>2>>>0];u;u=(v(),C)[u>>>2>>>0])d[(v(),F)[u+4>>>2>>>0]](u)},zl=(u,d,h)=>{(v(),C)[u>>>2>>>0]=d,(v(),C)[u+4>>>2>>>0]=h},V1=u=>{var d=(v(),C)[u>>>2>>>0];return u=(v(),C)[u+4>>>2>>>0],Hs(d,u)},gr=u=>{var d=(v(),C)[u>>>2>>>0];return u=(v(),C)[u+4>>>2>>>0],d?Hs(d,u):u===0?"":void 0},WS=u=>{var d=gr(u+4),h=(h=(v(),C)[u+12>>>2>>>0])?se(h):"auto";if(u+=16){var g=se((v(),C)[u+4>>>2>>>0]),b=(v(),C)[u+16>>>2>>>0],M=(v(),C)[u+20>>>2>>>0];if(b){for(var I={},N=0;N<b;++N){var U=M+24*N;I[V1(U+4)]=(v(),le)[U+16>>>3>>>0]}b=I}else b=void 0;u={module:g,constants:b,entryPoint:gr(u+8)}}else u=void 0;return{label:d,layout:h,compute:u}},H1=(u,d)=>{function h(g,b){g=u[g],(v(),C)[d+b>>>2>>>0]=g}h("maxTextureDimension1D",4),h("maxTextureDimension2D",8),h("maxTextureDimension3D",12),h("maxTextureArrayLayers",16),h("maxBindGroups",20),h("maxBindGroupsPlusVertexBuffers",24),h("maxBindingsPerBindGroup",28),h("maxDynamicUniformBuffersPerPipelineLayout",32),h("maxDynamicStorageBuffersPerPipelineLayout",36),h("maxSampledTexturesPerShaderStage",40),h("maxSamplersPerShaderStage",44),h("maxStorageBuffersPerShaderStage",48),h("maxStorageTexturesPerShaderStage",52),h("maxUniformBuffersPerShaderStage",56),h("minUniformBufferOffsetAlignment",80),h("minStorageBufferOffsetAlignment",84),Dp(d+64,u.maxUniformBufferBindingSize),Dp(d+72,u.maxStorageBufferBindingSize),h("maxVertexBuffers",88),Dp(d+96,u.maxBufferSize),h("maxVertexAttributes",104),h("maxVertexBufferArrayStride",108),h("maxInterStageShaderVariables",112),h("maxColorAttachments",116),h("maxColorAttachmentBytesPerSample",120),h("maxComputeWorkgroupStorageSize",124),h("maxComputeInvocationsPerWorkgroup",128),h("maxComputeWorkgroupSizeX",132),h("maxComputeWorkgroupSizeY",136),h("maxComputeWorkgroupSizeZ",140),h("maxComputeWorkgroupsPerDimension",144),u.Ae!==void 0&&h("maxImmediateSize",148)},VS=[,"validation","out-of-memory","internal"],HS=[,"compatibility","core"],X1={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"},XS=[,"low-power","high-performance"],KS=[,"occlusion","timestamp"],QS={undefined:1,unknown:1,destroyed:2};function YS(u,d,h,g,b,M){d=Et(d),h=Et(h),g>>>=0,b>>>=0,M>>>=0;var I=se(u>>>0);if(u={},M){var N=(v(),C)[M+12>>>2>>>0];if(N){var U=(v(),C)[M+16>>>2>>>0];u.requiredFeatures=Array.from((v(),C).subarray(U>>>2>>>0,U+4*N>>>2>>>0),ne=>X1[ne])}var Y=(v(),C)[M+20>>>2>>>0];if(Y){let ne=function(Mt,pt,us=!1){pt=Y+pt,(pt=(v(),C)[pt>>>2>>>0])==4294967295||us&&pt==0||(je[Mt]=pt)},ut=function(Mt,pt){pt=Y+pt;var us=(v(),C)[pt>>>2>>>0],vO=(v(),C)[pt+4>>>2>>>0];us==4294967295&&vO==4294967295||(je[Mt]=eo(pt))};var Te=ne,Ne=ut,je={};ne("maxTextureDimension1D",4),ne("maxTextureDimension2D",8),ne("maxTextureDimension3D",12),ne("maxTextureArrayLayers",16),ne("maxBindGroups",20),ne("maxBindGroupsPlusVertexBuffers",24),ne("maxDynamicUniformBuffersPerPipelineLayout",32),ne("maxDynamicStorageBuffersPerPipelineLayout",36),ne("maxSampledTexturesPerShaderStage",40),ne("maxSamplersPerShaderStage",44),ne("maxStorageBuffersPerShaderStage",48),ne("maxStorageTexturesPerShaderStage",52),ne("maxUniformBuffersPerShaderStage",56),ne("minUniformBufferOffsetAlignment",80),ne("minStorageBufferOffsetAlignment",84),ut("maxUniformBufferBindingSize",64),ut("maxStorageBufferBindingSize",72),ne("maxVertexBuffers",88),ut("maxBufferSize",96),ne("maxVertexAttributes",104),ne("maxVertexBufferArrayStride",108),ne("maxInterStageShaderVariables",112),ne("maxColorAttachments",116),ne("maxColorAttachmentBytesPerSample",120),ne("maxComputeWorkgroupStorageSize",124),ne("maxComputeInvocationsPerWorkgroup",128),ne("maxComputeWorkgroupSizeX",132),ne("maxComputeWorkgroupSizeY",136),ne("maxComputeWorkgroupSizeZ",140),ne("maxComputeWorkgroupsPerDimension",144),ne("maxImmediateSize",148,!0),u.requiredLimits=je}(N=(v(),C)[M+24>>>2>>>0])&&(N={label:gr(N+4)},u.defaultQueue=N),u.label=gr(M+4)}ve+=1,Ks(d,I.requestDevice(u).then(ne=>{--ve,At(()=>{gt[b>>>0]=ne.queue,gt[g>>>0]=ne,Ks(h,ne.lost.then(ut=>{At(()=>{ne.onuncapturederror=()=>{};var Mt=ue(),pt=or(ut.message);Gp(h,QS[ut.reason],pt),ce(Mt)})})),ne.onuncapturederror=ut=>{var Mt=5;ut.error instanceof GPUValidationError?Mt=2:ut.error instanceof GPUOutOfMemoryError?Mt=3:ut.error instanceof GPUInternalError&&(Mt=4);var pt=ue();ut=or(ut.error.message),mv(g,Mt,ut),ce(pt)},"adapterInfo"in ne||(ne.adapterInfo=I.info),Vp(d,1,g,0)})},ne=>{--ve,At(()=>{var ut=ue(),Mt=or(ne.message);Vp(d,3,g,Mt),h&&Gp(h,4,Mt),ce(ut)})}))}function JS(u){var d=se(u>>>=0),h=hr[u];if(h){for(var g=0;g<h.length;++g)h[g]();delete hr[u]}d.destroy()}function ZS(u,d,h){h>>>=0;var g=se(u>>>=0);h==4294967295&&(h=void 0);try{var b=g.getMappedRange(d>>>0,h)}catch{return 0}var M=Kp(16,b.byteLength);return(v(),V).set(new Uint8Array(b),M>>>0),hr[u].push(()=>Ht(M)),M}function eT(u,d,h){h>>>=0;var g=se(u>>>=0);h==4294967295&&(h=void 0);try{var b=g.getMappedRange(d>>>0,h)}catch{return 0}var M=Kp(16,b.byteLength);return(v(),V).fill(0,M,b.byteLength),hr[u].push(()=>{new Uint8Array(b).set((v(),V).subarray(M>>>0,M+b.byteLength>>>0)),Ht(M)}),M}function tT(u,d,h,g,b){u>>>=0,d=Et(d),h=Et(h),b>>>=0;var M=se(u);hr[u]=[],b==4294967295&&(b=void 0),ve+=1,Ks(d,M.mapAsync(h,g>>>0,b).then(()=>{--ve,At(()=>{qp(d,1,0)})},I=>{--ve,At(()=>{ue();var N=or(I.message);qp(d,I.name==="AbortError"?4:I.name==="OperationError"?3:0,N),delete hr[u]})}))}function rT(u){var d=se(u>>>=0),h=hr[u];if(h){for(var g=0;g<h.length;++g)h[g]();delete hr[u],d.unmap()}}function sT(u){delete gt[u>>>0]}function nT(u,d,h){u>>>=0,d>>>=0,h>>>=0;var g=!!(v(),C)[d+32>>>2>>>0];d={label:gr(d+4),usage:(v(),C)[d+16>>>2>>>0],size:eo(d+24),mappedAtCreation:g},u=se(u);try{var b=u.createBuffer(d)}catch{return!1}return gt[h>>>0]=b,g&&(hr[h]=[]),!0}function oT(u,d,h,g){u>>>=0,d=Et(d),g>>>=0,h=WS(h>>>0),u=se(u),ve+=1,Ks(d,u.createComputePipelineAsync(h).then(b=>{--ve,At(()=>{gt[g>>>0]=b,jp(d,1,g,0)})},b=>{--ve,At(()=>{var M=ue(),I=or(b.message);jp(d,b.reason==="validation"?3:b.reason==="internal"?4:0,g,I),ce(M)})}))}function aT(u,d,h){u>>>=0,d>>>=0,h>>>=0;var g=(v(),C)[d>>>2>>>0],b=(v(),F)[g+4>>>2>>>0];d={label:gr(d+4),code:""},b===2&&(d.code=V1(g+8)),u=se(u).createShaderModule(d),gt[h>>>0]=u}var iT=u=>{(u=se(u)).onuncapturederror=null,u.destroy()};function lT(u,d){d=Et(d),u=se(u>>>0),ve+=1,Ks(d,u.popErrorScope().then(h=>{--ve,At(()=>{var g=5;h?h instanceof GPUValidationError?g=2:h instanceof GPUOutOfMemoryError?g=3:h instanceof GPUInternalError&&(g=4):g=1;var b=ue(),M=h?or(h.message):0;Wp(d,1,g,M),ce(b)})},h=>{--ve,At(()=>{var g=ue(),b=or(h.message);Wp(d,1,5,b),ce(g)})}))}function cT(u,d,h,g){if(d=Et(d),g>>>=0,h>>>=0){var b={featureLevel:HS[(v(),F)[h+4>>>2>>>0]],powerPreference:XS[(v(),F)[h+8>>>2>>>0]],forceFallbackAdapter:!!(v(),C)[h+12>>>2>>>0]};(u=(v(),C)[h>>>2>>>0])!==0&&(v(),b.Fe=!!(v(),C)[u+8>>>2>>>0])}"gpu"in navigator?(ve+=1,Ks(d,navigator.gpu.requestAdapter(b).then(M=>{--ve,At(()=>{if(M)gt[g>>>0]=M,to(d,1,g,0);else{var I=ue(),N=or("WebGPU not available on this browser (requestAdapter returned null)");to(d,3,g,N),ce(I)}})},M=>{--ve,At(()=>{var I=ue(),N=or(M.message);to(d,4,g,N),ce(I)})}))):(b=ue(),u=or("WebGPU not available on this browser (navigator.gpu is not available)"),to(d,3,g,u),ce(b))}function uT(u,d,h){return u>>>=0,d>>>=0,h>>>=0,R1(async()=>{var g=[];if(h){var b=(v(),F)[h>>>2>>>0];g.length=d+1,g[d]=new Promise(N=>setTimeout(N,b,0))}else g.length=d;for(var M=0;M<d;++M){var I=eo(u+8*M);if(!(I in Pl))return I;g[M]=Pl[I]}return g=await Promise.race(g),delete Pl[g],g})}var Fp,Bp={},K1=()=>{if(!Fp){var u,d={USER:"web_user",LOGNAME:"web_user",PATH:"/",PWD:"/",HOME:"/home/web_user",LANG:(globalThis.navigator?.language??"C").replace("-","_")+".UTF-8",_:"./this.program"};for(u in Bp)Bp[u]===void 0?delete d[u]:d[u]=Bp[u];var h=[];for(u in d)h.push(`${u}=${d[u]}`);Fp=h}return Fp};function Q1(u,d){if(n)return De(19,1,u,d);u>>>=0,d>>>=0;var h,g=0,b=0;for(h of K1()){var M=d+g;(v(),C)[u+b>>>2>>>0]=M,g+=_r(h,M,1/0)+1,b+=4}return 0}function Y1(u,d){if(n)return De(20,1,u,d);u>>>=0,d>>>=0;var h=K1();for(var g of((v(),C)[u>>>2>>>0]=h.length,u=0,h))u+=mr(g)+1;return(v(),C)[d>>>2>>>0]=u,0}function J1(u){return n?De(21,1,u):52}function Z1(u,d,h,g){return n?De(22,1,u,d,h,g):52}function ev(u,d,h,g){return n?De(23,1,u,d,h,g):70}var pT=[null,[],[]];function tv(u,d,h,g){if(n)return De(24,1,u,d,h,g);d>>>=0,h>>>=0,g>>>=0;for(var b=0,M=0;M<h;M++){var I=(v(),C)[d>>>2>>>0],N=(v(),C)[d+4>>>2>>>0];d+=8;for(var U=0;U<N;U++){var Y=u,Te=(v(),V)[I+U>>>0],Ne=pT[Y];Te===0||Te===10?((Y===1?T:S)(g1(Ne)),Ne.length=0):Ne.push(Te)}b+=N}return(v(),C)[g>>>2>>>0]=b,0}function dT(u){return u>>>0}function fT(u,d){return H1(se(u>>>0).limits,d>>>0),1}function _T(u,d){return se(u>>>0).features.has(X1[d])}function mT(u){return BigInt(se(u>>>0).size)}function hT(u){return BigInt(se(u>>>0).usage)}function gT(u,d){if(u>>>=0,d>>>=0){var h=gr(d+4);h={label:h,timestampWrites:d=(d=(v(),C)[d+12>>>2>>>0])!==0?{querySet:se((v(),C)[d+4>>>2>>>0]),beginningOfPassWriteIndex:(v(),C)[d+8>>>2>>>0],endOfPassWriteIndex:(v(),C)[d+12>>>2>>>0]}:void 0}}return d=se(u),u=uv(0),h=d.beginComputePass(h),gt[u>>>0]=h,u}function wT(u,d,h,g,b,M){h=Et(h),b=Et(b),M=Et(M),se(u>>>0).copyBufferToBuffer(se(d>>>0),h,se(g>>>0),b,M)}function xT(u){var d=se(u>>>0);return u=lv(0),d=d.finish(),gt[u>>>0]=d,u}function yT(u,d,h,g,b,M){M=Et(M),se(u>>>0).resolveQuerySet(se(d>>>0),h,g,se(b>>>0),M)}function bT(u,d,h,g){se(u>>>0).dispatchWorkgroups(d,h,g)}function vT(u,d,h){h=Et(h),se(u>>>0).dispatchWorkgroupsIndirect(se(d>>>0),h)}function kT(u){se(u>>>0).end()}function ET(u,d,h,g,b){g>>>=0,b>>>=0,u=se(u>>>0),h=se(h>>>0),g==0?u.setBindGroup(d,h):u.setBindGroup(d,h,(v(),C),b>>>2,g)}function AT(u,d){se(u>>>0).setPipeline(se(d>>>0))}function MT(u,d,h){se(u>>>0).Ee(se(d>>>0),h)}function ST(u,d){var h=se(u>>>0);return u=iv(0),d=h.getBindGroupLayout(d),gt[u>>>0]=d,u}function TT(u,d){function h(b){var M=(v(),C)[b+8>>>2>>>0],I=(v(),C)[b+32>>>2>>>0],N=(v(),C)[b+36>>>2>>>0],U=0;return qS(b,{327681:Y=>{U=(v(),C)[Y+8>>>2>>>0]}}),M?((I=eo(b+24))==-1&&(I=void 0),M={buffer:se(M),offset:eo(b+16),size:I}):M=se(I||N||U),{binding:(v(),C)[b+4>>>2>>>0],resource:M}}u>>>=0,d={label:gr(4+(d>>>=0)),layout:se((v(),C)[d+12>>>2>>>0]),entries:(function(b,M){for(var I=[],N=0;N<b;++N)I.push(h(M+40*N));return I})((v(),C)[d+16>>>2>>>0],(v(),C)[d+20>>>2>>>0])},u=se(u);var g=av(0);return GS(g,u.createBindGroup(d)),g}function OT(u,d){var h;return u>>>=0,(d>>>=0)&&(h={label:gr(d+4)}),d=se(u),u=cv(0),h=d.createCommandEncoder(h),gt[u>>>0]=h,u}function IT(u,d){u>>>=0,d>>>=0,d={type:KS[(v(),F)[d+12>>>2>>>0]],count:(v(),C)[d+16>>>2>>>0]};var h=se(u);return u=pv(0),d=h.createQuerySet(d),gt[u>>>0]=d,u}function CT(u,d){u=se(u>>>0).adapterInfo,d>>>=0,(v(),C)[d+52>>>2>>>0]=u.subgroupMinSize,(v(),C)[d+56>>>2>>>0]=u.subgroupMaxSize;var h=u.vendor+u.architecture+u.device+u.description,g=mr(h)+1,b=Qs(g);return b&&_r(h,b,g),h=b,g=mr(u.vendor),zl(d+4,h,g),h+=g,g=mr(u.architecture),zl(d+12,h,g),h+=g,g=mr(u.device),zl(d+20,h,g),zl(d+28,h+g,mr(u.description)),(v(),F)[d+36>>>2>>>0]=2,u=u.isFallbackAdapter?3:4,(v(),F)[d+40>>>2>>>0]=u,(v(),C)[d+44>>>2>>>0]=0,(v(),C)[d+48>>>2>>>0]=0,1}var LT={"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 PT(u,d){d>>>=0;var h=se(u>>>0);u=Qs(4*h.features.size);var g=0,b=0;for(let M of h.features)0<=(h=LT[M])&&((v(),F)[u+g>>>2>>>0]=h,g+=4,b++);(v(),C)[d+4>>>2>>>0]=u,(v(),C)[d>>>2>>>0]=b}function zT(u,d){return H1(se(u>>>0).limits,d>>>0),1}function NT(u,d){se(u>>>0).pushErrorScope(VS[d])}function $T(u,d,h){d>>>=0,h>>>=0,u=se(u>>>0),d=Array.from((v(),F).subarray(h>>>2>>>0,h+4*d>>>2>>>0),g=>se(g)),u.submit(d)}function RT(u,d,h,g,b){h=Et(h),g>>>=0,b>>>=0,u=se(u>>>0),d=se(d>>>0),g=(v(),V).subarray(g>>>0,g+b>>>0),u.writeBuffer(d,h,g,0,b)}n||(function(){for(var u=e.numThreads-1;u--;)u1();Se.push(async()=>{var d=(async function(){if(!n)return Promise.all(ot.map(c1))})();xe++,await d,--xe==0&&We&&(d=We,We=null,d())})})(),n||(Tr=new WebAssembly.Memory({initial:256,maximum:65536,shared:!0}),Ie()),e.wasmBinary&&(f=e.wasmBinary),e.stackSave=()=>ue(),e.stackRestore=u=>ce(u),e.stackAlloc=u=>$l(u),e.setValue=function(u,d,h="i8"){switch(h.endsWith("*")&&(h="*"),h){case"i1":case"i8":(v(),B)[u>>>0]=d;break;case"i16":(v(),q)[u>>>1>>>0]=d;break;case"i32":(v(),F)[u>>>2>>>0]=d;break;case"i64":(v(),L)[u>>>3>>>0]=BigInt(d);break;case"float":(v(),te)[u>>>2>>>0]=d;break;case"double":(v(),le)[u>>>3>>>0]=d;break;case"*":(v(),C)[u>>>2>>>0]=d;break;default:Ue(`invalid type for setValue: ${h}`)}},e.getValue=function(u,d="i8"){switch(d.endsWith("*")&&(d="*"),d){case"i1":case"i8":return(v(),B)[u>>>0];case"i16":return(v(),q)[u>>>1>>>0];case"i32":return(v(),F)[u>>>2>>>0];case"i64":return(v(),L)[u>>>3>>>0];case"float":return(v(),te)[u>>>2>>>0];case"double":return(v(),le)[u>>>3>>>0];case"*":return(v(),C)[u>>>2>>>0];default:Ue(`invalid type for getValue: ${d}`)}},e.UTF8ToString=Hs,e.stringToUTF8=_r,e.lengthBytesUTF8=mr;var rv,sv,Up,Nl,Ht,Qs,nv,ov,av,iv,lv,cv,uv,pv,dv,fv,_v,jp,Gp,qp,Wp,to,Vp,mv,Hp,hv,gv,wv,Xp,xv,yv,Kp,ge,ro,bv,ce,$l,ue,vv,Qp,kv,Ev,Av,Yp,Mv,Sv,Tv,Ov,Iv,Cv,Lv,Pv,zv,Nv,$v,Rv,Dv,Fv,Bv,Uv,jv,Gv,qv,Wv,Vv,Hv,Xv,Kv,Qv,Yv,Jv,Zv,ek,tk,rk,sk,nk,ok,ak,ik,lk,ck,uk,wr,DT=[Sr,is,f1,w1,x1,y1,b1,v1,k1,E1,A1,M1,S1,T1,O1,I1,j1,G1,q1,Q1,Y1,J1,Z1,ev,tv],Jp={925676:(u,d,h,g,b)=>{if(e===void 0||!e.Uc)return 1;if((u=Hs(Number(u>>>0))).startsWith("./")&&(u=u.substring(2)),!(u=e.Uc.get(u)))return 2;if(d=Number(d>>>0),h=Number(h>>>0),g=Number(g>>>0),d+h>u.byteLength)return 3;try{let M=u.subarray(d,d+h);switch(b){case 0:(v(),V).set(M,g>>>0);break;case 1:e.ad?e.ad(g,M):e.oe(g,M);break;default:return 4}return 0}catch{return 4}},926500:(u,d,h)=>{e.Sd(u,(v(),V).subarray(d>>>0,d+h>>>0))},926564:()=>e.me(),926606:u=>{e.jd(u)},926643:()=>typeof wasmOffsetConverter<"u"};function FT(u,d,h,g){var b=ue();try{return Pv(u,d,h,g)}catch(M){if(ce(b),M!==M+0)throw M;ge(1,0)}}function BT(u,d,h){var g=ue();try{return Iv(u,d,h)}catch(b){if(ce(g),b!==b+0)throw b;ge(1,0)}}function UT(u,d,h){var g=ue();try{Av(u,d,h)}catch(b){if(ce(g),b!==b+0)throw b;ge(1,0)}}function jT(u,d){var h=ue();try{return Yp(u,d)}catch(g){if(ce(h),g!==g+0)throw g;ge(1,0)}}function GT(u){var d=ue();try{Mv(u)}catch(h){if(ce(d),h!==h+0)throw h;ge(1,0)}}function qT(u,d,h,g,b,M,I){var N=ue();try{return Ov(u,d,h,g,b,M,I)}catch(U){if(ce(N),U!==U+0)throw U;ge(1,0)}}function WT(u,d){var h=ue();try{zv(u,d)}catch(g){if(ce(h),g!==g+0)throw g;ge(1,0)}}function VT(u,d,h,g,b,M){var I=ue();try{Sv(u,d,h,g,b,M)}catch(N){if(ce(I),N!==N+0)throw N;ge(1,0)}}function HT(u,d,h,g){var b=ue();try{Lv(u,d,h,g)}catch(M){if(ce(b),M!==M+0)throw M;ge(1,0)}}function XT(u,d,h,g,b,M,I){var N=ue();try{$v(u,d,h,g,b,M,I)}catch(U){if(ce(N),U!==U+0)throw U;ge(1,0)}}function KT(u,d,h,g,b,M,I){var N=ue();try{Rv(u,d,h,g,b,M,I)}catch(U){if(ce(N),U!==U+0)throw U;ge(1,0)}}function QT(u,d,h,g,b,M,I,N){var U=ue();try{Vv(u,d,h,g,b,M,I,N)}catch(Y){if(ce(U),Y!==Y+0)throw Y;ge(1,0)}}function YT(u,d,h,g,b,M,I,N,U,Y,Te,Ne){var je=ue();try{Dv(u,d,h,g,b,M,I,N,U,Y,Te,Ne)}catch(ne){if(ce(je),ne!==ne+0)throw ne;ge(1,0)}}function JT(u,d,h,g,b){var M=ue();try{return Nv(u,d,h,g,b)}catch(I){if(ce(M),I!==I+0)throw I;ge(1,0)}}function ZT(u,d,h,g,b){var M=ue();try{Tv(u,d,h,g,b)}catch(I){if(ce(M),I!==I+0)throw I;ge(1,0)}}function eO(u,d,h,g,b,M,I,N){var U=ue();try{Cv(u,d,h,g,b,M,I,N)}catch(Y){if(ce(U),Y!==Y+0)throw Y;ge(1,0)}}function tO(u){var d=ue();try{return Hv(u)}catch(h){if(ce(d),h!==h+0)throw h;ge(1,0)}}function rO(u,d,h){var g=ue();try{return Xv(u,d,h)}catch(b){if(ce(g),b!==b+0)throw b;ge(1,0)}}function sO(u,d){var h=ue();try{return ak(u,d)}catch(g){if(ce(h),g!==g+0)throw g;return ge(1,0),0n}}function nO(u,d,h,g,b){var M=ue();try{Kv(u,d,h,g,b)}catch(I){if(ce(M),I!==I+0)throw I;ge(1,0)}}function oO(u){var d=ue();try{return Fv(u)}catch(h){if(ce(d),h!==h+0)throw h;return ge(1,0),0n}}function aO(u,d,h,g,b,M){var I=ue();try{return qv(u,d,h,g,b,M)}catch(N){if(ce(I),N!==N+0)throw N;ge(1,0)}}function iO(u,d,h,g,b,M){var I=ue();try{return Qv(u,d,h,g,b,M)}catch(N){if(ce(I),N!==N+0)throw N;ge(1,0)}}function lO(u,d,h,g,b,M){var I=ue();try{return Yv(u,d,h,g,b,M)}catch(N){if(ce(I),N!==N+0)throw N;ge(1,0)}}function cO(u,d,h,g,b,M,I,N){var U=ue();try{return Wv(u,d,h,g,b,M,I,N)}catch(Y){if(ce(U),Y!==Y+0)throw Y;ge(1,0)}}function uO(u,d,h,g,b){var M=ue();try{return Jv(u,d,h,g,b)}catch(I){if(ce(M),I!==I+0)throw I;return ge(1,0),0n}}function pO(u,d,h,g){var b=ue();try{return Zv(u,d,h,g)}catch(M){if(ce(b),M!==M+0)throw M;ge(1,0)}}function dO(u,d,h,g){var b=ue();try{return ek(u,d,h,g)}catch(M){if(ce(b),M!==M+0)throw M;ge(1,0)}}function fO(u,d,h,g,b,M,I,N,U,Y,Te,Ne){var je=ue();try{return tk(u,d,h,g,b,M,I,N,U,Y,Te,Ne)}catch(ne){if(ce(je),ne!==ne+0)throw ne;ge(1,0)}}function _O(u,d,h,g,b,M,I,N,U,Y,Te){var Ne=ue();try{rk(u,d,h,g,b,M,I,N,U,Y,Te)}catch(je){if(ce(Ne),je!==je+0)throw je;ge(1,0)}}function mO(u,d,h,g,b,M,I,N,U,Y,Te,Ne,je,ne,ut,Mt){var pt=ue();try{sk(u,d,h,g,b,M,I,N,U,Y,Te,Ne,je,ne,ut,Mt)}catch(us){if(ce(pt),us!==us+0)throw us;ge(1,0)}}function hO(u,d,h,g){var b=ue();try{return nk(u,d,h,g)}catch(M){if(ce(b),M!==M+0)throw M;ge(1,0)}}function gO(u,d,h,g,b){var M=ue();try{return ok(u,d,h,g,b)}catch(I){if(ce(M),I!==I+0)throw I;ge(1,0)}}function wO(u,d,h){var g=ue();try{return Uv(u,d,h)}catch(b){if(ce(g),b!==b+0)throw b;return ge(1,0),0n}}function xO(u,d,h){var g=ue();try{return Bv(u,d,h)}catch(b){if(ce(g),b!==b+0)throw b;ge(1,0)}}function yO(u,d,h){var g=ue();try{return jv(u,d,h)}catch(b){if(ce(g),b!==b+0)throw b;ge(1,0)}}function bO(u,d,h,g){var b=ue();try{Gv(u,d,h,g)}catch(M){if(ce(b),M!==M+0)throw M;ge(1,0)}}function Rl(){if(0<xe)We=Rl;else if(n)w?.(e),ae();else{for(var u=Se;0<u.length;)u.shift()(e);0<xe?We=Rl:(e.calledRun=!0,P||(ae(),w?.(e)))}}return n||(wr=await tt(),Rl()),e.PTR_SIZE=4,e.webgpuInit=u=>{let d=new WeakMap,h,g,b=1;e.webgpuRegisterDevice=N=>{if(g!==void 0)throw Error("another WebGPU EP inference session is being created.");if(N){var U=d.get(N);if(!U){let Y=((Te,Ne=0)=>{var je=_v(Ne);return Ne=fv(Ne,je),gt[je>>>0]=Te.queue,gt[Ne>>>0]=Te,Ne})(N,U=ov(0));U=[b++,U,Y],d.set(N,U)}return h=N,g=U[0],U}h=void 0,g=0};let M=new Map;e.webgpuOnCreateSession=N=>{if(g!==void 0){var U=g;if(g=void 0,N){let Y=Up(U);M.set(N,Y),U===0&&u(h??se(Y))}h=void 0}},e.webgpuOnReleaseSession=N=>{M.delete(N)};let I=Symbol("gpuBufferMetadata");e.webgpuRegisterBuffer=(N,U,Y)=>{if(Y)return N[I]=[Y,NaN],Y;if(Y=N[I])return Y[1]++,Y[0];if((U=M.get(U))===void 0)throw Error("Invalid session handle passed to webgpuRegisterBuffer");return U=((Te,Ne=0)=>(Te.mapState==="unmapped"||Ue(),Ne=dv(Ne),gt[Ne>>>0]=Te,Ne))(N,U),N[I]=[U,1],U},e.webgpuUnregisterBuffer=N=>{let U=N[I];if(!U)throw Error("Buffer is not registered");U[1]--,U[1]===0&&(nv(U[0]),delete N[I])},e.webgpuGetBuffer=N=>se(N),e.webgpuCreateDownloader=(N,U,Y)=>{if((Y=M.get(Y))===void 0)throw Error("Invalid session handle passed to webgpuRegisterBuffer");let Te=se(Y),Ne=16*Math.ceil(Number(U)/16);return async()=>{let je=Te.createBuffer({size:Ne,usage:9});try{let ne=Te.createCommandEncoder();return ne.copyBufferToBuffer(N,0,je,0,Ne),Te.queue.submit([ne.finish()]),await je.mapAsync(GPUMapMode.READ),je.getMappedRange().slice(0,U)}finally{je.destroy()}}},e.ad=(N,U)=>{var Y=U.buffer;let Te=U.byteOffset,Ne=U.byteLength;if(U=16*Math.ceil(Number(Ne)/16),N=se(N),!h){var je=Up(g);h=se(je)}let ne=(je=h.createBuffer({mappedAtCreation:!0,size:U,usage:6})).getMappedRange();new Uint8Array(ne).set(new Uint8Array(Y,Te,Ne)),je.unmap(),(Y=h.createCommandEncoder()).copyBufferToBuffer(je,0,N,0,U),h.queue.submit([Y.finish()]),je.destroy()}},e.webnnInit=u=>{let d=u[0];[e.me,e.jd,e.webnnEnsureTensor,e.Sd,e.webnnDownloadTensor,e.le,e.webnnEnableTraceEvent]=u.slice(1),e.webnnReleaseTensorId=e.jd,e.webnnUploadTensor=e.Sd,e.webnnRegisterMLContext=e.le,e.webnnOnRunStart=h=>d.onRunStart(h),e.webnnOnRunEnd=d.onRunEnd.bind(d),e.webnnOnReleaseSession=h=>{d.onReleaseSession(h)},e.webnnCreateMLTensorDownloader=(h,g)=>d.createMLTensorDownloader(h,g),e.webnnRegisterMLTensor=(h,g,b,M)=>d.registerMLTensor(h,g,b,M),e.webnnCreateMLContext=h=>d.createMLContext(h),e.webnnRegisterMLConstant=(h,g,b,M,I,N)=>d.registerMLConstant(h,g,b,M,I,e.Uc,N),e.webnnRegisterGraphInput=d.registerGraphInput.bind(d),e.webnnIsGraphInput=d.isGraphInput.bind(d),e.webnnRegisterGraphOutput=d.registerGraphOutput.bind(d),e.webnnIsGraphOutput=d.isGraphOutput.bind(d),e.webnnCreateTemporaryTensor=d.createTemporaryTensor.bind(d),e.webnnIsGraphInputOutputTypeSupported=d.isGraphInputOutputTypeSupported.bind(d)},J?e:new Promise((u,d)=>{w=u,x=d})}var lA,mE,gP=be(()=>{"use strict";lA=_E,mE=globalThis.self?.name?.startsWith("em-pthread"),mE&&_E()}),bd,Rd,hE,Pt,cA,Zl,gE,wE,vd,xE,kd,uA,Ed,pA,Vd=be(()=>{"use strict";Wd(),bd=typeof location>"u"?void 0:location.origin,Rd=import.meta.url>"file:"&&import.meta.url<"file;",hE=()=>{if(Rd){let t=URL;return new URL(new t("ort.webgpu.bundle.min.mjs",import.meta.url).href,bd).href}return import.meta.url},Pt=hE(),cA=()=>{if(Pt&&!Pt.startsWith("blob:"))return Pt.substring(0,Pt.lastIndexOf("/")+1)},Zl=(t,e)=>{try{let r=e??Pt;return(r?new URL(t,r):new URL(t)).origin===bd}catch{return!1}},gE=(t,e)=>{let r=e??Pt;try{return(r?new URL(t,r):new URL(t)).href}catch{return}},wE=(t,e)=>`${e??"./"}${t}`,vd=async t=>{let e=await(await fetch(t,{credentials:"same-origin"})).blob();return URL.createObjectURL(e)},xE=async t=>(await import(t)).default,kd=(hP(),oc(oA)).default,uA=async()=>{if(!Pt)throw new Error("Failed to load proxy worker: cannot determine the script source URL.");if(Zl(Pt))return[void 0,kd()];let t=await vd(Pt);return[t,kd(t)]},Ed=(gP(),oc(iA)).default,pA=async(t,e,r,s)=>{let n=Ed&&!(t||e);if(n)if(Pt)n=Zl(Pt)||s&&!r;else if(s&&!r)n=!0;else throw new Error("cannot determine the script source URL.");if(n)return[void 0,Ed];{let o="ort-wasm-simd-threaded.asyncify.mjs",a=t??gE(o,e),i=r&&a&&!Zl(a,e),l=i?await vd(a):a??wE(o,e);return[i?l:void 0,await xE(l)]}}}),Ad,ec,mo,Md,yE,bE,vE,Hd,Be,Es=be(()=>{"use strict";Vd(),ec=!1,mo=!1,Md=!1,yE=()=>{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}},bE=()=>{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}},vE=()=>{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}},Hd=async t=>{if(ec)return Promise.resolve();if(mo)throw new Error("multiple calls to 'initializeWebAssembly()' detected.");if(Md)throw new Error("previous call to 'initializeWebAssembly()' failed.");mo=!0;let e=t.initTimeout,r=t.numThreads;if(t.simd!==!1){if(t.simd==="relaxed"){if(!vE())throw new Error("Relaxed WebAssembly SIMD is not supported in the current environment.")}else if(!bE())throw new Error("WebAssembly SIMD is not supported in the current environment.")}let s=yE();r>1&&!s&&(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."),t.numThreads=r=1);let n=t.wasmPaths,o=typeof n=="string"?n:void 0,a=n?.mjs,i=a?.href??a,l=n?.wasm,c=l?.href??l,p=t.wasmBinary,[f,_]=await pA(i,o,r>1,!!p||!!c),m=!1,w=[];if(e>0&&w.push(new Promise(x=>{setTimeout(()=>{m=!0,x()},e)})),w.push(new Promise((x,k)=>{let E={numThreads:r};if(p)E.wasmBinary=p,E.locateFile=A=>A;else if(c||o)E.locateFile=A=>c??o+A;else if(i&&i.indexOf("blob:")!==0)E.locateFile=A=>new URL(A,i).href;else if(f){let A=cA();A&&(E.locateFile=T=>A+T)}_(E).then(A=>{mo=!1,ec=!0,Ad=A,x(),f&&URL.revokeObjectURL(f)},A=>{mo=!1,Md=!0,k(A)})})),await Promise.race(w),m)throw new Error(`WebAssembly backend initializing failed due to timeout: ${e}ms`)},Be=()=>{if(ec&&Ad)return Ad;throw new Error("WebAssembly is not initialized yet.")}}),zt,ic,Le,Xd=be(()=>{"use strict";Es(),zt=(t,e)=>{let r=Be(),s=r.lengthBytesUTF8(t)+1,n=r._malloc(s);return r.stringToUTF8(t,n,s),e.push(n),n},ic=(t,e,r,s)=>{if(typeof t=="object"&&t!==null){if(r.has(t))throw new Error("Circular reference in options");r.add(t)}Object.entries(t).forEach(([n,o])=>{let a=e?e+n:n;if(typeof o=="object")ic(o,a+".",r,s);else if(typeof o=="string"||typeof o=="number")s(a,o.toString());else if(typeof o=="boolean")s(a,o?"1":"0");else throw new Error(`Can't handle extra config type: ${typeof o}`)})},Le=t=>{let e=Be(),r=e.stackSave();try{let s=e.PTR_SIZE,n=e.stackAlloc(2*s);e._OrtGetLastError(n,n+s);let o=Number(e.getValue(n,s===4?"i32":"i64")),a=e.getValue(n+s,"*"),i=a?e.UTF8ToString(a):"";throw new Error(`${t} ERROR_CODE: ${o}, ERROR_MESSAGE: ${i}`)}finally{e.stackRestore(r)}}}),dA,wP=be(()=>{"use strict";Es(),Xd(),dA=t=>{let e=Be(),r=0,s=[],n=t||{};try{if(t?.logSeverityLevel===void 0)n.logSeverityLevel=2;else if(typeof t.logSeverityLevel!="number"||!Number.isInteger(t.logSeverityLevel)||t.logSeverityLevel<0||t.logSeverityLevel>4)throw new Error(`log severity level is not valid: ${t.logSeverityLevel}`);if(t?.logVerbosityLevel===void 0)n.logVerbosityLevel=0;else if(typeof t.logVerbosityLevel!="number"||!Number.isInteger(t.logVerbosityLevel))throw new Error(`log verbosity level is not valid: ${t.logVerbosityLevel}`);t?.terminate===void 0&&(n.terminate=!1);let o=0;return t?.tag!==void 0&&(o=zt(t.tag,s)),r=e._OrtCreateRunOptions(n.logSeverityLevel,n.logVerbosityLevel,!!n.terminate,o),r===0&&Le("Can't create run options."),t?.extra!==void 0&&ic(t.extra,"",new WeakSet,(a,i)=>{let l=zt(a,s),c=zt(i,s);e._OrtAddRunConfigEntry(r,l,c)!==0&&Le(`Can't set a run config entry: ${a} - ${i}.`)}),[r,s]}catch(o){throw r!==0&&e._OrtReleaseRunOptions(r),s.forEach(a=>e._free(a)),o}}}),kE,EE,AE,tc,$r,ME,fA,xP=be(()=>{"use strict";Es(),Xd(),kE=t=>{switch(t){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: ${t}`)}},EE=t=>{switch(t){case"sequential":return 0;case"parallel":return 1;default:throw new Error(`unsupported execution mode: ${t}`)}},AE=t=>{t.extra||(t.extra={}),t.extra.session||(t.extra.session={});let e=t.extra.session;e.use_ort_model_bytes_directly||(e.use_ort_model_bytes_directly="1"),t.executionProviders&&t.executionProviders.some(r=>(typeof r=="string"?r:r.name)==="webgpu")&&(t.enableMemPattern=!1)},tc=(t,e,r,s)=>{let n=zt(e,s),o=zt(r,s);Be()._OrtAddSessionConfigEntry(t,n,o)!==0&&Le(`Can't set a session config entry: ${e} - ${r}.`)},$r=(t,e,r,s)=>{let n=zt(e,s),o=zt(r,s);t.push([n,o])},ME=async(t,e,r)=>{let s=e.executionProviders;for(let n of s){let o=typeof n=="string"?n:n.name,a=[];switch(o){case"webnn":if(o="WEBNN",typeof n!="string"){let f=n?.deviceType;f&&tc(t,"deviceType",f,r)}break;case"webgpu":{o="WebGPU";let f;if(typeof n!="string"){let m=n;if(m.device)if(typeof GPUDevice<"u"&&m.device instanceof GPUDevice)f=m.device;else throw new Error("Invalid GPU device set in WebGPU EP options.");let{enableGraphCapture:w}=e;if(typeof w=="boolean"&&w&&$r(a,"enableGraphCapture","1",r),typeof m.preferredLayout=="string"&&$r(a,"preferredLayout",m.preferredLayout,r),m.forceCpuNodeNames){let x=Array.isArray(m.forceCpuNodeNames)?m.forceCpuNodeNames:[m.forceCpuNodeNames];$r(a,"forceCpuNodeNames",x.join(`
13
- `),r)}m.validationMode&&$r(a,"validationMode",m.validationMode,r)}let _=Be().webgpuRegisterDevice(f);if(_){let[m,w,x]=_;$r(a,"deviceId",m.toString(),r),$r(a,"webgpuInstance",w.toString(),r),$r(a,"webgpuDevice",x.toString(),r)}}break;case"wasm":case"cpu":continue;default:throw new Error(`not supported execution provider: ${o}`)}let i=zt(o,r),l=a.length,c=0,p=0;if(l>0){c=Be()._malloc(l*Be().PTR_SIZE),r.push(c),p=Be()._malloc(l*Be().PTR_SIZE),r.push(p);for(let f=0;f<l;f++)Be().setValue(c+f*Be().PTR_SIZE,a[f][0],"*"),Be().setValue(p+f*Be().PTR_SIZE,a[f][1],"*")}await Be()._OrtAppendExecutionProvider(t,i,c,p,l)!==0&&Le(`Can't append execution provider: ${o}.`)}},fA=async t=>{let e=Be(),r=0,s=[],n=t||{};AE(n);try{let o=kE(n.graphOptimizationLevel??"all"),a=EE(n.executionMode??"sequential"),i=typeof n.logId=="string"?zt(n.logId,s):0,l=n.logSeverityLevel??2;if(!Number.isInteger(l)||l<0||l>4)throw new Error(`log severity level is not valid: ${l}`);let c=n.logVerbosityLevel??0;if(!Number.isInteger(c)||c<0||c>4)throw new Error(`log verbosity level is not valid: ${c}`);let p=typeof n.optimizedModelFilePath=="string"?zt(n.optimizedModelFilePath,s):0;if(r=e._OrtCreateSessionOptions(o,!!n.enableCpuMemArena,!!n.enableMemPattern,a,!!n.enableProfiling,0,i,l,c,p),r===0&&Le("Can't create session options."),n.executionProviders&&await ME(r,n,s),n.enableGraphCapture!==void 0){if(typeof n.enableGraphCapture!="boolean")throw new Error(`enableGraphCapture must be a boolean value: ${n.enableGraphCapture}`);tc(r,"enableGraphCapture",n.enableGraphCapture.toString(),s)}if(n.freeDimensionOverrides)for(let[f,_]of Object.entries(n.freeDimensionOverrides)){if(typeof f!="string")throw new Error(`free dimension override name must be a string: ${f}`);if(typeof _!="number"||!Number.isInteger(_)||_<0)throw new Error(`free dimension override value must be a non-negative integer: ${_}`);let m=zt(f,s);e._OrtAddFreeDimensionOverride(r,m,_)!==0&&Le(`Can't set a free dimension override: ${f} - ${_}.`)}return n.extra!==void 0&&ic(n.extra,"",new WeakSet,(f,_)=>{tc(r,f,_,s)}),[r,s]}catch(o){throw r!==0&&e._OrtReleaseSessionOptions(r)!==0&&Le("Can't release session options."),s.forEach(a=>e._free(a)),o}}}),xs,nc,ln,yo,lc,Kd,Qd,Dd,cn=be(()=>{"use strict";xs=t=>{switch(t){case"int8":return 3;case"uint8":return 2;case"bool":return 9;case"int16":return 5;case"uint16":return 4;case"int32":return 6;case"uint32":return 12;case"float16":return 10;case"float32":return 1;case"float64":return 11;case"string":return 8;case"int64":return 7;case"uint64":return 13;case"int4":return 22;case"uint4":return 21;default:throw new Error(`unsupported data type: ${t}`)}},nc=t=>{switch(t){case 3:return"int8";case 2:return"uint8";case 9:return"bool";case 5:return"int16";case 4:return"uint16";case 6:return"int32";case 12:return"uint32";case 10:return"float16";case 1:return"float32";case 11:return"float64";case 8:return"string";case 7:return"int64";case 13:return"uint64";case 22:return"int4";case 21:return"uint4";default:throw new Error(`unsupported data type: ${t}`)}},ln=(t,e)=>{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][t],s=typeof e=="number"?e:e.reduce((n,o)=>n*o,1);return r>0?Math.ceil(s*r):void 0},yo=t=>{switch(t){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: ${t}`)}},lc=t=>{switch(t){case"verbose":return 0;case"info":return 1;case"warning":return 2;case"error":return 3;case"fatal":return 4;default:throw new Error(`unsupported logging level: ${t}`)}},Kd=t=>t==="float32"||t==="float16"||t==="int32"||t==="int64"||t==="uint32"||t==="uint8"||t==="bool"||t==="uint4"||t==="int4",Qd=t=>t==="float32"||t==="float16"||t==="int32"||t==="int64"||t==="uint32"||t==="uint64"||t==="int8"||t==="uint8"||t==="bool"||t==="uint4"||t==="int4",Dd=t=>{switch(t){case"none":return 0;case"cpu":return 1;case"cpu-pinned":return 2;case"texture":return 3;case"gpu-buffer":return 4;case"ml-tensor":return 5;default:throw new Error(`unsupported data location: ${t}`)}}}),Yd,_A=be(()=>{"use strict";Wd(),Yd=async t=>{if(typeof t=="string"){let e=await fetch(t);if(!e.ok)throw new Error(`failed to load external data file: ${t}`);let r=e.headers.get("Content-Length"),s=r?parseInt(r,10):0;if(s<1073741824)return new Uint8Array(await e.arrayBuffer());{if(!e.body)throw new Error(`failed to load external data file: ${t}, no response body.`);let n=e.body.getReader(),o;try{o=new ArrayBuffer(s)}catch(i){if(i instanceof RangeError){let l=Math.ceil(s/65536);o=new WebAssembly.Memory({initial:l,maximum:l}).buffer}else throw i}let a=0;for(;;){let{done:i,value:l}=await n.read();if(i)break;let c=l.byteLength;new Uint8Array(o,a,c).set(l),a+=c}return new Uint8Array(o,0,s)}}else return t instanceof Blob?new Uint8Array(await t.arrayBuffer()):t instanceof Uint8Array?t:new Uint8Array(t)}}),mA,yP=be(()=>{"use strict";cn(),mA=(t,e)=>new(yo(e))(t)}),SE,TE,OE,IE,hA,CE,bt,gA=be(()=>{"use strict";cn(),SE=["V","I","W","E","F"],TE=(t,e)=>{console.log(`[${SE[t]},${new Date().toISOString()}]${e}`)},hA=(t,e)=>{OE=t,IE=e},CE=(t,e)=>{let r=lc(t),s=lc(OE);r>=s&&TE(r,typeof e=="function"?e():e)},bt=(...t)=>{IE&&CE(...t)}}),Sd,Fd,Td,LE,Od,PE,Id,Cd,Ld,zE,wA,bP=be(()=>{"use strict";cn(),gA(),Sd=new Map([["float32",32],["float16",16],["int32",32],["uint32",32],["int64",64],["uint64",64],["int8",8],["uint8",8],["int4",4],["uint4",4]]),Fd=(t,e)=>{if(e==="int32")return t;let r=Sd.get(e);if(!r)throw new Error(`WebNN backend does not support data type: ${e}`);let s=r/8;if(t.byteLength%s!==0)throw new Error(`Invalid Uint8Array length - must be a multiple of ${s}.`);let n=t.byteLength/s,o=new(yo(e))(t.buffer,t.byteOffset,n);switch(e){case"int64":case"uint64":{let a=new Int32Array(n);for(let i=0;i<n;i++){let l=o[i];if(l>2147483647n||l<-2147483648n)throw new Error("Can not convert int64 data to int32 - value out of range.");a[i]=Number(l)}return new Uint8Array(a.buffer)}case"int8":case"uint8":case"uint32":{if(e==="uint32"&&o.some(i=>i>2147483647))throw new Error("Can not convert uint32 data to int32 - value out of range.");let a=Int32Array.from(o,Number);return new Uint8Array(a.buffer)}default:throw new Error(`Unsupported data conversion from ${e} to 'int32'`)}},Td=(t,e)=>{if(e==="int32")return t;if(t.byteLength%4!==0)throw new Error("Invalid Uint8Array length - must be a multiple of 4 (int32).");let r=t.byteLength/4,s=new Int32Array(t.buffer,t.byteOffset,r);switch(e){case"int64":{let n=BigInt64Array.from(s,BigInt);return new Uint8Array(n.buffer)}case"uint64":{if(s.some(o=>o<0))throw new Error("Can not convert int32 data to uin64 - negative value found.");let n=BigUint64Array.from(s,BigInt);return new Uint8Array(n.buffer)}case"int8":{if(s.some(o=>o<-128||o>127))throw new Error("Can not convert int32 data to int8 - value out of range.");let n=Int8Array.from(s,Number);return new Uint8Array(n.buffer)}case"uint8":{if(s.some(n=>n<0||n>255))throw new Error("Can not convert int32 data to uint8 - value out of range.");return Uint8Array.from(s,Number)}case"uint32":{if(s.some(o=>o<0))throw new Error("Can not convert int32 data to uint32 - negative value found.");let n=Uint32Array.from(s,Number);return new Uint8Array(n.buffer)}default:throw new Error(`Unsupported data conversion from 'int32' to ${e}`)}},LE=1,Od=()=>LE++,PE=new Map([["int8","int32"],["uint8","int32"],["uint32","int32"],["int64","int32"]]),Id=(t,e)=>{let r=Sd.get(t);if(!r)throw new Error(`WebNN backend does not support data type: ${t}`);return e.length>0?Math.ceil(e.reduce((s,n)=>s*n)*r/8):0},Cd=class{constructor(t){this.isDataConverted=!1;let{sessionId:e,context:r,tensor:s,dataType:n,shape:o,fallbackDataType:a}=t;this.sessionId=e,this.mlContext=r,this.mlTensor=s,this.dataType=n,this.tensorShape=o,this.fallbackDataType=a}get tensor(){return this.mlTensor}get type(){return this.dataType}get fallbackType(){return this.fallbackDataType}get shape(){return this.tensorShape}get byteLength(){return Id(this.dataType,this.tensorShape)}destroy(){bt("verbose",()=>"[WebNN] TensorWrapper.destroy"),this.mlTensor.destroy()}write(t){this.mlContext.writeTensor(this.mlTensor,t)}async read(t){if(this.fallbackDataType){let e=await this.mlContext.readTensor(this.mlTensor),r=Td(new Uint8Array(e),this.dataType);if(t){(t instanceof ArrayBuffer?new Uint8Array(t):new Uint8Array(t.buffer,t.byteOffset,t.byteLength)).set(r);return}else return r.buffer}else return t?this.mlContext.readTensor(this.mlTensor,t):this.mlContext.readTensor(this.mlTensor)}canReuseTensor(t,e,r){return this.mlContext===t&&this.dataType===e&&this.tensorShape.length===r.length&&this.tensorShape.every((s,n)=>s===r[n])}setIsDataConverted(t){this.isDataConverted=t}},Ld=class{constructor(t,e){this.tensorManager=t,this.wrapper=e}get tensorWrapper(){return this.wrapper}releaseTensor(){this.tensorWrapper&&(this.tensorManager.releaseTensor(this.tensorWrapper),this.wrapper=void 0)}async ensureTensor(t,e,r,s){let n=this.tensorManager.getMLContext(t),o=this.tensorManager.getMLOpSupportLimits(t),a;if(!o?.input.dataTypes.includes(e)){if(a=PE.get(e),!a||o?.input.dataTypes.includes(a))throw new Error(`WebNN backend does not support data type: ${e}`);bt("verbose",()=>`[WebNN] TensorIdTracker.ensureTensor: fallback dataType from ${e} to ${a}`)}if(this.wrapper){if(this.wrapper.canReuseTensor(n,e,r))return this.wrapper.tensor;if(s){if(this.wrapper.byteLength!==Id(e,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(t,e,r,i,!0,!0,a),s&&this.activeUpload&&(this.wrapper.write(this.activeUpload),this.activeUpload=void 0),this.wrapper.tensor}upload(t){let e=t;if(this.wrapper){if(this.wrapper.fallbackType)if(this.wrapper.fallbackType==="int32")e=Fd(t,this.wrapper.type),this.wrapper.setIsDataConverted(!0);else throw new Error(`Unsupported fallback data type: ${this.wrapper.fallbackType}`);if(t.byteLength===this.wrapper.byteLength){this.wrapper.write(e);return}else bt("verbose",()=>"Data size does not match tensor size. Releasing tensor."),this.releaseTensor()}this.activeUpload?this.activeUpload.set(e):this.activeUpload=new Uint8Array(e)}async download(t){if(this.activeUpload){let e=this.wrapper?.isDataConverted?Td(this.activeUpload,this.wrapper?.type):this.activeUpload;if(t){t instanceof ArrayBuffer?new Uint8Array(t).set(e):new Uint8Array(t.buffer,t.byteOffset,t.byteLength).set(e);return}else return e.buffer}if(!this.wrapper)throw new Error("Tensor has not been created.");return t?this.wrapper.read(t):this.wrapper.read()}},zE=class{constructor(t){this.backend=t,this.tensorTrackersById=new Map,this.freeTensors=[],this.externalTensors=new Set}getMLContext(t){let e=this.backend.getMLContext(t);if(!e)throw new Error("MLContext not found for session.");return e}getMLOpSupportLimits(t){return this.backend.getMLOpSupportLimits(t)}reserveTensorId(){let t=Od();return this.tensorTrackersById.set(t,new Ld(this)),t}releaseTensorId(t){let e=this.tensorTrackersById.get(t);e&&(this.tensorTrackersById.delete(t),e.tensorWrapper&&this.releaseTensor(e.tensorWrapper))}async ensureTensor(t,e,r,s,n){bt("verbose",()=>`[WebNN] TensorManager.ensureTensor {tensorId: ${e}, dataType: ${r}, shape: ${s}, copyOld: ${n}}`);let o=this.tensorTrackersById.get(e);if(!o)throw new Error("Tensor not found.");return o.ensureTensor(t,r,s,n)}upload(t,e){let r=this.tensorTrackersById.get(t);if(!r)throw new Error("Tensor not found.");r.upload(e)}async download(t,e){bt("verbose",()=>`[WebNN] TensorManager.download {tensorId: ${t}, dstBuffer: ${e?.byteLength}}`);let r=this.tensorTrackersById.get(t);if(!r)throw new Error("Tensor not found.");return r.download(e)}releaseTensorsForSession(t){for(let e of this.freeTensors)e.sessionId===t&&e.destroy();this.freeTensors=this.freeTensors.filter(e=>e.sessionId!==t)}registerTensor(t,e,r,s){let n=this.getMLContext(t),o=Od(),a=new Cd({sessionId:t,context:n,tensor:e,dataType:r,shape:s});return this.tensorTrackersById.set(o,new Ld(this,a)),this.externalTensors.add(a),o}async getCachedTensor(t,e,r,s,n,o,a){let i=this.getMLContext(t);for(let[c,p]of this.freeTensors.entries())if(p.canReuseTensor(i,e,r)){bt("verbose",()=>`[WebNN] Reusing tensor {dataType: ${e}, ${a?`fallbackDataType: ${a},`:""} shape: ${r}`);let f=this.freeTensors.splice(c,1)[0];return f.sessionId=t,f}bt("verbose",()=>`[WebNN] MLContext.createTensor {dataType: ${e}, ${a?`fallbackDataType: ${a},`:""} shape: ${r}}`);let l=await i.createTensor({dataType:a??e,shape:r,dimensions:r,usage:s,writable:n,readable:o});return new Cd({sessionId:t,context:i,tensor:l,dataType:e,shape:r,fallbackDataType:a})}releaseTensor(t){this.externalTensors.has(t)&&this.externalTensors.delete(t),this.freeTensors.push(t)}},wA=(...t)=>new zE(...t)}),xA={};bo(xA,{WebNNBackend:()=>yA});var ho,NE,yA,vP=be(()=>{"use strict";cn(),Es(),yP(),bP(),gA(),ho=new Map([[1,"float32"],[10,"float16"],[6,"int32"],[12,"uint32"],[7,"int64"],[13,"uint64"],[22,"int4"],[21,"uint4"],[3,"int8"],[2,"uint8"],[9,"uint8"]]),NE=(t,e)=>{if(t===e)return!0;if(t===void 0||e===void 0)return!1;let r=Object.keys(t).sort(),s=Object.keys(e).sort();return r.length===s.length&&r.every((n,o)=>n===s[o]&&t[n]===e[n])},yA=class{constructor(t){this.tensorManager=wA(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,hA(t.logLevel,!!t.debug)}get currentSessionId(){if(this.activeSessionId===void 0)throw new Error("No active session");return this.activeSessionId}onRunStart(t){bt("verbose",()=>`[WebNN] onRunStart {sessionId: ${t}}`),this.activeSessionId=t}onRunEnd(t){bt("verbose",()=>`[WebNN] onRunEnd {sessionId: ${t}}`);let e=this.temporarySessionTensorIds.get(t);if(e){for(let r of e)bt("verbose",()=>`[WebNN] releasing temporary tensor {tensorId: ${r}}`),this.tensorManager.releaseTensorId(r);this.temporarySessionTensorIds.delete(t),this.activeSessionId=void 0}}async createMLContext(t){if(t instanceof GPUDevice){let r=this.mlContextCache.findIndex(s=>s.gpuDevice===t);if(r!==-1)return this.mlContextCache[r].mlContext;{let s=await navigator.ml.createContext(t);return this.mlContextCache.push({gpuDevice:t,mlContext:s}),s}}else if(t===void 0){let r=this.mlContextCache.findIndex(s=>s.options===void 0&&s.gpuDevice===void 0);if(r!==-1)return this.mlContextCache[r].mlContext;{let s=await navigator.ml.createContext();return this.mlContextCache.push({mlContext:s}),s}}let e=this.mlContextCache.findIndex(r=>NE(r.options,t));if(e!==-1)return this.mlContextCache[e].mlContext;{let r=await navigator.ml.createContext(t);return this.mlContextCache.push({options:t,mlContext:r}),r}}registerMLContext(t,e){this.mlContextBySessionId.set(t,e);let r=this.sessionIdsByMLContext.get(e);r||(r=new Set,this.sessionIdsByMLContext.set(e,r)),r.add(t),this.mlOpSupportLimitsBySessionId.has(t)||this.mlOpSupportLimitsBySessionId.set(t,e.opSupportLimits()),this.temporaryGraphInputs.length>0&&(this.sessionGraphInputs.set(t,this.temporaryGraphInputs),this.temporaryGraphInputs=[]),this.temporaryGraphOutputs.length>0&&(this.sessionGraphOutputs.set(t,this.temporaryGraphOutputs),this.temporaryGraphOutputs=[])}onReleaseSession(t){this.sessionGraphInputs.delete(t),this.sessionGraphOutputs.delete(t);let e=this.mlContextBySessionId.get(t);if(!e)return;this.tensorManager.releaseTensorsForSession(t),this.mlContextBySessionId.delete(t),this.mlOpSupportLimitsBySessionId.delete(t);let r=this.sessionIdsByMLContext.get(e);if(r.delete(t),r.size===0){this.sessionIdsByMLContext.delete(e);let s=this.mlContextCache.findIndex(n=>n.mlContext===e);s!==-1&&this.mlContextCache.splice(s,1)}}getMLContext(t){return this.mlContextBySessionId.get(t)}getMLOpSupportLimits(t){return this.mlOpSupportLimitsBySessionId.get(t)}reserveTensorId(){return this.tensorManager.reserveTensorId()}releaseTensorId(t){bt("verbose",()=>`[WebNN] releaseTensorId {tensorId: ${t}}`),this.tensorManager.releaseTensorId(t)}async ensureTensor(t,e,r,s,n){let o=ho.get(r);if(!o)throw new Error(`Unsupported ONNX data type: ${r}`);return this.tensorManager.ensureTensor(t??this.currentSessionId,e,o,s,n)}async createTemporaryTensor(t,e,r){bt("verbose",()=>`[WebNN] createTemporaryTensor {onnxDataType: ${e}, shape: ${r}}`);let s=ho.get(e);if(!s)throw new Error(`Unsupported ONNX data type: ${e}`);let n=this.tensorManager.reserveTensorId();await this.tensorManager.ensureTensor(t,n,s,r,!1);let o=this.temporarySessionTensorIds.get(t);return o?o.push(n):this.temporarySessionTensorIds.set(t,[n]),n}uploadTensor(t,e){if(!Be().shouldTransferToMLTensor)throw new Error("Trying to upload to a MLTensor while shouldTransferToMLTensor is false");bt("verbose",()=>`[WebNN] uploadTensor {tensorId: ${t}, data: ${e.byteLength}}`),this.tensorManager.upload(t,e)}async downloadTensor(t,e){return this.tensorManager.download(t,e)}createMLTensorDownloader(t,e){return async()=>{let r=await this.tensorManager.download(t);return mA(r,e)}}registerMLTensor(t,e,r,s){let n=ho.get(r);if(!n)throw new Error(`Unsupported ONNX data type: ${r}`);let o=this.tensorManager.registerTensor(t,e,n,s);return bt("verbose",()=>`[WebNN] registerMLTensor {tensor: ${e}, dataType: ${n}, dimensions: ${s}} -> {tensorId: ${o}}`),o}registerMLConstant(t,e,r,s,n,o,a=!1){if(!o)throw new Error("External mounted files are not available.");let i=t;t.startsWith("./")&&(i=t.substring(2));let l=o.get(i);if(!l)throw new Error(`File with name ${i} not found in preloaded files.`);if(e+r>l.byteLength)throw new Error("Out of bounds: data offset and length exceed the external file data size.");let c=l.slice(e,e+r).buffer,p;switch(n.dataType){case"float32":p=new Float32Array(c);break;case"float16":p=typeof Float16Array<"u"&&Float16Array.from?new Float16Array(c):new Uint16Array(c);break;case"int32":p=new Int32Array(c);break;case"uint32":p=new Uint32Array(c);break;case"int64":if(a){let f=Fd(new Uint8Array(c),"int64");p=new Int32Array(f.buffer),n.dataType="int32"}else p=new BigInt64Array(c);break;case"uint64":p=new BigUint64Array(c);break;case"int8":p=new Int8Array(c);break;case"int4":case"uint4":case"uint8":p=new Uint8Array(c);break;default:throw new Error(`Unsupported data type: ${n.dataType} in creating WebNN Constant from external data.`)}return bt("verbose",()=>`[WebNN] registerMLConstant {dataType: ${n.dataType}, shape: ${n.shape}}} ${a?"(Note: it was int64 data type and registered to int32 as workaround)":""}`),s.constant(n,p)}registerGraphInput(t){this.temporaryGraphInputs.push(t)}registerGraphOutput(t){this.temporaryGraphOutputs.push(t)}isGraphInput(t,e){let r=this.sessionGraphInputs.get(t);return r?r.includes(e):!1}isGraphOutput(t,e){let r=this.sessionGraphOutputs.get(t);return r?r.includes(e):!1}isGraphInputOutputTypeSupported(t,e,r=!0){let s=ho.get(xs(e)),n=this.mlOpSupportLimitsBySessionId.get(t);return typeof s>"u"?!1:r?!!n?.input.dataTypes.includes(s):!!n?.output.dataTypes.includes(s)}flush(){}}}),$E,Jd,Zd,Rr,RE,Pd,cc,ef,tf,zd,rf,sf,nf,bA=be(()=>{"use strict";ks(),wP(),xP(),cn(),Es(),Xd(),_A(),$E=(t,e)=>{Be()._OrtInit(t,e)!==0&&Le("Can't initialize onnxruntime.")},Jd=async t=>{$E(t.wasm.numThreads,lc(t.logLevel))},Zd=async(t,e)=>{Be().asyncInit?.();let r=t.webgpu.adapter;if(e==="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 s=t.webgpu.powerPreference;if(s!==void 0&&s!=="low-power"&&s!=="high-performance")throw new Error(`Invalid powerPreference setting: "${s}"`);let n=t.webgpu.forceFallbackAdapter;if(n!==void 0&&typeof n!="boolean")throw new Error(`Invalid forceFallbackAdapter setting: "${n}"`);if(r=await navigator.gpu.requestAdapter({powerPreference:s,forceFallbackAdapter:n}),!r)throw new Error('Failed to get GPU adapter. You may need to enable flag "--enable-unsafe-webgpu" if you are using Chrome.')}}if(e==="webnn"&&(typeof navigator>"u"||!navigator.ml))throw new Error("WebNN is not supported in current environment");if(e==="webgpu"&&Be().webgpuInit(s=>{t.webgpu.device=s}),e==="webnn"){let s=new(vP(),oc(xA)).WebNNBackend(t);Be().webnnInit([s,()=>s.reserveTensorId(),n=>s.releaseTensorId(n),async(n,o,a,i,l)=>s.ensureTensor(n,o,a,i,l),(n,o)=>{s.uploadTensor(n,o)},async(n,o)=>s.downloadTensor(n,o),(n,o)=>s.registerMLContext(n,o),!!t.trace])}},Rr=new Map,RE=t=>{let e=Be(),r=e.stackSave();try{let s=e.PTR_SIZE,n=e.stackAlloc(2*s);e._OrtGetInputOutputCount(t,n,n+s)!==0&&Le("Can't get session input/output count.");let o=s===4?"i32":"i64";return[Number(e.getValue(n,o)),Number(e.getValue(n+s,o))]}finally{e.stackRestore(r)}},Pd=(t,e)=>{let r=Be(),s=r.stackSave(),n=0;try{let o=r.PTR_SIZE,a=r.stackAlloc(2*o);r._OrtGetInputOutputMetadata(t,e,a,a+o)!==0&&Le("Can't get session input/output metadata.");let i=Number(r.getValue(a,"*"));n=Number(r.getValue(a+o,"*"));let l=r.HEAP32[n/4];if(l===0)return[i,0];let c=r.HEAPU32[n/4+1],p=[];for(let f=0;f<c;f++){let _=Number(r.getValue(n+8+f*o,"*"));p.push(_!==0?r.UTF8ToString(_):Number(r.getValue(n+8+(f+c)*o,"*")))}return[i,l,p]}finally{r.stackRestore(s),n!==0&&r._OrtFree(n)}},cc=t=>{let e=Be(),r=e._malloc(t.byteLength);if(r===0)throw new Error(`Can't create a session. failed to allocate a buffer of size ${t.byteLength}.`);return e.HEAPU8.set(t,r),[r,t.byteLength]},ef=async(t,e)=>{let r,s,n=Be();Array.isArray(t)?[r,s]=t:t.buffer===n.HEAPU8.buffer?[r,s]=[t.byteOffset,t.byteLength]:[r,s]=cc(t);let o=0,a=0,i=0,l=[],c=[],p=[];try{if([a,l]=await fA(e),e?.externalData&&n.mountExternalData){let S=[];for(let P of e.externalData){let O=typeof P=="string"?P:P.path;S.push(Yd(typeof P=="string"?P:P.data).then(v=>{n.mountExternalData(O,v)}))}await Promise.all(S)}for(let S of e?.executionProviders??[])if((typeof S=="string"?S:S.name)==="webnn"){if(n.shouldTransferToMLTensor=!1,typeof S!="string"){let P=S,O=P?.context,v=P?.gpuDevice,j=P?.deviceType,H=P?.powerPreference;O?n.currentContext=O:v?n.currentContext=await n.webnnCreateMLContext(v):n.currentContext=await n.webnnCreateMLContext({deviceType:j,powerPreference:H})}else n.currentContext=await n.webnnCreateMLContext();break}o=await n._OrtCreateSession(r,s,a),n.webgpuOnCreateSession?.(o),o===0&&Le("Can't create a session."),n.jsepOnCreateSession?.(),n.currentContext&&(n.webnnRegisterMLContext(o,n.currentContext),n.currentContext=void 0,n.shouldTransferToMLTensor=!0);let[f,_]=RE(o),m=!!e?.enableGraphCapture,w=[],x=[],k=[],E=[],A=[];for(let S=0;S<f;S++){let[P,O,v]=Pd(o,S);P===0&&Le("Can't get an input name."),c.push(P);let j=n.UTF8ToString(P);w.push(j),k.push(O===0?{name:j,isTensor:!1}:{name:j,isTensor:!0,type:nc(O),shape:v})}for(let S=0;S<_;S++){let[P,O,v]=Pd(o,S+f);P===0&&Le("Can't get an output name."),p.push(P);let j=n.UTF8ToString(P);x.push(j),E.push(O===0?{name:j,isTensor:!1}:{name:j,isTensor:!0,type:nc(O),shape:v});{if(m&&e?.preferredOutputLocation===void 0){A.push("gpu-buffer");continue}let H=typeof e?.preferredOutputLocation=="string"?e.preferredOutputLocation:e?.preferredOutputLocation?.[j]??"cpu",B=n.webnnIsGraphOutput;if(H==="cpu"&&B&&B(o,j)){A.push("ml-tensor-cpu-output");continue}if(H!=="cpu"&&H!=="cpu-pinned"&&H!=="gpu-buffer"&&H!=="ml-tensor")throw new Error(`Not supported preferred output location: ${H}.`);if(m&&H!=="gpu-buffer")throw new Error(`Not supported preferred output location: ${H}. Only 'gpu-buffer' location is supported when enableGraphCapture is true.`);A.push(H)}}let T=null;return A.some(S=>S==="gpu-buffer"||S==="ml-tensor"||S==="ml-tensor-cpu-output")&&(i=n._OrtCreateBinding(o),i===0&&Le("Can't create IO binding."),T={handle:i,outputPreferredLocations:A,outputPreferredLocationsEncoded:A.map(S=>S==="ml-tensor-cpu-output"?"ml-tensor":S).map(S=>Dd(S))}),Rr.set(o,[o,c,p,T,m,!1]),[o,w,x,k,E]}catch(f){throw c.forEach(_=>n._OrtFree(_)),p.forEach(_=>n._OrtFree(_)),i!==0&&n._OrtReleaseBinding(i)!==0&&Le("Can't release IO binding."),o!==0&&n._OrtReleaseSession(o)!==0&&Le("Can't release session."),f}finally{n._free(r),a!==0&&n._OrtReleaseSessionOptions(a)!==0&&Le("Can't release session options."),l.forEach(f=>n._free(f)),n.unmountExternalData?.()}},tf=t=>{let e=Be(),r=Rr.get(t);if(!r)throw new Error(`cannot release session. invalid session id: ${t}`);let[s,n,o,a,i]=r;a&&(i&&e._OrtClearBoundOutputs(a.handle)!==0&&Le("Can't clear bound outputs."),e._OrtReleaseBinding(a.handle)!==0&&Le("Can't release IO binding.")),e.jsepOnReleaseSession?.(t),e.webnnOnReleaseSession?.(t),e.webgpuOnReleaseSession?.(t),n.forEach(l=>e._OrtFree(l)),o.forEach(l=>e._OrtFree(l)),e._OrtReleaseSession(s)!==0&&Le("Can't release session."),Rr.delete(t)},zd=async(t,e,r,s,n,o,a=!1)=>{if(!t){e.push(0);return}let i=Be(),l=i.PTR_SIZE,c=t[0],p=t[1],f=t[3],_=f,m,w;if(c==="string"&&(f==="gpu-buffer"||f==="ml-tensor"))throw new Error("String tensor is not supported on GPU.");if(a&&f!=="gpu-buffer")throw new Error(`External buffer must be provided for input/output index ${o} when enableGraphCapture is true.`);if(f==="gpu-buffer"){let E=t[2].gpuBuffer;w=ln(xs(c),p);{let A=i.webgpuRegisterBuffer;if(!A)throw new Error('Tensor location "gpu-buffer" is not supported without using WebGPU.');m=A(E,s)}}else if(f==="ml-tensor"){let E=t[2].mlTensor;w=ln(xs(c),p);let A=i.webnnRegisterMLTensor;if(!A)throw new Error('Tensor location "ml-tensor" is not supported without using WebNN.');m=A(s,E,xs(c),p)}else{let E=t[2];if(Array.isArray(E)){w=l*E.length,m=i._malloc(w),r.push(m);for(let A=0;A<E.length;A++){if(typeof E[A]!="string")throw new TypeError(`tensor data at index ${A} is not a string`);i.setValue(m+A*l,zt(E[A],r),"*")}}else{let A=i.webnnIsGraphInput,T=i.webnnIsGraphOutput;if(c!=="string"&&A&&T){let S=i.UTF8ToString(n);if(A(s,S)||T(s,S)){let P=xs(c);w=ln(P,p),_="ml-tensor";let O=i.webnnCreateTemporaryTensor,v=i.webnnUploadTensor;if(!O||!v)throw new Error('Tensor location "ml-tensor" is not supported without using WebNN.');let j=await O(s,P,p);v(j,new Uint8Array(E.buffer,E.byteOffset,E.byteLength)),m=j}else w=E.byteLength,m=i._malloc(w),r.push(m),i.HEAPU8.set(new Uint8Array(E.buffer,E.byteOffset,w),m)}else w=E.byteLength,m=i._malloc(w),r.push(m),i.HEAPU8.set(new Uint8Array(E.buffer,E.byteOffset,w),m)}}let x=i.stackSave(),k=i.stackAlloc(4*p.length);try{p.forEach((A,T)=>i.setValue(k+T*l,A,l===4?"i32":"i64"));let E=i._OrtCreateTensor(xs(c),m,w,k,p.length,Dd(_));E===0&&Le(`Can't create tensor for input/output. session=${s}, index=${o}.`),e.push(E)}finally{i.stackRestore(x)}},rf=async(t,e,r,s,n,o)=>{let a=Be(),i=a.PTR_SIZE,l=Rr.get(t);if(!l)throw new Error(`cannot run inference. invalid session id: ${t}`);let c=l[0],p=l[1],f=l[2],_=l[3],m=l[4],w=l[5],x=e.length,k=s.length,E=0,A=[],T=[],S=[],P=[],O=[],v=a.stackSave(),j=a.stackAlloc(x*i),H=a.stackAlloc(x*i),B=a.stackAlloc(k*i),V=a.stackAlloc(k*i);try{[E,A]=dA(o),Fr("wasm prepareInputOutputTensor");for(let C=0;C<x;C++)await zd(r[C],T,P,t,p[e[C]],e[C],m);for(let C=0;C<k;C++)await zd(n[C],S,P,t,f[s[C]],x+s[C],m);Br("wasm prepareInputOutputTensor");for(let C=0;C<x;C++)a.setValue(j+C*i,T[C],"*"),a.setValue(H+C*i,p[e[C]],"*");for(let C=0;C<k;C++)a.setValue(B+C*i,S[C],"*"),a.setValue(V+C*i,f[s[C]],"*");if(_&&!w){let{handle:C,outputPreferredLocations:te,outputPreferredLocationsEncoded:le}=_;if(p.length!==x)throw new Error(`input count from feeds (${x}) is expected to be always equal to model's input count (${p.length}).`);Fr("wasm bindInputsOutputs");for(let L=0;L<x;L++){let z=e[L];await a._OrtBindInput(C,p[z],T[L])!==0&&Le(`Can't bind input[${L}] for session=${t}.`)}for(let L=0;L<k;L++){let z=s[L];n[L]?.[3]?(O.push(S[L]),a._OrtBindOutput(C,f[z],S[L],0)!==0&&Le(`Can't bind pre-allocated output[${L}] for session=${t}.`)):a._OrtBindOutput(C,f[z],0,le[z])!==0&&Le(`Can't bind output[${L}] to ${te[L]} for session=${t}.`)}Br("wasm bindInputsOutputs"),Rr.set(t,[c,p,f,_,m,!0])}a.jsepOnRunStart?.(c),a.webnnOnRunStart?.(c);let q;_?q=await a._OrtRunWithBinding(c,_.handle,k,B,E):q=await a._OrtRun(c,H,j,x,V,k,B,E),q!==0&&Le("failed to call OrtRun().");let Q=[],F=[];Fr("wasm ProcessOutputTensor");for(let C=0;C<k;C++){let te=Number(a.getValue(B+C*i,"*"));if(te===S[C]||O.includes(S[C])){Q.push(n[C]),te!==S[C]&&a._OrtReleaseTensor(te)!==0&&Le("Can't release tensor.");continue}let le=a.stackSave(),L=a.stackAlloc(4*i),z=!1,R,J=0;try{a._OrtGetTensorData(te,L,L+i,L+2*i,L+3*i)!==0&&Le(`Can't access output tensor data on index ${C}.`);let Ie=i===4?"i32":"i64",ae=Number(a.getValue(L,Ie));J=a.getValue(L+i,"*");let Ue=a.getValue(L+i*2,"*"),Je=Number(a.getValue(L+i*3,Ie)),tt=[];for(let Se=0;Se<Je;Se++)tt.push(Number(a.getValue(Ue+Se*i,Ie)));a._OrtFree(Ue)!==0&&Le("Can't free memory for tensor dims.");let nt=tt.reduce((Se,xe)=>Se*xe,1);R=nc(ae);let at=_?.outputPreferredLocations[s[C]];if(R==="string"){if(at==="gpu-buffer"||at==="ml-tensor")throw new Error("String tensor is not supported on GPU.");let Se=[];for(let xe=0;xe<nt;xe++){let We=a.getValue(J+xe*i,"*"),St=a.getValue(J+(xe+1)*i,"*"),ve=xe===nt-1?void 0:St-We;Se.push(a.UTF8ToString(We,ve))}Q.push([R,tt,Se,"cpu"])}else if(at==="gpu-buffer"&&nt>0){let Se=a.webgpuGetBuffer;if(!Se)throw new Error('preferredLocation "gpu-buffer" is not supported without using WebGPU.');let xe=Se(J),We=ln(ae,nt);if(We===void 0||!Kd(R))throw new Error(`Unsupported data type: ${R}`);z=!0;{a.webgpuRegisterBuffer(xe,t,J);let St=a.webgpuCreateDownloader(xe,We,t);Q.push([R,tt,{gpuBuffer:xe,download:async()=>{let ve=await St();return new(yo(R))(ve)},dispose:()=>{a._OrtReleaseTensor(te)!==0&&Le("Can't release tensor.")}},"gpu-buffer"])}}else if(at==="ml-tensor"&&nt>0){let Se=a.webnnEnsureTensor,xe=a.webnnIsGraphInputOutputTypeSupported;if(!Se||!xe)throw new Error('preferredLocation "ml-tensor" is not supported without using WebNN.');if(ln(ae,nt)===void 0||!Qd(R))throw new Error(`Unsupported data type: ${R}`);if(!xe(t,R,!1))throw new Error(`preferredLocation "ml-tensor" for ${R} output is not supported by current WebNN Context.`);let We=await Se(t,J,ae,tt,!1);z=!0,Q.push([R,tt,{mlTensor:We,download:a.webnnCreateMLTensorDownloader(J,R),dispose:()=>{a.webnnReleaseTensorId(J),a._OrtReleaseTensor(te)}},"ml-tensor"])}else if(at==="ml-tensor-cpu-output"&&nt>0){let Se=a.webnnCreateMLTensorDownloader(J,R)(),xe=Q.length;z=!0,F.push((async()=>{let We=[xe,await Se];return a.webnnReleaseTensorId(J),a._OrtReleaseTensor(te),We})()),Q.push([R,tt,[],"cpu"])}else{let Se=yo(R),xe=new Se(nt);new Uint8Array(xe.buffer,xe.byteOffset,xe.byteLength).set(a.HEAPU8.subarray(J,J+xe.byteLength)),Q.push([R,tt,xe,"cpu"])}}finally{a.stackRestore(le),R==="string"&&J&&a._free(J),z||a._OrtReleaseTensor(te)}}_&&!m&&(a._OrtClearBoundOutputs(_.handle)!==0&&Le("Can't clear bound outputs."),Rr.set(t,[c,p,f,_,m,!1]));for(let[C,te]of await Promise.all(F))Q[C][2]=te;return Br("wasm ProcessOutputTensor"),Q}finally{a.webnnOnRunEnd?.(c),a.stackRestore(v),r.forEach(q=>{q&&q[3]==="gpu-buffer"&&a.webgpuUnregisterBuffer(q[2].gpuBuffer)}),n.forEach(q=>{q&&q[3]==="gpu-buffer"&&a.webgpuUnregisterBuffer(q[2].gpuBuffer)}),T.forEach(q=>a._OrtReleaseTensor(q)),S.forEach(q=>a._OrtReleaseTensor(q)),P.forEach(q=>a._free(q)),E!==0&&a._OrtReleaseRunOptions(E),A.forEach(q=>a._free(q))}},sf=t=>{let e=Be(),r=Rr.get(t);if(!r)throw new Error("invalid session id");let s=r[0],n=e._OrtEndProfiling(s);n===0&&Le("Can't get an profile file name."),e._OrtFree(n)},nf=t=>{let e=[];for(let r of t){let s=r[2];!Array.isArray(s)&&"buffer"in s&&e.push(s.buffer)}return e}}),Dr,Bt,an,go,wo,rc,Nd,sc,hs,gs,DE,vA,kA,EA,AA,MA,SA,TA,OA=be(()=>{"use strict";ks(),bA(),Es(),Vd(),Dr=()=>!!He.wasm.proxy&&typeof document<"u",an=!1,go=!1,wo=!1,sc=new Map,hs=(t,e)=>{let r=sc.get(t);r?r.push(e):sc.set(t,[e])},gs=()=>{if(an||!go||wo||!Bt)throw new Error("worker not ready")},DE=t=>{switch(t.data.type){case"init-wasm":an=!1,t.data.err?(wo=!0,Nd[1](t.data.err)):(go=!0,Nd[0]()),rc&&(URL.revokeObjectURL(rc),rc=void 0);break;case"init-ep":case"copy-from":case"create":case"release":case"run":case"end-profiling":{let e=sc.get(t.data.type);t.data.err?e.shift()[1](t.data.err):e.shift()[0](t.data.out);break}default:}},vA=async()=>{if(!go){if(an)throw new Error("multiple calls to 'initWasm()' detected.");if(wo)throw new Error("previous call to 'initWasm()' failed.");if(an=!0,Dr())return new Promise((t,e)=>{Bt?.terminate(),uA().then(([r,s])=>{try{Bt=s,Bt.onerror=o=>e(o),Bt.onmessage=DE,Nd=[t,e];let n={type:"init-wasm",in:He};!n.in.wasm.wasmPaths&&(r||Rd)&&(n.in.wasm.wasmPaths={wasm:new URL("ort-wasm-simd-threaded.asyncify.wasm",import.meta.url).href}),Bt.postMessage(n),rc=r}catch(n){e(n)}},e)});try{await Hd(He.wasm),await Jd(He),go=!0}catch(t){throw wo=!0,t}finally{an=!1}}},kA=async t=>{if(Dr())return gs(),new Promise((e,r)=>{hs("init-ep",[e,r]);let s={type:"init-ep",in:{epName:t,env:He}};Bt.postMessage(s)});await Zd(He,t)},EA=async t=>Dr()?(gs(),new Promise((e,r)=>{hs("copy-from",[e,r]);let s={type:"copy-from",in:{buffer:t}};Bt.postMessage(s,[t.buffer])})):cc(t),AA=async(t,e)=>{if(Dr()){if(e?.preferredOutputLocation)throw new Error('session option "preferredOutputLocation" is not supported for proxy.');return gs(),new Promise((r,s)=>{hs("create",[r,s]);let n={type:"create",in:{model:t,options:{...e}}},o=[];t instanceof Uint8Array&&o.push(t.buffer),Bt.postMessage(n,o)})}else return ef(t,e)},MA=async t=>{if(Dr())return gs(),new Promise((e,r)=>{hs("release",[e,r]);let s={type:"release",in:t};Bt.postMessage(s)});tf(t)},SA=async(t,e,r,s,n,o)=>{if(Dr()){if(r.some(a=>a[3]!=="cpu"))throw new Error("input tensor on GPU is not supported for proxy.");if(n.some(a=>a))throw new Error("pre-allocated output tensor is not supported for proxy.");return gs(),new Promise((a,i)=>{hs("run",[a,i]);let l=r,c={type:"run",in:{sessionId:t,inputIndices:e,inputs:l,outputIndices:s,options:o}};Bt.postMessage(c,nf(l))})}else return rf(t,e,r,s,n,o)},TA=async t=>{if(Dr())return gs(),new Promise((e,r)=>{hs("end-profiling",[e,r]);let s={type:"end-profiling",in:t};Bt.postMessage(s)});sf(t)}}),$d,FE,IA,kP=be(()=>{"use strict";ks(),OA(),cn(),Wd(),_A(),$d=(t,e)=>{switch(t.location){case"cpu":return[t.type,t.dims,t.data,"cpu"];case"gpu-buffer":return[t.type,t.dims,{gpuBuffer:t.gpuBuffer},"gpu-buffer"];case"ml-tensor":return[t.type,t.dims,{mlTensor:t.mlTensor},"ml-tensor"];default:throw new Error(`invalid data location: ${t.location} for ${e()}`)}},FE=t=>{switch(t[3]){case"cpu":return new Zt(t[0],t[2],t[1]);case"gpu-buffer":{let e=t[0];if(!Kd(e))throw new Error(`not supported data type: ${e} for deserializing GPU tensor`);let{gpuBuffer:r,download:s,dispose:n}=t[2];return Zt.fromGpuBuffer(r,{dataType:e,dims:t[1],download:s,dispose:n})}case"ml-tensor":{let e=t[0];if(!Qd(e))throw new Error(`not supported data type: ${e} for deserializing MLTensor tensor`);let{mlTensor:r,download:s,dispose:n}=t[2];return Zt.fromMLTensor(r,{dataType:e,dims:t[1],download:s,dispose:n})}default:throw new Error(`invalid data location: ${t[3]}`)}},IA=class{async fetchModelAndCopyToWasmMemory(t){return EA(await Yd(t))}async loadModel(t,e){bs();let r;typeof t=="string"?r=await this.fetchModelAndCopyToWasmMemory(t):r=t,[this.sessionId,this.inputNames,this.outputNames,this.inputMetadata,this.outputMetadata]=await AA(r,e),vs()}async dispose(){return MA(this.sessionId)}async run(t,e,r){bs();let s=[],n=[];Object.entries(t).forEach(f=>{let _=f[0],m=f[1],w=this.inputNames.indexOf(_);if(w===-1)throw new Error(`invalid input '${_}'`);s.push(m),n.push(w)});let o=[],a=[];Object.entries(e).forEach(f=>{let _=f[0],m=f[1],w=this.outputNames.indexOf(_);if(w===-1)throw new Error(`invalid output '${_}'`);o.push(m),a.push(w)});let i=s.map((f,_)=>$d(f,()=>`input "${this.inputNames[n[_]]}"`)),l=o.map((f,_)=>f?$d(f,()=>`output "${this.outputNames[a[_]]}"`):null),c=await SA(this.sessionId,n,i,a,l,r),p={};for(let f=0;f<c.length;f++)p[this.outputNames[a[f]]]=o[f]??FE(c[f]);return vs(),p}startProfiling(){}endProfiling(){TA(this.sessionId)}}}),CA={};bo(CA,{OnnxruntimeWebAssemblyBackend:()=>Ud,initializeFlags:()=>Bd,wasmBackend:()=>LA});var Bd,Ud,LA,EP=be(()=>{"use strict";ks(),OA(),kP(),Bd=()=>{(typeof He.wasm.initTimeout!="number"||He.wasm.initTimeout<0)&&(He.wasm.initTimeout=0);let t=He.wasm.simd;if(typeof t!="boolean"&&t!==void 0&&t!=="fixed"&&t!=="relaxed"&&(console.warn(`Property "env.wasm.simd" is set to unknown value "${t}". Reset it to \`false\` and ignore SIMD feature checking.`),He.wasm.simd=!1),typeof He.wasm.proxy!="boolean"&&(He.wasm.proxy=!1),typeof He.wasm.trace!="boolean"&&(He.wasm.trace=!1),typeof He.wasm.numThreads!="number"||!Number.isInteger(He.wasm.numThreads)||He.wasm.numThreads<=0)if(typeof self<"u"&&!self.crossOriginIsolated)He.wasm.numThreads=1;else{let e=typeof navigator>"u"?tP("node:os").cpus().length:navigator.hardwareConcurrency;He.wasm.numThreads=Math.min(4,Math.ceil((e||1)/2))}},Ud=class{async init(t){Bd(),await vA(),await kA(t)}async createInferenceSessionHandler(t,e){let r=new IA;return await r.loadModel(t,e),r}},LA=new Ud});ks();ks();ks();var AP="1.25.0-dev.20260307-d626b568e0",MP=nA;{let t=(EP(),oc(CA)).wasmBackend;ys("webgpu",t,5),ys("webnn",t,5),ys("cpu",t,10),ys("wasm",t,10)}Object.defineProperty(He.versions,"web",{value:AP,enumerable:!0});async function PA(t){let e=t.split("/").pop(),r;try{if(r=await Jt(),r){let n=await r.match(t);if(n)return n}}catch(n){Z.warn(`Failed to load ${e} from cache:`,n)}let s=await _e.fetch(t);if(!s.ok)throw new Error(`Failed to fetch ${e}: ${s.status} ${s.statusText}`);if(r)try{await r.put(t,s.clone())}catch(n){Z.warn(`Failed to cache ${e}:`,n)}return s}async function zA(t){let e=await PA(t);if(!e||typeof e=="string")return null;try{return await e.arrayBuffer()}catch(r){return Z.warn("Failed to read WASM binary:",r),null}}async function NA(t){if(ie.IS_SERVICE_WORKER_ENV||ie.IS_CHROME_AVAILABLE)return t;let e=await PA(t);if(!e||typeof e=="string")return null;try{let r=await e.text();r=r.replaceAll("globalThis.process?.versions?.node","false");let s=new Blob([r],{type:"text/javascript"});return URL.createObjectURL(s)}catch(r){return Z.warn("Failed to read WASM factory:",r),null}}import{Tensor as UA}from"onnxruntime-common";var TP=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 FA(t){return t<=Ot.DEBUG?0:t<=Ot.INFO?2:t<=Ot.WARNING||t<=Ot.ERROR?3:4}var OP={0:"verbose",1:"info",2:"warning",3:"error",4:"fatal"},Ut=[],af,pn,$A=Symbol.for("onnxruntime");if($A in globalThis)pn=globalThis[$A];else if(ie.IS_NODE_ENV){switch(pn=SP,process.platform){case"win32":Ut.push("dml");break;case"linux":process.arch==="x64"&&Ut.push("cuda");break;case"darwin":Ut.push("coreml");break}Ut.push("webgpu"),Ut.push("cpu"),af=["cpu"]}else pn=of,ie.IS_WEBNN_AVAILABLE&&Ut.push("webnn-npu","webnn-gpu","webnn-cpu","webnn"),ie.IS_WEBGPU_AVAILABLE&&Ut.push("webgpu"),Ut.push("wasm"),af=["wasm"];var IP=pn.InferenceSession;function BA(t=null){if(!t)return af;switch(t){case"auto":return Ut;case"gpu":return Ut.filter(e=>["webgpu","cuda","dml","webnn-gpu"].includes(e))}if(Ut.includes(t))return[TP[t]??t];throw new Error(`Unsupported device: "${t}". Should be one of: ${Ut.join(", ")}.`)}var RA=Promise.resolve(),un=null;async function CP(){if(un)return un;if(!(_e.useWasmCache&&typeof lt?.wasm?.wasmPaths=="object"&&lt?.wasm?.wasmPaths?.wasm&&lt?.wasm?.wasmPaths?.mjs)){if(ie.IS_DENO_WEB_RUNTIME)throw new Error("env.useWasmCache=false is not supported in Deno's web runtime. Remove the useWasmCache override.");return un=Promise.resolve(),un}return un=(async()=>{let e=lt.wasm.wasmPaths,r=!1;await Promise.all([e.wasm&&!cd(e.wasm)?(async()=>{try{let s=await zA(ud(e.wasm));s&&(lt.wasm.wasmBinary=s,r=!0)}catch(s){Z.warn("Failed to pre-load WASM binary:",s)}})():Promise.resolve(),e.mjs&&!cd(e.mjs)?(async()=>{try{let s=await NA(ud(e.mjs));s&&(lt.wasm.wasmPaths.mjs=s)}catch(s){Z.warn("Failed to pre-load WASM factory:",s)}})():Promise.resolve()]),r||(lt.wasm.wasmPaths.mjs=e.mjs)})(),un}async function uc(t,e,r){await CP();let s=FA(_e.logLevel??Ot.WARNING),n=()=>IP.create(t,{logSeverityLevel:s,...e}),o=await(ie.IS_WEB_ENV?RA=RA.then(n):n());return o.config=r,o}var DA=Promise.resolve();async function pc(t,e){let r=()=>t.run(e);return ie.IS_WEB_ENV?DA=DA.then(r):r()}function dc(t){return t instanceof pn.Tensor}var lt=pn?.env;function vo(){return lt?.wasm?.proxy}if(lt){let t=function(e){let r=FA(e);lt.logLevel=OP[r]};if(lt.wasm){if(!(typeof ServiceWorkerGlobalScope<"u"&&self instanceof ServiceWorkerGlobalScope)&&lt.versions?.web&&!lt.wasm.wasmPaths){let e=`https://cdn.jsdelivr.net/npm/onnxruntime-web@${lt.versions.web}/dist/`;lt.wasm.wasmPaths=ie.IS_SAFARI?{mjs:`${e}ort-wasm-simd-threaded.mjs`,wasm:`${e}ort-wasm-simd-threaded.wasm`}:{mjs:`${e}ort-wasm-simd-threaded.asyncify.mjs`,wasm:`${e}ort-wasm-simd-threaded.asyncify.wasm`}}lt.wasm.proxy=!1}lt.webgpu&&(lt.webgpu.powerPreference="high-performance"),t(_e.logLevel??Ot.WARNING),_e.backends.onnx={...lt,setLogLevel:t}}var Ur=async(t,e,r)=>{let s=await uc(new Uint8Array(t),e);return(async n=>{let o=vo(),a=Object.fromEntries(Object.entries(n).map(([l,c])=>[l,(o?c.clone():c).ort_tensor])),i=await pc(s,a);return Array.isArray(r)?r.map(l=>new $(i[l])):new $(i[r])})},cr=class{static session_options={};static get nearest_interpolate_4d(){return this._nearest_interpolate_4d||(this._nearest_interpolate_4d=Ur([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=Ur([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=Ur([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=Ur([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=Ur([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=Ur([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=Ur([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=Ur([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}};var jA=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"}),lf=ie.IS_NODE_ENV?"cpu":"wasm";function fc(t,e,{warn:r}={}){return t?typeof t=="string"?t:t.hasOwnProperty(e)?t[e]:(r&&r(`device not specified for "${e}". Using the default device (${lf}).`),lf):lf}var WA=(function(){let t;return async function(){if(t===void 0)if(!ie.IS_WEBGPU_AVAILABLE)t=!1;else try{t=(await navigator.gpu.requestAdapter()).features.has("shader-f16")}catch{t=!1}return t}})(),yt=Object.freeze({auto:"auto",fp32:"fp32",fp16:"fp16",q8:"q8",int8:"int8",uint8:"uint8",q4:"q4",bnb4:"bnb4",q4f16:"q4f16"}),GA=yt.fp32,qA=Object.freeze({[jA.wasm]:yt.q8}),ko=Object.freeze({[yt.fp32]:"",[yt.fp16]:"_fp16",[yt.int8]:"_int8",[yt.uint8]:"_uint8",[yt.q8]:"_quantized",[yt.q4]:"_q4",[yt.q4f16]:"_q4f16",[yt.bnb4]:"_bnb4"});function _c(t,e,r,{configDtype:s=null,warn:n}={}){let o,a=!1;t&&typeof t!="string"?t.hasOwnProperty(e)?o=t[e]:(o=null,a=!0):o=t;let i;if(o===yt.auto){if(s){let l=typeof s=="string"?s:s?.[e];if(l&&l!==yt.auto&&yt.hasOwnProperty(l))return l}i=qA[r]??GA}else o&&yt.hasOwnProperty(o)?i=o:i=qA[r]??GA;return a&&n&&n(`dtype not specified for "${e}". Using the default dtype (${i}) for this device (${r}).`),i}var br=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});var $=class t{get dims(){return this.ort_tensor.dims}set dims(e){this.ort_tensor.dims=e}get type(){return this.ort_tensor.type}get data(){return this.ort_tensor.data}get size(){return this.ort_tensor.size}get location(){return this.ort_tensor.location}ort_tensor;constructor(...e){return dc(e[0])?this.ort_tensor=e[0]:this.ort_tensor=new UA(e[0],e[1],e[2]),new Proxy(this,{get:(r,s)=>{if(typeof s=="string"){let n=Number(s);if(Number.isInteger(n))return r._getitem(n)}return r[s]},set:(r,s,n)=>r[s]=n})}dispose(){this.ort_tensor.dispose()}*[Symbol.iterator](){let[e,...r]=this.dims;if(r.length>0){let s=r.reduce((n,o)=>n*o);for(let n=0;n<e;++n)yield this._subarray(n,s,r)}else yield*this.data}_getitem(e){let[r,...s]=this.dims;if(e=ur(e,r),s.length>0){let n=s.reduce((o,a)=>o*a);return this._subarray(e,n,s)}else return new t(this.type,[this.data[e]],s)}indexOf(e){let r=this.data;for(let s=0;s<r.length;++s)if(r[s]==e)return s;return-1}_subarray(e,r,s){let n=e*r,o=(e+1)*r,a="subarray"in this.data?this.data.subarray(n,o):this.data.slice(n,o);return new t(this.type,a,s)}item(){let e=this.data;if(e.length!==1)throw new Error(`a Tensor with ${e.length} elements cannot be converted to Scalar`);return e[0]}tolist(){return LP(this.data,this.dims)}sigmoid(){return this.clone().sigmoid_()}sigmoid_(){let e=this.data;for(let r=0;r<e.length;++r)e[r]=1/(1+Math.exp(-e[r]));return this}map(e){return this.clone().map_(e)}map_(e){let r=this.data;for(let s=0;s<r.length;++s)r[s]=e(r[s],s,r);return this}mul(e){return this.clone().mul_(e)}mul_(e){let r=this.data;for(let s=0;s<r.length;++s)r[s]*=e;return this}div(e){return this.clone().div_(e)}div_(e){let r=this.data;for(let s=0;s<r.length;++s)r[s]/=e;return this}add(e){return this.clone().add_(e)}add_(e){let r=this.data;for(let s=0;s<r.length;++s)r[s]+=e;return this}sub(e){return this.clone().sub_(e)}sub_(e){let r=this.data;for(let s=0;s<r.length;++s)r[s]-=e;return this}clone(){return new t(this.type,this.data.slice(),this.dims.slice())}slice(...e){let r=[],s=[];for(let p=0;p<this.dims.length;++p){let f=e[p];if(f==null)s.push([0,this.dims[p]]),r.push(this.dims[p]);else if(typeof f=="number")f=ur(f,this.dims[p],p),s.push([f,f+1]);else if(Array.isArray(f)&&f.length===2){let[_,m]=f;if(_=_===null?0:ur(_,this.dims[p],p,!1),m=m===null?this.dims[p]:ur(m,this.dims[p],p,!1),_>m)throw new Error(`Invalid slice: ${f}`);let w=[Math.max(_,0),Math.min(m,this.dims[p])];s.push(w),r.push(w[1]-w[0])}else throw new Error(`Invalid slice: ${f}`)}let n=s.map(([p,f])=>f-p),o=n.reduce((p,f)=>p*f),a=this.data,i=new a.constructor(o),l=this.stride(),c=!0;for(let p=1;p<n.length;++p)if(s[p][0]!==0||s[p][1]!==this.dims[p]){c=!1;break}if(c){let p=s[0][0]*l[0],f=s[0][1]*l[0];if(ArrayBuffer.isView(a))i.set(a.subarray(p,f));else if(Array.isArray(a)){let _=a.slice(p,f);for(let m=0;m<_.length;++m)i[m]=_[m]}else throw new Error("Unsupported data type for slicing")}else for(let p=0;p<o;++p){let f=0;for(let _=n.length-1,m=p;_>=0;--_){let w=n[_];f+=(m%w+s[_][0])*l[_],m=Math.floor(m/w)}i[p]=a[f]}return new t(this.type,i,r)}permute(...e){return PP(this,e)}transpose(...e){return this.permute(...e)}sum(e=null,r=!1){return this.norm(1,e,r)}norm(e="fro",r=null,s=!1){if(e==="fro")e=2;else if(typeof e=="string")throw Error(`Unsupported norm: ${e}`);let n=this.data,o=n instanceof BigInt64Array||n instanceof BigUint64Array;if(o&&e!==1)throw Error(`Expected a floating point tensor as input. Got ${this.type}`);let a,i;if(o?(a=(f,_)=>f+_,i=0n):(a=(f,_)=>f+_**e,i=0),r===null){let f=n.reduce(a,i);return e!==1&&(f=f**(1/e)),new t(this.type,[f],[])}let[l,c,p]=Eo(a,this,r,s);if(e!==1)for(let f=0;f<c.length;++f)c[f]=c[f]**(1/e);return new t(l,c,p)}normalize_(e=2,r=1){r=ur(r,this.dims.length);let s=this.norm(e,r,!0),n=this.data,o=s.data;for(let a=0;a<n.length;++a){let i=0;for(let l=this.dims.length-1,c=a,p=1;l>=0;--l){let f=this.dims[l];if(l!==r){let _=c%f;i+=_*p,p*=this.dims[l]}c=Math.floor(c/f)}n[a]/=o[i]}return this}normalize(e=2,r=1){return this.clone().normalize_(e,r)}stride(){return cf(this.dims)}squeeze(e=null){return new t(this.type,this.data,VA(this.dims,e))}squeeze_(e=null){return this.dims=VA(this.dims,e),this}unsqueeze(e){return new t(this.type,this.data,HA(this.dims,e))}unsqueeze_(e){return this.dims=HA(this.dims,e),this}flatten_(e=0,r=-1){r=(r+this.dims.length)%this.dims.length;let s=this.dims.slice(0,e),n=this.dims.slice(e,r+1),o=this.dims.slice(r+1);return this.dims=[...s,n.reduce((a,i)=>a*i,1),...o],this}flatten(e=0,r=-1){return this.clone().flatten_(e,r)}view(...e){let r=-1;for(let n=0;n<e.length;++n)if(e[n]===-1){if(r!==-1)throw new Error("Only one dimension can be inferred");r=n}let s=this.data;if(r!==-1){let n=e.reduce((o,a,i)=>i!==r?o*a:o,1);e[r]=s.length/n}return new t(this.type,s,e)}neg_(){let e=this.data;for(let r=0;r<e.length;++r)e[r]=-e[r];return this}neg(){return this.clone().neg_()}gt(e){let r=new Uint8Array(this.data.length),s=this.data;for(let n=0;n<s.length;++n)r[n]=s[n]>e?1:0;return new t("bool",r,this.dims)}lt(e){let r=new Uint8Array(this.data.length),s=this.data;for(let n=0;n<s.length;++n)r[n]=s[n]<e?1:0;return new t("bool",r,this.dims)}clamp_(e,r){let s=this.data;for(let n=0;n<s.length;++n)s[n]=Math.min(Math.max(s[n],e),r);return this}clamp(e,r){return this.clone().clamp_(e,r)}round_(){let e=this.data;for(let r=0;r<e.length;++r)e[r]=Math.round(e[r]);return this}round(){return this.clone().round_()}mean(e=null,r=!1){return gc(this,e,r)}min(e=null,r=!1){if(e===null){let a=fo(this.data)[0];return new t(this.type,[a],[])}let[s,n,o]=Eo((a,i)=>Math.min(a,i),this,e,r,1/0);return new t(s,n,o)}max(e=null,r=!1){if(e===null){let a=Ce(this.data)[0];return new t(this.type,[a],[])}let[s,n,o]=Eo((a,i)=>Math.max(a,i),this,e,r,-1/0);return new t(s,n,o)}argmin(e=null,r=!1){if(e!==null)throw new Error("`dim !== null` not yet implemented.");let s=fo(this.data)[1];return new t("int64",[BigInt(s)],[])}argmax(e=null,r=!1){if(e!==null)throw new Error("`dim !== null` not yet implemented.");let s=Ce(this.data)[1];return new t("int64",[BigInt(s)],[])}repeat(...e){if(e.length<this.dims.length)throw new Error(`Number of dimensions of repeat dims (${e.length}) cannot be smaller than number of dimensions of tensor (${this.dims.length})`);if(e.every(p=>p===1)){if(e.length===this.dims.length)return this.clone();let p=e.length-this.dims.length,f=Array(p).fill(1).concat(this.dims);return new t(this.type,this.data.slice(),f)}let r=e.length-this.dims.length,s=Array(r).fill(1).concat(this.dims),n=s.map((p,f)=>p*e[f]),o=n.reduce((p,f)=>p*f,1),a=this.data,i=new a.constructor(o),l=cf(s),c=cf(n);for(let p=0;p<o;++p){let f=p,_=0;for(let m=0;m<n.length;++m){let w=Math.floor(f/c[m]);f=f%c[m];let x=w%s[m];_+=x*l[m]}i[p]=a[_]}return new t(this.type,i,n)}tile(...e){if(e.length<this.dims.length){let r=this.dims.length-e.length;e=Array(r).fill(1).concat(e)}return this.repeat(...e)}to(e){if(this.type===e)return this;if(!br.hasOwnProperty(e))throw new Error(`Unsupported type: ${e}`);let r,s=["int64","uint64"].includes(this.type),n=["int64","uint64"].includes(e);if(s&&!n)r=Number;else if(!s&&n)["float16","float32","float64"].includes(this.type)?r=o=>BigInt(Math.floor(o)):r=BigInt;else if(this.type==="float16"&&e=="float32"&&this.data instanceof Uint16Array)return new t(e,dE(this.data),this.dims);return new t(e,br[e].from(this.data,r),this.dims)}};function LP(t,e){let r=t.length,s=e.reduce((o,a)=>o*a);if(r!==s)throw Error(`cannot reshape array of size ${r} into shape (${e})`);let n=t;for(let o=e.length-1;o>=0;o--)n=n.reduce((a,i)=>{let l=a[a.length-1];return l.length<e[o]?l.push(i):a.push([i]),a},[[]]);return n[0]}function PP(t,e){let[r,s]=aE(t.data,t.dims,e);return new $(t.type,r,s)}function uf(t,[e,r],s="bilinear",n=!1){let o=t.dims.at(-3)??1,a=t.dims.at(-2),i=t.dims.at(-1),l=oE(t.data,[o,a,i],[e,r],s,n);return new $(t.type,l,[o,e,r])}async function vt(t,{size:e=null,mode:r="bilinear"}={}){if(t.dims.length!==4)throw new Error("`interpolate_4d` currently only supports 4D input.");if(!e)throw new Error("`interpolate_4d` requires a `size` argument.");let s;if(e.length===2)s=[...t.dims.slice(0,2),...e];else if(e.length===3)s=[t.dims[0],...e];else if(e.length===4)s=e;else throw new Error("`size` must be of length 2, 3, or 4.");let n;if(r==="nearest")n=await cr.nearest_interpolate_4d;else if(r==="bilinear")n=await cr.bilinear_interpolate_4d;else if(r==="bicubic")n=await cr.bicubic_interpolate_4d;else throw new Error(`Unsupported mode: ${r}`);let o=new $("int64",new BigInt64Array(s.map(BigInt)),[s.length]);return await n({x:t,s:o})}async function XA(t,e){return await(await cr.matmul)({a:t,b:e})}async function bR(t,e){return await(await cr.rfft)({x:t,a:e})}async function er(t,e){let r=await cr.top_k;return e==null?e=t.dims.at(-1):e=Math.min(e,t.dims.at(-1)),await r({x:t,k:new $("int64",[BigInt(e)],[1])})}var mc=t=>new $("int64",t,[t.length]);async function hc(t,e,r,s,n){return await(await cr.slice)({x:t,s:mc(e),e:mc(r),a:mc(s),t:mc(n??new Array(s.length).fill(1))})}function KA(t,e){let r=t.data,s=e.data,n=[t.dims[0],t.dims[2]],o=new r.constructor(n[0]*n[1]),[a,i,l]=t.dims,c=0;for(let p=0;p<a;++p){let f=p*l*i;for(let _=0;_<l;++_){let m=0,w=0,x=p*i,k=f+_;for(let A=0;A<i;++A){let T=Number(s[x+A]);w+=T,m+=r[k+A*l]*T}let E=m/w;o[c++]=E}}return new $(t.type,o,n)}function vR(t,e,{eps:r=1e-5}={}){if(t.dims.length!==2)throw new Error("`layer_norm` currently only supports 2D input.");let[s,n]=t.dims;if(e.length!==1&&e[0]!==n)throw new Error("`normalized_shape` must be a 1D array with shape `[input.dims[1]]`.");let[o,a]=pf(t,1,0,!0),i=o.data,l=a.data,c=t.data,p=new c.constructor(c.length);for(let f=0;f<s;++f){let _=f*n;for(let m=0;m<n;++m){let w=_+m;p[w]=(c[w]-l[f])/(i[f]+r)}}return new $(t.type,p,t.dims)}function VA(t,e){return t=t.slice(),e===null?t=t.filter(r=>r!==1):typeof e=="number"?t[e]===1&&t.splice(e,1):Array.isArray(e)&&(t=t.filter((r,s)=>r!==1||!e.includes(s))),t}function HA(t,e){return e=ur(e,t.length+1),t=t.slice(),t.splice(e,0,1),t}function ur(t,e,r=null,s=!0){if(t<-e||t>=e){if(s)throw new Error(`IndexError: index ${t} is out of bounds for dimension${r===null?"":" "+r} with size ${e}`);return t<-e?0:e}return t<0&&(t=(t%e+e)%e),t}function Ee(t,e=0){e=ur(e,t[0].dims.length);let r=t[0].dims.slice();r[e]=t.reduce((a,i)=>a+i.dims[e],0);let s=r.reduce((a,i)=>a*i,1),n=new t[0].data.constructor(s),o=t[0].type;if(e===0){let a=0;for(let i of t){let l=i.data;n.set(l,a),a+=l.length}}else{let a=0;for(let i=0;i<t.length;++i){let{data:l,dims:c}=t[i];for(let p=0;p<l.length;++p){let f=0;for(let _=c.length-1,m=p,w=1;_>=0;--_){let x=c[_],k=m%x;_===e&&(k+=a),f+=k*w,w*=r[_],m=Math.floor(m/x)}n[f]=l[p]}a+=c[e]}}return new $(o,n,r)}function It(t,e=0){return Ee(t.map(r=>r.unsqueeze(e)),e)}function Eo(t,e,r,s=!1,n=null){let o=e.data,a=e.dims;r=ur(r,a.length);let i=a.slice();i[r]=1;let l=new o.constructor(o.length/a[r]);n!==null&&l.fill(n);for(let c=0;c<o.length;++c){let p=0;for(let f=a.length-1,_=c,m=1;f>=0;--f){let w=a[f];if(f!==r){let x=_%w;p+=x*m,m*=i[f]}_=Math.floor(_/w)}l[p]=t(l[p],o[c],c,p)}return s||i.splice(r,1),[e.type,l,i]}function pf(t,e=null,r=1,s=!1){let n=t.data,o=t.dims;if(e===null){let m=n.reduce((E,A)=>E+A,0)/n.length,w=Math.sqrt(n.reduce((E,A)=>E+(A-m)**2,0)/(n.length-r)),x=new $(t.type,[m],[]);return[new $(t.type,[w],[]),x]}e=ur(e,o.length);let a=gc(t,e,s),i=a.data,[l,c,p]=Eo((_,m,w,x)=>_+(m-i[x])**2,t,e,s);for(let _=0;_<c.length;++_)c[_]=Math.sqrt(c[_]/(o[e]-r));return[new $(l,c,p),a]}function gc(t,e=null,r=!1){let s=t.dims,n=t.data;if(e===null){let l=n.reduce((c,p)=>c+p,0);return new $(t.type,[l/n.length],[])}e=ur(e,s.length);let[o,a,i]=Eo((l,c)=>l+c,t,e,r);if(s[e]!==1)for(let l=0;l<a.length;++l)a[l]/=s[e];return new $(o,a,i)}function cf(t){let e=new Array(t.length);for(let r=t.length-1,s=1;r>=0;--r)e[r]=s,s*=t[r];return e}function df(t,e,r,s){let n=t.reduce((o,a)=>o*a,1);return new $(r,new s(n).fill(e),t)}function Xe(t,e){let r,s;if(typeof e=="number")r="float32",s=Float32Array;else if(typeof e=="bigint")r="int64",s=BigInt64Array;else if(typeof e=="boolean")r="bool",s=Uint8Array;else throw new Error(`Unsupported data type: ${typeof e}`);return df(t,e,r,s)}function Ao(t,e){return Xe(t.dims,e)}function st(t){return df(t,1n,"int64",BigInt64Array)}function wc(t){return st(t.dims)}function ff(t){return df(t,0n,"int64",BigInt64Array)}function _f(t){return ff(t.dims)}function kR(t){let e=t.reduce((r,s)=>r*s,1);return new $("float32",Float32Array.from({length:e},()=>_s.random()),t)}function QA(t){let e=t.reduce((r,s)=>r*s,1);return new $("float32",Float32Array.from({length:e},()=>_s.gauss()),t)}function YA(t,e){if(t.dims.length!==2)throw new Error("The tensor must have 2 dimensions");if(t.dims.at(-1)%8!==0)throw new Error("The last dimension of the tensor must be a multiple of 8");if(!["binary","ubinary"].includes(e))throw new Error("The precision must be either 'binary' or 'ubinary'");let r=e==="binary",s=r?"int8":"uint8",n=r?Int8Array:Uint8Array,o=t.data,a=new n(o.length/8);for(let i=0;i<o.length;++i){let l=o[i]>0?1:0,c=Math.floor(i/8),p=i%8;a[c]|=l<<7-p,r&&p===0&&(a[c]-=128)}return new $(s,a,[t.dims[0],t.dims[1]/8])}async function dn(t){if(!t)throw new Error("modelId is required for get_tokenizer_files");return(await lr(t,"tokenizer_config.json",{})).exists?["tokenizer.json","tokenizer_config.json"]:[]}async function mf(t,e){let r=await dn(t);return await Promise.all(r.map(s=>ft(t,s,!0,e)))}function hf(t){let e=t.dims;switch(e.length){case 1:return t.tolist();case 2:if(e[0]!==1)throw new Error("Unable to decode tensor with `batch size !== 1`. Use `tokenizer.batch_decode(...)` for batched inputs.");return t.tolist()[0];default:throw new Error(`Expected tensor to have 1-2 dimensions, got ${e.length}.`)}}var zP=["bos_token","eos_token","unk_token","sep_token","pad_token","cls_token","mask_token"];function NP(t,e,r,s){for(let n of Object.keys(t)){let o=e-t[n].length,a=r(n),i=new Array(o).fill(a);t[n]=s==="right"?wt(t[n],i):wt(i,t[n])}}function $P(t,e){for(let r of Object.keys(t))t[r].length=e}function As(t,...e){for(let r of e){if(!Object.hasOwn(t,r))continue;let s=t[r];if(s)if(typeof s=="object"){if(s.__type==="AddedToken")return s.content;throw Error(`Unknown token: ${s}`)}else return s}return null}function RP(t){let e=[];for(let r of t.get_added_tokens_decoder().values())r.special&&e.push(r);return e}var W=class extends rt{return_token_type_ids=!1;padding_side="right";constructor(e,r){if(super(),this._tokenizerJSON=e,this._tokenizerConfig=r,this._tokenizer=new Nk(e,r),this.config=r,this.padding_side=r.padding_side??this.padding_side,this.mask_token=As(r,"mask_token"),this.mask_token_id=this._tokenizer.token_to_id(this.mask_token),this.pad_token=As(r,"pad_token","eos_token"),this.pad_token_id=this._tokenizer.token_to_id(this.pad_token),this.sep_token=As(r,"sep_token"),this.sep_token_id=this._tokenizer.token_to_id(this.sep_token),this.unk_token=As(r,"unk_token"),this.unk_token_id=this._tokenizer.token_to_id(this.unk_token),this.bos_token=As(r,"bos_token"),this.bos_token_id=this._tokenizer.token_to_id(this.bos_token),this.eos_token=As(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)){let n=Object.create(null);for(let{name:o,template:a}of this.chat_template){if(typeof o!="string"||typeof a!="string")throw new Error('Chat template must be a list of objects with "name" and "template" properties');n[o]=a}this.chat_template=n}this._compiled_template_cache=new Map;let s=RP(this._tokenizer);this.all_special_ids=s.map(n=>n.id),this.all_special_tokens=s.map(n=>n.content)}static async from_pretrained(e,{progress_callback:r=null,config:s=null,cache_dir:n=null,local_files_only:o=!1,revision:a="main"}={}){let i=await mf(e,{progress_callback:r,config:s,cache_dir:n,local_files_only:o,revision:a});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(e){return typeof e=="string"?this._tokenizer.token_to_id(e):e.map(r=>this._tokenizer.token_to_id(r))}_call(e,{text_pair:r=null,add_special_tokens:s=!0,padding:n=!1,truncation:o=null,max_length:a=null,return_tensor:i=!0,return_token_type_ids:l=null}={}){let c=Array.isArray(e),p;if(c){if(e.length===0)throw Error("text array must be non-empty");if(r!==null){if(Array.isArray(r)){if(e.length!==r.length)throw Error("text and text_pair must have the same length")}else throw Error("text_pair must also be an array");p=e.map((_,m)=>this._encode_plus(_,{text_pair:r[m],add_special_tokens:s,return_token_type_ids:l}))}else p=e.map(_=>this._encode_plus(_,{add_special_tokens:s,return_token_type_ids:l}))}else{if(e==null)throw Error("text may not be null or undefined");if(Array.isArray(r))throw Error("When specifying `text_pair`, since `text` is a string, `text_pair` must also be a string (i.e., not an array).");p=[this._encode_plus(e,{text_pair:r,add_special_tokens:s,return_token_type_ids:l})]}if(a===null?a=this.model_max_length:o===null&&(n===!0?(Z.warn("`max_length` is ignored when `padding: true` and there is no truncation strategy. To pad to max length, use `padding: 'max_length'`."),a=this.model_max_length):n===!1&&(Z.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."),o=!0)),n===!0&&(a=Math.min(Ce(p.map(_=>_.input_ids.length))[0],a??1/0)),a=Math.min(a,this.model_max_length??1/0),n||o)for(let _=0;_<p.length;++_)p[_].input_ids.length!==a&&(p[_].input_ids.length>a?o&&$P(p[_],a):n&&NP(p[_],a,m=>m==="input_ids"?this.pad_token_id:0,this.padding_side));let f={};if(i){if(!(n&&o)&&p.some(m=>{for(let w of Object.keys(m))if(m[w].length!==p[0][w]?.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.");let _=[p.length,p[0].input_ids.length];for(let m of Object.keys(p[0]))f[m]=new $("int64",BigInt64Array.from(p.flatMap(w=>w[m]).map(BigInt)),_)}else{for(let _ of Object.keys(p[0]))f[_]=p.map(m=>m[_]);if(!c)for(let _ of Object.keys(f))f[_]=f[_][0]}return f}_encode_text(e){return e===null?null:this._tokenizer.encode(e).tokens}_encode_plus(e,{text_pair:r=null,add_special_tokens:s=!0,return_token_type_ids:n=null}={}){let{ids:o,attention_mask:a,token_type_ids:i}=this._tokenizer.encode(e,{text_pair:r,add_special_tokens:s,return_token_type_ids:n??this.return_token_type_ids});return{input_ids:o,attention_mask:a,...i?{token_type_ids:i}:{}}}tokenize(e,{pair:r=null,add_special_tokens:s=!1}={}){return this._tokenizer.tokenize(e,{text_pair:r,add_special_tokens:s})}encode(e,{text_pair:r=null,add_special_tokens:s=!0,return_token_type_ids:n=null}={}){return this._tokenizer.encode(e,{text_pair:r,add_special_tokens:s,return_token_type_ids:n}).ids}batch_decode(e,r={}){return e instanceof $&&(e=e.tolist()),e.map(s=>this.decode(s,r))}decode(e,r={}){if(e instanceof $&&(e=hf(e)),!Array.isArray(e)||e.length===0||!gk(e[0]))throw Error("token_ids must be a non-empty array of integers.");return this.decode_single(e,r)}decode_single(e,{skip_special_tokens:r=!1,clean_up_tokenization_spaces:s=null}){return this._tokenizer.decode(e,{skip_special_tokens:r,clean_up_tokenization_spaces:s})}get_chat_template({chat_template:e=null,tools:r=null}={}){if(this.chat_template&&typeof this.chat_template=="object"){let s=this.chat_template;if(e!==null&&Object.hasOwn(s,e))e=s[e];else if(e===null)if(r!==null&&"tool_use"in s)e=s.tool_use;else if("default"in s)e=s.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(s).sort()}.`)}else if(e===null)if(this.chat_template)e=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 e}apply_chat_template(e,{tools:r=null,documents:s=null,chat_template:n=null,add_generation_prompt:o=!1,tokenize:a=!0,padding:i=!1,truncation:l=!1,max_length:c=null,return_tensor:p=!0,return_dict:f=!0,tokenizer_kwargs:_={},...m}={}){if(n=this.get_chat_template({chat_template:n,tools:r}),typeof n!="string")throw Error(`chat_template must be a string, but got ${typeof n}`);let w=this._compiled_template_cache.get(n);w===void 0&&(w=new Hk(n),this._compiled_template_cache.set(n,w));let x=Object.create(null);for(let E of zP){let A=As(this.config,E);A&&(x[E]=A)}let k=w.render({messages:e,add_generation_prompt:o,tools:r,documents:s,...x,...m});if(a){let E=this._call(k,{add_special_tokens:!1,padding:i,truncation:l,max_length:c,return_tensor:p,..._});return f?E:E.input_ids}return k}};function fn(t,e,r,s){if(!("language_codes"in t)||!Array.isArray(t.language_codes))throw new Error("Tokenizer must have `language_codes` attribute set and it should be an array of language ids.");if(!("languageRegex"in t)||!(t.languageRegex instanceof RegExp))throw new Error("Tokenizer must have `languageRegex` attribute set and it should be a regular expression.");if(!("lang_to_token"in t)||typeof t.lang_to_token!="function")throw new Error("Tokenizer must have `lang_to_token` attribute set and it should be a function.");let n=s.src_lang,o=s.tgt_lang;if(!t.language_codes.includes(o))throw new Error(`Target language code "${o}" is not valid. Must be one of: {${t.language_codes.join(", ")}}`);if(n!==void 0){if(!t.language_codes.includes(n))throw new Error(`Source language code "${n}" is not valid. Must be one of: {${t.language_codes.join(", ")}}`);for(let a of t._tokenizer.post_processor.config.single)if("SpecialToken"in a&&t.languageRegex.test(a.SpecialToken.id)){a.SpecialToken.id=t.lang_to_token(n);break}}return s.forced_bos_token_id=t._tokenizer.token_to_id(t.lang_to_token(o)),t._call(e,r)}var i_={};Ys(i_,{AlbertTokenizer:()=>gf,AutoTokenizer:()=>oe,BartTokenizer:()=>wf,BertTokenizer:()=>xf,BlenderbotSmallTokenizer:()=>yf,BlenderbotTokenizer:()=>bf,BloomTokenizer:()=>vf,CLIPTokenizer:()=>Ef,CamembertTokenizer:()=>kf,CodeGenTokenizer:()=>Mf,CodeLlamaTokenizer:()=>Af,CohereTokenizer:()=>Sf,ConvBertTokenizer:()=>Tf,DebertaTokenizer:()=>If,DebertaV2Tokenizer:()=>Of,DistilBertTokenizer:()=>Cf,ElectraTokenizer:()=>Lf,EsmTokenizer:()=>Pf,FalconTokenizer:()=>zf,GPT2Tokenizer:()=>Rf,GPTNeoXTokenizer:()=>$f,GemmaTokenizer:()=>Nf,HerbertTokenizer:()=>Df,LlamaTokenizer:()=>Ff,M2M100Tokenizer:()=>Bf,MBart50Tokenizer:()=>jf,MBartTokenizer:()=>Mo,MPNetTokenizer:()=>Wf,MarianTokenizer:()=>Uf,MgpstrTokenizer:()=>Gf,MobileBertTokenizer:()=>qf,NllbTokenizer:()=>Vf,NougatTokenizer:()=>Hf,PreTrainedTokenizer:()=>W,Qwen2Tokenizer:()=>Xf,RoFormerTokenizer:()=>Qf,RobertaTokenizer:()=>Kf,SiglipTokenizer:()=>Yf,SpeechT5Tokenizer:()=>Jf,SqueezeBertTokenizer:()=>Zf,T5Tokenizer:()=>e_,TokenizersBackend:()=>W,VitsTokenizer:()=>r_,Wav2Vec2CTCTokenizer:()=>s_,WhisperTokenizer:()=>n_,XLMRobertaTokenizer:()=>o_,XLMTokenizer:()=>a_});var gf=class extends W{return_token_type_ids=!0};var wf=class extends W{};var xf=class extends W{return_token_type_ids=!0};var yf=class extends W{};var bf=class extends W{};var vf=class extends W{};var kf=class extends W{};var Ef=class extends W{};var Af=class extends W{};var Mf=class extends W{};var Sf=class extends W{};var Tf=class extends W{return_token_type_ids=!0};var Of=class extends W{return_token_type_ids=!0};var If=class extends W{return_token_type_ids=!0};var Cf=class extends W{};var Lf=class extends W{return_token_type_ids=!0};var Pf=class extends W{};var zf=class extends W{};var Nf=class extends W{};var $f=class extends W{};var Rf=class extends W{};var Df=class extends W{return_token_type_ids=!0};var Ff=class extends W{padding_side="left"};var Bf=class extends W{constructor(e,r){super(e,r),this.languageRegex=/^__[a-z]{2,3}__$/,this.language_codes=this.all_special_tokens.filter(s=>this.languageRegex.test(s)).map(s=>s.slice(2,-2)),this.lang_to_token=s=>`__${s}__`}_build_translation_inputs(e,r,s){return fn(this,e,r,s)}};var Uf=class extends W{constructor(e,r){super(e,r),this.languageRegex=/^(>>\w+<<)\s*/g,this.supported_language_codes=Array.from(this.get_vocab().keys()).filter(s=>this.languageRegex.test(s)),Z.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;let[r,...s]=e.trim().split(this.languageRegex);if(s.length===0)return super._encode_text(r);if(s.length===2){let[n,o]=s;return this.supported_language_codes.includes(n)||Z.warn(`Unsupported language code "${n}" detected, which may lead to unexpected behavior. Should be one of: ${JSON.stringify(this.supported_language_codes)}`),wt([n],super._encode_text(o))}}};var Mo=class extends W{constructor(e,r){super(e,r),this.languageRegex=/^[a-z]{2}_[A-Z]{2}$/,this.language_codes=this.all_special_tokens.filter(s=>this.languageRegex.test(s)).map(s=>s),this.lang_to_token=s=>s}_build_translation_inputs(e,r,s){return fn(this,e,r,s)}};var jf=class extends Mo{};var Gf=class extends W{};var qf=class extends W{return_token_type_ids=!0};var Wf=class extends W{};var Vf=class extends W{constructor(e,r){super(e,r),this.languageRegex=/^[a-z]{3}_[A-Z][a-z]{3}$/,this.language_codes=this.all_special_tokens.filter(s=>this.languageRegex.test(s)),this.lang_to_token=s=>s}_build_translation_inputs(e,r,s){return fn(this,e,r,s)}};var Hf=class extends W{};var Xf=class extends W{};var Kf=class extends W{};var Qf=class extends W{return_token_type_ids=!0};var Yf=class extends W{};var Jf=class extends W{};var Zf=class extends W{return_token_type_ids=!0};var e_=class extends W{};var t_=class extends Dt{decode_chain(e){let r="";for(let s=1;s<e.length;s+=2)r+=e[s];return[r]}},r_=class extends W{constructor(e,r){super(e,r),this._tokenizer.decoder=new t_({type:"VitsDecoder"})}};var s_=class extends W{};var JA=[["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"]],So=new Map(JA),DP=new Map([...JA.map(([t,e])=>[e,t]),["burmese","my"],["valencian","ca"],["flemish","nl"],["haitian","ht"],["letzeburgesch","lb"],["pushto","ps"],["panjabi","pa"],["moldavian","ro"],["moldovan","ro"],["sinhalese","si"],["castilian","es"]]);function ZA(t){t=t.toLowerCase();let e=DP.get(t);if(e===void 0){let r=t.match(/^<\|([a-z]{2})\|>$/);if(r&&(t=r[1]),So.has(t))e=t;else{let n=t.length===2?So.keys():So.values();throw new Error(`Language "${t}" is not supported. Must be one of: ${JSON.stringify(Array.from(n))}`)}}return e}var FP="\\p{P}\\u0021-\\u002F\\u003A-\\u0040\\u005B-\\u0060\\u007B-\\u007E",e2=new RegExp(`^[${FP}]+$`,"gu"),n_=class extends W{get timestamp_begin(){return this._tokenizer.token_to_id("<|notimestamps|>")+1}_decode_asr(e,{return_timestamps:r=!1,return_language:s=!1,time_precision:n=null,force_full_sequences:o=!0}={}){if(n===null)throw Error("Must specify time_precision");let a=null,i=r==="word";function l(){return{language:a,timestamp:[null,null],text:""}}let c=[],p=l(),f=0,_=this.timestamp_begin,w=_+1500,x=[],k=[],E=!1,A=null,T=new Set(this.all_special_ids);for(let O of e){let v=O.tokens,j=i?O.token_timestamps:null,H=null,B=_;if("stride"in O){let[Q,F,C]=O.stride;if(f-=F,A=Q-C,F&&(B=F/n+_),C)for(let te=v.length-1;te>=0;--te){let le=Number(v[te]);if(le>=_){if(H!==null&&(le-_)*n<A)break;H=le}}}let V=[],q=[];for(let Q=0;Q<v.length;++Q){let F=Number(v[Q]);if(T.has(F)){let C=this.decode([F]),te=So.get(C.slice(2,-2));if(te!==void 0){if(a!==null&&te!==a&&!r){x.push(V);let le=this.findLongestCommonSequence(x)[0],L=this.decode(le);p.text=L,c.push(p),x=[],V=[],p=l()}a=p.language=te}}else if(F>=_&&F<=w){let C=(F-_)*n+f,te=ms(C,2);if(H!==null&&F>=H)E=!0;else if(E||x.length>0&&F<B)E=!1;else if(p.timestamp[0]===null)p.timestamp[0]=te;else if(te!==p.timestamp[0]){p.timestamp[1]=te,x.push(V),i&&k.push(q);let[le,L]=this.findLongestCommonSequence(x,k),z=this.decode(le);p.text=z,i&&(p.words=this.collateWordTimestamps(le,L,a)),c.push(p),x=[],V=[],k=[],q=[],p=l()}}else if(V.push(F),i){let C=ms(j[Q]+f,2),te;if(Q+1<j.length){te=ms(j[Q+1]+f,2);let le=this.decode([F]);e2.test(le)&&(te=ms(Math.min(C+n,te),2))}else te=null;q.push([C,te])}}if("stride"in O){let[Q,F,C]=O.stride;f+=Q-C}V.length>0?(x.push(V),i&&k.push(q)):x.every(Q=>Q.length===0)&&(p=l(),x=[],V=[],k=[],q=[])}if(x.length>0){if(o&&r)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.");let[O,v]=this.findLongestCommonSequence(x,k),j=this.decode(O);p.text=j,i&&(p.words=this.collateWordTimestamps(O,v,a)),c.push(p)}let S=Object.create(null),P=c.map(O=>O.text).join("");if(r||s){for(let O=0;O<c.length;++O){let v=c[O];r||delete v.timestamp,s||delete v.language}if(i){let O=[];for(let v of c)for(let j of v.words)O.push(j);S={chunks:O}}else S={chunks:c}}return[P,S]}findLongestCommonSequence(e,r=null){let s=e[0],n=s.length,o=[],a=Array.isArray(r)&&r.length>0,i=a?[]:null,l=a?r[0]:null;for(let c=1;c<e.length;++c){let p=e[c],f=0,_=[n,n,0,0],m=p.length;for(let S=1;S<n+m;++S){let P=Math.max(0,n-S),O=Math.min(n,n+m-S),v=s.slice(P,O),j=Math.max(0,S-n),H=Math.min(m,S),B=p.slice(j,H);if(v.length!==B.length)throw new Error("There is a bug within whisper `decode_asr` function, please report it. Dropping to prevent bad inference.");let V;a?V=v.filter((F,C)=>F===B[C]&&l[P+C]<=r[c][j+C]).length:V=v.filter((F,C)=>F===B[C]).length;let q=S/1e4,Q=V/S+q;V>1&&Q>f&&(f=Q,_=[P,O,j,H])}let[w,x,k,E]=_,A=Math.floor((x+w)/2),T=Math.floor((E+k)/2);o.push(...s.slice(0,A)),s=p.slice(T),n=s.length,a&&(i.push(...l.slice(0,A)),l=r[c].slice(T))}return o.push(...s),a?(i.push(...l),[o,i]):[o,[]]}collateWordTimestamps(e,r,s){let[n,o,a]=this.combineTokensIntoWords(e,s),i=[];for(let l=0;l<n.length;++l){let c=a[l];i.push({text:n[l],timestamp:[r[c.at(0)][0],r[c.at(-1)][1]]})}return i}combineTokensIntoWords(e,r,s=`"'\u201C\xA1\xBF([{-`,n=`"'.\u3002,\uFF0C!\uFF01?\uFF1F:\uFF1A\u201D)]}\u3001`){r=r??"english";let o,a,i;return["chinese","japanese","thai","lao","myanmar"].includes(r)?[o,a,i]=this.splitTokensOnUnicode(e):[o,a,i]=this.splitTokensOnSpaces(e),this.mergePunctuations(o,a,i,s,n)}decode(e,r){let s;return r?.decode_with_timestamps?(e instanceof $&&(e=hf(e)),s=this.decodeWithTimestamps(e,r)):s=super.decode(e,r),s}decodeWithTimestamps(e,r){let s=r?.time_precision??.02,n=this.all_special_ids.at(-1)+1,o=[[]];for(let a of e)if(a=Number(a),a>=n){let i=((a-n)*s).toFixed(2);o.push(`<|${i}|>`),o.push([])}else o[o.length-1].push(a);return o=o.map(a=>typeof a=="string"?a:super.decode(a,r)),o.join("")}splitTokensOnUnicode(e){let r=this.decode(e,{decode_with_timestamps:!0}),s="\uFFFD",n=[],o=[],a=[],i=[],l=[],c=0;for(let p=0;p<e.length;++p){let f=e[p];i.push(f),l.push(p);let _=this.decode(i,{decode_with_timestamps:!0});(!_.includes(s)||r[c+_.indexOf(s)]===s)&&(n.push(_),o.push(i),a.push(l),i=[],l=[],c+=_.length)}return[n,o,a]}splitTokensOnSpaces(e){let[r,s,n]=this.splitTokensOnUnicode(e),o=[],a=[],i=[];for(let l=0;l<r.length;++l){let c=r[l],p=s[l],f=n[l],_=p[0]>=this._tokenizer.token_to_id("<|endoftext|>"),m=c.startsWith(" "),w=c.trim(),x=e2.test(w);if(_||m||x||o.length===0)o.push(c),a.push(p),i.push(f);else{let k=o.length-1;o[k]+=c,a[k].push(...p),i[k].push(...f)}}return[o,a,i]}mergePunctuations(e,r,s,n,o){let a=structuredClone(e),i=structuredClone(r),l=structuredClone(s),c=a.length-2,p=a.length-1;for(;c>=0;)a[c].startsWith(" ")&&n.includes(a[c].trim())?(a[p]=a[c]+a[p],i[p]=wt(i[c],i[p]),l[p]=wt(l[c],l[p]),a[c]="",i[c]=[],l[c]=[]):p=c,--c;for(c=0,p=1;p<a.length;)!a[c].endsWith(" ")&&o.includes(a[p])?(a[c]+=a[p],i[c]=wt(i[c],i[p]),l[c]=wt(l[c],l[p]),a[p]="",i[p]=[],l[p]=[]):c=p,++p;return[a.filter(f=>f),i.filter(f=>f.length>0),l.filter(f=>f.length>0)]}};var o_=class extends W{};var a_=class extends W{return_token_type_ids=!0;constructor(e,r){super(e,r),Z.warn('WARNING: `XLMTokenizer` is not yet supported by Hugging Face\'s "fast" tokenizers library. Therefore, you may experience slightly inaccurate results.')}};var oe=class{static async from_pretrained(e,{progress_callback:r=null,config:s=null,cache_dir:n=null,local_files_only:o=!1,revision:a="main"}={}){let[i,l]=await mf(e,{progress_callback:r,config:s,cache_dir:n,local_files_only:o,revision:a}),c=l.tokenizer_class?.replace(/Fast$/,"")??"PreTrainedTokenizer",p=i_[c];return p||(Z.warn(`Unknown tokenizer class "${c}", attempting to construct from base class.`),p=W),new p(i,l)}};var jr="https://github.com/huggingface/transformers.js/issues/new/choose";var To="preprocessor_config.json",vr=To,t2="processor_config.json",r2="chat_template.jinja";var re=class extends rt{static classes=["image_processor_class","tokenizer_class","feature_extractor_class"];static uses_processor_config=!1;static uses_chat_template_file=!1;constructor(e,r,s){super(),this.config=e,this.components=r,this.chat_template=s}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,r={}){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,...r})}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,...r){for(let s of[this.image_processor,this.feature_extractor,this.tokenizer])if(s)return s(e,...r);throw new Error("No image processor, feature extractor, or tokenizer found.")}static async from_pretrained(e,r={}){let[s,n,o]=await Promise.all([this.uses_processor_config?ft(e,t2,!0,r):{},Promise.all(this.classes.filter(a=>a in this).map(async a=>{let i=await this[a].from_pretrained(e,r);return[a.replace(/_class$/,""),i]})).then(Object.fromEntries),this.uses_chat_template_file?fd(e,r2,!0,r):null]);return new this(s,n,o)}};var qc={};Ys(qc,{ChatterboxProcessor:()=>E_,Florence2Processor:()=>hm,Gemma3nProcessor:()=>gm,GraniteSpeechProcessor:()=>wm,GroundingDinoProcessor:()=>xm,Idefics3Processor:()=>Bc,JinaCLIPProcessor:()=>bm,Lfm2VlProcessor:()=>vm,LlavaProcessor:()=>km,MgpstrProcessor:()=>Em,MoonshineProcessor:()=>Am,OwlViTProcessor:()=>Mm,PaliGemmaProcessor:()=>Sm,Phi3VProcessor:()=>Tm,PixtralProcessor:()=>Om,Processor:()=>re,PyAnnoteProcessor:()=>Im,Qwen2VLProcessor:()=>No,Qwen2_5_VLProcessor:()=>$o,Qwen3VLProcessor:()=>Cm,Sam2Processor:()=>Uc,Sam2VideoProcessor:()=>Lm,SamProcessor:()=>Ro,SmolVLMProcessor:()=>Bc,SpeechT5Processor:()=>Pm,UltravoxProcessor:()=>zm,VLChatProcessor:()=>ym,VoxtralProcessor:()=>Nm,VoxtralRealtimeProcessor:()=>Rm,Wav2Vec2Processor:()=>Dm,Wav2Vec2ProcessorWithLM:()=>Fm,WhisperProcessor:()=>Bm});var Ae=class extends rt{constructor(e){super(),this.config=e}static async from_pretrained(e,r={}){let s=await ft(e,To,!0,r);return new this(s)}};function Fe(t,e){if(!(t instanceof Float32Array||t instanceof Float64Array))throw new Error(`${e} expects input to be a Float32Array or a Float64Array, but got ${t?.constructor?.name??typeof t} instead. If using the feature extractor directly, remember to use \`read_audio(url, sampling_rate)\` to obtain the raw audio data of the file/url.`)}var Po={};Ys(Po,{ASTFeatureExtractor:()=>u_,ChatterboxFeatureExtractor:()=>p_,ClapFeatureExtractor:()=>d_,DacFeatureExtractor:()=>Co,EncodecFeatureExtractor:()=>Io,FeatureExtractor:()=>Ae,Gemma3nAudioFeatureExtractor:()=>f_,GraniteSpeechFeatureExtractor:()=>__,MoonshineFeatureExtractor:()=>m_,ParakeetFeatureExtractor:()=>h_,PyAnnoteFeatureExtractor:()=>Lo,SeamlessM4TFeatureExtractor:()=>g_,SnacFeatureExtractor:()=>w_,SpeechT5FeatureExtractor:()=>x_,VoxtralRealtimeFeatureExtractor:()=>v_,Wav2Vec2FeatureExtractor:()=>y_,WeSpeakerFeatureExtractor:()=>b_,WhisperFeatureExtractor:()=>k_});import BP from"fs";import{Readable as UP}from"stream";import{pipeline as jP}from"stream/promises";async function xc(t,e){if(ie.IS_BROWSER_ENV){if(ie.IS_WEBWORKER_ENV)throw new Error("Unable to save a file from a Web Worker.");let r=URL.createObjectURL(e),s=document.createElement("a");s.href=r,s.download=t,s.click(),s.remove(),URL.revokeObjectURL(r)}else if(ie.IS_FS_AVAILABLE){let r=e.stream(),s=UP.fromWeb(r),n=BP.createWriteStream(t);await jP(s,n)}else throw new Error("Unable to save because filesystem is disabled in this environment.")}async function c_(t,e){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.");let r=await(await Lr(t)).arrayBuffer(),s=new AudioContext({sampleRate:e});typeof e>"u"&&Z.warn(`No sampling rate provided, using default of ${s.sampleRate}Hz.`);let n=await s.decodeAudioData(r),o;if(n.numberOfChannels===2){let a=Math.sqrt(2),i=n.getChannelData(0),l=n.getChannelData(1);o=new Float32Array(i.length);for(let c=0;c<n.length;++c)o[c]=a*(i[c]+l[c])/2}else o=n.getChannelData(0);return o}function o2(t,e){if(t<1)return new Float64Array;if(t===1)return new Float64Array([1]);let r=1-e,s=2*Math.PI/(t-1),n=new Float64Array(t);for(let o=0;o<t;++o)n[o]=e-r*Math.cos(o*s);return n}function s2(t){return o2(t,.5)}function GP(t){return o2(t,.54)}var qP={htk:t=>2595*Math.log10(1+t/700),kaldi:t=>1127*Math.log(1+t/700),slaney:(t,e=1e3,r=15,s=27/Math.log(6.4))=>t>=e?r+Math.log(t/e)*s:3*t/200};function l_(t,e="htk"){let r=qP[e];if(!r)throw new Error('mel_scale should be one of "htk", "slaney" or "kaldi".');return typeof t=="number"?r(t):t.map(s=>r(s))}var WP={htk:t=>700*(10**(t/2595)-1),kaldi:t=>700*(Math.exp(t/1127)-1),slaney:(t,e=1e3,r=15,s=Math.log(6.4)/27)=>t>=r?e*Math.exp(s*(t-r)):200*t/3};function VP(t,e="htk"){let r=WP[e];if(!r)throw new Error('mel_scale should be one of "htk", "slaney" or "kaldi".');return typeof t=="number"?r(t):t.map(s=>r(s))}function HP(t,e){let r=Float64Array.from({length:e.length-1},(a,i)=>e[i+1]-e[i]),s=Array.from({length:t.length},()=>new Array(e.length));for(let a=0;a<t.length;++a){let i=s[a];for(let l=0;l<e.length;++l)i[l]=e[l]-t[a]}let n=e.length-2,o=Array.from({length:n},()=>new Array(t.length));for(let a=0;a<t.length;++a){let i=s[a];for(let l=0;l<n;++l){let c=-i[l]/r[l],p=i[l+2]/r[l+1];o[l][a]=Math.max(0,Math.min(c,p))}}return o}function n2(t,e,r){let s=(e-t)/(r-1);return Float64Array.from({length:r},(n,o)=>t+s*o)}function ct(t,e,r,s,n,o=null,a="htk",i=!1){if(o!==null&&o!=="slaney")throw new Error('norm must be one of null or "slaney"');if(t<2)throw new Error(`Require num_frequency_bins: ${t} >= 2`);if(r>s)throw new Error(`Require min_frequency: ${r} <= max_frequency: ${s}`);let l=l_(r,a),c=l_(s,a),p=n2(l,c,e+2),f=VP(p,a),_;if(i){let w=n/((t-1)*2);_=l_(Float64Array.from({length:t},(x,k)=>k*w),a),f=p}else _=n2(0,Math.floor(n/2),t);let m=HP(_,f);if(o!==null&&o==="slaney")for(let w=0;w<e;++w){let x=m[w],k=2/(f[w+2]-f[w]);for(let E=0;E<t;++E)x[E]*=k}return m}function XP(t,e,r){let s=new t.constructor(t.length+e+r),n=t.length-1;for(let o=0;o<t.length;++o)s[e+o]=t[o];for(let o=1;o<=e;++o)s[e-o]=t[en(o,n)];for(let o=1;o<=r;++o)s[n+e+o]=t[en(n-o,n)];return s}function a2(t,e,r,s,n){if(r<=0)throw new Error("reference must be greater than zero");if(s<=0)throw new Error("min_value must be greater than zero");r=Math.max(s,r);let o=Math.log10(r);for(let a=0;a<t.length;++a)t[a]=e*Math.log10(Math.max(s,t[a])-o);if(n!==null){if(n<=0)throw new Error("db_range must be greater than zero");let a=Ce(t)[0]-n;for(let i=0;i<t.length;++i)t[i]=Math.max(t[i],a)}return t}function KP(t,e=1,r=1e-5,s=null){return a2(t,20,e,r,s)}function QP(t,e=1,r=1e-10,s=null){return a2(t,10,e,r,s)}async function mt(t,e,r,s,{fft_length:n=null,power:o=1,center:a=!0,pad_mode:i="reflect",onesided:l=!0,preemphasis:c=null,preemphasis_htk_flavor:p=!0,mel_filters:f=null,mel_floor:_=1e-10,log_mel:m=null,max_log_mel:w=null,reference:x=1,min_value:k=1e-10,db_range:E=null,remove_dc_offset:A=null,min_num_frames:T=null,max_num_frames:S=null,do_pad:P=!0,transpose:O=!1,mel_offset:v=0}={}){let j=e.length;if(n===null&&(n=r),r>n)throw Error(`frame_length (${r}) may not be larger than fft_length (${n})`);if(j!==r)throw new Error(`Length of the window (${j}) must equal frame_length (${r})`);if(s<=0)throw new Error("hop_length must be greater than zero");if(o===null&&f!==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(!p)throw new Error("`preemphasis_htk_flavor=false` is not currently supported.");if(a)switch(i){case"reflect":{let R=Math.floor((n-1)/2)+1;t=XP(t,R,R);break}case"constant":{let R=Math.floor(n/2),J=new t.constructor(t.length+2*R);J.set(t,R),t=J;break}default:throw new Error(`pad_mode="${i}" not implemented yet.`)}let H=Math.floor(1+Math.floor((t.length-r)/s));T!==null&&H<T&&(H=T);let B=l?Math.floor(n/2)+1:n,V=H,q=H;S!==null&&(S>H?P&&(q=S):q=V=S);let Q=new Yl(n),F=new Float64Array(n),C=new Float64Array(Q.outputBufferSize),te=new Float32Array(B*q);for(let R=0;R<V;++R){let J=R*s,Ie=Math.min(t.length-J,r);Ie!==r&&F.fill(0,0,r);for(let ae=0;ae<Ie;++ae)F[ae]=t[J+ae];if(A){let ae=0;for(let Je=0;Je<Ie;++Je)ae+=F[Je];let Ue=ae/Ie;for(let Je=0;Je<Ie;++Je)F[Je]-=Ue}if(c!==null){for(let ae=Ie-1;ae>=1;--ae)F[ae]-=c*F[ae-1];F[0]*=1-c}for(let ae=0;ae<e.length;++ae)F[ae]*=e[ae];Q.realTransform(C,F);for(let ae=0;ae<B;++ae){let Ue=ae<<1;te[ae*q+R]=C[Ue]**2+C[Ue+1]**2}}if(o!==null&&o!==2){let R=o/2;for(let J=0;J<te.length;++J)te[J]**=R}let le=f.length,L=await XA(new $("float32",f.flat(),[le,B]),new $("float32",te,[B,q]));O&&(L=L.transpose(1,0));let z=L.data;for(let R=0;R<z.length;++R)z[R]=v+Math.max(_,z[R]);if(o!==null&&m!==null){let R=Math.min(z.length,V*le);switch(m){case"log":for(let J=0;J<R;++J)z[J]=Math.log(z[J]);break;case"log10":for(let J=0;J<R;++J)z[J]=Math.log10(z[J]);break;case"log10_max_norm":{for(let ae=0;ae<R;++ae)z[ae]=Math.log10(z[ae]);let Ie=(w??Ce(z)[0])-8;for(let ae=0;ae<R;++ae)z[ae]=(Math.max(z[ae],Ie)+4)/4;break}case"dB":if(o===1)KP(z,x,k,E);else if(o===2)QP(z,x,k,E);else throw new Error(`Cannot use log_mel option '${m}' with power ${o}`);break;default:throw new Error(`log_mel must be one of null, 'log', 'log10', 'log10_max_norm', or 'dB'. Got '${m}'`)}}return L}function ht(t,e,{periodic:r=!0,frame_length:s=null,center:n=!0}={}){let o=r?t+1:t,a;switch(e){case"boxcar":a=new Float64Array(o).fill(1);break;case"hann":case"hann_window":a=s2(o);break;case"hamming":a=GP(o);break;case"povey":a=s2(o).map(i=>Math.pow(i,.85));break;default:throw new Error(`Unknown window type ${e}.`)}if(r&&(a=a.subarray(0,t)),s===null)return a;if(t>s)throw new Error(`Length of the window (${t}) may not be larger than frame_length (${s})`);return a}function YP(t,e){let r=t.reduce((o,a)=>o+a.length,0),s=new ArrayBuffer(44),n=new DataView(s);return yc(n,0,"RIFF"),n.setUint32(4,36+r*4,!0),yc(n,8,"WAVE"),yc(n,12,"fmt "),n.setUint32(16,16,!0),n.setUint16(20,3,!0),n.setUint16(22,1,!0),n.setUint32(24,e,!0),n.setUint32(28,e*4,!0),n.setUint16(32,4,!0),n.setUint16(34,32,!0),yc(n,36,"data"),n.setUint32(40,r*4,!0),new Blob([s,...t.map(o=>o.buffer)],{type:"audio/wav"})}function yc(t,e,r){for(let s=0;s<r.length;++s)t.setUint8(e+s,r.charCodeAt(s))}var Oo=class{constructor(e,r){this.audio=e,this.sampling_rate=r}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];let e=this.audio.reduce((n,o)=>n+o.length,0),r=new Float32Array(e),s=0;for(let n of this.audio)r.set(n,s),s+=n.length;return r}else return this.audio}toBlob(){let e=this.audio;return e instanceof Float32Array&&(e=[e]),YP(e,this.sampling_rate)}async save(e){return xc(e,this.toBlob())}};var u_=class extends Ae{constructor(e){super(e);let r=this.config.sampling_rate,s=ct(257,this.config.num_mel_bins,20,Math.floor(r/2),r,null,"kaldi",!0);this.mel_filters=s,this.window=ht(400,"hann",{periodic:!1}),this.mean=this.config.mean,this.std=this.config.std}async _extract_fbank_features(e,r){return mt(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:r,transpose:!0})}async _call(e){Fe(e,"ASTFeatureExtractor");let r=await this._extract_fbank_features(e,this.config.max_length);if(this.config.do_normalize){let s=this.std*2,n=r.data;for(let o=0;o<n.length;++o)n[o]=(n[o]-this.mean)/s}return{input_values:r.unsqueeze_(0)}}};var Io=class extends Ae{async _call(e){Fe(e,"EncodecFeatureExtractor"),e instanceof Float64Array&&(e=new Float32Array(e));let r=this.config.feature_size;if(e.length%r!==0)throw new Error(`The length of the audio data must be a multiple of the number of channels (${r}).`);let s=[1,r,e.length/r];return{input_values:new $("float32",e,s)}}};var p_=class extends Ae{async _call(e){Fe(e,"ChatterboxFeatureExtractor"),e instanceof Float64Array&&(e=new Float32Array(e));let r=[1,e.length];return{input_values:new $("float32",e,r)}}};var d_=class extends Ae{constructor(e){super(e),this.mel_filters=ct(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=ct(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=ht(this.config.fft_window_size,"hann")}async _get_input_mel(e,r,s,n){let o,a=!1,i=e.length-r;if(i>0)if(s==="rand_trunc"){a=!0;let l=Math.floor(_s.random()*(i+1));e=e.subarray(l,l+r),o=await this._extract_fbank_features(e,this.mel_filters_slaney,this.config.nb_max_samples)}else throw new Error(`Truncation strategy "${s}" not implemented`);else{if(i<0){let l=new Float64Array(r);if(l.set(e),n==="repeat")for(let c=e.length;c<r;c+=e.length)l.set(e.subarray(0,Math.min(e.length,r-c)),c);else if(n==="repeatpad")for(let c=e.length;c<-i;c+=e.length)l.set(e,c);e=l}if(s==="fusion")throw new Error(`Truncation strategy "${s}" not implemented`);o=await this._extract_fbank_features(e,this.mel_filters_slaney,this.config.nb_max_samples)}return o.unsqueeze_(0)}async _extract_fbank_features(e,r,s=null){return mt(e,this.window,this.config.fft_window_size,this.config.hop_length,{power:2,mel_filters:r,log_mel:"dB",max_num_frames:s,do_pad:!1,transpose:!0})}async _call(e,{max_length:r=null}={}){return Fe(e,"ClapFeatureExtractor"),{input_features:(await this._get_input_mel(e,r??this.config.nb_max_samples,this.config.truncation,this.config.padding)).unsqueeze_(0)}}};var Co=class extends Io{};var f_=class extends Ae{constructor(e){super(e);let{fft_length:r,feature_size:s,min_frequency:n,max_frequency:o,sampling_rate:a,frame_length:i}=this.config,l=ct(Math.floor(1+r/2),s,n,o,a,null,"htk",!1);this.mel_filters=l,this.window=ht(i,"hann")}async _extract_fbank_features(e,r){return mt(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:r=48e4,truncation:s=!0,padding:n=!0,pad_to_multiple_of:o=128}={}){if(Fe(e,"Gemma3nAudioFeatureExtractor"),s&&e.length>r&&(e=e.slice(0,r)),n&&e.length%o!==0){let l=o-e.length%o,c=new Float64Array(e.length+l);c.set(e),this.config.padding_value!==0&&c.fill(this.config.padding_value,e.length),e=c}let a=await this._extract_fbank_features(e,this.config.max_length),i=Xe([1,a.dims[0]],!0);return{input_features:a.unsqueeze_(0),input_features_mask:i}}};var __=class extends Ae{constructor(e){super(e);let{n_fft:r,win_length:s,n_mels:n,sample_rate:o}=e.melspec_kwargs;this.mel_filters=ct(Math.floor(1+r/2),n,0,o/2,o,null,"htk");let a=ht(s,"hann");this.window=new Float64Array(r);let i=Math.floor((r-s)/2);this.window.set(a,i)}async _call(e){Fe(e,"GraniteSpeechFeatureExtractor");let{n_fft:r,hop_length:s,n_mels:n}=this.config.melspec_kwargs,o=1+Math.floor((e.length-1)/s),a=o-o%2;return{input_features:(await mt(e,this.window,r,s,{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)}}};var m_=class extends Ae{async _call(e){Fe(e,"MoonshineFeatureExtractor"),e instanceof Float64Array&&(e=new Float32Array(e));let r=[1,e.length];return{input_values:new $("float32",e,r)}}};var JP=1e-5,h_=class extends Ae{constructor(e){super(e),this.config.mel_filters??=ct(Math.floor(1+this.config.n_fft/2),this.config.feature_size,0,this.config.sampling_rate/2,this.config.sampling_rate,"slaney","slaney");let r=ht(this.config.win_length,"hann",{periodic:!1});this.window=new Float64Array(this.config.n_fft);let s=Math.floor((this.config.n_fft-this.config.win_length)/2);this.window.set(r,s)}async _extract_fbank_features(e){let r=this.config.preemphasis;e=new Float64Array(e);for(let n=e.length-1;n>=1;--n)e[n]-=r*e[n-1];return await mt(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){Fe(e,"ParakeetFeatureExtractor");let r=await this._extract_fbank_features(e),s=Math.floor((e.length+Math.floor(this.config.n_fft/2)*2-this.config.n_fft)/this.config.hop_length),n=r.data;n.fill(0,s*r.dims[1]);let[o,a]=r.dims,i=new Float64Array(a),l=new Float64Array(a);for(let f=0;f<s;++f){let _=f*a;for(let m=0;m<a;++m){let w=n[_+m];i[m]+=w,l[m]+=w*w}}let c=s>1?s-1:1;for(let f=0;f<a;++f){let _=i[f]/s,m=(l[f]-s*_*_)/c,x=1/(Math.sqrt(m)+JP);for(let k=0;k<s;++k){let E=k*a+f;n[E]=(n[E]-_)*x}}let p=new BigInt64Array(o);return p.fill(1n,0,s),{input_features:r.unsqueeze_(0),attention_mask:new $("int64",p,[1,o])}}};var Lo=class extends Ae{async _call(e){Fe(e,"PyAnnoteFeatureExtractor"),e instanceof Float64Array&&(e=new Float32Array(e));let r=[1,1,e.length];return{input_values:new $("float32",e,r)}}samples_to_frames(e){return(e-this.config.offset)/this.config.step}post_process_speaker_diarization(e,r){let s=r/this.samples_to_frames(r)/this.config.sampling_rate,n=[];for(let o of e.tolist()){let a=[],i=-1;for(let l=0;l<o.length;++l){let c=$e(o[l]),[p,f]=Ce(c),[_,m]=[l,l+1];f!==i?(i=f,a.push({id:f,start:_,end:m,score:p})):(a.at(-1).end=m,a.at(-1).score+=p)}n.push(a.map(({id:l,start:c,end:p,score:f})=>({id:l,start:c*s,end:p*s,confidence:f/(p-c)})))}return n}};var g_=class extends Ae{constructor(e){super(e);let r=this.config.sampling_rate,s=ct(257,this.config.num_mel_bins,20,Math.floor(r/2),r,null,"kaldi",!0);this.mel_filters=s,this.window=ht(400,"povey",{periodic:!1})}async _extract_fbank_features(e,r){return e=e.map(s=>s*32768),mt(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:r,transpose:!0})}async _call(e,{padding:r=!0,pad_to_multiple_of:s=2,do_normalize_per_mel_bins:n=!0,return_attention_mask:o=!0}={}){Fe(e,"SeamlessM4TFeatureExtractor");let a=await this._extract_fbank_features(e,this.config.max_length);if(n){let[w,x]=a.dims,k=a.data;for(let E=0;E<x;++E){let A=0;for(let O=0;O<w;++O)A+=k[O*x+E];let T=A/w,S=0;for(let O=0;O<w;++O)S+=(k[O*x+E]-T)**2;S/=w-1;let P=Math.sqrt(S+1e-7);for(let O=0;O<w;++O){let v=O*x+E;k[v]=(k[v]-T)/P}}}let i;if(r){let[w,x]=a.dims,k=a.data,E=w%s;if(E>0){let A=new Float32Array(x*(w+E));A.set(k),A.fill(this.config.padding_value,k.length);let T=w+E;a=new $(a.type,A,[T,x]),o&&(i=new $("int64",new BigInt64Array(T),[1,T]),i.data.fill(1n,0,w))}}let[l,c]=a.dims,p=this.config.stride;if(l%p!==0)throw new Error(`The number of frames (${l}) must be a multiple of the stride (${p}).`);let _=a.view(1,Math.floor(l/p),c*p),m={input_features:_};if(o){let w=_.dims[1],x=new BigInt64Array(w);if(i){let k=i.data;for(let E=1,A=0;E<l;E+=p,++A)x[A]=k[E]}else x.fill(1n);m.attention_mask=new $("int64",x,[1,w])}return m}};var w_=class extends Co{};var x_=class extends Ae{};var y_=class extends Ae{_zero_mean_unit_var_norm(e){let s=e.reduce((o,a)=>o+a,0)/e.length,n=e.reduce((o,a)=>o+(a-s)**2,0)/e.length;return e.map(o=>(o-s)/Math.sqrt(n+1e-7))}async _call(e){Fe(e,"Wav2Vec2FeatureExtractor"),e instanceof Float64Array&&(e=new Float32Array(e));let r=e;this.config.do_normalize&&(r=this._zero_mean_unit_var_norm(r));let s=[1,r.length];return{input_values:new $("float32",r,s),attention_mask:new $("int64",new BigInt64Array(r.length).fill(1n),s)}}};var b_=class extends Ae{constructor(e){super(e);let r=this.config.sampling_rate,s=ct(257,this.config.num_mel_bins,20,Math.floor(r/2),r,null,"kaldi",!0);this.mel_filters=s,this.window=ht(400,"hamming",{periodic:!1}),this.min_num_frames=this.config.min_num_frames}async _extract_fbank_features(e){return e=e.map(r=>r*32768),mt(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){Fe(e,"WeSpeakerFeatureExtractor");let r=(await this._extract_fbank_features(e)).unsqueeze_(0);if(this.config.fbank_centering_span===null){let s=r.mean(1).data,n=r.data,[o,a,i]=r.dims;for(let l=0;l<o;++l){let c=l*a*i,p=l*i;for(let f=0;f<a;++f){let _=c+f*i;for(let m=0;m<i;++m)n[_+m]-=s[p+m]}}}return{input_features:r}}};var v_=class extends Ae{constructor(e){super(e),this.config.mel_filters??=ct(Math.floor(1+this.config.n_fft/2),this.config.feature_size,0,8e3,this.config.sampling_rate,"slaney","slaney"),this.window=ht(this.config.n_fft,"hann")}async _extract_fbank_features(e,{center:r=!0}={}){let{n_fft:s,hop_length:n,mel_filters:o,global_log_mel_max:a}=this.config,i=Math.floor(r?e.length/n:(e.length-s)/n);return await mt(e,this.window,s,n,{power:2,mel_filters:o,log_mel:"log10_max_norm",max_log_mel:a,center:r,max_num_frames:i,do_pad:!1})}async _call(e,{center:r=!0}={}){return Fe(e,"VoxtralRealtimeFeatureExtractor"),{input_features:(await this._extract_fbank_features(e,{center:r})).unsqueeze_(0)}}};var k_=class extends Ae{constructor(e){super(e),this.config.mel_filters??=ct(Math.floor(1+this.config.n_fft/2),this.config.feature_size,0,8e3,this.config.sampling_rate,"slaney","slaney"),this.window=ht(this.config.n_fft,"hann")}async _extract_fbank_features(e){return await mt(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:r=null}={}){Fe(e,"WhisperFeatureExtractor");let s,n=r??this.config.n_samples;return e.length>n?(e.length>this.config.n_samples&&Z.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`."),s=e.slice(0,n)):(s=new Float32Array(n),s.set(e)),{input_features:(await this._extract_fbank_features(s)).unsqueeze_(0)}}};var Ke=class{static async from_pretrained(e,r={}){let s=await ft(e,To,!0,r),n=s.feature_extractor_type,o=Po[n];if(!o)throw new Error(`Unknown feature_extractor_type: '${n}'. Please report this at ${jr}.`);return new o(s)}};var E_=class extends re{static tokenizer_class=oe;static feature_extractor_class=Ke;async _call(e,r=null){let s=this.tokenizer(e),n=r?await this.feature_extractor(r):{};return{...s,...n}}};import A_ from"sharp";var Ms,i2,Gr;if(ie.IS_WEB_ENV)Ms=(t,e)=>{if(!self.OffscreenCanvas)throw new Error("OffscreenCanvas not supported by this environment.");return new self.OffscreenCanvas(t,e)},Gr=self.createImageBitmap,i2=self.ImageData;else if(A_)Gr=async t=>{let r=(await t.metadata()).channels,{data:s,info:n}=await t.rotate().raw().toBuffer({resolveWithObject:!0}),o=new Ye(new Uint8ClampedArray(s),n.width,n.height,n.channels);return r!==void 0&&r!==n.channels&&o.convert(r),o};else throw new Error("Unable to load image processing library.");var ZP={0:"nearest",1:"lanczos",2:"bilinear",3:"bicubic",4:"box",5:"hamming"},ez=new Map([["png","image/png"],["jpg","image/jpeg"],["jpeg","image/jpeg"],["gif","image/gif"]]),Ye=class t{constructor(e,r,s,n){this.data=e,this.width=r,this.height=s,this.channels=n}get size(){return[this.width,this.height]}static async read(e){if(e instanceof t)return e;if(typeof e=="string"||e instanceof URL)return await this.fromURL(e);if(e instanceof Blob)return await this.fromBlob(e);if(typeof HTMLCanvasElement<"u"&&e instanceof HTMLCanvasElement||typeof OffscreenCanvas<"u"&&e instanceof OffscreenCanvas)return this.fromCanvas(e);throw new Error(`Unsupported input type: ${typeof e}`)}static fromCanvas(e){if(!ie.IS_WEB_ENV)throw new Error("fromCanvas() is only supported in browser environments.");let s=e.getContext("2d").getImageData(0,0,e.width,e.height).data;return new t(s,e.width,e.height,4)}static async fromURL(e){let r=await Lr(e);if(r.status!==200)throw new Error(`Unable to read image from "${e}" (${r.status} ${r.statusText})`);let s=await r.blob();return this.fromBlob(s)}static async fromBlob(e){if(ie.IS_WEB_ENV){let r=await Gr(e),s=Ms(r.width,r.height).getContext("2d");return s.drawImage(r,0,0),new this(s.getImageData(0,0,r.width,r.height).data,r.width,r.height,4)}else{let r=A_(await e.arrayBuffer());return await Gr(r)}}static fromTensor(e,r="CHW"){if(e.dims.length!==3)throw new Error(`Tensor should have 3 dimensions, but has ${e.dims.length} dimensions.`);if(r==="CHW")e=e.transpose(1,2,0);else if(r!=="HWC")throw new Error(`Unsupported channel format: ${r}`);if(!(e.data instanceof Uint8ClampedArray||e.data instanceof Uint8Array))throw new Error(`Unsupported tensor type: ${e.type}`);switch(e.dims[2]){case 1:case 2:case 3:case 4:return new t(e.data,e.dims[1],e.dims[0],e.dims[2]);default:throw new Error(`Unsupported number of channels: ${e.dims[2]}`)}}grayscale(){if(this.channels===1)return this;let e=new Uint8ClampedArray(this.width*this.height*1);switch(this.channels){case 3:case 4:for(let r=0,s=0;r<this.data.length;r+=this.channels){let n=this.data[r],o=this.data[r+1],a=this.data[r+2];e[s++]=Math.round(.2989*n+.587*o+.114*a)}break;default:throw new Error(`Conversion failed due to unsupported number of channels: ${this.channels}`)}return this._update(e,this.width,this.height,1)}rgb(){if(this.channels===3)return this;let e=new Uint8ClampedArray(this.width*this.height*3);switch(this.channels){case 1:for(let r=0,s=0;r<this.data.length;++r)e[s++]=this.data[r],e[s++]=this.data[r],e[s++]=this.data[r];break;case 4:for(let r=0,s=0;r<this.data.length;r+=4)e[s++]=this.data[r],e[s++]=this.data[r+1],e[s++]=this.data[r+2];break;default:throw new Error(`Conversion failed due to unsupported number of channels: ${this.channels}`)}return this._update(e,this.width,this.height,3)}rgba(){if(this.channels===4)return this;let e=new Uint8ClampedArray(this.width*this.height*4);switch(this.channels){case 1:for(let r=0,s=0;r<this.data.length;++r)e[s++]=this.data[r],e[s++]=this.data[r],e[s++]=this.data[r],e[s++]=255;break;case 3:for(let r=0,s=0;r<this.data.length;r+=3)e[s++]=this.data[r],e[s++]=this.data[r+1],e[s++]=this.data[r+2],e[s++]=255;break;default:throw new Error(`Conversion failed due to unsupported number of channels: ${this.channels}`)}return this._update(e,this.width,this.height,4)}putAlpha(e){if(e.width!==this.width||e.height!==this.height)throw new Error(`Expected mask size to be ${this.width}x${this.height}, but got ${e.width}x${e.height}`);if(e.channels!==1)throw new Error(`Expected mask to have 1 channel, but got ${e.channels}`);let r=this.data,s=e.data,n=this.width*this.height;if(this.channels===3){let o=new Uint8ClampedArray(n*4);for(let a=0,i=0,l=0;a<n;++a)o[l++]=r[i++],o[l++]=r[i++],o[l++]=r[i++],o[l++]=s[a];return this._update(o,this.width,this.height,4)}else if(this.channels===4){for(let o=0;o<n;++o)r[4*o+3]=s[o];return this}throw new Error(`Expected image to have 3 or 4 channels, but got ${this.channels}`)}async resize(e,r,{resample:s=2}={}){if(this.width===e&&this.height===r)return this;let n=ZP[s]??s,o=sd(e),a=sd(r);if(o&&a)return this;if(o?e=r/this.height*this.width:a&&(r=e/this.width*this.height),ie.IS_WEB_ENV){let i=this.channels,l=this.toCanvas(),c=Ms(e,r).getContext("2d");return c.drawImage(l,0,0,e,r),new t(c.getImageData(0,0,e,r).data,e,r,4).convert(i)}else{let i=this.toSharp();switch(n){case"box":case"hamming":(n==="box"||n==="hamming")&&(Z.warn(`Resampling method ${n} is not yet supported. Using bilinear instead.`),n="bilinear");case"nearest":case"bilinear":case"bicubic":i=i.affine([e/this.width,0,0,r/this.height],{interpolator:n});break;case"lanczos":i=i.resize({width:e,height:r,fit:"fill",kernel:"lanczos3"});break;default:throw new Error(`Resampling method ${n} is not supported.`)}return await Gr(i)}}async pad([e,r,s,n]){if(e=Math.max(e,0),r=Math.max(r,0),s=Math.max(s,0),n=Math.max(n,0),e===0&&r===0&&s===0&&n===0)return this;if(ie.IS_WEB_ENV){let o=this.channels,a=this.toCanvas(),i=this.width+e+r,l=this.height+s+n,c=Ms(i,l).getContext("2d");return c.drawImage(a,0,0,this.width,this.height,e,s,this.width,this.height),new t(c.getImageData(0,0,i,l).data,i,l,4).convert(o)}else{let o=this.toSharp().extend({left:e,right:r,top:s,bottom:n});return await Gr(o)}}async crop([e,r,s,n]){if(e=Math.max(e,0),r=Math.max(r,0),s=Math.min(s,this.width-1),n=Math.min(n,this.height-1),e===0&&r===0&&s===this.width-1&&n===this.height-1)return this;let o=s-e+1,a=n-r+1;if(ie.IS_WEB_ENV){let i=this.channels,l=this.toCanvas(),c=Ms(o,a).getContext("2d");return c.drawImage(l,e,r,o,a,0,0,o,a),new t(c.getImageData(0,0,o,a).data,o,a,4).convert(i)}else{let i=this.toSharp().extract({left:e,top:r,width:o,height:a});return await Gr(i)}}async center_crop(e,r){if(this.width===e&&this.height===r)return this;let s=(this.width-e)/2,n=(this.height-r)/2;if(ie.IS_WEB_ENV){let o=this.channels,a=this.toCanvas(),i=Ms(e,r).getContext("2d"),l=0,c=0,p=0,f=0;return s>=0?l=s:p=-s,n>=0?c=n:f=-n,i.drawImage(a,l,c,e,r,p,f,e,r),new t(i.getImageData(0,0,e,r).data,e,r,4).convert(o)}else{let o=this.toSharp();if(s>=0&&n>=0)o=o.extract({left:Math.floor(s),top:Math.floor(n),width:e,height:r});else if(s<=0&&n<=0){let a=Math.floor(-n),i=Math.floor(-s);o=o.extend({top:a,left:i,right:e-this.width-i,bottom:r-this.height-a})}else{let a=[0,0],i=0;n<0?(a[0]=Math.floor(-n),a[1]=r-this.height-a[0]):i=Math.floor(n);let l=[0,0],c=0;s<0?(l[0]=Math.floor(-s),l[1]=e-this.width-l[0]):c=Math.floor(s),o=o.extend({top:a[0],bottom:a[1],left:l[0],right:l[1]}).extract({left:c,top:i,width:e,height:r})}return await Gr(o)}}async toBlob(e="image/png",r=1){if(!ie.IS_WEB_ENV)throw new Error("toBlob() is only supported in browser environments.");return await this.toCanvas().convertToBlob({type:e,quality:r})}toTensor(e="CHW"){let r=new $("uint8",new Uint8Array(this.data),[this.height,this.width,this.channels]);if(e!=="HWC")if(e==="CHW")r=r.permute(2,0,1);else throw new Error(`Unsupported channel format: ${e}`);return r}toCanvas(){if(!ie.IS_WEB_ENV)throw new Error("toCanvas() is only supported in browser environments.");let e=this.clone().rgba(),r=Ms(e.width,e.height),s=new i2(e.data,e.width,e.height);return r.getContext("2d").putImageData(s,0,0),r}split(){let{data:e,width:r,height:s,channels:n}=this,o=e.constructor,a=e.length/n,i=Array.from({length:n},()=>new o(a));for(let l=0;l<a;++l){let c=n*l;for(let p=0;p<n;++p)i[p][l]=e[c+p]}return i.map(l=>new t(l,r,s,1))}_update(e,r,s,n=null){return this.data=e,this.width=r,this.height=s,n!==null&&(this.channels=n),this}clone(){return new t(this.data.slice(),this.width,this.height,this.channels)}convert(e){if(this.channels===e)return this;switch(e){case 1:this.grayscale();break;case 3:this.rgb();break;case 4:this.rgba();break;default:throw new Error(`Conversion failed due to unsupported number of channels: ${this.channels}`)}return this}async save(e){if(ie.IS_WEB_ENV){if(ie.IS_WEBWORKER_ENV)throw new Error("Unable to save an image from a Web Worker.");let r=e.split(".").pop().toLowerCase(),s=ez.get(r)??"image/png",n=await this.toBlob(s);return xc(e,n)}else if(ie.IS_FS_AVAILABLE)await this.toSharp().toFile(e);else throw new Error("Unable to save the image because filesystem is disabled in this environment.")}toSharp(){if(ie.IS_WEB_ENV)throw new Error("toSharp() is only supported in server-side environments.");return A_(this.data,{raw:{width:this.width,height:this.height,channels:this.channels}})}},tz=Ye.read.bind(Ye);function l2(t,e,r=0,s=null){let n=t/e,o=uE(n)*e;return s!==null&&o>s&&(o=Math.floor(n)*e),o<r&&(o=Math.ceil(n)*e),o}function M_([t,e],r){return[Math.max(Math.floor(t/r),1)*r,Math.max(Math.floor(e/r),1)*r]}function S_([t,e,r,s]){return[t-r/2,e-s/2,t+r/2,e+s/2]}function qr(t,e=.5,r=null,s=!1){let n=t.logits,o=t.pred_boxes,[a,i,l]=n.dims;if(r!==null&&r.length!==a)throw Error("Make sure that you pass in as many target sizes as the batch dimension of the logits");let c=[];for(let p=0;p<a;++p){let f=r!==null?r[p]:null,_={boxes:[],classes:[],scores:[]},m=n[p],w=o[p];for(let x=0;x<i;++x){let k=m[x],E=[],A;if(s){A=k.sigmoid().data;for(let T=0;T<A.length;++T)A[T]>e&&E.push(T)}else{let T=Ce(k.data)[1];if(T===l-1||(A=$e(k.data),A[T]<e))continue;E.push(T)}for(let T of E){let S=w[x].data;S=S_(S),f!==null&&(S=S.map((P,O)=>P*f[(O+1)%2])),_.boxes.push(S),_.classes.push(T),_.scores.push(A[T])}}c.push(_)}return c}function bc(t,e=null){let r=t.logits,s=r.dims[0];if(e!==null&&e.length!==s)throw Error("Make sure that you pass in as many target sizes as the batch dimension of the logits");let n=[];for(let o=0;o<s;++o){let a=e!==null?e[o]:null,i=r[o];a!==null&&(i=uf(i,a,"bilinear",!1));let[l,c]=a??i.dims.slice(-2),p=new $("int32",new Int32Array(l*c),[l,c]),f=i[0].data,_=p.data;for(let x=1;x<i.dims[0];++x){let k=i[x].data;for(let E=0;E<k.length;++E)k[E]>f[E]&&(f[E]=k[E],_[E]=x)}let m=new Array(i.dims[0]);for(let x=0;x<_.length;++x){let k=_[x];m[k]=k}let w=m.filter(x=>x!==void 0);n.push({segmentation:p,labels:w})}return n}function rz(t,e,r,s){let n=[],o=[],a=[];for(let i=0;i<t.dims[0];++i){let l=t[i],c=e[i],p=Ce(l.data)[1];if(p===s)continue;let _=$e(l.data)[p];_>r&&(n.push(c),o.push(_),a.push(p))}return[n,o,a]}function sz(t,e,r,s=.5,n=.8){let o=[],a=0,i=0,l=e[r].data;for(let p=0;p<t.length;++p)t[p]===r&&(o.push(p),++a),l[p]>=s&&++i;let c=a>0&&i>0;return c&&(c=a/i>n),[c,o]}function nz(t,e,r,s,n,o=null,a=null){let[i,l]=a??t[0].dims,c=new $("int32",new Int32Array(i*l),[i,l]),p=[];if(a!==null)for(let x=0;x<t.length;++x)t[x]=uf(t[x],a,"bilinear",!1);let f=new Int32Array(t[0].data.length),_=new Float32Array(t[0].data.length);for(let x=0;x<t.length;++x){let k=e[x],E=t[x].data;for(let A=0;A<E.length;++A)E[A]*=k,E[A]>_[A]&&(f[A]=x,_[A]=E[A])}let m=0,w=c.data;for(let x=0;x<r.length;++x){let k=r[x],[E,A]=sz(f,t,x,s,n);if(E){++m;for(let T of A)w[T]=m;p.push({id:m,label_id:k,score:e[x]})}}return[c,p]}function vc(t,e,r=28,s=3136,n=784*1280){if(t<r||e<r)throw new Error(`height:${t} or width:${e} must be larger than factor:${r}`);if(Math.max(t,e)/Math.min(t,e)>200)throw new Error(`absolute aspect ratio must be smaller than 200, got ${Math.max(t,e)/Math.min(t,e)}`);let o=Math.round(t/r)*r,a=Math.round(e/r)*r;if(o*a>n){let i=Math.sqrt(t*e/n);o=Math.floor(t/i/r)*r,a=Math.floor(e/i/r)*r}else if(o*a<s){let i=Math.sqrt(s/(t*e));o=Math.ceil(t*i/r)*r,a=Math.ceil(e*i/r)*r}return[o,a]}function kc(t,e=.5,r=.5,s=.8,n=null,o=null){n===null&&(Z.warn("`label_ids_to_fuse` unset. No instance will be fused."),n=new Set);let a=t.class_queries_logits??t.logits,l=(t.masks_queries_logits??t.pred_masks).sigmoid(),[c,p,f]=a.dims;if(f-=1,o!==null&&o.length!==c)throw Error("Make sure that you pass in as many target sizes as the batch dimension of the logits");let _=[];for(let m=0;m<c;++m){let w=o!==null?o[m]:null,x=a[m],k=l[m],[E,A,T]=rz(x,k,e,f);if(T.length===0){let[O,v]=w??k.dims.slice(-2),j=new $("int32",new Int32Array(O*v).fill(-1),[O,v]);_.push({segmentation:j,segments_info:[]});continue}let[S,P]=nz(E,A,T,r,s,n,w);_.push({segmentation:S,segments_info:P})}return _}function Ec(t,e=.5,r=null){throw new Error("`post_process_instance_segmentation` is not yet implemented.")}var X=class extends rt{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&&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,r,s=2){let n=e.height,o=e.width,a=r.height,i=r.width,l=Math.min(n,a),c=Math.min(o,i);return l===n&&c===o?e:(n>o?c=Math.floor(o*l/n):o>n&&(l=Math.floor(n*c/o)),await e.resize(c,l,{resample:s}))}async crop_margin(e,r=200){let s=e.clone().grayscale(),n=fo(s.data)[0],a=Ce(s.data)[0]-n;if(a===0)return e;let i=r/255,l=s.width,c=s.height,p=0,f=0,_=s.data;for(let m=0;m<s.height;++m){let w=m*s.width;for(let x=0;x<s.width;++x)(_[w+x]-n)/a<i&&(l=Math.min(l,x),c=Math.min(c,m),p=Math.max(p,x),f=Math.max(f,m))}return e=await e.crop([l,c,p,f]),e}pad_image(e,r,s,{mode:n="constant",center:o=!1,constant_values:a=0}={}){let[i,l,c]=r,p,f;if(typeof s=="number"?(p=s,f=s):s==="square"?p=f=Math.max(i,l):(p=s.width,f=s.height),p!==l||f!==i){let _=new Float32Array(p*f*c);if(Array.isArray(a))for(let x=0;x<_.length;++x)_[x]=a[x%c];else a!==0&&_.fill(a);let[m,w]=o?[Math.floor((p-l)/2),Math.floor((f-i)/2)]:[0,0];for(let x=0;x<i;++x){let k=(x+w)*p,E=x*l;for(let A=0;A<l;++A){let T=(k+A+m)*c,S=(E+A)*c;for(let P=0;P<c;++P)_[T+P]=e[S+P]}}if(n==="symmetric"){if(o)throw new Error("`center` padding is not supported when `mode` is set to `symmetric`.");let x=i-1,k=l-1;for(let E=0;E<f;++E){let A=E*p,T=en(E,x)*l;for(let S=0;S<p;++S){if(E<i&&S<l)continue;let P=(A+S)*c,O=(T+en(S,k))*c;for(let v=0;v<c;++v)_[P+v]=e[O+v]}}}e=_,r=[f,p,c]}return[e,r]}rescale(e){for(let r=0;r<e.length;++r)e[r]=this.rescale_factor*e[r]}get_resize_output_image_size(e,r){let[s,n]=e.size,o,a;if(this.do_thumbnail){let{height:i,width:l}=r;o=Math.min(i,l)}else Number.isInteger(r)?(o=r,a=this.config.max_size??o):r!==void 0&&(o=r.shortest_edge,a=r.longest_edge);if(o!==void 0||a!==void 0){let i=o===void 0?1:Math.max(o/s,o/n),l=s*i,c=n*i,p=a===void 0?1:Math.min(a/l,a/c),f=Math.floor(Number((l*p).toFixed(2))),_=Math.floor(Number((c*p).toFixed(2)));return this.size_divisibility!==void 0&&([f,_]=M_([f,_],this.size_divisibility)),[f,_]}else if(r!==void 0&&r.width!==void 0&&r.height!==void 0){let i=r.width,l=r.height;if(this.config.keep_aspect_ratio&&this.config.ensure_multiple_of){let c=l/n,p=i/s;Math.abs(1-p)<Math.abs(1-c)?c=p:p=c,l=l2(c*n,this.config.ensure_multiple_of),i=l2(p*s,this.config.ensure_multiple_of)}return[i,l]}else{if(this.size_divisibility!==void 0)return M_([s,n],this.size_divisibility);throw new Error(`Could not resize image due to unsupported \`this.size\` option in config: ${JSON.stringify(r)}`)}}async resize(e){let[r,s]=this.get_resize_output_image_size(e,this.size);return await e.resize(r,s,{resample:this.resample})}async preprocess(e,{do_normalize:r=null,do_pad:s=null,do_convert_rgb:n=null,do_convert_grayscale:o=null,do_flip_channel_order:a=null}={}){this.do_crop_margin&&(e=await this.crop_margin(e));let[i,l]=e.size;if(n??this.do_convert_rgb?e=e.rgb():o&&(e=e.grayscale()),this.do_resize&&(e=await this.resize(e)),this.do_thumbnail&&(e=await this.thumbnail(e,this.size,this.resample)),this.do_center_crop){let m,w;Number.isInteger(this.crop_size)?(m=this.crop_size,w=this.crop_size):(m=this.crop_size.width,w=this.crop_size.height),e=await e.center_crop(m,w)}let c=[e.height,e.width],p=Float32Array.from(e.data),f=[e.height,e.width,e.channels];if(this.do_rescale&&this.rescale(p),r??this.do_normalize){let m=this.image_mean;Array.isArray(this.image_mean)||(m=new Array(e.channels).fill(m));let w=this.image_std;if(Array.isArray(this.image_std)||(w=new Array(e.channels).fill(w)),m.length!==e.channels||w.length!==e.channels)throw new Error(`When set to arrays, the length of \`image_mean\` (${m.length}) and \`image_std\` (${w.length}) must match the number of channels in the image (${e.channels}).`);for(let x=0;x<p.length;x+=e.channels)for(let k=0;k<e.channels;++k)p[x+k]=(p[x+k]-m[k])/w[k]}if(s??this.do_pad){if(this.pad_size)[p,f]=this.pad_image(p,[e.height,e.width,e.channels],this.pad_size);else if(this.size_divisibility){let[m,w]=M_([f[1],f[0]],this.size_divisibility);[p,f]=this.pad_image(p,f,{width:m,height:w})}}if(a??this.do_flip_channel_order){if(f[2]!==3)throw new Error("Flipping channel order is only supported for RGB images.");for(let m=0;m<p.length;m+=3){let w=p[m];p[m]=p[m+2],p[m+2]=w}}let _=new $("float32",p,f).permute(2,0,1);return{original_size:[l,i],reshaped_input_size:c,pixel_values:_}}async _call(e,...r){Array.isArray(e)||(e=[e]);let s=await Promise.all(e.map(o=>this.preprocess(o)));return{pixel_values:It(s.map(o=>o.pixel_values),0),original_sizes:s.map(o=>o.original_size),reshaped_input_sizes:s.map(o=>o.reshaped_input_size)}}static async from_pretrained(e,r={}){let s=await ft(e,vr,!0,r);return new this(s)}};var wn={};Ys(wn,{BeitFeatureExtractor:()=>T_,BitImageProcessor:()=>O_,CLIPFeatureExtractor:()=>C_,CLIPImageProcessor:()=>Ac,ChineseCLIPFeatureExtractor:()=>I_,ConvNextFeatureExtractor:()=>L_,ConvNextImageProcessor:()=>Mc,DINOv3ViTImageProcessor:()=>N_,DPTFeatureExtractor:()=>R_,DPTImageProcessor:()=>Oc,DeiTFeatureExtractor:()=>P_,DeiTImageProcessor:()=>Sc,DetrFeatureExtractor:()=>z_,DetrImageProcessor:()=>Tc,DonutFeatureExtractor:()=>$_,DonutImageProcessor:()=>_n,EfficientNetImageProcessor:()=>D_,GLPNFeatureExtractor:()=>F_,GroundingDinoImageProcessor:()=>B_,Idefics3ImageProcessor:()=>Ic,ImageFeatureExtractor:()=>X,ImageProcessor:()=>X,JinaCLIPImageProcessor:()=>j_,Lfm2VlImageProcessor:()=>G_,LlavaOnevisionImageProcessor:()=>q_,Mask2FormerImageProcessor:()=>V_,MaskFormerFeatureExtractor:()=>W_,MaskFormerImageProcessor:()=>mn,MobileNetV1FeatureExtractor:()=>H_,MobileNetV1ImageProcessor:()=>Cc,MobileNetV2FeatureExtractor:()=>X_,MobileNetV2ImageProcessor:()=>Lc,MobileNetV3FeatureExtractor:()=>K_,MobileNetV3ImageProcessor:()=>Pc,MobileNetV4FeatureExtractor:()=>Q_,MobileNetV4ImageProcessor:()=>zc,MobileViTFeatureExtractor:()=>Y_,MobileViTImageProcessor:()=>Nc,NougatImageProcessor:()=>J_,OwlViTFeatureExtractor:()=>Z_,OwlViTImageProcessor:()=>hn,Owlv2ImageProcessor:()=>em,Phi3VImageProcessor:()=>sm,PixtralImageProcessor:()=>nm,PvtImageProcessor:()=>om,Qwen2VLImageProcessor:()=>am,RTDetrImageProcessor:()=>im,Sam2ImageProcessor:()=>zo,Sam3ImageProcessor:()=>zo,SamImageProcessor:()=>zo,SapiensFeatureExtractor:()=>lm,SapiensImageProcessor:()=>$c,SegformerFeatureExtractor:()=>cm,SegformerImageProcessor:()=>Rc,SiglipImageProcessor:()=>um,SmolVLMImageProcessor:()=>Ic,Swin2SRImageProcessor:()=>pm,VLMImageProcessor:()=>U_,ViTFeatureExtractor:()=>dm,ViTImageProcessor:()=>Dc,VitMatteImageProcessor:()=>fm,VitPoseImageProcessor:()=>_m,YolosFeatureExtractor:()=>mm,YolosImageProcessor:()=>Fc});var T_=class extends X{};var O_=class extends X{};var I_=class extends X{};var Ac=class extends X{},C_=class extends Ac{};var Mc=class extends X{constructor(e){super(e),this.crop_pct=this.config.crop_pct??224/256}async resize(e){let r=this.size?.shortest_edge;if(r===void 0)throw new Error("Size dictionary must contain 'shortest_edge' key.");if(r<384){let s=Math.floor(r/this.crop_pct),[n,o]=this.get_resize_output_image_size(e,{shortest_edge:s});e=await e.resize(n,o,{resample:this.resample}),e=await e.center_crop(r,r)}else e=await e.resize(r,r,{resample:this.resample});return e}},L_=class extends Mc{};var Sc=class extends X{},P_=class extends Sc{};var Tc=class extends X{async _call(e){let r=await super._call(e),s=[r.pixel_values.dims[0],64,64],n=Xe(s,1n);return{...r,pixel_mask:n}}post_process_object_detection(...e){return qr(...e)}post_process_panoptic_segmentation(...e){return kc(...e)}post_process_instance_segmentation(...e){return Ec(...e)}},z_=class extends Tc{};var N_=class extends X{};var _n=class extends X{pad_image(e,r,s,n={}){let[o,a,i]=r,l=this.image_mean;Array.isArray(this.image_mean)||(l=new Array(i).fill(l));let c=this.image_std;Array.isArray(c)||(c=new Array(i).fill(l));let p=l.map((f,_)=>-f/c[_]);return super.pad_image(e,r,s,{center:!0,constant_values:p,...n})}},$_=class extends _n{};var Oc=class extends X{},R_=class extends Oc{};var D_=class extends X{constructor(e){super(e),this.include_top=this.config.include_top??!0,this.include_top&&(this.image_std=this.image_std.map(r=>r*r))}};var F_=class extends X{};var B_=class extends X{async _call(e){let r=await super._call(e),s=r.pixel_values.dims,n=st([s[0],s[2],s[3]]);return{...r,pixel_mask:n}}};var Ic=class extends X{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,r){let[s,n]=e.dims.slice(-2),o=n/s;return n>=s?(n=Math.ceil(n/r)*r,s=Math.floor(n/o),s=Math.ceil(s/r)*r):(s=Math.ceil(s/r)*r,n=Math.floor(s*o),n=Math.ceil(n/r)*r),{height:s,width:n}}async _call(e,{do_image_splitting:r=null,return_row_col_info:s=!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 o=[],a=[],i=[],l=[],c=[];for(let E of n){let A=await Promise.all(E.map(P=>this.preprocess(P)));l.push(...A.map(P=>P.original_size)),c.push(...A.map(P=>P.reshaped_input_size)),A.forEach(P=>P.pixel_values.unsqueeze_(0));let{longest_edge:T}=this.max_image_size,S;if(r??this.do_image_splitting){let P=new Array(A.length),O=new Array(A.length);S=await Promise.all(A.map(async(v,j)=>{let H=this.get_resize_for_vision_encoder(v.pixel_values,T),B=await vt(v.pixel_values,{size:[H.height,H.width]}),{frames:V,num_splits_h:q,num_splits_w:Q}=await this.split_image(B,this.max_image_size);return P[j]=q,O[j]=Q,Ee(V,0)})),a.push(P),i.push(O)}else{let P=[T,T];S=await Promise.all(A.map(O=>vt(O.pixel_values,{size:P}))),a.push(new Array(A.length).fill(0)),i.push(new Array(A.length).fill(0))}o.push(Ee(S,0))}let p=o.length,[f,_,m,w]=o[0].dims,x,k;if(p===1)x=o[0].unsqueeze_(0),k=Xe([p,f,m,w],!0);else{let E=Math.max(...o.map(S=>S.dims.at(0)));k=Xe([p,E,m,w],!0);let A=k.data,T=E*m*w;for(let S=0;S<p;++S){let P=o[S].dims[0];if(P<E){o[S]=Ee([o[S],Xe([E-P,_,m,w],0)],0);let O=S*T+P*m*w,v=(S+1)*T;A.fill(!1,O,v)}}x=It(o,0)}return{pixel_values:x,pixel_attention_mask:k,original_sizes:l,reshaped_input_sizes:c,...s?{rows:a,cols:i}:{}}}async split_image(e,{longest_edge:r}){let s=r,n=r,o=[],[a,i]=e.dims.slice(-2),l=0,c=0;if(a>s||i>n){l=Math.ceil(a/s),c=Math.ceil(i/n);let p=Math.ceil(a/l),f=Math.ceil(i/c);for(let w=0;w<l;++w)for(let x=0;x<c;++x){let k,E,A,T;w===l-1?(E=a-p,T=a):(E=w*p,T=(w+1)*p),x===c-1?(k=i-f,A=i):(k=x*f,A=(x+1)*f);let O=await hc(e,[E,k],[T,A],[2,3]);o.push(O)}let _=s,m=n;(a!==_||i!==m)&&(e=await vt(e,{size:[_,m]}))}return o.push(e),{frames:o,num_splits_h:l,num_splits_w:c}}};var U_=class extends X{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(r=>r*this.rescale_factor)}pad_image(e,r,s,n){return super.pad_image(e,r,s,{constant_values:this.constant_values,center:!0,...n})}};var j_=class extends X{constructor(e){let{resize_mode:r,fill_color:s,interpolation:n,size:o,...a}=e,i=r==="squash"?{width:o,height:o}:r==="shortest"?{shortest_edge:o}:{longest_edge:o},l=n==="bicubic"?3:2;super({...a,size:i,resample:l,do_center_crop:!0,crop_size:o,do_normalize:!0})}};function c2(t,e){return Math.round(t/e)*e}function oz(t,e,r,s,n){let o=1/0,a=[1,1],i=r*s;for(let l of e){let c=Math.abs(t-l[0]/l[1]);c<o?(o=c,a=l):c===o&&i>.5*n*n*l[0]*l[1]&&(a=l)}return a}function az(t,e){let r=[],s=new Set;for(let n=t;n<=e;++n)for(let o=1;o<=n;++o)for(let a=1;a<=n;++a){let i=o*a;if(i>=t&&i<=e){let l=o<<16|a;s.has(l)||(s.add(l),r.push([o,a]))}}return r.sort((n,o)=>n[0]*n[1]-o[0]*o[1])}function iz(t,e){let[r,s,n,o]=t.dims,a=Math.floor(n/e),i=Math.floor(o/e),l=e*e*s,c=t.data,p=new Float32Array(r*a*i*l),f=n*o;for(let _=0;_<r;++_){let m=_*s*f,w=_*a*i*l;for(let x=0;x<a;++x)for(let k=0;k<i;++k){let E=w+(x*i+k)*l;for(let A=0;A<e;++A){let T=(x*e+A)*o+k*e;for(let S=0;S<e;++S){let P=T+S;for(let O=0;O<s;++O)p[E++]=c[m+O*f+P]}}}}return new $("float32",p,[r,a*i,l])}function lz(t,e){let[,r,s]=t.dims,n=new BigInt64Array(e);n.fill(1n,0,r);let o=t;if(r<e){let a=new Float32Array(e*s);a.set(t.data),o=new $("float32",a,[1,e,s])}return{padded:o,mask:new $("int64",n,[e])}}var G_=class extends X{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;let r=this.max_image_tokens*this.downsample_factor**2,s=this.do_image_splitting?(this.tile_size/this.encoder_patch_size)**2:0;this.max_num_patches=Math.max(r,s)}_is_image_too_large(e,r){let s=this.encoder_patch_size*this.downsample_factor,n=Math.max(this.encoder_patch_size,c2(e,s)),o=Math.max(this.encoder_patch_size,c2(r,s));return n*o>this.max_image_tokens*(this.encoder_patch_size*this.downsample_factor)**2*this.max_pixels_tolerance}_get_grid_layout(e,r){let s=az(this.min_tiles,this.max_tiles),[n,o]=oz(r/e,s,r,e,this.tile_size);return{grid_width:n,grid_height:o,target_width:this.tile_size*n,target_height:this.tile_size*o}}async _call(e,{return_row_col_info:r=null}={}){let s;Array.isArray(e)?Array.isArray(e[0])?s=e:s=[e]:s=[[e]];let n=[],o=[],a=[],i=[],l=[],c=[];for(let f of s){let _=await Promise.all(f.map(m=>this.preprocess(m,{do_pad:!1})));for(let{pixel_values:m}of _){let[,w,x]=m.dims,k=m.unsqueeze_(0),E=this.encoder_patch_size*this.downsample_factor,A=E**2,[T,S]=vc(Math.max(E,w),Math.max(E,x),E,this.min_image_tokens*A,this.max_image_tokens*A).map(B=>Math.max(E,B)),P,O=1,v=1,j=this._is_image_too_large(w,x),H=this.do_image_splitting&&!(this.min_tiles===1&&this.max_tiles===1);if(j&&H){let{grid_width:B,grid_height:V,target_width:q,target_height:Q}=this._get_grid_layout(w,x);O=V,v=B;let F=await vt(k,{size:[Q,q]});P=[];for(let C=0;C<V;++C)for(let te=0;te<B;++te){let le=C*this.tile_size,L=te*this.tile_size;P.push(F.slice(null,null,[le,le+this.tile_size],[L,L+this.tile_size]))}this.use_thumbnail&&B*V!==1&&P.push(await vt(k,{size:[T,S]}))}else P=[await vt(k,{size:[T,S]})];for(let B of P){let[,,V,q]=B.dims,Q=iz(B,this.encoder_patch_size),{padded:F,mask:C}=lz(Q,this.max_num_patches);n.push(F),o.push(C),a.push([Math.floor(V/this.encoder_patch_size),Math.floor(q/this.encoder_patch_size)])}i.push(O),l.push(v),c.push([T,S])}}let p={pixel_values:Ee(n,0),pixel_attention_mask:It(o,0),spatial_shapes:new $("int64",BigInt64Array.from(a.flat(),BigInt),[a.length,2])};return(r??this.return_row_col_info)&&(p.image_rows=i,p.image_cols=l,p.image_sizes=c),p}};var q_=class extends X{};var mn=class extends X{post_process_panoptic_segmentation(...e){return kc(...e)}post_process_instance_segmentation(...e){return Ec(...e)}},W_=class extends mn{};var V_=class extends mn{};var Cc=class extends X{},H_=class extends Cc{};var Lc=class extends X{},X_=class extends Lc{};var Pc=class extends X{},K_=class extends Pc{};var zc=class extends X{},Q_=class extends zc{};var Nc=class extends X{},Y_=class extends Nc{};var J_=class extends _n{};var hn=class extends X{post_process_object_detection(...e){return qr(...e)}},Z_=class extends hn{};var em=class extends hn{};var $t=336,cz=[2,3],{ceil:tm,floor:gn,sqrt:rm}=Math,sm=class extends X{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,r){let{num_img_tokens:s}=this.config;return gn((gn(r/$t)*gn(e/$t)+1)*s+1+(gn(r/$t)+1)*rm(s))}get_resize_output_image_size(e,r){let s=this._num_crops,[n,o]=e.size,a=n/o,i=1;for(;i*Math.ceil(i/a)<=s;)i+=1;i-=1;let l=Math.floor(i*336),c=Math.floor(l/a);return[l,c]}pad_image(e,r,s,n={}){let[o,a]=r,i=$t*tm(o/$t),l=$t*tm(a/$t),c=[1,1,1].map((p,f)=>(p-this.image_mean[f])/this.image_std[f]);return super.pad_image(e,r,{width:l,height:i},{center:!0,constant_values:c,...n})}async _call(e,{num_crops:r=null}={}){if(this._num_crops=r??=this.config.num_crops,r<4||rm(r)%1!==0)throw new Error("num_crops must be a square number >= 4");Array.isArray(e)||(e=[e]);let s=e.length,n=await Promise.all(e.map(_=>this.preprocess(_))),o=n.map(_=>_.original_size),a=n.map(_=>_.reshaped_input_size),i=[];for(let{pixel_values:_}of n){_.unsqueeze_(0);let[m,w]=_.dims.slice(-2),x=await vt(_,{size:[$t,$t],mode:"bicubic"});if(r>0){let k=[],E=rm(r),A=gn(w/E),T=gn(m/E);for(let P=0;P<E;++P)for(let O=0;O<E;++O){let v,j,H,B;P===E-1?(j=m-T,B=m):(j=P*T,B=(P+1)*T),O===E-1?(v=w-A,H=w):(v=O*A,H=(O+1)*A);let Q=await hc(_,[j,v],[B,H],cz);k.push(Q)}let S=await vt(Ee(k,0),{size:[$t,$t],mode:"bicubic"});i.push(Ee([x,S],0))}else i.push(x)}let l=It(i,0),c=a.map(_=>_.map(m=>$t*tm(m/$t))),p=new $("int64",c.flat(),[s,2]),f=c.map(([_,m])=>this.calc_num_image_tokens_from_image_size(m,_));return{pixel_values:l,original_sizes:o,reshaped_input_sizes:a,image_sizes:p,num_img_tokens:f}}};var nm=class extends X{get_resize_output_image_size(e,r){let{longest_edge:s}=r;if(s===void 0)throw new Error("size must contain 'longest_edge'");let[n,o]=e.size,a=Math.max(n,o)/s,i=n,l=o;a>1&&(i=Math.floor(n/a),l=Math.floor(o/a));let{patch_size:c,spatial_merge_size:p}=this.config;if(!p)throw new Error("config must contain 'spatial_merge_size'");let f=c*p,_=Math.floor((i-1)/f)+1,m=Math.floor((l-1)/f)+1;return[_*f,m*f]}};var om=class extends X{};var am=class extends X{constructor(e){super(e),this.min_pixels=e.min_pixels??e.size?.shortest_edge,this.max_pixels=e.max_pixels??e.size?.longest_edge,this.patch_size=e.patch_size,this.merge_size=e.merge_size}get_resize_output_image_size(e,r){let s=this.patch_size*this.merge_size;return vc(e.height,e.width,s,this.min_pixels,this.max_pixels)}async _call(e,...r){let{pixel_values:s,original_sizes:n,reshaped_input_sizes:o}=await super._call(e,...r),a=s,{temporal_patch_size:i,merge_size:l,patch_size:c}=this.config;a.dims[0]===1&&(a=Ee(Array.from({length:i},()=>a),0));let p=a.dims[0]/i,f=a.dims[1],_=Math.floor(a.dims[2]/c),m=Math.floor(a.dims[3]/c),w=a.view(p,i,f,Math.floor(_/l),l,c,Math.floor(m/l),l,c).permute(0,3,6,4,7,2,1,5,8).view(p*_*m,f*i*c*c),x=new $("int64",[p,_,m],[1,3]);return{pixel_values:w,image_grid_thw:x,original_sizes:n,reshaped_input_sizes:o}}};var im=class extends X{post_process_object_detection(...e){return qr(...e)}};var zo=class extends X{reshape_input_points(e,r,s,n=!1){e=structuredClone(e);let o=nd(e);if(o.length===3)n||(o=[1,...o]),e=[e];else if(o.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){let[i,l]=r[a],[c,p]=s[a],f=[p/l,c/i];for(let _=0;_<e[a].length;++_)for(let m=0;m<e[a][_].length;++m)for(let w=0;w<e[a][_][m].length;++w)e[a][_][m][w]*=f[w%2]}return new $("float32",Float32Array.from(e.flat(1/0)),o)}add_input_labels(e,r){let s=nd(e);if(s.length===2)s=[1,...s],e=[e];else if(s.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(s.some((n,o)=>n!==r.dims[o]))throw Error(`The first ${s.length} dimensions of 'input_points' and 'input_labels' must be the same.`);return new $("int64",e.flat(1/0).map(BigInt),s)}async _call(e,{input_points:r=null,input_labels:s=null,input_boxes:n=null}={}){let o=await super._call(e);if(r&&(o.input_points=this.reshape_input_points(r,o.original_sizes,o.reshaped_input_sizes)),s){if(!o.input_points)throw Error("`input_points` must be provided if `input_labels` are provided.");o.input_labels=this.add_input_labels(s,o.input_points)}return n&&(o.input_boxes=this.reshape_input_points(n,o.original_sizes,o.reshaped_input_sizes,!0)),o}async post_process_masks(e,r,s,{mask_threshold:n=0,binarize:o=!0,pad_size:a=null}={}){let i=[];a=a??this.pad_size??this.size;let l=[a.height,a.width];for(let c=0;c<r.length;++c){let p=r[c],f=s[c],_=await vt(e[c],{mode:"bilinear",size:l});if(_=_.slice(null,null,[0,f[0]],[0,f[1]]),_=await vt(_,{mode:"bilinear",size:p}),o){let m=_.data,w=new Uint8Array(m.length);for(let x=0;x<m.length;++x)m[x]>n&&(w[x]=1);_=new $("bool",w,_.dims)}i.push(_)}return i}generate_crop_boxes(e,r,{crop_n_layers:s=0,overlap_ratio:n=512/1500,points_per_crop:o=32,crop_n_points_downscale_factor:a=1}={}){}};var $c=class extends X{post_process_semantic_segmentation(...e){return bc(...e)}},lm=class extends $c{};var Rc=class extends X{post_process_semantic_segmentation(...e){return bc(...e)}},cm=class extends Rc{};var um=class extends X{};var pm=class extends X{pad_image(e,r,s,n={}){let[o,a,i]=r;return super.pad_image(e,r,{width:a+(s-a%s)%s,height:o+(s-o%s)%s},{mode:"symmetric",center:!1,constant_values:-1,...n})}};var Dc=class extends X{},dm=class extends Dc{};var fm=class extends X{async _call(e,r){Array.isArray(e)||(e=[e]),Array.isArray(r)||(r=[r]);let s=await Promise.all(e.map(a=>this.preprocess(a))),n=await Promise.all(r.map(a=>this.preprocess(a,{do_normalize:!1,do_convert_rgb:!1,do_convert_grayscale:!0})));return{pixel_values:It(s.map((a,i)=>Ee([a.pixel_values,n[i].pixel_values],0)),0),original_sizes:s.map(a=>a.original_size),reshaped_input_sizes:s.map(a=>a.reshaped_input_size)}}};var _m=class extends X{post_process_pose_estimation(e,r,{threshold:s=null}={}){let n=e.tolist(),[o,a,i,l]=e.dims,c=[];for(let p=0;p<o;++p){let f=n[p],_=r[p],m=[];for(let w=0;w<_.length;++w){let x=_[w],k=[],E=[],A=[],T=x.at(-2)/l,S=x.at(-1)/i;for(let P=0;P<f.length;++P){let[O,v]=[0,0],j=0,H=-1/0,B=f[P];for(let q=0;q<B.length;++q){let Q=B[q];for(let F=0;F<Q.length;++F){let C=Q[F];j+=C,H=Math.max(H,C),O+=(F+.5)*C,v+=q*C}}if(s!=null&&H<s)continue;let V=[T*O/j,S*v/j];k.push(V),A.push(P),E.push(H)}m.push({bbox:x,scores:E,labels:A,keypoints:k})}c.push(m)}return c}};var Fc=class extends X{post_process_object_detection(...e){return qr(...e)}},mm=class extends Fc{};var Pe=class{static async from_pretrained(e,r={}){let s=await ft(e,vr,!0,r),n=s.image_processor_type??s.feature_extractor_type,o=wn[n?.replace(/Fast$/,"")];return o||(n!==void 0&&Z.warn(`Image processor type '${n}' not found, assuming base ImageProcessor. Please report this at ${jr}.`),o=X),new o(s)}};var hm=class extends re{static tokenizer_class=oe;static image_processor_class=Pe;constructor(e,r,s){super(e,r,s);let{tasks_answer_post_processing_type:n,task_prompts_without_inputs:o,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(o??{})),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]);let r=[];for(let s of e)if(this.task_prompts_without_inputs.has(s))r.push(this.task_prompts_without_inputs.get(s));else{for(let[n,o]of this.task_prompts_with_input)if(s.includes(n)){r.push(o.replaceAll("{input}",s).replaceAll(n,""));break}r.length!==e.length&&r.push(s)}return r}post_process_generation(e,r,s){let n=this.tasks_answer_post_processing_type.get(r)??"pure_text";e=e.replaceAll("<s>","").replaceAll("</s>","");let o;switch(n){case"pure_text":o=e;break;case"description_with_bboxes":case"bboxes":case"phrase_grounding":case"ocr":let a=n==="ocr"?"quad_boxes":"bboxes",i=e.matchAll(this.regexes[a]),l=[],c=[];for(let[p,f,..._]of i)l.push(f?f.trim():l.at(-1)??""),c.push(_.map((m,w)=>(Number(m)+.5)/this.size_per_bin*s[w%2]));o={labels:l,[a]:c};break;default:throw new Error(`Task "${r}" (of type "${n}") not yet implemented.`)}return{[r]:o}}async _call(e,r=null,s={}){if(!e&&!r)throw new Error("Either text or images must be provided");let n=await this.image_processor(e,s),o=r?this.tokenizer(this.construct_prompts(r),s):{};return{...n,...o}}};var gm=class extends re{static image_processor_class=Pe;static feature_extractor_class=Ke;static tokenizer_class=oe;static uses_processor_config=!0;static uses_chat_template_file=!0;constructor(e,r,s){super(e,r,s),this.audio_seq_length=this.config.audio_seq_length,this.image_seq_length=this.config.image_seq_length;let{audio_token_id:n,boa_token:o,audio_token:a,eoa_token:i,image_token_id:l,boi_token:c,image_token:p,eoi_token:f}=this.tokenizer.config;this.audio_token_id=n,this.boa_token=o,this.audio_token=a;let _=a.repeat(this.audio_seq_length);this.full_audio_sequence=`
7
+ `));case"join":case"string":return t;case"int":{let n=parseInt(t.value,10);return new me(isNaN(n)?0:n)}case"float":{let n=parseFloat(t.value);return new Ye(isNaN(n)?0:n)}default:throw new Error(`Unknown StringValue filter: ${s.value}`)}else if(t instanceof me||t instanceof Ye)switch(s.value){case"abs":return t instanceof me?new me(Math.abs(t.value)):new Ye(Math.abs(t.value));case"int":return new me(Math.floor(t.value));case"float":return new Ye(t.value);case"string":return new ee(t.toString());default:throw new Error(`Unknown NumericValue filter: ${s.value}`)}else if(t instanceof ct)switch(s.value){case"items":return new ye(Array.from(t.value.entries()).map(([n,o])=>new ye([new ee(n),o])));case"length":return new me(t.value.size);default:{let n=t.builtins.get(s.value);if(n)return n instanceof Ge?n.value([],r):n;throw new Error(`Unknown ObjectValue filter: ${s.value}`)}}else if(t instanceof pe)switch(s.value){case"bool":return new pe(t.value);case"int":return new me(t.value?1:0);case"float":return new Ye(t.value?1:0);case"string":return new ee(t.value?"true":"false");default:throw new Error(`Unknown BooleanValue filter: ${s.value}`)}throw new Error(`Cannot apply filter "${s.value}" to type: ${t.type}`)}else if(e.type==="CallExpression"){let s=e;if(s.callee.type!=="Identifier")throw new Error(`Unknown filter: ${s.callee.type}`);let n=s.callee.value;if(n==="tojson"){let[,o]=this.evaluateArguments(s.args,r),a=o.get("indent")??new We;if(!(a instanceof me||a instanceof We))throw new Error("If set, indent must be a number");let i=o.get("ensure_ascii")??new pe(!1);if(!(i instanceof pe))throw new Error("If set, ensure_ascii must be a boolean");let l=o.get("sort_keys")??new pe(!1);if(!(l instanceof pe))throw new Error("If set, sort_keys must be a boolean");let c=o.get("separators")??new We,p=null;if(c instanceof ye||c instanceof gE){if(c.value.length!==2)throw new Error("separators must be a tuple of two strings");let[d,_]=c.value;if(!(d instanceof ee)||!(_ instanceof ee))throw new Error("separators must be a tuple of two strings");p=[d.value,_.value]}else if(!(c instanceof We))throw new Error("If set, separators must be a tuple of two strings");return new ee(us(t,{indent:a.value,ensureAscii:i.value,sortKeys:l.value,separators:p}))}else if(n==="join"){let o;if(t instanceof ee)o=Array.from(t.value);else if(t instanceof ye)o=t.value.map(c=>c.value);else throw new Error(`Cannot apply filter "${n}" to type: ${t.type}`);let[a,i]=this.evaluateArguments(s.args,r),l=a.at(0)??i.get("separator")??new ee("");if(!(l instanceof ee))throw new Error("separator must be a string");return new ee(o.join(l.value))}else if(n==="int"||n==="float"){let[o,a]=this.evaluateArguments(s.args,r),i=o.at(0)??a.get("default")??(n==="int"?new me(0):new Ye(0));if(t instanceof ee){let l=n==="int"?parseInt(t.value,10):parseFloat(t.value);return isNaN(l)?i:n==="int"?new me(l):new Ye(l)}else{if(t instanceof me||t instanceof Ye)return t;if(t instanceof pe)return n==="int"?new me(t.value?1:0):new Ye(t.value?1:0);throw new Error(`Cannot apply filter "${n}" to type: ${t.type}`)}}else if(n==="default"){let[o,a]=this.evaluateArguments(s.args,r),i=o[0]??new ee(""),l=o[1]??a.get("boolean")??new pe(!1);if(!(l instanceof pe))throw new Error("`default` filter flag must be a boolean");return t instanceof je||l.value&&!t.__bool__().value?i:t}if(t instanceof ye){switch(n){case"sort":{let[o,a]=this.evaluateArguments(s.args,r),i=o.at(0)??a.get("reverse")??new pe(!1);if(!(i instanceof pe))throw new Error("reverse must be a boolean");let l=o.at(1)??a.get("case_sensitive")??new pe(!1);if(!(l instanceof pe))throw new Error("case_sensitive must be a boolean");let c=o.at(2)??a.get("attribute")??new We;if(!(c instanceof ee||c instanceof me||c instanceof We))throw new Error("attribute must be a string, integer, or null");let p=d=>{if(c instanceof We)return d;let _=c instanceof me?String(c.value):c.value;return wE(d,_)};return new ye(t.value.slice().sort((d,_)=>{let m=p(d),w=p(_),x=hd(m,w,l.value);return i.value?-x:x}))}case"selectattr":case"rejectattr":{let o=n==="selectattr";if(t.value.some(d=>!(d instanceof ct)))throw new Error(`\`${n}\` can only be applied to array of objects`);if(s.args.some(d=>d.type!=="StringLiteral"))throw new Error(`arguments of \`${n}\` must be strings`);let[a,i,l]=s.args.map(d=>this.evaluate(d,r)),c;if(i){let d=r.tests.get(i.value);if(!d)throw new Error(`Unknown test: ${i.value}`);c=d}else c=(...d)=>d[0].__bool__().value;let p=t.value.filter(d=>{let _=d.value.get(a.value),m=_?c(_,l):!1;return o?m:!m});return new ye(p)}case"map":{let[,o]=this.evaluateArguments(s.args,r);if(o.has("attribute")){let a=o.get("attribute");if(!(a instanceof ee))throw new Error("attribute must be a string");let i=o.get("default"),l=t.value.map(c=>{if(!(c instanceof ct))throw new Error("items in map must be an object");let p=wE(c,a.value);return p instanceof je?i??new je:p});return new ye(l)}else throw new Error("`map` expressions without `attribute` set are not currently supported.")}}throw new Error(`Unknown ArrayValue filter: ${n}`)}else if(t instanceof ee){switch(n){case"indent":{let[o,a]=this.evaluateArguments(s.args,r),i=o.at(0)??a.get("width")??new me(4);if(!(i instanceof me))throw new Error("width must be a number");let l=o.at(1)??a.get("first")??new pe(!1),c=o.at(2)??a.get("blank")??new pe(!1),p=t.value.split(`
8
+ `),d=" ".repeat(i.value),_=p.map((m,w)=>!l.value&&w===0||!c.value&&m.length===0?m:d+m);return new ee(_.join(`
9
+ `))}case"replace":{let o=t.builtins.get("replace");if(!(o instanceof Ge))throw new Error("replace filter not available");let[a,i]=this.evaluateArguments(s.args,r);return o.value([...a,new po(i)],r)}}throw new Error(`Unknown StringValue filter: ${n}`)}else if(t instanceof ct){let o=t.builtins.get(n);if(o&&o instanceof Ge){let[a,i]=this.evaluateArguments(s.args,r);return i.size>0&&a.push(new po(i)),o.value(a,r)}throw new Error(`Unknown ObjectValue filter: ${n}`)}else throw new Error(`Cannot apply filter "${n}" to type: ${t.type}`)}throw new Error(`Unknown filter: ${e.type}`)}evaluateFilterExpression(t,e){let r=this.evaluate(t.operand,e);return this.applyFilter(r,t.filter,e)}evaluateTestExpression(t,e){let r=this.evaluate(t.operand,e),s=e.tests.get(t.test.value);if(!s)throw new Error(`Unknown test: ${t.test.value}`);let n=s(r);return new pe(t.negate?!n:n)}evaluateSelectExpression(t,e){return this.evaluate(t.test,e).__bool__().value?this.evaluate(t.lhs,e):new je}evaluateUnaryExpression(t,e){let r=this.evaluate(t.argument,e);if(t.operator.value==="not")return new pe(!r.value);throw new SyntaxError(`Unknown operator: ${t.operator.value}`)}evaluateTernaryExpression(t,e){return this.evaluate(t.condition,e).__bool__().value?this.evaluate(t.trueExpr,e):this.evaluate(t.falseExpr,e)}evalProgram(t,e){return this.evaluateBlock(t.body,e)}evaluateBlock(t,e){let r="";for(let s of t){let n=this.evaluate(s,e);n.type!=="NullValue"&&n.type!=="UndefinedValue"&&(r+=n.toString())}return new ee(r)}evaluateIdentifier(t,e){return e.lookupVariable(t.value)}evaluateCallExpression(t,e){let[r,s]=this.evaluateArguments(t.args,e);s.size>0&&r.push(new po(s));let n=this.evaluate(t.callee,e);if(n.type!=="FunctionValue")throw new Error(`Cannot call something that is not a function: got ${n.type}`);return n.value(r,e)}evaluateSliceExpression(t,e,r){if(!(t instanceof ye||t instanceof ee))throw new Error("Slice object must be an array or string");let s=this.evaluate(e.start,r),n=this.evaluate(e.stop,r),o=this.evaluate(e.step,r);if(!(s instanceof me||s instanceof je))throw new Error("Slice start must be numeric or undefined");if(!(n instanceof me||n instanceof je))throw new Error("Slice stop must be numeric or undefined");if(!(o instanceof me||o instanceof je))throw new Error("Slice step must be numeric or undefined");return t instanceof ye?new ye(fE(t.value,s.value,n.value,o.value)):new ee(fE(Array.from(t.value),s.value,n.value,o.value).join(""))}evaluateMemberExpression(t,e){let r=this.evaluate(t.object,e),s;if(t.computed){if(t.property.type==="SliceExpression")return this.evaluateSliceExpression(r,t.property,e);s=this.evaluate(t.property,e)}else s=new ee(t.property.value);let n;if(r instanceof ct){if(!(s instanceof ee))throw new Error(`Cannot access property with non-string: got ${s.type}`);n=r.value.get(s.value)??r.builtins.get(s.value)}else if(r instanceof ye||r instanceof ee)if(s instanceof me)n=r.value.at(s.value),r instanceof ee&&(n=new ee(r.value.at(s.value)));else if(s instanceof ee)n=r.builtins.get(s.value);else throw new Error(`Cannot access property with non-string/non-number: got ${s.type}`);else{if(!(s instanceof ee))throw new Error(`Cannot access property with non-string: got ${s.type}`);n=r.builtins.get(s.value)}return n instanceof nr?n:new je}evaluateSet(t,e){let r=t.value?this.evaluate(t.value,e):this.evaluateBlock(t.body,e);if(t.assignee.type==="Identifier"){let s=t.assignee.value;e.setVariable(s,r)}else if(t.assignee.type==="TupleLiteral"){let s=t.assignee;if(!(r instanceof ye))throw new Error(`Cannot unpack non-iterable type in set: ${r.type}`);let n=r.value;if(n.length!==s.value.length)throw new Error(`Too ${s.value.length>n.length?"few":"many"} items to unpack in set`);for(let o=0;o<s.value.length;++o){let a=s.value[o];if(a.type!=="Identifier")throw new Error(`Cannot unpack to non-identifier in set: ${a.type}`);e.setVariable(a.value,n[o])}}else if(t.assignee.type==="MemberExpression"){let s=t.assignee,n=this.evaluate(s.object,e);if(!(n instanceof ct))throw new Error("Cannot assign to member of non-object");if(s.property.type!=="Identifier")throw new Error("Cannot assign to member with non-identifier property");n.value.set(s.property.value,r)}else throw new Error(`Invalid LHS inside assignment expression: ${JSON.stringify(t.assignee)}`);return new We}evaluateIf(t,e){let r=this.evaluate(t.test,e);return this.evaluateBlock(r.__bool__().value?t.body:t.alternate,e)}evaluateFor(t,e){let r=new cs(e),s,n;if(t.iterable.type==="SelectExpression"){let c=t.iterable;n=this.evaluate(c.lhs,r),s=c.test}else n=this.evaluate(t.iterable,r);if(!(n instanceof ye||n instanceof ct))throw new Error(`Expected iterable or object type in for loop: got ${n.type}`);n instanceof ct&&(n=n.keys());let o=[],a=[];for(let c=0;c<n.value.length;++c){let p=new cs(r),d=n.value[c],_;if(t.loopvar.type==="Identifier")_=m=>m.setVariable(t.loopvar.value,d);else if(t.loopvar.type==="TupleLiteral"){let m=t.loopvar;if(d.type!=="ArrayValue")throw new Error(`Cannot unpack non-iterable type: ${d.type}`);let w=d;if(m.value.length!==w.value.length)throw new Error(`Too ${m.value.length>w.value.length?"few":"many"} items to unpack`);_=x=>{for(let E=0;E<m.value.length;++E){if(m.value[E].type!=="Identifier")throw new Error(`Cannot unpack non-identifier type: ${m.value[E].type}`);x.setVariable(m.value[E].value,w.value[E])}}}else throw new Error(`Invalid loop variable(s): ${t.loopvar.type}`);s&&(_(p),!this.evaluate(s,p).__bool__().value)||(o.push(d),a.push(_))}let i="",l=!0;for(let c=0;c<o.length;++c){let p=new Map([["index",new me(c+1)],["index0",new me(c)],["revindex",new me(o.length-c)],["revindex0",new me(o.length-c-1)],["first",new pe(c===0)],["last",new pe(c===o.length-1)],["length",new me(o.length)],["previtem",c>0?o[c-1]:new je],["nextitem",c<o.length-1?o[c+1]:new je]]);r.setVariable("loop",new ct(p)),a[c](r);try{let d=this.evaluateBlock(t.body,r);i+=d.value}catch(d){if(d instanceof mE)continue;if(d instanceof _E)break;throw d}l=!1}if(l){let c=this.evaluateBlock(t.defaultBlock,r);i+=c.value}return new ee(i)}evaluateMacro(t,e){return e.setVariable(t.name.value,new Ge((r,s)=>{let n=new cs(s);r=r.slice();let o;r.at(-1)?.type==="KeywordArgumentsValue"&&(o=r.pop());for(let a=0;a<t.args.length;++a){let i=t.args[a],l=r[a];if(i.type==="Identifier"){let c=i;if(!l)throw new Error(`Missing positional argument: ${c.value}`);n.setVariable(c.value,l)}else if(i.type==="KeywordArgumentExpression"){let c=i,p=l??o?.value.get(c.key.value)??this.evaluate(c.value,n);n.setVariable(c.key.value,p)}else throw new Error(`Unknown argument type: ${i.type}`)}return this.evaluateBlock(t.body,n)})),new We}evaluateCallStatement(t,e){let r=new Ge((i,l)=>{let c=new cs(l);if(t.callerArgs)for(let p=0;p<t.callerArgs.length;++p){let d=t.callerArgs[p];if(d.type!=="Identifier")throw new Error(`Caller parameter must be an identifier, got ${d.type}`);c.setVariable(d.value,i[p]??new je)}return this.evaluateBlock(t.body,c)}),[s,n]=this.evaluateArguments(t.call.args,e);s.push(new po(n));let o=this.evaluate(t.call.callee,e);if(o.type!=="FunctionValue")throw new Error(`Cannot call something that is not a function: got ${o.type}`);let a=new cs(e);return a.setVariable("caller",r),o.value(s,a)}evaluateFilterStatement(t,e){let r=this.evaluateBlock(t.body,e);return this.applyFilter(r,t.filter,e)}evaluate(t,e){if(!t)return new je;switch(t.type){case"Program":return this.evalProgram(t,e);case"Set":return this.evaluateSet(t,e);case"If":return this.evaluateIf(t,e);case"For":return this.evaluateFor(t,e);case"Macro":return this.evaluateMacro(t,e);case"CallStatement":return this.evaluateCallStatement(t,e);case"Break":throw new _E;case"Continue":throw new mE;case"IntegerLiteral":return new me(t.value);case"FloatLiteral":return new Ye(t.value);case"StringLiteral":return new ee(t.value);case"ArrayLiteral":return new ye(t.value.map(r=>this.evaluate(r,e)));case"TupleLiteral":return new gE(t.value.map(r=>this.evaluate(r,e)));case"ObjectLiteral":{let r=new Map;for(let[s,n]of t.value){let o=this.evaluate(s,e);if(!(o instanceof ee))throw new Error(`Object keys must be strings: got ${o.type}`);r.set(o.value,this.evaluate(n,e))}return new ct(r)}case"Identifier":return this.evaluateIdentifier(t,e);case"CallExpression":return this.evaluateCallExpression(t,e);case"MemberExpression":return this.evaluateMemberExpression(t,e);case"UnaryExpression":return this.evaluateUnaryExpression(t,e);case"BinaryExpression":return this.evaluateBinaryExpression(t,e);case"FilterExpression":return this.evaluateFilterExpression(t,e);case"FilterStatement":return this.evaluateFilterStatement(t,e);case"TestExpression":return this.evaluateTestExpression(t,e);case"SelectExpression":return this.evaluateSelectExpression(t,e);case"Ternary":return this.evaluateTernaryExpression(t,e);case"Comment":return new We;default:throw new SyntaxError(`Unknown node type: ${t.type}`)}}};function Zl(t){switch(typeof t){case"number":return Number.isInteger(t)?new me(t):new Ye(t);case"string":return new ee(t);case"boolean":return new pe(t);case"undefined":return new je;case"object":return t===null?new We:Array.isArray(t)?new ye(t.map(Zl)):new ct(new Map(Object.entries(t).map(([e,r])=>[e,Zl(r)])));case"function":return new Ge((e,r)=>{let s=t(...e.map(n=>n.value))??null;return Zl(s)});default:throw new Error(`Cannot convert to runtime value: ${t}`)}}var rt=`
10
+ `,oP="{%- ",aP=" -%}";function iP(t){switch(t.operator.type){case"MultiplicativeBinaryOperator":return 4;case"AdditiveBinaryOperator":return 3;case"ComparisonBinaryOperator":return 2;case"Identifier":return t.operator.value==="and"?1:t.operator.value==="in"||t.operator.value==="not in"?2:0}return 0}function lP(t,e=" "){let r=typeof e=="number"?" ".repeat(e):e;return Ht(t.body,0,r).replace(/\n$/,"")}function gt(...t){return oP+t.join(" ")+aP}function Ht(t,e,r){return t.map(s=>cP(s,e,r)).join(rt)}function cP(t,e,r){let s=r.repeat(e);switch(t.type){case"Program":return Ht(t.body,e,r);case"If":return uP(t,e,r);case"For":return pP(t,e,r);case"Set":return dP(t,e,r);case"Macro":return fP(t,e,r);case"Break":return s+gt("break");case"Continue":return s+gt("continue");case"CallStatement":return _P(t,e,r);case"FilterStatement":return mP(t,e,r);case"Comment":return s+"{# "+t.value+" #}";default:return s+"{{- "+ve(t)+" -}}"}}function uP(t,e,r){let s=r.repeat(e),n=[],o=t;for(;o&&(n.push({test:o.test,body:o.body}),o.alternate.length===1&&o.alternate[0].type==="If");)o=o.alternate[0];let a=s+gt("if",ve(n[0].test))+rt+Ht(n[0].body,e+1,r);for(let i=1;i<n.length;++i)a+=rt+s+gt("elif",ve(n[i].test))+rt+Ht(n[i].body,e+1,r);return o&&o.alternate.length>0&&(a+=rt+s+gt("else")+rt+Ht(o.alternate,e+1,r)),a+=rt+s+gt("endif"),a}function pP(t,e,r){let s=r.repeat(e),n="";if(t.iterable.type==="SelectExpression"){let a=t.iterable;n=`${ve(a.lhs)} if ${ve(a.test)}`}else n=ve(t.iterable);let o=s+gt("for",ve(t.loopvar),"in",n)+rt+Ht(t.body,e+1,r);return t.defaultBlock.length>0&&(o+=rt+s+gt("else")+rt+Ht(t.defaultBlock,e+1,r)),o+=rt+s+gt("endfor"),o}function dP(t,e,r){let s=r.repeat(e),n=ve(t.assignee),o=t.value?ve(t.value):"",a=s+gt("set",`${n}${t.value?" = "+o:""}`);return t.body.length===0?a:a+rt+Ht(t.body,e+1,r)+rt+s+gt("endset")}function fP(t,e,r){let s=r.repeat(e),n=t.args.map(ve).join(", ");return s+gt("macro",`${t.name.value}(${n})`)+rt+Ht(t.body,e+1,r)+rt+s+gt("endmacro")}function _P(t,e,r){let s=r.repeat(e),n=t.callerArgs&&t.callerArgs.length>0?`(${t.callerArgs.map(ve).join(", ")})`:"",o=ve(t.call),a=s+gt(`call${n}`,o)+rt;return a+=Ht(t.body,e+1,r)+rt,a+=s+gt("endcall"),a}function mP(t,e,r){let s=r.repeat(e),n=t.filter.type==="Identifier"?t.filter.value:ve(t.filter),o=s+gt("filter",n)+rt;return o+=Ht(t.body,e+1,r)+rt,o+=s+gt("endfilter"),o}function ve(t,e=-1){switch(t.type){case"SpreadExpression":return`*${ve(t.argument)}`;case"Identifier":return t.value;case"IntegerLiteral":return`${t.value}`;case"FloatLiteral":return`${t.value}`;case"StringLiteral":return JSON.stringify(t.value);case"BinaryExpression":{let r=t,s=iP(r),n=ve(r.left,s),o=ve(r.right,s+1),a=`${n} ${r.operator.value} ${o}`;return s<e?`(${a})`:a}case"UnaryExpression":{let r=t;return r.operator.value+(r.operator.value==="not"?" ":"")+ve(r.argument,1/0)}case"CallExpression":{let r=t,s=r.args.map(ve).join(", ");return`${ve(r.callee)}(${s})`}case"MemberExpression":{let r=t,s=ve(r.object);["Identifier","MemberExpression","CallExpression","StringLiteral","IntegerLiteral","FloatLiteral","ArrayLiteral","TupleLiteral","ObjectLiteral"].includes(r.object.type)||(s=`(${s})`);let n=ve(r.property);return!r.computed&&r.property.type!=="Identifier"&&(n=`(${n})`),r.computed?`${s}[${n}]`:`${s}.${n}`}case"FilterExpression":{let r=t,s=ve(r.operand,1/0);return r.filter.type==="CallExpression"?`${s} | ${ve(r.filter)}`:`${s} | ${r.filter.value}`}case"SelectExpression":{let r=t;return`${ve(r.lhs)} if ${ve(r.test)}`}case"TestExpression":{let r=t;return`${ve(r.operand)} is${r.negate?" not":""} ${r.test.value}`}case"ArrayLiteral":case"TupleLiteral":{let r=t.value.map(ve),s=t.type==="ArrayLiteral"?"[]":"()";return`${s[0]}${r.join(", ")}${s[1]}`}case"ObjectLiteral":return`{${Array.from(t.value.entries()).map(([s,n])=>`${ve(s)}: ${ve(n)}`).join(", ")}}`;case"SliceExpression":{let r=t,s=r.start?ve(r.start):"",n=r.stop?ve(r.stop):"",o=r.step?`:${ve(r.step)}`:"";return`${s}:${n}${o}`}case"KeywordArgumentExpression":{let r=t;return`${r.key.value}=${ve(r.value)}`}case"Ternary":{let r=t,s=`${ve(r.trueExpr)} if ${ve(r.condition,0)} else ${ve(r.falseExpr)}`;return e>-1?`(${s})`:s}default:throw new Error(`Unknown expression type: ${t.type}`)}}var xE=class{parsed;constructor(t){let e=AL(t,{lstrip_blocks:!0,trim_blocks:!0});this.parsed=KL(e)}render(t){let e=new cs;if(sP(e),t)for(let[n,o]of Object.entries(t))e.set(n,o);return new nP(e).run(this.parsed).value}format(t){return lP(this.parsed,t?.indent||" ")}};var et=class{constructor(){let t=function(...e){return t._call(...e)};return Object.setPrototypeOf(t,new.target.prototype)}_call(...t){throw Error("Must implement _call method in subclass")}};import on from"fs";var hP={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"},Tr=class t{constructor(e){if(this.filePath=e,this.headers=new Headers,this.exists=on.existsSync(e),this.exists){this.status=200,this.statusText="OK";let r=on.statSync(e);this.headers.set("content-length",r.size.toString()),this.updateContentType();let s=on.createReadStream(e);this.body=new ReadableStream({start(n){s.on("data",o=>n.enqueue(o)),s.on("end",()=>n.close()),s.on("error",o=>n.error(o))},cancel(){s.destroy()}})}else this.status=404,this.statusText="Not Found",this.body=null}updateContentType(){let e=this.filePath.toString().split(".").pop().toLowerCase();this.headers.set("content-type",hP[e]??"application/octet-stream")}clone(){let e=new t(this.filePath);return e.exists=this.exists,e.status=this.status,e.statusText=this.statusText,e.headers=new Headers(this.headers),e}async arrayBuffer(){return(await on.promises.readFile(this.filePath)).buffer}async blob(){let e=await on.promises.readFile(this.filePath);return new Blob([e],{type:this.headers.get("content-type")})}async text(){return await on.promises.readFile(this.filePath,"utf8")}async json(){return JSON.parse(await this.text())}};import fo from"fs";import ec from"path";var an=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(ie.IS_CRYPTO_AVAILABLE){let i=new Uint32Array(1);crypto.getRandomValues(i),e=i[0]}else e=Date.now()>>>0;let r=this._mt,s=(i,l)=>Math.imul(i,l)>>>0,n=[];for(let i=e||0;i>0;i=Math.floor(i/4294967296))n.push(i&4294967295);n.length||n.push(0),r[0]=19650218;for(let i=1;i<624;++i)r[i]=s(1812433253,r[i-1]^r[i-1]>>>30)+i>>>0;let o=1,a=0;for(let i=Math.max(624,n.length);i>0;--i,++o,++a)o>=624&&(r[0]=r[623],o=1),a>=n.length&&(a=0),r[o]=(r[o]^s(r[o-1]^r[o-1]>>>30,1664525))+n[a]+a>>>0;for(let i=623;i>0;--i,++o)o>=624&&(r[0]=r[623],o=1),r[o]=(r[o]^s(r[o-1]^r[o-1]>>>30,1566083941))-o>>>0;r[0]=2147483648,this._idx=624,this._gauss_next=null}_int32(){let e=this._mt;if(this._idx>=624){for(let s=0;s<624;++s){let n=e[s]&2147483648|e[(s+1)%624]&2147483647;e[s]=(e[(s+397)%624]^n>>>1^(n&1?2567483615:0))>>>0}this._idx=0}let r=e[this._idx++];return r^=r>>>11,r^=r<<7&2636928640,r^=r<<15&4022730752,r^=r>>>18,r>>>0}random(){return((this._int32()>>>5)*67108864+(this._int32()>>>6))/9007199254740992}gauss(e=0,r=1){let s=this._gauss_next;if(this._gauss_next=null,s===null){let n=this.random()*2*Math.PI,o=Math.sqrt(-2*Math.log(1-this.random()));s=Math.cos(n)*o,this._gauss_next=Math.sin(n)*o}return e+s*r}shuffle(e){for(let r=e.length-1;r>0;--r){let s=32-Math.clz32(r+1),n=this._int32()>>>32-s;for(;n>r;)n=this._int32()>>>32-s;let o=e[r];e[r]=e[n],e[n]=o}}choices(e,r){return e[yE(this._random_fn,r)]}};function yE(t,e){let r=0;for(let n=0;n<e.length;++n)r+=e[n];let s=t()*r;for(let n=0;n<e.length;++n)if(s-=e[n],s<0)return n;return e.length-1}var or=new an,ps=Object.freeze({Random:an,seed:or.seed.bind(or),random:or.random.bind(or),gauss:or.gauss.bind(or),shuffle:or.shuffle.bind(or),choices:or.choices.bind(or)}),bE=t=>yE(ps.random,t);var gP=new an,ln=class{constructor(e){this.path=e}async match(e){let r=ec.join(this.path,e),s=new Tr(r);if(s.exists)return s}async put(e,r,s=void 0){let n=ec.join(this.path,e),o=ie.IS_PROCESS_AVAILABLE?process.pid:Date.now(),a=gP._int32().toString(36),i=n+`.tmp.${o}.${a}`;try{let l=r.headers.get("Content-Length"),c=parseInt(l??"0"),p=0;await fo.promises.mkdir(ec.dirname(n),{recursive:!0});let d=fo.createWriteStream(i),_=r.body.getReader();for(;;){let{done:m,value:w}=await _.read();if(m)break;await new Promise((E,k)=>{d.write(w,A=>{if(A){k(A);return}E()})}),p+=w.length;let x=c?p/c*100:0;s?.({progress:x,loaded:p,total:c})}await new Promise((m,w)=>{d.close(x=>x?w(x):m())}),await fo.promises.rename(i,n)}catch(l){try{await fo.promises.unlink(i)}catch{}throw l}}async delete(e){let r=ec.join(this.path,e);try{return await fo.promises.unlink(r),!0}catch{return!1}}};var vE={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"},tc=100,kE=/^(\b[\w\-.]+\b\/)?\b[\w\-.]{1,96}\b$/;function _o(...t){return t=t.map((e,r)=>(r&&(e=e.replace(new RegExp("^/"),"")),r!==t.length-1&&(e=e.replace(new RegExp("/$"),"")),e)),t.join("/")}function Or(t,e=null,r=null){let s;try{s=new URL(t)}catch{return!1}return!(e&&!e.includes(s.protocol)||r&&!r.includes(s.hostname))}function EE(t){return!(!kE.test(t)||t.includes("..")||t.includes("--")||t.endsWith(".git")||t.endsWith(".ipynb"))}function AE(t,e,r){if(!r)return null;let s=vE[t]??`Error (${t}) occurred while trying to load file`;throw Error(`${s}: "${e}".`)}async function ME(t,e,r){let s=t.headers.get("Content-Length"),n=s?parseInt(s,10):r??0;s===null&&!r&&Z.warn("Unable to determine content-length from response headers. Will expand buffer when needed.");let o=new Uint8Array(n),a=0,i=t.body.getReader();async function l(){let{done:c,value:p}=await i.read();if(c)return;let d=a+p.length;if(d>n){n=d;let m=new Uint8Array(n);m.set(o),o=m}o.set(p,a),a=d;let _=a/n*100;return e({progress:_,loaded:a,total:n}),l()}return await l(),o}function gd(t){return Or(t,["blob:"])}function wd(t){let e;if(typeof location<"u"&&location.href)e=location.href;else if(typeof import.meta<"u"&&import.meta.url)e=import.meta.url;else return t;return new URL(t,e).href}var TE="SHA-256",wP="experimental_transformers-hash-cache",SE=t=>({algorithm:TE,value:t}),mo=class{#t=null;_getHashCache=()=>(this.#t??=caches.open(wP),this.#t);static isAvailable=()=>typeof navigator<"u"&&"crossOriginStorage"in navigator;match=async e=>{let r=await this._getFileHash(e);if(r)try{let[s]=await navigator.crossOriginStorage.requestFileHandles([SE(r)]),n=await s.getFile();return new Response(n,{headers:{"Content-Length":String(n.size)}})}catch{return}};put=async(e,r)=>{let s=await this._getFileHash(e);if(s){let n=await r.blob();await this._storeBlobInCOS(n,s)}else this._processAndStore(e,r.body)};_storeBlobInCOS=async(e,r)=>{let[s]=await navigator.crossOriginStorage.requestFileHandles([SE(r)],{create:!0}),n=await s.createWritable();await n.write(e),await n.close()};_processAndStore=async(e,r)=>{try{let s=[];for await(let a of r)s.push(a);let n=new Blob(s),o=await this._getBlobHash(n);await this._storeBlobInCOS(n,o);try{await(await this._getHashCache()).put(e,new Response(o))}catch{}}catch{}};delete=async e=>{try{return await(await this._getHashCache()).delete(e)}catch{return!1}};_getFileHash=async e=>{try{let r=await this._getHashCache(),s=await r.match(e);if(s)return s.text();let n=await this._getLfsFileHash(e);return n?(await r.put(e,new Response(n)),n):null}catch{return null}};_getLfsFileHash=async e=>{if(!e.includes("/resolve/"))return null;let r=e.replace("/resolve/","/raw/");try{let n=(await fetch(r).then(o=>o.text())).match(/^oid sha256:([0-9a-f]+)$/m);return n?n[1]:null}catch{return null}};_getBlobHash=async e=>{let r=await e.arrayBuffer(),s=await crypto.subtle.digest(TE,r);return Array.from(new Uint8Array(s)).map(o=>o.toString(16).padStart(2,"0")).join("")}};async function Kt(t=null){let e=null;if(_e.useCustomCache){if(!_e.customCache)throw Error("`env.useCustomCache=true`, but `env.customCache` is not defined.");if(!_e.customCache.match||!_e.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");e=_e.customCache}if(!e&&_e.experimental_useCrossOriginStorage&&mo.isAvailable()&&(e=new mo),!e&&_e.useBrowserCache){if(typeof caches>"u")throw Error("Browser cache is not available in this environment.");try{e=await caches.open(_e.cacheKey)}catch(r){Z.warn("An error occurred while opening the browser cache:",r)}}if(!e&&_e.useFSCache){if(!ie.IS_FS_AVAILABLE)throw Error("File System Cache is not available in this environment.");e=new ln(t??_e.cacheDir)}return e}async function OE(t,...e){for(let r of e)try{let s=await t.match(r);if(s)return s}catch{continue}}var rc=class{#t;#e;constructor(e){this.#t=e,this.#e=new Map}get(e){if(!this.#e.has(e))return;let r=this.#e.get(e);return this.#e.delete(e),this.#e.set(e,r),r}put(e,r){this.#e.has(e)&&this.#e.delete(e),this.#e.set(e,r),this.#e.size>this.#t&&this.#e.delete(this.#e.keys().next().value)}delete(e){return this.#e.delete(e)}clear(){this.#e.clear()}};var xP=100,xd=new rc(xP);function sc(t,e){let r=xd.get(t);if(r!==void 0)return r;let s=e().then(n=>n,n=>(xd.delete(t),Promise.reject(n)));return xd.put(t,s),s}async function yP(t){if(!Or(t,["http:","https:"]))return null;let e=yd(t);return e.set("Range","bytes=0-0"),_e.fetch(t,{method:"GET",headers:e,cache:"no-store"})}function ar(t,e,r={}){let s=JSON.stringify([t,e,r?.revision,r?.cache_dir,r?.local_files_only]);return sc(s,()=>bP(t,e,r))}async function bP(t,e,r){let s=await Kt(r?.cache_dir),{localPath:n,remoteURL:o,proposedCacheKey:a,validModelId:i}=Cr(t,e,r,s),l=await Lr(s,n,a);if(l!==void 0&&typeof l!="string"){let c=l.headers.get("content-length"),p=l.headers.get("content-type");return{exists:!0,size:c?parseInt(c,10):void 0,contentType:p||void 0,fromCache:!0}}if(_e.allowLocalModels&&!Or(n,["http:","https:"]))try{let p=await Ir(n);if(typeof p!="string"&&p.status!==404){let d=p.headers.get("content-length"),_=p.headers.get("content-type");return{exists:!0,size:d?parseInt(d,10):void 0,contentType:_||void 0,fromCache:!1}}}catch{}if(_e.allowRemoteModels&&!r.local_files_only&&i)try{let c=await yP(o);if(c&&c.status>=200&&c.status<300){let p,d=c.headers.get("content-type");if(c.status===206){let _=c.headers.get("content-range");if(_){let m=_.match(/bytes \d+-\d+\/(\d+)/);m&&(p=parseInt(m[1],10))}}else if(c.status===200)try{await c.body?.cancel()}catch{}if(p===void 0){let _=c.headers.get("content-length");p=_?parseInt(_,10):void 0}return{exists:!0,size:p,contentType:d||void 0,fromCache:!1}}}catch(c){Z.warn(`Unable to fetch file metadata for "${o}": ${c}`)}return{exists:!1,fromCache:!1}}async function Ir(t){return _e.useFS&&!Or(t,["http:","https:","blob:"])?new Tr(t instanceof URL?t.protocol==="file:"?t.pathname:t.toString():t):_e.fetch(t,{headers:yd(t)})}function yd(t){let e=typeof process<"u"&&process?.release?.name==="node",r=new Headers;if(e){let s=!!process.env?.TESTING_REMOTELY,n=_e.version;if(r.set("User-Agent",`transformers.js/${n}; is_ci/${s};`),Or(t,["http:","https:"],["huggingface.co","hf.co"])){let a=process.env?.HF_TOKEN??process.env?.HF_ACCESS_TOKEN;a&&r.set("Authorization",`Bearer ${a}`)}}return r}function Cr(t,e,r={},s=null){let n=r.revision??"main",o=_o(t,e),a=EE(t),i=a?_o(_e.localModelPath,o):o,l=_o(_e.remoteHost,_e.remotePathTemplate.replaceAll("{model}",t).replaceAll("{revision}",encodeURIComponent(n)),e),c=s instanceof ln?n==="main"?o:_o(t,n,e):l;return{requestURL:o,localPath:i,remoteURL:l,proposedCacheKey:c,validModelId:a}}async function Lr(t,e,r){if(t)return await OE(t,e,r)}async function vP(t,e,r,s,n,o,a={}){if(await r.match(s)===void 0)if(o){if(typeof n!="string"){let i=new Headers(n.headers);i.set("content-length",o.byteLength.toString()),await r.put(s,new Response(o,{headers:i})).catch(l=>{Z.warn(`Unable to add response to browser cache: ${l}.`)})}}else{let i=a.progress_callback?l=>gr(a.progress_callback,{status:"progress",name:t,file:e,...l}):void 0;await r.put(s,n,i)}}async function kP(t,e,r=!0,s={},n=!1,o=null){let{requestURL:a,localPath:i,remoteURL:l,proposedCacheKey:c,validModelId:p}=Cr(t,e,s,o),d,_=!1,m;m=await Lr(o,i,c);let w=m!==void 0;if(!w){if(_e.allowLocalModels)if(Or(a,["http:","https:"])){if(s.local_files_only)throw new Error(`\`local_files_only=true\`, but attempted to load a remote file from: ${a}.`);if(!_e.allowRemoteModels)throw new Error(`\`env.allowRemoteModels=false\`, but attempted to load a remote file from: ${a}.`)}else try{m=await Ir(i),d=i}catch(A){Z.warn(`Unable to load from local path "${i}": "${A}"`)}if(m===void 0||typeof m!="string"&&m.status===404){if(s.local_files_only||!_e.allowRemoteModels){if(r)throw Error(`\`local_files_only=true\` or \`env.allowRemoteModels=false\` and file was not found locally at "${i}".`);return null}if(!p)throw Error(`Local file missing at "${i}" and download aborted due to invalid model ID "${t}".`);if(m=await Ir(l),m.status!==200)return AE(m.status,l,r);d=c}_=o&&typeof Response<"u"&&m instanceof Response&&m.status===200}gr(s.progress_callback,{status:"download",name:t,file:e});let x;if(!(ie.IS_NODE_ENV&&n)){let k;if(typeof m!="string")if(!s.progress_callback)k=new Uint8Array(await m.arrayBuffer());else if(w&&typeof navigator<"u"&&/firefox/i.test(navigator.userAgent))k=new Uint8Array(await m.arrayBuffer()),gr(s.progress_callback,{status:"progress",name:t,file:e,progress:100,loaded:k.length,total:k.length});else{let A,T=m.headers.get("content-length");if(T)A=parseInt(T,10);else try{let S=await ar(t,e,s);S.size&&(A=S.size)}catch{}k=await ME(m,S=>{gr(s.progress_callback,{status:"progress",name:t,file:e,...S})},A)}x=k}if(_&&d&&typeof m!="string"&&await vP(t,e,o,d,m,x,s),gr(s.progress_callback,{status:"done",name:t,file:e}),x){if(!ie.IS_NODE_ENV&&n)throw new Error("Cannot return path in a browser environment.");return x}if(m instanceof Tr)return m.filePath;let E=await o?.match(d);if(E instanceof Tr)return E.filePath;if(E instanceof Response)return new Uint8Array(await E.arrayBuffer());if(typeof E=="string")return E;throw new Error("Unable to get model file path or buffer.")}async function ho(t,e,r=!0,s={},n=!1){if(!_e.allowLocalModels){if(s.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(!_e.allowRemoteModels)throw Error("Invalid configuration detected: both local and remote models are disabled. Fix by setting `env.allowLocalModels` or `env.allowRemoteModels` to `true`.")}gr(s.progress_callback,{status:"initiate",name:t,file:e});let o=await Kt(s?.cache_dir);return await kP(t,e,r,s,n,o)}async function bd(t,e,r=!0,s={}){let n=await ho(t,e,r,s,!1);return n===null?null:new TextDecoder("utf-8").decode(n)}async function ut(t,e,r=!0,s={}){let n=await bd(t,e,r,s);return n===null?{}:JSON.parse(n)}function CE(t,[e,r,s],[n,o],a="bilinear",i=!1){let l=o/s,c=n/r,p=new t.constructor(n*o*e),d=r*s,_=n*o;for(let m=0;m<n;++m)for(let w=0;w<o;++w){let x=m*o+w,E=(w+.5)/l-.5,k=(m+.5)/c-.5,A=Math.floor(E),T=Math.floor(k),S=Math.min(A+1,s-1),L=Math.min(T+1,r-1);A=Math.max(A,0),T=Math.max(T,0);let O=E-A,v=k-T,W=(1-O)*(1-v),X=O*(1-v),B=(1-O)*v,H=O*v,G=T*s,Q=L*s,R=G+A,C=G+S,te=Q+A,ae=Q+S;for(let P=0;P<e;++P){let N=P*d;p[P*_+x]=W*t[N+R]+X*t[N+C]+B*t[N+te]+H*t[N+ae]}}return p}function LE(t,e,r){let s=new Array(r.length),n=new Array(r.length);for(let i=r.length-1,l=1;i>=0;--i)n[i]=l,s[i]=e[r[i]],l*=s[i];let o=r.map((i,l)=>n[r.indexOf(l)]),a=new t.constructor(t.length);for(let i=0;i<t.length;++i){let l=0;for(let c=e.length-1,p=i;c>=0;--c)l+=p%e[c]*o[c],p=Math.floor(p/e[c]);a[l]=t[i]}return[a,s]}function Ne(t){let e=Oe(t)[0],r=t.map(o=>Math.exp(o-e)),s=r.reduce((o,a)=>o+a,0);return r.map(o=>o/s)}function kd(t){let e=Oe(t)[0],r=0;for(let o=0;o<t.length;++o)r+=Math.exp(t[o]-e);let s=Math.log(r);return t.map(o=>o-e-s)}function PE(t,e){let r=0;for(let s=0;s<t.length;++s)r+=t[s]*e[s];return r}function EP(t,e){let r=PE(t,e),s=IE(t),n=IE(e);return r/(s*n)}function IE(t){return Math.sqrt(t.reduce((e,r)=>e+r*r,0))}function go(t){if(t.length===0)throw Error("Array must not be empty");let e=t[0],r=0;for(let s=1;s<t.length;++s)t[s]<e&&(e=t[s],r=s);return[e,r]}function Oe(t){if(t.length===0)throw Error("Array must not be empty");let e=t[0],r=0;for(let s=1;s<t.length;++s)t[s]>e&&(e=t[s],r=s);return[e,r]}function zE(t){return t>0&&(t&t-1)===0}var nc=class{constructor(e){if(this.size=e|0,this.size<=1||!zE(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 s=0;s<this.table.length;s+=2){let n=Math.PI*s/this.size;this.table[s]=Math.cos(n),this.table[s+1]=-Math.sin(n)}let r=0;for(let s=1;this.size>s;s<<=1)++r;this._width=r%2===0?r-1:r,this._bitrev=new Int32Array(1<<this._width);for(let s=0;s<this._bitrev.length;++s){this._bitrev[s]=0;for(let n=0;n<this._width;n+=2){let o=this._width-n-2;this._bitrev[s]|=(s>>>n&3)<<o}}}createComplexArray(){return new Float64Array(this._csize)}fromComplexArray(e,r){let s=r||new Array(e.length>>>1);for(let n=0;n<e.length;n+=2)s[n>>>1]=e[n];return s}toComplexArray(e,r){let s=r||this.createComplexArray();for(let n=0;n<s.length;n+=2)s[n]=e[n>>>1],s[n+1]=0;return s}transform(e,r){if(e===r)throw new Error("Input and output buffers must be different");this._transform4(e,r,1)}realTransform(e,r){if(e===r)throw new Error("Input and output buffers must be different");this._realTransform4(e,r,1)}inverseTransform(e,r){if(e===r)throw new Error("Input and output buffers must be different");this._transform4(e,r,-1);for(let s=0;s<e.length;++s)e[s]/=this.size}_transform4(e,r,s){let n=this._csize,a=1<<this._width,i=n/a<<1,l,c,p=this._bitrev;if(i===4)for(l=0,c=0;l<n;l+=i,++c){let _=p[c];this._singleTransform2(r,e,l,_,a)}else for(l=0,c=0;l<n;l+=i,++c){let _=p[c];this._singleTransform4(r,e,l,_,a,s)}let d=this.table;for(a>>=2;a>=2;a>>=2){i=n/a<<1;let _=i>>>2;for(l=0;l<n;l+=i){let m=l+_-1;for(let w=l,x=0;w<m;w+=2,x+=a){let E=w,k=E+_,A=k+_,T=A+_,S=e[E],L=e[E+1],O=e[k],v=e[k+1],W=e[A],X=e[A+1],B=e[T],H=e[T+1],G=d[x],Q=s*d[x+1],R=O*G-v*Q,C=O*Q+v*G,te=d[2*x],ae=s*d[2*x+1],P=W*te-X*ae,N=W*ae+X*te,F=d[3*x],J=s*d[3*x+1],xe=B*F-H*J,ue=B*J+H*F,qe=S+P,ot=L+N,_t=S-P,at=L-N,vt=R+xe,Fe=C+ue,Me=s*(R-xe),Ze=s*(C-ue);e[E]=qe+vt,e[E+1]=ot+Fe,e[k]=_t+Ze,e[k+1]=at-Me,e[A]=qe-vt,e[A+1]=ot-Fe,e[T]=_t-Ze,e[T+1]=at+Me}}}}_singleTransform2(e,r,s,n,o){let a=e[n],i=e[n+1],l=e[n+o],c=e[n+o+1];r[s]=a+l,r[s+1]=i+c,r[s+2]=a-l,r[s+3]=i-c}_singleTransform4(e,r,s,n,o,a){let i=o*2,l=o*3,c=e[n],p=e[n+1],d=e[n+o],_=e[n+o+1],m=e[n+i],w=e[n+i+1],x=e[n+l],E=e[n+l+1],k=c+m,A=p+w,T=c-m,S=p-w,L=d+x,O=_+E,v=a*(d-x),W=a*(_-E);r[s]=k+L,r[s+1]=A+O,r[s+2]=T+W,r[s+3]=S-v,r[s+4]=k-L,r[s+5]=A-O,r[s+6]=T-W,r[s+7]=S+v}_realTransform4(e,r,s){let n=this._csize,a=1<<this._width,i=n/a<<1,l,c,p=this._bitrev;if(i===4)for(l=0,c=0;l<n;l+=i,++c){let m=p[c];this._singleRealTransform2(r,e,l,m>>>1,a>>>1)}else for(l=0,c=0;l<n;l+=i,++c){let m=p[c];this._singleRealTransform4(r,e,l,m>>>1,a>>>1,s)}let d=this.table;for(a>>=2;a>=2;a>>=2){i=n/a<<1;let m=i>>>1,w=m>>>1,x=w>>>1;for(l=0;l<n;l+=i)for(let E=0,k=0;E<=x;E+=2,k+=a){let A=l+E,T=A+w,S=T+w,L=S+w,O=e[A],v=e[A+1],W=e[T],X=e[T+1],B=e[S],H=e[S+1],G=e[L],Q=e[L+1],R=O,C=v,te=d[k],ae=s*d[k+1],P=W*te-X*ae,N=W*ae+X*te,F=d[2*k],J=s*d[2*k+1],xe=B*F-H*J,ue=B*J+H*F,qe=d[3*k],ot=s*d[3*k+1],_t=G*qe-Q*ot,at=G*ot+Q*qe,vt=R+xe,Fe=C+ue,Me=R-xe,Ze=C-ue,er=P+_t,Pe=N+at,Be=s*(P-_t),Vs=s*(N-at);if(e[A]=vt+er,e[A+1]=Fe+Pe,e[T]=Me+Vs,e[T+1]=Ze-Be,E===0){e[S]=vt-er,e[S+1]=Fe-Pe;continue}if(E===x)continue;let to=l+w-E,Hs=l+m-E;e[to]=Me-s*Vs,e[to+1]=-Ze-s*Be,e[Hs]=vt-s*er,e[Hs+1]=-Fe+s*Pe}}let _=n>>>1;for(let m=2;m<_;m+=2)e[n-m]=e[m],e[n-m+1]=-e[m+1]}_singleRealTransform2(e,r,s,n,o){let a=e[n],i=e[n+o];r[s]=a+i,r[s+1]=0,r[s+2]=a-i,r[s+3]=0}_singleRealTransform4(e,r,s,n,o,a){let i=o*2,l=o*3,c=e[n],p=e[n+o],d=e[n+i],_=e[n+l],m=c+d,w=c-d,x=p+_,E=a*(p-_);r[s]=m+x,r[s+1]=0,r[s+2]=w,r[s+3]=-E,r[s+4]=m-x,r[s+5]=0,r[s+6]=w,r[s+7]=E}},vd=class{constructor(e){let r=2*(e-1),s=2*(2*e-1),n=2**Math.ceil(Math.log2(s));this.bufferSize=n,this._a=r;let o=new Float64Array(s),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);let i=-2*Math.PI/e,l=Math.cos(i),c=Math.sin(i);for(let p=0;p<s>>1;++p){let d=(p+1-e)**2/2,_=Math.sqrt(l**2+c**2)**d,m=d*Math.atan2(c,l),w=2*p;o[w]=_*Math.cos(m),o[w+1]=_*Math.sin(m),a[w]=o[w],a[w+1]=-o[w+1]}this._slicedChirpBuffer=o.subarray(r,s),this._f=new nc(n>>1),this._f.transform(this._chirpBuffer,a)}_transform(e,r,s){let n=this._buffer1,o=this._buffer2,a=this._outBuffer1,i=this._outBuffer2,l=this._chirpBuffer,c=this._slicedChirpBuffer,p=this._a;if(s)for(let d=0;d<c.length;d+=2){let _=d+1,m=d>>1,w=r[m];n[d]=w*c[d],n[_]=w*c[_]}else for(let d=0;d<c.length;d+=2){let _=d+1;n[d]=r[d]*c[d]-r[_]*c[_],n[_]=r[d]*c[_]+r[_]*c[d]}this._f.transform(a,n);for(let d=0;d<l.length;d+=2){let _=d+1;o[d]=a[d]*l[d]-a[_]*l[_],o[_]=a[d]*l[_]+a[_]*l[d]}this._f.inverseTransform(i,o);for(let d=0;d<i.length;d+=2){let _=i[d+p],m=i[d+p+1],w=c[d],x=c[d+1];e[d]=_*w-m*x,e[d+1]=_*x+m*w}}transform(e,r){this._transform(e,r,!1)}realTransform(e,r){this._transform(e,r,!0)}},oc=class{constructor(e){this.fft_length=e,this.isPowerOfTwo=zE(e),this.isPowerOfTwo?(this.fft=new nc(e),this.outputBufferSize=2*e):(this.fft=new vd(e),this.outputBufferSize=this.fft.bufferSize)}realTransform(e,r){this.fft.realTransform(e,r)}transform(e,r){this.fft.transform(e,r)}};function NE(t,e){if(e%2===0||e<=0)throw new Error("Window size must be a positive odd number");let r=new t.constructor(t.length),s=new t.constructor(e),n=Math.floor(e/2);for(let o=0;o<t.length;++o){let a=0;for(let i=-n;i<=n;++i){let l=o+i;l<0?l=Math.abs(l):l>=t.length&&(l=2*(t.length-1)-l),s[a++]=t[l]}s.sort(),r[o]=s[n]}return r}function ds(t,e){let r=Math.pow(10,e);return Math.round(t*r)/r}function $E(t){let e=Math.round(t);return Math.abs(t)%1===.5?e%2===0?e:e-1:e}function RE(t){let e=t.length,r=t[0].length,s=[e+1,r+1],n=Array.from({length:s[0]},()=>Array(s[1]).fill(1/0));n[0][0]=0;let o=Array.from({length:s[0]},()=>Array(s[1]).fill(-1));for(let p=1;p<s[1];++p)for(let d=1;d<s[0];++d){let _=n[d-1][p-1],m=n[d-1][p],w=n[d][p-1],x,E;_<m&&_<w?(x=_,E=0):m<_&&m<w?(x=m,E=1):(x=w,E=2),n[d][p]=t[d-1][p-1]+x,o[d][p]=E}for(let p=0;p<s[1];++p)o[0][p]=2;for(let p=0;p<s[0];++p)o[p][0]=1;let a=e,i=r,l=[],c=[];for(;a>0||i>0;)switch(l.push(a-1),c.push(i-1),o[a][i]){case 0:--a,--i;break;case 1:--a;break;case 2:--i;break;default:throw new Error(`Internal error in dynamic time warping. Unexpected trace[${a}, ${i}]. Please file a bug report.`)}return l.reverse(),c.reverse(),[l,c]}var DE=(function(){let t=null;return function(e){if(!t){t=new Float32Array(65536);let o=new ArrayBuffer(4),a=new Uint32Array(o),i=new Float32Array(o);for(let l=0;l<t.length;++l){let c=0,p=(l&32768)<<16,d=(l&31744)>>10,_=l&1023;if(d===31)c=p|2139095040|_<<13;else if(d===0)if(_===0)c=p;else{let m=113;for(;(_&1024)===0;)_<<=1,--m;_&=-1025,c=p|m<<23|_<<13}else c=p|d+112<<23|_<<13;a[0]=c,t[l]=i[0]}}let r=e.length,s=t,n=new Float32Array(r);for(let o=0;o<r;++o)n[o]=s[e[o]];return n}})();import*as ez from"onnxruntime-node";var _f={};Zs(_f,{InferenceSession:()=>Jd,TRACE:()=>_c,TRACE_EVENT_BEGIN:()=>Rr,TRACE_EVENT_END:()=>Dr,TRACE_FUNC_BEGIN:()=>ws,TRACE_FUNC_END:()=>xs,Tensor:()=>Qt,default:()=>ZP,env:()=>Ve,registerBackend:()=>gs});var Qd=Object.defineProperty,AP=Object.getOwnPropertyDescriptor,MP=Object.getOwnPropertyNames,SP=Object.prototype.hasOwnProperty,TP=(t=>typeof ls<"u"?ls:typeof Proxy<"u"?new Proxy(t,{get:(e,r)=>(typeof ls<"u"?ls:e)[r]}):t)(function(t){if(typeof ls<"u")return ls.apply(this,arguments);throw Error('Dynamic require of "'+t+'" is not supported')}),be=(t,e)=>()=>(t&&(e=t(t=0)),e),Ao=(t,e)=>{for(var r in e)Qd(t,r,{get:e[r],enumerable:!0})},OP=(t,e,r,s)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of MP(e))!SP.call(t,n)&&n!==r&&Qd(t,n,{get:()=>e[n],enumerable:!(s=AP(e,n))||s.enumerable});return t},fc=t=>OP(Qd({},"__esModule",{value:!0}),t),wo,Pr,gs,FE,dA,fA=be(()=>{"use strict";wo=new Map,Pr=[],gs=(t,e,r)=>{if(e&&typeof e.init=="function"&&typeof e.createInferenceSessionHandler=="function"){let s=wo.get(t);if(s===void 0)wo.set(t,{backend:e,priority:r});else{if(s.priority>r)return;if(s.priority===r&&s.backend!==e)throw new Error(`cannot register backend "${t}" using priority ${r}`)}if(r>=0){let n=Pr.indexOf(t);n!==-1&&Pr.splice(n,1);for(let o=0;o<Pr.length;o++)if(wo.get(Pr[o]).priority<=r){Pr.splice(o,0,t);return}Pr.push(t)}return}throw new TypeError("not a valid backend")},FE=async t=>{let e=wo.get(t);if(!e)return"backend not found.";if(e.initialized)return e.backend;if(e.aborted)return e.error;{let r=!!e.initPromise;try{return r||(e.initPromise=e.backend.init(t)),await e.initPromise,e.initialized=!0,e.backend}catch(s){return r||(e.error=`${s}`,e.aborted=!0),e.error}finally{delete e.initPromise}}},dA=async t=>{let e=t.executionProviders||[],r=e.map(l=>typeof l=="string"?l:l.name),s=r.length===0?Pr:r,n,o=[],a=new Set;for(let l of s){let c=await FE(l);typeof c=="string"?o.push({name:l,err:c}):(n||(n=c),n===c&&a.add(l))}if(!n)throw new Error(`no available backend found. ERR: ${o.map(l=>`[${l.name}] ${l.err}`).join(", ")}`);for(let{name:l,err:c}of o)r.includes(l)&&console.warn(`removing requested execution provider "${l}" from session options because it is not available: ${c}`);let i=e.filter(l=>a.has(typeof l=="string"?l:l.name));return[n,new Proxy(t,{get:(l,c)=>c==="executionProviders"?i:Reflect.get(l,c)})]}}),IP=be(()=>{"use strict";fA()}),_A,CP=be(()=>{"use strict";_A="1.24.0-dev.20251116-b39e144322"}),Ed,pt,mA=be(()=>{"use strict";CP(),Ed="warning",pt={wasm:{},webgl:{},webgpu:{},versions:{common:_A},set logLevel(t){if(t!==void 0){if(typeof t!="string"||["verbose","info","warning","error","fatal"].indexOf(t)===-1)throw new Error(`Unsupported logging level: ${t}`);Ed=t}},get logLevel(){return Ed}},Object.defineProperty(pt,"logLevel",{enumerable:!0})}),Ve,LP=be(()=>{"use strict";mA(),Ve=pt}),hA,gA,PP=be(()=>{"use strict";hA=(t,e)=>{let r=typeof document<"u"?document.createElement("canvas"):new OffscreenCanvas(1,1);r.width=t.dims[3],r.height=t.dims[2];let s=r.getContext("2d");if(s!=null){let n,o;e?.tensorLayout!==void 0&&e.tensorLayout==="NHWC"?(n=t.dims[2],o=t.dims[3]):(n=t.dims[3],o=t.dims[2]);let a=e?.format!==void 0?e.format:"RGB",i=e?.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 p=o*n,d=0,_=p,m=p*2,w=-1;a==="RGBA"?(d=0,_=p,m=p*2,w=p*3):a==="RGB"?(d=0,_=p,m=p*2):a==="RBG"&&(d=0,m=p,_=p*2);for(let x=0;x<o;x++)for(let E=0;E<n;E++){let k=(t.data[d++]-c[0])*l[0],A=(t.data[_++]-c[1])*l[1],T=(t.data[m++]-c[2])*l[2],S=w===-1?255:(t.data[w++]-c[3])*l[3];s.fillStyle="rgba("+k+","+A+","+T+","+S+")",s.fillRect(E,x,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")},gA=(t,e)=>{let r=typeof document<"u"?document.createElement("canvas").getContext("2d"):new OffscreenCanvas(1,1).getContext("2d"),s;if(r!=null){let n,o,a;e?.tensorLayout!==void 0&&e.tensorLayout==="NHWC"?(n=t.dims[2],o=t.dims[1],a=t.dims[3]):(n=t.dims[3],o=t.dims[2],a=t.dims[1]);let i=e!==void 0&&e.format!==void 0?e.format:"RGB",l=e?.norm,c,p;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?p=[0,0,0,0]:typeof l.bias=="number"?p=[l.bias,l.bias,l.bias,l.bias]:(p=[l.bias[0],l.bias[1],l.bias[2],0],l.bias[3]!==void 0&&(p[3]=l.bias[3]));let d=o*n;if(e!==void 0&&(e.format!==void 0&&a===4&&e.format!=="RGBA"||a===3&&e.format!=="RGB"&&e.format!=="BGR"))throw new Error("Tensor format doesn't match input tensor dims");let _=4,m=0,w=1,x=2,E=3,k=0,A=d,T=d*2,S=-1;i==="RGBA"?(k=0,A=d,T=d*2,S=d*3):i==="RGB"?(k=0,A=d,T=d*2):i==="RBG"&&(k=0,T=d,A=d*2),s=r.createImageData(n,o);for(let L=0;L<o*n;m+=_,w+=_,x+=_,E+=_,L++)s.data[m]=(t.data[k++]-p[0])*c[0],s.data[w]=(t.data[A++]-p[1])*c[1],s.data[x]=(t.data[T++]-p[2])*c[2],s.data[E]=S===-1?255:(t.data[S++]-p[3])*c[3]}else throw new Error("Can not access image data");return s}}),ac,wA,xA,yA,bA,vA,zP=be(()=>{"use strict";Yd(),ac=(t,e)=>{if(t===void 0)throw new Error("Image buffer must be defined");if(e.height===void 0||e.width===void 0)throw new Error("Image height and width must be defined");if(e.tensorLayout==="NHWC")throw new Error("NHWC Tensor layout is not supported yet");let{height:r,width:s}=e,n=e.norm??{mean:255,bias:0},o,a;typeof n.mean=="number"?o=[n.mean,n.mean,n.mean,n.mean]:o=[n.mean[0],n.mean[1],n.mean[2],n.mean[3]??255],typeof n.bias=="number"?a=[n.bias,n.bias,n.bias,n.bias]:a=[n.bias[0],n.bias[1],n.bias[2],n.bias[3]??0];let i=e.format!==void 0?e.format:"RGBA",l=e.tensorFormat!==void 0&&e.tensorFormat!==void 0?e.tensorFormat:"RGB",c=r*s,p=l==="RGBA"?new Float32Array(c*4):new Float32Array(c*3),d=4,_=0,m=1,w=2,x=3,E=0,k=c,A=c*2,T=-1;i==="RGB"&&(d=3,_=0,m=1,w=2,x=-1),l==="RGBA"?T=c*3:l==="RBG"?(E=0,A=c,k=c*2):l==="BGR"&&(A=0,k=c,E=c*2);for(let S=0;S<c;S++,_+=d,w+=d,m+=d,x+=d)p[E++]=(t[_]+a[0])/o[0],p[k++]=(t[m]+a[1])/o[1],p[A++]=(t[w]+a[2])/o[2],T!==-1&&x!==-1&&(p[T++]=(t[x]+a[3])/o[3]);return l==="RGBA"?new Pt("float32",p,[1,4,r,s]):new Pt("float32",p,[1,3,r,s])},wA=async(t,e)=>{let r=typeof HTMLImageElement<"u"&&t instanceof HTMLImageElement,s=typeof ImageData<"u"&&t instanceof ImageData,n=typeof ImageBitmap<"u"&&t instanceof ImageBitmap,o=typeof t=="string",a,i=e??{},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=p=>typeof HTMLCanvasElement<"u"&&p instanceof HTMLCanvasElement||p instanceof OffscreenCanvas?p.getContext("2d"):null;if(r){let p=l();p.width=t.width,p.height=t.height;let d=c(p);if(d!=null){let _=t.height,m=t.width;if(e!==void 0&&e.resizedHeight!==void 0&&e.resizedWidth!==void 0&&(_=e.resizedHeight,m=e.resizedWidth),e!==void 0){if(i=e,e.tensorFormat!==void 0)throw new Error("Image input config format must be RGBA for HTMLImageElement");i.tensorFormat="RGBA",i.height=_,i.width=m}else i.tensorFormat="RGBA",i.height=_,i.width=m;d.drawImage(t,0,0),a=d.getImageData(0,0,m,_).data}else throw new Error("Can not access image data")}else if(s){let p,d;if(e!==void 0&&e.resizedWidth!==void 0&&e.resizedHeight!==void 0?(p=e.resizedHeight,d=e.resizedWidth):(p=t.height,d=t.width),e!==void 0&&(i=e),i.format="RGBA",i.height=p,i.width=d,e!==void 0){let _=l();_.width=d,_.height=p;let m=c(_);if(m!=null)m.putImageData(t,0,0),a=m.getImageData(0,0,d,p).data;else throw new Error("Can not access image data")}else a=t.data}else if(n){if(e===void 0)throw new Error("Please provide image config with format for Imagebitmap");let p=l();p.width=t.width,p.height=t.height;let d=c(p);if(d!=null){let _=t.height,m=t.width;return d.drawImage(t,0,0,m,_),a=d.getImageData(0,0,m,_).data,i.height=_,i.width=m,ac(a,i)}else throw new Error("Can not access image data")}else{if(o)return new Promise((p,d)=>{let _=l(),m=c(_);if(!t||!m)return d();let w=new Image;w.crossOrigin="Anonymous",w.src=t,w.onload=()=>{_.width=w.width,_.height=w.height,m.drawImage(w,0,0,_.width,_.height);let x=m.getImageData(0,0,_.width,_.height);i.height=_.height,i.width=_.width,p(ac(x.data,i))}});throw new Error("Input data provided is not supported - aborted tensor creation")}if(a!==void 0)return ac(a,i);throw new Error("Input data provided is not supported - aborted tensor creation")},xA=(t,e)=>{let{width:r,height:s,download:n,dispose:o}=e,a=[1,s,r,4];return new Pt({location:"texture",type:"float32",texture:t,dims:a,download:n,dispose:o})},yA=(t,e)=>{let{dataType:r,dims:s,download:n,dispose:o}=e;return new Pt({location:"gpu-buffer",type:r??"float32",gpuBuffer:t,dims:s,download:n,dispose:o})},bA=(t,e)=>{let{dataType:r,dims:s,download:n,dispose:o}=e;return new Pt({location:"ml-tensor",type:r??"float32",mlTensor:t,dims:s,download:n,dispose:o})},vA=(t,e,r)=>new Pt({location:"cpu-pinned",type:t,data:e,dims:r??[e.length]})}),ms,ko,Ad,kA,NP=be(()=>{"use strict";ms=new Map([["float32",Float32Array],["uint8",Uint8Array],["int8",Int8Array],["uint16",Uint16Array],["int16",Int16Array],["int32",Int32Array],["bool",Uint8Array],["float64",Float64Array],["uint32",Uint32Array],["int4",Uint8Array],["uint4",Uint8Array]]),ko=new Map([[Float32Array,"float32"],[Uint8Array,"uint8"],[Int8Array,"int8"],[Uint16Array,"uint16"],[Int16Array,"int16"],[Int32Array,"int32"],[Float64Array,"float64"],[Uint32Array,"uint32"]]),Ad=!1,kA=()=>{if(!Ad){Ad=!0;let t=typeof BigInt64Array<"u"&&BigInt64Array.from,e=typeof BigUint64Array<"u"&&BigUint64Array.from,r=globalThis.Float16Array,s=typeof r<"u"&&r.from;t&&(ms.set("int64",BigInt64Array),ko.set(BigInt64Array,"int64")),e&&(ms.set("uint64",BigUint64Array),ko.set(BigUint64Array,"uint64")),s?(ms.set("float16",r),ko.set(r,"float16")):ms.set("float16",Uint16Array)}}}),EA,AA,$P=be(()=>{"use strict";Yd(),EA=t=>{let e=1;for(let r=0;r<t.length;r++){let s=t[r];if(typeof s!="number"||!Number.isSafeInteger(s))throw new TypeError(`dims[${r}] must be an integer, got: ${s}`);if(s<0)throw new RangeError(`dims[${r}] must be a non-negative integer, got: ${s}`);e*=s}return e},AA=(t,e)=>{switch(t.location){case"cpu":return new Pt(t.type,t.data,e);case"cpu-pinned":return new Pt({location:"cpu-pinned",data:t.data,type:t.type,dims:e});case"texture":return new Pt({location:"texture",texture:t.texture,type:t.type,dims:e});case"gpu-buffer":return new Pt({location:"gpu-buffer",gpuBuffer:t.gpuBuffer,type:t.type,dims:e});case"ml-tensor":return new Pt({location:"ml-tensor",mlTensor:t.mlTensor,type:t.type,dims:e});default:throw new Error(`tensorReshape: tensor location ${t.location} is not supported`)}}}),Pt,Yd=be(()=>{"use strict";PP(),zP(),NP(),$P(),Pt=class{constructor(t,e,r){kA();let s,n;if(typeof t=="object"&&"location"in t)switch(this.dataLocation=t.location,s=t.type,n=t.dims,t.location){case"cpu-pinned":{let a=ms.get(s);if(!a)throw new TypeError(`unsupported type "${s}" to create tensor from pinned buffer`);if(!(t.data instanceof a))throw new TypeError(`buffer should be of type ${a.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 a,i;if(typeof t=="string")if(s=t,i=r,t==="string"){if(!Array.isArray(e))throw new TypeError("A string tensor's data must be a string array.");a=e}else{let l=ms.get(t);if(l===void 0)throw new TypeError(`Unsupported tensor type: ${t}.`);if(Array.isArray(e)){if(t==="float16"&&l===Uint16Array||t==="uint4"||t==="int4")throw new TypeError(`Creating a ${t} tensor from number array is not supported. Please use ${l.name} as data.`);t==="uint64"||t==="int64"?a=l.from(e,BigInt):a=l.from(e)}else if(e instanceof l)a=e;else if(e instanceof Uint8ClampedArray)if(t==="uint8")a=Uint8Array.from(e);else throw new TypeError("A Uint8ClampedArray tensor's data must be type of uint8");else if(t==="float16"&&e instanceof Uint16Array&&l!==Uint16Array)a=new globalThis.Float16Array(e.buffer,e.byteOffset,e.length);else throw new TypeError(`A ${s} tensor's data must be type of ${l}`)}else if(i=e,Array.isArray(t)){if(t.length===0)throw new TypeError("Tensor type cannot be inferred from an empty array.");let l=typeof t[0];if(l==="string")s="string",a=t;else if(l==="boolean")s="bool",a=Uint8Array.from(t);else throw new TypeError(`Invalid element type of data array: ${l}.`)}else if(t instanceof Uint8ClampedArray)s="uint8",a=Uint8Array.from(t);else{let l=ko.get(t.constructor);if(l===void 0)throw new TypeError(`Unsupported type for tensor data: ${t.constructor}.`);s=l,a=t}if(i===void 0)i=[a.length];else if(!Array.isArray(i))throw new TypeError("A tensor's dims must be a number array");n=i,this.cpuData=a,this.dataLocation="cpu"}let o=EA(n);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=n,this.size=o}static async fromImage(t,e){return wA(t,e)}static fromTexture(t,e){return xA(t,e)}static fromGpuBuffer(t,e){return yA(t,e)}static fromMLTensor(t,e){return bA(t,e)}static fromPinnedBuffer(t,e,r){return vA(t,e,r)}toDataURL(t){return hA(this,t)}toImageData(t){return gA(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;let e=await this.downloader();return this.downloader=void 0,this.dataLocation="cpu",this.cpuData=e,t&&this.disposer&&(this.disposer(),this.disposer=void 0),e}finally{this.isDownloading=!1}}default:throw new Error(`cannot get data from location: ${this.dataLocation}`)}}dispose(){if(this.isDownloading)throw new Error("The current tensor is being downloaded.");this.disposer&&(this.disposer(),this.disposer=void 0),this.cpuData=void 0,this.gpuTextureData=void 0,this.gpuBufferData=void 0,this.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 AA(this,t)}}}),Qt,MA=be(()=>{"use strict";Yd(),Qt=Pt}),_c,Md,ws,xs,Rr,Dr,SA=be(()=>{"use strict";mA(),_c=(t,e)=>{(typeof pt.trace>"u"?!pt.wasm.trace:!pt.trace)||console.timeStamp(`${t}::ORT::${e}`)},Md=(t,e)=>{let r=new Error().stack?.split(/\r\n|\r|\n/g)||[],s=!1;for(let n=0;n<r.length;n++){if(s&&!r[n].includes("TRACE_FUNC")){let o=`FUNC_${t}::${r[n].trim().split(" ")[1]}`;e&&(o+=`::${e}`),_c("CPU",o);return}r[n].includes("TRACE_FUNC")&&(s=!0)}},ws=t=>{(typeof pt.trace>"u"?!pt.wasm.trace:!pt.trace)||Md("BEGIN",t)},xs=t=>{(typeof pt.trace>"u"?!pt.wasm.trace:!pt.trace)||Md("END",t)},Rr=t=>{(typeof pt.trace>"u"?!pt.wasm.trace:!pt.trace)||console.time(`ORT::${t}`)},Dr=t=>{(typeof pt.trace>"u"?!pt.wasm.trace:!pt.trace)||console.timeEnd(`ORT::${t}`)}}),TA,RP=be(()=>{"use strict";fA(),MA(),SA(),TA=class OA{constructor(e){this.handler=e}async run(e,r,s){ws(),Rr("InferenceSession.run");let n={},o={};if(typeof e!="object"||e===null||e instanceof Qt||Array.isArray(e))throw new TypeError("'feeds' must be an object that use input names as keys and OnnxValue as corresponding values.");let a=!0;if(typeof r=="object"){if(r===null)throw new TypeError("Unexpected argument[1]: cannot be null.");if(r instanceof Qt)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.");a=!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}.`);n[c]=null}if(typeof s=="object"&&s!==null)o=s;else if(typeof s<"u")throw new TypeError("'options' must be an object.")}else{let c=!1,p=Object.getOwnPropertyNames(r);for(let d of this.outputNames)if(p.indexOf(d)!==-1){let _=r[d];(_===null||_ instanceof Qt)&&(c=!0,a=!1,n[d]=_)}if(c){if(typeof s=="object"&&s!==null)o=s;else if(typeof s<"u")throw new TypeError("'options' must be an object.")}else o=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 e[c]>"u")throw new Error(`input '${c}' is missing in 'feeds'.`);if(a)for(let c of this.outputNames)n[c]=null;let i=await this.handler.run(e,n,o),l={};for(let c in i)if(Object.hasOwnProperty.call(i,c)){let p=i[c];p instanceof Qt?l[c]=p:l[c]=new Qt(p.type,p.data,p.dims)}return Dr("InferenceSession.run"),xs(),l}async release(){return this.handler.dispose()}static async create(e,r,s,n){ws(),Rr("InferenceSession.create");let o,a={};if(typeof e=="string"){if(o=e,typeof r=="object"&&r!==null)a=r;else if(typeof r<"u")throw new TypeError("'options' must be an object.")}else if(e instanceof Uint8Array){if(o=e,typeof r=="object"&&r!==null)a=r;else if(typeof r<"u")throw new TypeError("'options' must be an object.")}else if(e instanceof ArrayBuffer||typeof SharedArrayBuffer<"u"&&e instanceof SharedArrayBuffer){let p=e,d=0,_=e.byteLength;if(typeof r=="object"&&r!==null)a=r;else if(typeof r=="number"){if(d=r,!Number.isSafeInteger(d))throw new RangeError("'byteOffset' must be an integer.");if(d<0||d>=p.byteLength)throw new RangeError(`'byteOffset' is out of range [0, ${p.byteLength}).`);if(_=e.byteLength-d,typeof s=="number"){if(_=s,!Number.isSafeInteger(_))throw new RangeError("'byteLength' must be an integer.");if(_<=0||d+_>p.byteLength)throw new RangeError(`'byteLength' is out of range (0, ${p.byteLength-d}].`);if(typeof n=="object"&&n!==null)a=n;else if(typeof n<"u")throw new TypeError("'options' must be an object.")}else if(typeof s<"u")throw new TypeError("'byteLength' must be a number.")}else if(typeof r<"u")throw new TypeError("'options' must be an object.");o=new Uint8Array(p,d,_)}else throw new TypeError("Unexpected argument[0]: must be 'path' or 'buffer'.");let[i,l]=await dA(a),c=await i.createInferenceSessionHandler(o,l);return Dr("InferenceSession.create"),xs(),new OA(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}}}),Jd,DP=be(()=>{"use strict";RP(),Jd=TA}),FP=be(()=>{"use strict"}),BP=be(()=>{"use strict"}),UP=be(()=>{"use strict"}),jP=be(()=>{"use strict"}),IA={};Ao(IA,{InferenceSession:()=>Jd,TRACE:()=>_c,TRACE_EVENT_BEGIN:()=>Rr,TRACE_EVENT_END:()=>Dr,TRACE_FUNC_BEGIN:()=>ws,TRACE_FUNC_END:()=>xs,Tensor:()=>Qt,env:()=>Ve,registerBackend:()=>gs});var ys=be(()=>{"use strict";IP(),LP(),DP(),MA(),FP(),BP(),SA(),UP(),jP()}),Zd=be(()=>{"use strict"}),CA={};Ao(CA,{default:()=>LA});var Sd,Td,LA,GP=be(()=>{"use strict";HA(),bs(),ef(),Sd="ort-wasm-proxy-worker",Td=globalThis.self?.name===Sd,Td&&(self.onmessage=t=>{let{type:e,in:r}=t.data;try{switch(e){case"init-wasm":tf(r.wasm).then(()=>{af(r).then(()=>{postMessage({type:e})},s=>{postMessage({type:e,err:s})})},s=>{postMessage({type:e,err:s})});break;case"init-ep":{let{epName:s,env:n}=r;lf(n,s).then(()=>{postMessage({type:e})},o=>{postMessage({type:e,err:o})});break}case"copy-from":{let{buffer:s}=r,n=gc(s);postMessage({type:e,out:n});break}case"create":{let{model:s,options:n}=r;cf(s,n).then(o=>{postMessage({type:e,out:o})},o=>{postMessage({type:e,err:o})});break}case"release":uf(r),postMessage({type:e});break;case"run":{let{sessionId:s,inputIndices:n,inputs:o,outputIndices:a,options:i}=r;pf(s,n,o,a,new Array(a.length).fill(null),i).then(l=>{l.some(c=>c[3]!=="cpu")?postMessage({type:e,err:"Proxy does not support non-cpu tensor location."}):postMessage({type:e,out:l},ff([...o,...l]))},l=>{postMessage({type:e,err:l})});break}case"end-profiling":df(r),postMessage({type:e});break;default:}}catch(s){postMessage({type:e,err:s})}}),LA=Td?null:t=>new Worker(t??Ct,{type:"module",name:Sd})}),PA={};Ao(PA,{default:()=>zA});async function BE(t={}){var e=t,r=!!globalThis.window,s=!!globalThis.WorkerGlobalScope,n=s&&self.name?.startsWith("em-pthread");e.mountExternalData=(u,f)=>{u.startsWith("./")&&(u=u.substring(2)),(e.Uc||(e.Uc=new Map)).set(u,f)},e.unmountExternalData=()=>{delete e.Uc},globalThis.SharedArrayBuffer??new WebAssembly.Memory({initial:0,maximum:0,Be:!0}).buffer.constructor;let o=()=>{let u=f=>(...h)=>{let g=rr;return h=f(...h),rr!=g?new Promise((b,M)=>{Gp={resolve:b,reject:M}}):h};(()=>{for(let f of["_OrtAppendExecutionProvider","_OrtCreateSession","_OrtRun","_OrtRunWithBinding","_OrtBindInput"])e[f]=u(e[f])})(),typeof jsepRunAsync<"u"&&(e._OrtRun=jsepRunAsync(e._OrtRun),e._OrtRunWithBinding=jsepRunAsync(e._OrtRunWithBinding)),o=void 0};e.asyncInit=()=>{o?.()};var a,i,l=(u,f)=>{throw f},c=import.meta.url,p="";if(r||s){try{p=new URL(".",c).href}catch{}s&&(i=u=>{var f=new XMLHttpRequest;return f.open("GET",u,!1),f.responseType="arraybuffer",f.send(null),new Uint8Array(f.response)}),a=async u=>{if(O(u))return new Promise((h,g)=>{var b=new XMLHttpRequest;b.open("GET",u,!0),b.responseType="arraybuffer",b.onload=()=>{b.status==200||b.status==0&&b.response?h(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 d,_,m,w,x,E,k=console.log.bind(console),A=console.error.bind(console),T=k,S=A,L=!1,O=u=>u.startsWith("file://");function v(){Mr.buffer!=B.buffer&&xe()}if(n){let u=function(f){try{var h=f.data,g=h.Oc;if(g==="load"){let b=[];self.onmessage=M=>b.push(M),E=()=>{postMessage({Oc:"loaded"});for(let M of b)u(M);self.onmessage=u};for(let M of h.de)e[M]&&!e[M].proxy||(e[M]=(...I)=>{postMessage({Oc:"callHandler",ce:M,args:I})},M=="print"&&(T=e[M]),M=="printErr"&&(S=e[M]));Mr=h.je,xe(),_=h.ke,_t(),Wl()}else if(g==="run"){(function(b){var M=(v(),C)[b+52>>>2>>>0];b=(v(),C)[b+56>>>2>>>0],Hv(M,M-b),le(M)})(h.Nc),td(h.Nc,0,0,1,0,0),z1(),Bp(h.Nc),X||(Ov(),X=!0);try{QM(h.he,h.Wc)}catch(b){if(b!="unwind")throw b}}else h.target!=="setimmediate"&&(g==="checkMailbox"?X&&Rl():g&&(S(`worker: received unknown command ${g}`),S(h)))}catch(b){throw jv(),b}};var W=u,X=!1;self.onunhandledrejection=f=>{throw f.reason||f},self.onmessage=u}var B,H,G,Q,R,C,te,ae,P,N,F,J=!1;function xe(){var u=Mr.buffer;e.HEAP8=B=new Int8Array(u),G=new Int16Array(u),e.HEAPU8=H=new Uint8Array(u),Q=new Uint16Array(u),e.HEAP32=R=new Int32Array(u),e.HEAPU32=C=new Uint32Array(u),te=new Float32Array(u),ae=new Float64Array(u),P=new BigInt64Array(u),N=new BigUint64Array(u)}function ue(){J=!0,n?E():hr._b()}function qe(u){throw S(u="Aborted("+u+")"),L=!0,u=new WebAssembly.RuntimeError(u+". Build with -sASSERTIONS for more info."),x?.(u),u}function ot(){return{a:{f:YM,J:JM,k:ZM,p:eS,l:tS,ta:rS,b:sS,ca:nS,Ka:B1,s:oS,da:q1,_a:W1,Ga:V1,Ia:H1,$a:X1,Ya:K1,Ra:Q1,Xa:Y1,pa:J1,Ha:Z1,Yb:ev,Za:tv,Fa:rv,eb:aS,Da:lS,Tb:cS,Rb:pS,Ca:fS,M:_S,I:mS,Sb:hS,ka:kS,Ub:ES,Ua:AS,Wb:SS,La:TS,Pb:OS,la:IS,Ta:Bp,bb:CS,U:NS,n:BS,c:Dp,sb:US,w:jS,L:GS,z:qS,j:WS,o:uv,tb:VS,G:HS,T:XS,h:KS,u:QS,m:YS,i:JS,Oa:ZS,Pa:eT,Qa:tT,Ma:_v,Na:mv,Qb:hv,fb:sT,db:aT,Y:iT,rb:lT,ma:cT,cb:nT,gb:uT,ab:pT,Xb:dT,N:rT,hb:fT,X:_T,Vb:mT,ob:ET,C:AT,sa:MT,ra:ST,qb:TT,W:OT,v:IT,nb:CT,mb:LT,lb:PT,pb:zT,kb:NT,jb:$T,ib:RT,Va:vv,Wa:kv,Ja:Hs,ea:Ev,oa:Av,Sa:Mv,na:Sv,Db:HO,xa:FO,Eb:VO,ya:DO,F:TO,e:mO,r:fO,x:dO,D:AO,Ib:NO,ba:PO,B:gO,za:$O,$:BO,ha:zO,Fb:qO,Gb:GO,Ba:OO,Aa:LO,Jb:IO,wa:WO,aa:RO,d:hO,A:wO,q:_O,Cb:XO,t:yO,y:MO,H:xO,E:bO,K:SO,S:UO,ja:EO,_:jO,Kb:kO,Lb:vO,P:CO,g:FT,a:Mr,Ob:Vs,Hb:BT,ia:UT,O:jT,qa:GT,Mb:qT,Q:WT,zb:VT,Ab:HT,ua:XT,fa:KT,R:QT,Ea:YT,va:JT,Z:ZT,xb:eO,Zb:tO,V:rO,Bb:sO,ub:nO,vb:aO,wb:iO,ga:lO,yb:cO,Nb:uO}}}async function _t(){function u(g,b){var M=hr=g.exports;g={};for(let[I,z]of Object.entries(M))typeof z=="function"?(M=LS(z),g[I]=M):g[I]=z;return hr=g,hr=(function(){var I=hr,z=Y=>Se=>Y(Se)>>>0,U=Y=>()=>Y()>>>0;return(I=Object.assign({},I)).$b=z(I.$b),I.Cc=U(I.Cc),I.Ec=z(I.Ec),I.rd=(Y=>(Se,ze)=>Y(Se,ze)>>>0)(I.rd),I.wd=z(I.wd),I.xd=U(I.xd),I.Bd=z(I.Bd),I})(),L1.push(hr.id),Tv=(g=hr).$b,Ov=g.ac,e._OrtInit=g.bc,e._OrtGetLastError=g.cc,e._OrtCreateSessionOptions=g.dc,e._OrtAppendExecutionProvider=g.ec,e._OrtAddFreeDimensionOverride=g.fc,e._OrtAddSessionConfigEntry=g.gc,e._OrtReleaseSessionOptions=g.hc,e._OrtCreateSession=g.ic,e._OrtReleaseSession=g.jc,e._OrtGetInputOutputCount=g.kc,e._OrtGetInputOutputMetadata=g.lc,e._OrtFree=g.mc,e._OrtCreateTensor=g.nc,e._OrtGetTensorData=g.oc,e._OrtReleaseTensor=g.pc,e._OrtCreateRunOptions=g.qc,e._OrtAddRunConfigEntry=g.rc,e._OrtReleaseRunOptions=g.sc,e._OrtCreateBinding=g.tc,e._OrtBindInput=g.uc,e._OrtBindOutput=g.vc,e._OrtClearBoundOutputs=g.wc,e._OrtReleaseBinding=g.xc,e._OrtRunWithBinding=g.yc,e._OrtRun=g.zc,e._OrtEndProfiling=g.Ac,Kp=e._OrtGetWebGpuDevice=g.Bc,Gl=g.Cc,qt=e._free=g.Dc,Js=e._malloc=g.Ec,Iv=e._wgpuBufferRelease=g.Fc,Cv=e._wgpuCreateInstance=g.Gc,Lv=g.Hc,Pv=g.Ic,zv=g.Jc,Nv=g.Kc,$v=g.Lc,Rv=g.Pc,Dv=g.Zc,Fv=g._c,Bv=g.$c,Qp=g.bd,Yp=g.cd,Jp=g.dd,Zp=g.ed,oo=g.fd,ed=g.gd,Uv=g.hd,td=g.kd,jv=g.ld,Gv=g.md,qv=g.nd,rd=g.od,Wv=g.pd,Vv=g.qd,sd=g.rd,we=g.sd,ao=g.td,Hv=g.ud,le=g.vd,ql=g.wd,ce=g.xd,Xv=g.yd,nd=g.zd,Kv=g.Ad,Qv=g.Bd,Yv=g.Cd,od=g.Dd,Jv=g.Ed,Zv=g.Fd,ek=g.Gd,tk=g.Hd,rk=g.Id,sk=g.Jd,nk=g.Kd,ok=g.Ld,ak=g.Md,ik=g.Nd,lk=g.Od,ck=g.Pd,uk=g.Qd,pk=g.Rd,dk=g.Td,fk=g.Ud,_k=g.Vd,mk=g.Wd,hk=g.Yd,gk=g.Zd,wk=g._d,xk=g.$d,yk=g.ae,bk=g.be,vk=g.pe,kk=g.qe,Ek=g.re,Ak=g.se,Mk=g.te,Sk=g.ue,Tk=g.ve,Ok=g.we,Ik=g.xe,Ck=g.ye,Lk=g.ze,Pk=g.Xe,zk=g.Ye,Nk=g.Ze,$k=g._e,_=b,hr}var f,h=ot();return e.instantiateWasm?new Promise(g=>{e.instantiateWasm(h,(b,M)=>{g(u(b,M))})}):n?u(new WebAssembly.Instance(_,ot()),_):(F??=e.locateFile?e.locateFile?e.locateFile("ort-wasm-simd-threaded.asyncify.wasm",p):p+"ort-wasm-simd-threaded.asyncify.wasm":new URL("ort-wasm-simd-threaded.asyncify.wasm",import.meta.url).href,f=await(async function(g){var b=F;if(!d&&!O(b))try{var M=fetch(b,{credentials:"same-origin"});return await WebAssembly.instantiateStreaming(M,g)}catch(I){S(`wasm streaming compile failed: ${I}`),S("falling back to ArrayBuffer instantiation")}return(async function(I,z){try{var U=await(async function(Y){if(!d)try{var Se=await a(Y);return new Uint8Array(Se)}catch{}if(Y==F&&d)Y=new Uint8Array(d);else{if(!i)throw"both async and sync fetching of the wasm failed";Y=i(Y)}return Y})(I);return await WebAssembly.instantiate(U,z)}catch(Y){S(`failed to asynchronously prepare wasm: ${Y}`),qe(Y)}})(b,g)})(h),u(f.instance,f.module))}class at{name="ExitStatus";constructor(f){this.message=`Program terminated with exit(${f})`,this.status=f}}var vt=u=>{u.terminate(),u.onmessage=()=>{}},Fe=[],Me=0,Ze=null,er=u=>{Ar.length==0&&($1(),N1(Ar[0]));var f=Ar.pop();if(!f)return 6;ro.push(f),os[u.Nc]=f,f.Nc=u.Nc;var h={Oc:"run",he:u.ge,Wc:u.Wc,Nc:u.Nc};return f.postMessage(h,u.Yc),0},Pe=0,Be=(u,f,...h)=>{var g,b=16*h.length,M=ce(),I=ql(b),z=I>>>3;for(g of h)typeof g=="bigint"?((v(),P)[z++>>>0]=1n,(v(),P)[z++>>>0]=g):((v(),P)[z++>>>0]=0n,(v(),ae)[z++>>>0]=g);return u=Gv(u,0,b,I,f),le(M),u};function Vs(u){if(n)return Be(0,1,u);if(m=u,!(0<Pe)){for(var f of ro)vt(f);for(f of Ar)vt(f);Ar=[],ro=[],os={},L=!0}l(0,new at(u))}function to(u){if(n)return Be(1,0,u);Hs(u)}var Hs=u=>{if(m=u,n)throw to(u),"unwind";Vs(u)},Ar=[],ro=[],L1=[],os={},P1=u=>{var f=u.Nc;delete os[f],Ar.push(u),ro.splice(ro.indexOf(u),1),u.Nc=0,qv(f)};function z1(){L1.forEach(u=>u())}var N1=u=>new Promise(f=>{u.onmessage=b=>{var M=b.data;if(b=M.Oc,M.Vc&&M.Vc!=Gl()){var I=os[M.Vc];I?I.postMessage(M,M.Yc):S(`Internal error! Worker sent a message "${b}" to target pthread ${M.Vc}, but that thread no longer exists!`)}else b==="checkMailbox"?Rl():b==="spawnThread"?er(M):b==="cleanupThread"?Et(()=>{P1(os[M.ie])}):b==="loaded"?(u.loaded=!0,f(u)):M.target==="setimmediate"?u.postMessage(M):b==="uncaughtException"?u.onerror(M.error):b==="callHandler"?e[M.ce](...M.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 h,g=[];for(h of[])e.propertyIsEnumerable(h)&&g.push(h);u.postMessage({Oc:"load",de:g,je:Mr,ke:_})});function $1(){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"});Ar.push(u)}var Mr,QM=(u,f)=>{Pe=0,u=od(u,f),0<Pe?m=u:rd(u)},Nl=[],$l=0,kt=u=>-9007199254740992>u||9007199254740992<u?NaN:Number(u);function YM(u){var f=new zp(u>>>=0);return(v(),B)[f.Qc+12>>>0]==0&&(R1(f,!0),$l--),D1(f,!1),Nl.push(f),Qv(u)}var Xs=0,JM=()=>{we(0,0);var u=Nl.pop();Xv(u.Xc),Xs=0};function R1(u,f){f=f?1:0,(v(),B)[u.Qc+12>>>0]=f}function D1(u,f){f=f?1:0,(v(),B)[u.Qc+13>>>0]=f}class zp{constructor(f){this.Xc=f,this.Qc=f-24}}var Np=u=>{var f=Xs;if(!f)return ao(0),0;var h=new zp(f);(v(),C)[h.Qc+16>>>2>>>0]=f;var g=(v(),C)[h.Qc+4>>>2>>>0];if(!g)return ao(0),f;for(var b of u){if(b===0||b===g)break;if(Kv(b,g,h.Qc+16))return ao(b),f}return ao(g),f};function ZM(){return Np([])}function eS(u){return Np([u>>>0])}function tS(u,f,h,g){return Np([u>>>0,f>>>0,h>>>0,g>>>0])}var rS=()=>{var u=Nl.pop();u||qe("no exception to throw");var f=u.Xc;throw(v(),B)[u.Qc+13>>>0]==0&&(Nl.push(u),D1(u,!0),R1(u,!1),$l++),nd(f),Xs=f};function sS(u,f,h){var g=new zp(u>>>=0);throw f>>>=0,h>>>=0,(v(),C)[g.Qc+16>>>2>>>0]=0,(v(),C)[g.Qc+4>>>2>>>0]=f,(v(),C)[g.Qc+8>>>2>>>0]=h,nd(u),$l++,Xs=u}var nS=()=>$l;function F1(u,f,h,g){return n?Be(2,1,u,f,h,g):B1(u,f,h,g)}function B1(u,f,h,g){if(u>>>=0,f>>>=0,h>>>=0,g>>>=0,!globalThis.SharedArrayBuffer)return 6;var b=[];return n&&b.length===0?F1(u,f,h,g):(u={ge:h,Nc:u,Wc:g,Yc:b},n?(u.Oc="spawnThread",postMessage(u,b),0):er(u))}function oS(u){throw Xs||=u>>>0,Xs}var U1=globalThis.TextDecoder&&new TextDecoder,j1=(u,f,h,g)=>{if(h=f+h,g)return h;for(;u[f]&&!(f>=h);)++f;return f},G1=(u,f=0,h,g)=>{if(16<(h=j1(u,f>>>=0,h,g))-f&&u.buffer&&U1)return U1.decode(u.buffer instanceof ArrayBuffer?u.subarray(f,h):u.slice(f,h));for(g="";f<h;){var b=u[f++];if(128&b){var M=63&u[f++];if((224&b)==192)g+=String.fromCharCode((31&b)<<6|M);else{var I=63&u[f++];65536>(b=(240&b)==224?(15&b)<<12|M<<6|I:(7&b)<<18|M<<12|I<<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},Ks=(u,f,h)=>(u>>>=0)?G1((v(),H),u,f,h):"";function q1(u,f,h){return n?Be(3,1,u,f,h):0}function W1(u,f){if(n)return Be(4,1,u,f)}function V1(u,f){if(n)return Be(5,1,u,f)}function H1(u,f,h){if(n)return Be(6,1,u,f,h)}function X1(u,f,h){return n?Be(7,1,u,f,h):0}function K1(u,f){if(n)return Be(8,1,u,f)}function Q1(u,f,h){if(n)return Be(9,1,u,f,h)}function Y1(u,f,h,g){if(n)return Be(10,1,u,f,h,g)}function J1(u,f,h,g){if(n)return Be(11,1,u,f,h,g)}function Z1(u,f,h,g){if(n)return Be(12,1,u,f,h,g)}function ev(u){if(n)return Be(13,1,u)}function tv(u,f){if(n)return Be(14,1,u,f)}function rv(u,f,h){if(n)return Be(15,1,u,f,h)}var aS=()=>qe(""),tr=u=>{u>>>=0;for(var f="";;){var h=(v(),H)[u++>>>0];if(!h)return f;f+=String.fromCharCode(h)}},$p={},Rp={},iS={},Qs=class extends Error{constructor(u){super(u),this.name="BindingError"}};function pr(u,f,h={}){return(function(g,b,M={}){var I=b.name;if(!g)throw new Qs(`type "${I}" must have a positive integer typeid pointer`);if(Rp.hasOwnProperty(g)){if(M.ee)return;throw new Qs(`Cannot register type '${I}' twice`)}Rp[g]=b,delete iS[g],$p.hasOwnProperty(g)&&(b=$p[g],delete $p[g],b.forEach(z=>z()))})(u,f,h)}var sv=(u,f,h)=>{switch(f){case 1:return h?g=>(v(),B)[g>>>0]:g=>(v(),H)[g>>>0];case 2:return h?g=>(v(),G)[g>>>1>>>0]:g=>(v(),Q)[g>>>1>>>0];case 4:return h?g=>(v(),R)[g>>>2>>>0]:g=>(v(),C)[g>>>2>>>0];case 8:return h?g=>(v(),P)[g>>>3>>>0]:g=>(v(),N)[g>>>3>>>0];default:throw new TypeError(`invalid integer width (${f}): ${u}`)}};function lS(u,f,h,g,b){u>>>=0,h>>>=0,f=tr(f>>>0);let M=I=>I;if(g=g===0n){let I=8*h;M=z=>BigInt.asUintN(I,z),b=M(b)}pr(u,{name:f,Mc:M,Sc:(I,z)=>(typeof z=="number"&&(z=BigInt(z)),z),Rc:sv(f,h,!g),Tc:null})}function cS(u,f,h,g){pr(u>>>=0,{name:f=tr(f>>>0),Mc:function(b){return!!b},Sc:function(b,M){return M?h:g},Rc:function(b){return this.Mc((v(),H)[b>>>0])},Tc:null})}var nv=[],as=[0,1,,1,null,1,!0,1,!1,1];function Dp(u){9<(u>>>=0)&&--as[u+1]==0&&(as[u]=void 0,nv.push(u))}var Nt=u=>{if(!u)throw new Qs(`Cannot use deleted val. handle = ${u}`);return as[u]},Gt=u=>{switch(u){case void 0:return 2;case null:return 4;case!0:return 6;case!1:return 8;default:let f=nv.pop()||as.length;return as[f]=u,as[f+1]=1,f}};function Fp(u){return this.Mc((v(),C)[u>>>2>>>0])}var uS={name:"emscripten::val",Mc:u=>{var f=Nt(u);return Dp(u),f},Sc:(u,f)=>Gt(f),Rc:Fp,Tc:null};function pS(u){return pr(u>>>0,uS)}var dS=(u,f)=>{switch(f){case 4:return function(h){return this.Mc((v(),te)[h>>>2>>>0])};case 8:return function(h){return this.Mc((v(),ae)[h>>>3>>>0])};default:throw new TypeError(`invalid float width (${f}): ${u}`)}};function fS(u,f,h){h>>>=0,pr(u>>>=0,{name:f=tr(f>>>0),Mc:g=>g,Sc:(g,b)=>b,Rc:dS(f,h),Tc:null})}function _S(u,f,h,g,b){u>>>=0,h>>>=0,f=tr(f>>>0);let M=z=>z;if(g===0){var I=32-8*h;M=z=>z<<I>>>I,b=M(b)}pr(u,{name:f,Mc:M,Sc:(z,U)=>U,Rc:sv(f,h,g!==0),Tc:null})}function mS(u,f,h){function g(M){var I=(v(),C)[M>>>2>>>0];return M=(v(),C)[M+4>>>2>>>0],new b((v(),B).buffer,M,I)}var b=[Int8Array,Uint8Array,Int16Array,Uint16Array,Int32Array,Uint32Array,Float32Array,Float64Array,BigInt64Array,BigUint64Array][f];pr(u>>>=0,{name:h=tr(h>>>0),Mc:g,Rc:g},{ee:!0})}var dr=(u,f,h)=>{var g=(v(),H);if(f>>>=0,0<h){var b=f;h=f+h-1;for(var M=0;M<u.length;++M){var I=u.codePointAt(M);if(127>=I){if(f>=h)break;g[f++>>>0]=I}else if(2047>=I){if(f+1>=h)break;g[f++>>>0]=192|I>>6,g[f++>>>0]=128|63&I}else if(65535>=I){if(f+2>=h)break;g[f++>>>0]=224|I>>12,g[f++>>>0]=128|I>>6&63,g[f++>>>0]=128|63&I}else{if(f+3>=h)break;g[f++>>>0]=240|I>>18,g[f++>>>0]=128|I>>12&63,g[f++>>>0]=128|I>>6&63,g[f++>>>0]=128|63&I,M++}}g[f>>>0]=0,u=f-b}else u=0;return u},fr=u=>{for(var f=0,h=0;h<u.length;++h){var g=u.charCodeAt(h);127>=g?f++:2047>=g?f+=2:55296<=g&&57343>=g?(f+=4,++h):f+=3}return f};function hS(u,f){pr(u>>>=0,{name:f=tr(f>>>0),Mc(h){var g=(v(),C)[h>>>2>>>0];return g=Ks(h+4,g,!0),qt(h),g},Sc(h,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 Qs("Cannot pass non-string to std::string");var M=b?fr(g):g.length,I=Js(4+M+1),z=I+4;return(v(),C)[I>>>2>>>0]=M,b?dr(g,z,M+1):(v(),H).set(g,z>>>0),h!==null&&h.push(qt,I),I},Rc:Fp,Tc(h){qt(h)}})}var ov=globalThis.TextDecoder?new TextDecoder("utf-16le"):void 0,gS=(u,f,h)=>{if(u>>>=1,16<(f=j1((v(),Q),u,f/2,h))-u&&ov)return ov.decode((v(),Q).slice(u,f));for(h="";u<f;++u){var g=(v(),Q)[u>>>0];h+=String.fromCharCode(g)}return h},wS=(u,f,h)=>{if(h??=2147483647,2>h)return 0;var g=f;h=(h-=2)<2*u.length?h/2:u.length;for(var b=0;b<h;++b){var M=u.charCodeAt(b);(v(),G)[f>>>1>>>0]=M,f+=2}return(v(),G)[f>>>1>>>0]=0,f-g},xS=u=>2*u.length,yS=(u,f,h)=>{var g="";u>>>=2;for(var b=0;!(b>=f/4);b++){var M=(v(),C)[u+b>>>0];if(!M&&!h)break;g+=String.fromCodePoint(M)}return g},bS=(u,f,h)=>{if(f>>>=0,h??=2147483647,4>h)return 0;var g=f;h=g+h-4;for(var b=0;b<u.length;++b){var M=u.codePointAt(b);if(65535<M&&b++,(v(),R)[f>>>2>>>0]=M,(f+=4)+4>h)break}return(v(),R)[f>>>2>>>0]=0,f-g},vS=u=>{for(var f=0,h=0;h<u.length;++h)65535<u.codePointAt(h)&&h++,f+=4;return f};function kS(u,f,h){if(u>>>=0,f>>>=0,h=tr(h>>>=0),f===2)var g=gS,b=wS,M=xS;else g=yS,b=bS,M=vS;pr(u,{name:h,Mc:I=>{var z=(v(),C)[I>>>2>>>0];return z=g(I+4,z*f,!0),qt(I),z},Sc:(I,z)=>{if(typeof z!="string")throw new Qs(`Cannot pass non-string to C++ string type ${h}`);var U=M(z),Y=Js(4+U+f);return(v(),C)[Y>>>2>>>0]=U/f,b(z,Y+4,U+f),I!==null&&I.push(qt,Y),Y},Rc:Fp,Tc(I){qt(I)}})}function ES(u,f){pr(u>>>=0,{fe:!0,name:f=tr(f>>>0),Mc:()=>{},Sc:()=>{}})}function AS(u){td(u>>>0,!s,1,!r,131072,!1),z1()}var Et=u=>{if(!L)try{if(u(),!(0<Pe))try{n?Gl()&&rd(m):Hs(m)}catch(f){f instanceof at||f=="unwind"||l(0,f)}}catch(f){f instanceof at||f=="unwind"||l(0,f)}},MS=!Atomics.waitAsync||globalThis.navigator?.userAgent&&91>Number((navigator.userAgent.match(/Chrom(e|ium)\/([0-9]+)\./)||[])[2]);function Bp(u){u>>>=0,MS||(Atomics.waitAsync((v(),R),u>>>2,u).value.then(Rl),u+=128,Atomics.store((v(),R),u>>>2,1))}var Rl=()=>Et(()=>{var u=Gl();u&&(Bp(u),Vv())});function SS(u,f){(u>>>=0)==f>>>0?setTimeout(Rl):n?postMessage({Vc:u,Oc:"checkMailbox"}):(u=os[u])&&u.postMessage({Oc:"checkMailbox"})}var Up=[];function TS(u,f,h,g,b){for(f>>>=0,b>>>=0,Up.length=0,h=b>>>3,g=b+g>>>3;h<g;){var M;M=(v(),P)[h++>>>0]?(v(),P)[h++>>>0]:(v(),ae)[h++>>>0],Up.push(M)}return(f?ad[f]:pO[u])(...Up)}var OS=()=>{Pe=0};function IS(u){u>>>=0,n?postMessage({Oc:"cleanupThread",ie:u}):P1(os[u])}function CS(u){}var Dl=u=>{try{u()}catch(f){qe(f)}};function LS(u){var f=(...h)=>{Fl.push(u);try{return u(...h)}finally{L||(Fl.pop(),rr&&Sr===1&&Fl.length===0&&(Sr=0,Pe+=1,Dl(zk),typeof Fibers<"u"&&Fibers.De()))}};return lv.set(u,f),f}var Sr=0,rr=null,av=0,Fl=[],jp=new Map,iv=new Map,lv=new Map,PS=0,Gp=null,zS=[],cv=u=>(function(f){if(!L){if(Sr===0){var h=!1,g=!1;f((b=0)=>{if(!L&&(av=b,h=!0,g)){Sr=2,Dl(()=>Nk(rr)),typeof MainLoop<"u"&&MainLoop.Xd&&MainLoop.resume(),b=!1;try{var M=(function(){var U=(v(),R)[rr+8>>>2>>>0];return U=iv.get(U),U=lv.get(U),--Pe,U()})()}catch(U){M=U,b=!0}var I=!1;if(!rr){var z=Gp;z&&(Gp=null,(b?z.reject:z.resolve)(M),I=!0)}if(b&&!I)throw M}}),g=!0,h||(Sr=1,rr=(function(){var b=Js(65548),M=b+12;if((v(),C)[b>>>2>>>0]=M,(v(),C)[b+4>>>2>>>0]=M+65536,M=Fl[0],!jp.has(M)){var I=PS++;jp.set(M,I),iv.set(I,M)}return M=jp.get(M),(v(),R)[b+8>>>2>>>0]=M,b})(),typeof MainLoop<"u"&&MainLoop.Xd&&MainLoop.pause(),Dl(()=>Pk(rr)))}else Sr===2?(Sr=0,Dl($k),qt(rr),rr=null,zS.forEach(Et)):qe(`invalid state: ${Sr}`);return av}})(f=>{u().then(f)});function NS(u){return u>>>=0,cv(async()=>{var f=await Nt(u);return Gt(f)})}var qp=[],$S=u=>{var f=qp.length;return qp.push(u),f},RS=(u,f)=>{for(var h=Array(u),g=0;g<u;++g){var b=g,M=(v(),C)[f+4*g>>>2>>>0],I=Rp[M];if(I===void 0)throw u=`parameter ${g}`,M=Tv(M),f=tr(M),qt(M),new Qs(`${u} has unknown type ${f}`);h[b]=I}return h},DS=(u,f,h)=>{var g=[];return u=u(g,h),g.length&&((v(),C)[f>>>2>>>0]=Gt(g)),u},FS={},Bl=u=>{var f=FS[u];return f===void 0?tr(u):f};function BS(u,f,h){var[g,...b]=RS(u,f>>>0);f=g.Sc.bind(g);var M=b.map(U=>U.Rc.bind(U));u--;var I={toValue:Nt};switch(u=M.map((U,Y)=>{var Se=`argFromPtr${Y}`;return I[Se]=U,`${Se}(args${Y?"+"+8*Y:""})`}),h){case 0:var z="toValue(handle)";break;case 2:z="new (toValue(handle))";break;case 3:z="";break;case 1:I.getStringOrSymbol=Bl,z="toValue(handle)[getStringOrSymbol(methodName)]"}return z+=`(${u})`,g.fe||(I.toReturnWire=f,I.emval_returnValue=DS,z=`return emval_returnValue(toReturnWire, destructorsRef, ${z})`),z=`return function (handle, methodName, destructorsRef, args) {
11
+ ${z}
12
+ }`,h=new Function(Object.keys(I),z)(...Object.values(I)),z=`methodCaller<(${b.map(U=>U.name)}) => ${g.name}>`,$S(Object.defineProperty(h,"name",{value:z}))}function US(u,f){return f>>>=0,(u=Nt(u>>>0))==Nt(f)}function jS(u){return(u>>>=0)?(u=Bl(u),Gt(globalThis[u])):Gt(globalThis)}function GS(u){return u=Bl(u>>>0),Gt(e[u])}function qS(u,f){return f>>>=0,u=Nt(u>>>0),f=Nt(f),Gt(u[f])}function WS(u){9<(u>>>=0)&&(as[u+1]+=1)}function uv(u,f,h,g,b){return qp[u>>>0](f>>>0,h>>>0,g>>>0,b>>>0)}function VS(u,f,h,g,b){return uv(u>>>0,f>>>0,h>>>0,g>>>0,b>>>0)}function HS(){return Gt([])}function XS(u){u=Nt(u>>>0);for(var f=Array(u.length),h=0;h<u.length;h++)f[h]=u[h];return Gt(f)}function KS(u){return Gt(Bl(u>>>0))}function QS(){return Gt({})}function YS(u){for(var f=Nt(u>>>=0);f.length;){var h=f.pop();f.pop()(h)}Dp(u)}function JS(u,f,h){f>>>=0,h>>>=0,u=Nt(u>>>0),f=Nt(f),h=Nt(h),u[f]=h}function ZS(u,f){u=kt(u),f>>>=0,u=new Date(1e3*u),(v(),R)[f>>>2>>>0]=u.getUTCSeconds(),(v(),R)[f+4>>>2>>>0]=u.getUTCMinutes(),(v(),R)[f+8>>>2>>>0]=u.getUTCHours(),(v(),R)[f+12>>>2>>>0]=u.getUTCDate(),(v(),R)[f+16>>>2>>>0]=u.getUTCMonth(),(v(),R)[f+20>>>2>>>0]=u.getUTCFullYear()-1900,(v(),R)[f+24>>>2>>>0]=u.getUTCDay(),u=(u.getTime()-Date.UTC(u.getUTCFullYear(),0,1,0,0,0,0))/864e5|0,(v(),R)[f+28>>>2>>>0]=u}var pv=u=>u%4==0&&(u%100!=0||u%400==0),dv=[0,31,60,91,121,152,182,213,244,274,305,335],fv=[0,31,59,90,120,151,181,212,243,273,304,334];function eT(u,f){u=kt(u),f>>>=0,u=new Date(1e3*u),(v(),R)[f>>>2>>>0]=u.getSeconds(),(v(),R)[f+4>>>2>>>0]=u.getMinutes(),(v(),R)[f+8>>>2>>>0]=u.getHours(),(v(),R)[f+12>>>2>>>0]=u.getDate(),(v(),R)[f+16>>>2>>>0]=u.getMonth(),(v(),R)[f+20>>>2>>>0]=u.getFullYear()-1900,(v(),R)[f+24>>>2>>>0]=u.getDay();var h=(pv(u.getFullYear())?dv:fv)[u.getMonth()]+u.getDate()-1|0;(v(),R)[f+28>>>2>>>0]=h,(v(),R)[f+36>>>2>>>0]=-60*u.getTimezoneOffset(),h=new Date(u.getFullYear(),6,1).getTimezoneOffset();var g=new Date(u.getFullYear(),0,1).getTimezoneOffset();u=0|(h!=g&&u.getTimezoneOffset()==Math.min(g,h)),(v(),R)[f+32>>>2>>>0]=u}function tT(u){u>>>=0;var f=new Date((v(),R)[u+20>>>2>>>0]+1900,(v(),R)[u+16>>>2>>>0],(v(),R)[u+12>>>2>>>0],(v(),R)[u+8>>>2>>>0],(v(),R)[u+4>>>2>>>0],(v(),R)[u>>>2>>>0],0),h=(v(),R)[u+32>>>2>>>0],g=f.getTimezoneOffset(),b=new Date(f.getFullYear(),6,1).getTimezoneOffset(),M=new Date(f.getFullYear(),0,1).getTimezoneOffset(),I=Math.min(M,b);return 0>h?(v(),R)[u+32>>>2>>>0]=+(b!=M&&I==g):0<h!=(I==g)&&(b=Math.max(M,b),f.setTime(f.getTime()+6e4*((0<h?I:b)-g))),(v(),R)[u+24>>>2>>>0]=f.getDay(),h=(pv(f.getFullYear())?dv:fv)[f.getMonth()]+f.getDate()-1|0,(v(),R)[u+28>>>2>>>0]=h,(v(),R)[u>>>2>>>0]=f.getSeconds(),(v(),R)[u+4>>>2>>>0]=f.getMinutes(),(v(),R)[u+8>>>2>>>0]=f.getHours(),(v(),R)[u+12>>>2>>>0]=f.getDate(),(v(),R)[u+16>>>2>>>0]=f.getMonth(),(v(),R)[u+20>>>2>>>0]=f.getYear(),u=f.getTime(),BigInt(isNaN(u)?-1:u/1e3)}function _v(u,f,h,g,b,M,I){return n?Be(16,1,u,f,h,g,b,M,I):-52}function mv(u,f,h,g,b,M){if(n)return Be(17,1,u,f,h,g,b,M)}var so={},rT=()=>performance.timeOrigin+performance.now();function hv(u,f){if(n)return Be(18,1,u,f);if(so[u]&&(clearTimeout(so[u].id),delete so[u]),!f)return 0;var h=setTimeout(()=>{delete so[u],Et(()=>Wv(u,performance.timeOrigin+performance.now()))},f);return so[u]={id:h,Ce:f},0}function sT(u,f,h,g){u>>>=0,f>>>=0,h>>>=0,g>>>=0;var b=new Date().getFullYear(),M=new Date(b,0,1).getTimezoneOffset();b=new Date(b,6,1).getTimezoneOffset();var I=Math.max(M,b);(v(),C)[u>>>2>>>0]=60*I,(v(),R)[f>>>2>>>0]=+(M!=b),u=(f=z=>{var U=Math.abs(z);return`UTC${0<=z?"-":"+"}${String(Math.floor(U/60)).padStart(2,"0")}${String(U%60).padStart(2,"0")}`})(M),f=f(b),b<M?(dr(u,h,17),dr(f,g,17)):(dr(u,g,17),dr(f,h,17))}var nT=()=>Date.now(),oT=1;function aT(u,f,h){if(h>>>=0,!(0<=u&&3>=u))return 28;if(u===0)u=Date.now();else{if(!oT)return 52;u=performance.timeOrigin+performance.now()}return u=Math.round(1e6*u),(v(),P)[h>>>3>>>0]=BigInt(u),0}var Wp=[],gv=(u,f)=>{Wp.length=0;for(var h;h=(v(),H)[u++>>>0];){var g=h!=105;f+=(g&=h!=112)&&f%8?4:0,Wp.push(h==112?(v(),C)[f>>>2>>>0]:h==106?(v(),P)[f>>>3>>>0]:h==105?(v(),R)[f>>>2>>>0]:(v(),ae)[f>>>3>>>0]),f+=g?8:4}return Wp};function iT(u,f,h){return u>>>=0,f=gv(f>>>0,h>>>0),ad[u](...f)}function lT(u,f,h){return u>>>=0,f=gv(f>>>0,h>>>0),ad[u](...f)}var cT=()=>{};function uT(u,f){return S(Ks(u>>>0,f>>>0))}var pT=()=>{throw Pe+=1,"unwind"};function dT(){return 4294901760}var fT=()=>1,_T=()=>navigator.hardwareConcurrency;function mT(u){u>>>=0;var f=(v(),H).length;if(u<=f||4294901760<u)return!1;for(var h=1;4>=h;h*=2){var g=f*(1+.2/h);g=Math.min(g,u+100663296);e:{g=(Math.min(4294901760,65536*Math.ceil(Math.max(u,g)/65536))-Mr.buffer.byteLength+65535)/65536|0;try{Mr.grow(g),xe();var b=1;break e}catch{}b=void 0}if(b)return!0}return!1}var sr=u=>{var f=fr(u)+1,h=ql(f);return dr(u,h,f),h},Vp=(u,f)=>{(v(),C)[u>>>2>>>0]=f;var h=(v(),C)[u>>>2>>>0];(v(),C)[u+4>>>2>>>0]=(f-h)/4294967296},no=u=>(v(),C)[u>>>2>>>0]+4294967296*(v(),R)[u+4>>>2>>>0],mt=[],hT=(u,f)=>{mt[u>>>0]=f},_r=[],Ul=[],Ys=(u,f)=>{Ul[u]=new Promise(h=>f.finally(()=>h(u)))},se=u=>{if(u)return mt[u>>>0]},gT=(u,f)=>{for(u=(v(),C)[u>>>2>>>0];u;u=(v(),C)[u>>>2>>>0])f[(v(),R)[u+4>>>2>>>0]](u)},jl=(u,f,h)=>{(v(),C)[u>>>2>>>0]=f,(v(),C)[u+4>>>2>>>0]=h},wv=u=>{var f=(v(),C)[u>>>2>>>0];return u=(v(),C)[u+4>>>2>>>0],Ks(f,u)},mr=u=>{var f=(v(),C)[u>>>2>>>0];return u=(v(),C)[u+4>>>2>>>0],f?Ks(f,u):u===0?"":void 0},wT=u=>{var f=mr(u+4),h=(h=(v(),C)[u+12>>>2>>>0])?se(h):"auto";if(u+=16){var g=se((v(),C)[u+4>>>2>>>0]),b=(v(),C)[u+16>>>2>>>0],M=(v(),C)[u+20>>>2>>>0];if(b){for(var I={},z=0;z<b;++z){var U=M+24*z;I[wv(U+4)]=(v(),ae)[U+16>>>3>>>0]}b=I}else b=void 0;u={module:g,constants:b,entryPoint:mr(u+8)}}else u=void 0;return{label:f,layout:h,compute:u}},xv=(u,f)=>{function h(g,b){g=u[g],(v(),C)[f+b>>>2>>>0]=g}h("maxTextureDimension1D",4),h("maxTextureDimension2D",8),h("maxTextureDimension3D",12),h("maxTextureArrayLayers",16),h("maxBindGroups",20),h("maxBindGroupsPlusVertexBuffers",24),h("maxBindingsPerBindGroup",28),h("maxDynamicUniformBuffersPerPipelineLayout",32),h("maxDynamicStorageBuffersPerPipelineLayout",36),h("maxSampledTexturesPerShaderStage",40),h("maxSamplersPerShaderStage",44),h("maxStorageBuffersPerShaderStage",48),h("maxStorageTexturesPerShaderStage",52),h("maxUniformBuffersPerShaderStage",56),h("minUniformBufferOffsetAlignment",80),h("minStorageBufferOffsetAlignment",84),Vp(f+64,u.maxUniformBufferBindingSize),Vp(f+72,u.maxStorageBufferBindingSize),h("maxVertexBuffers",88),Vp(f+96,u.maxBufferSize),h("maxVertexAttributes",104),h("maxVertexBufferArrayStride",108),h("maxInterStageShaderVariables",112),h("maxColorAttachments",116),h("maxColorAttachmentBytesPerSample",120),h("maxComputeWorkgroupStorageSize",124),h("maxComputeInvocationsPerWorkgroup",128),h("maxComputeWorkgroupSizeX",132),h("maxComputeWorkgroupSizeY",136),h("maxComputeWorkgroupSizeZ",140),h("maxComputeWorkgroupsPerDimension",144),u.Ae!==void 0&&h("maxImmediateSize",148)},xT=[,"validation","out-of-memory","internal"],yT=[,"compatibility","core"],yv={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"},bT=[,"low-power","high-performance"],vT=[,"occlusion","timestamp"],kT={undefined:1,unknown:1,destroyed:2};function ET(u,f,h,g,b,M){f=kt(f),h=kt(h),g>>>=0,b>>>=0,M>>>=0;var I=se(u>>>0);if(u={},M){var z=(v(),C)[M+12>>>2>>>0];if(z){var U=(v(),C)[M+16>>>2>>>0];u.requiredFeatures=Array.from((v(),C).subarray(U>>>2>>>0,U+4*z>>>2>>>0),ne=>yv[ne])}var Y=(v(),C)[M+20>>>2>>>0];if(Y){let ne=function(At,lt,is=!1){lt=Y+lt,(lt=(v(),C)[lt>>>2>>>0])==4294967295||is&&lt==0||(Ue[At]=lt)},it=function(At,lt){lt=Y+lt;var is=(v(),C)[lt>>>2>>>0],KO=(v(),C)[lt+4>>>2>>>0];is==4294967295&&KO==4294967295||(Ue[At]=no(lt))};var Se=ne,ze=it,Ue={};ne("maxTextureDimension1D",4),ne("maxTextureDimension2D",8),ne("maxTextureDimension3D",12),ne("maxTextureArrayLayers",16),ne("maxBindGroups",20),ne("maxBindGroupsPlusVertexBuffers",24),ne("maxDynamicUniformBuffersPerPipelineLayout",32),ne("maxDynamicStorageBuffersPerPipelineLayout",36),ne("maxSampledTexturesPerShaderStage",40),ne("maxSamplersPerShaderStage",44),ne("maxStorageBuffersPerShaderStage",48),ne("maxStorageTexturesPerShaderStage",52),ne("maxUniformBuffersPerShaderStage",56),ne("minUniformBufferOffsetAlignment",80),ne("minStorageBufferOffsetAlignment",84),it("maxUniformBufferBindingSize",64),it("maxStorageBufferBindingSize",72),ne("maxVertexBuffers",88),it("maxBufferSize",96),ne("maxVertexAttributes",104),ne("maxVertexBufferArrayStride",108),ne("maxInterStageShaderVariables",112),ne("maxColorAttachments",116),ne("maxColorAttachmentBytesPerSample",120),ne("maxComputeWorkgroupStorageSize",124),ne("maxComputeInvocationsPerWorkgroup",128),ne("maxComputeWorkgroupSizeX",132),ne("maxComputeWorkgroupSizeY",136),ne("maxComputeWorkgroupSizeZ",140),ne("maxComputeWorkgroupsPerDimension",144),ne("maxImmediateSize",148,!0),u.requiredLimits=Ue}(z=(v(),C)[M+24>>>2>>>0])&&(z={label:mr(z+4)},u.defaultQueue=z),u.label=mr(M+4)}Pe+=1,Ys(f,I.requestDevice(u).then(ne=>{--Pe,Et(()=>{mt[b>>>0]=ne.queue,mt[g>>>0]=ne,Ys(h,ne.lost.then(it=>{Et(()=>{ne.onuncapturederror=()=>{};var At=ce(),lt=sr(it.message);Yp(h,kT[it.reason],lt),le(At)})})),ne.onuncapturederror=it=>{var At=5;it.error instanceof GPUValidationError?At=2:it.error instanceof GPUOutOfMemoryError?At=3:it.error instanceof GPUInternalError&&(At=4);var lt=ce();it=sr(it.error.message),Uv(g,At,it),le(lt)},"adapterInfo"in ne||(ne.adapterInfo=I.info),ed(f,1,g,0)})},ne=>{--Pe,Et(()=>{var it=ce(),At=sr(ne.message);ed(f,3,g,At),h&&Yp(h,4,At),le(it)})}))}function AT(u){var f=se(u>>>=0),h=_r[u];if(h){for(var g=0;g<h.length;++g)h[g]();delete _r[u]}f.destroy()}function MT(u,f,h){h>>>=0;var g=se(u>>>=0);h==4294967295&&(h=void 0);try{var b=g.getMappedRange(f>>>0,h)}catch{return 0}var M=sd(16,b.byteLength);return(v(),H).set(new Uint8Array(b),M>>>0),_r[u].push(()=>qt(M)),M}function ST(u,f,h){h>>>=0;var g=se(u>>>=0);h==4294967295&&(h=void 0);try{var b=g.getMappedRange(f>>>0,h)}catch{return 0}var M=sd(16,b.byteLength);return(v(),H).fill(0,M,b.byteLength),_r[u].push(()=>{new Uint8Array(b).set((v(),H).subarray(M>>>0,M+b.byteLength>>>0)),qt(M)}),M}function TT(u,f,h,g,b){u>>>=0,f=kt(f),h=kt(h),b>>>=0;var M=se(u);_r[u]=[],b==4294967295&&(b=void 0),Pe+=1,Ys(f,M.mapAsync(h,g>>>0,b).then(()=>{--Pe,Et(()=>{Jp(f,1,0)})},I=>{--Pe,Et(()=>{ce();var z=sr(I.message);Jp(f,I.name==="AbortError"?4:I.name==="OperationError"?3:0,z),delete _r[u]})}))}function OT(u){var f=se(u>>>=0),h=_r[u];if(h){for(var g=0;g<h.length;++g)h[g]();delete _r[u],f.unmap()}}function IT(u){delete mt[u>>>0]}function CT(u,f,h){u>>>=0,f>>>=0,h>>>=0;var g=!!(v(),C)[f+32>>>2>>>0];f={label:mr(f+4),usage:(v(),C)[f+16>>>2>>>0],size:no(f+24),mappedAtCreation:g},u=se(u);try{var b=u.createBuffer(f)}catch{return!1}return mt[h>>>0]=b,g&&(_r[h]=[]),!0}function LT(u,f,h,g){u>>>=0,f=kt(f),g>>>=0,h=wT(h>>>0),u=se(u),Pe+=1,Ys(f,u.createComputePipelineAsync(h).then(b=>{--Pe,Et(()=>{mt[g>>>0]=b,Qp(f,1,g,0)})},b=>{--Pe,Et(()=>{var M=ce(),I=sr(b.message);Qp(f,b.reason==="validation"?3:b.reason==="internal"?4:0,g,I),le(M)})}))}function PT(u,f,h){u>>>=0,f>>>=0,h>>>=0;var g=(v(),C)[f>>>2>>>0],b=(v(),R)[g+4>>>2>>>0];f={label:mr(f+4),code:""},b===2&&(f.code=wv(g+8)),u=se(u).createShaderModule(f),mt[h>>>0]=u}var zT=u=>{(u=se(u)).onuncapturederror=null,u.destroy()};function NT(u,f){f=kt(f),u=se(u>>>0),Pe+=1,Ys(f,u.popErrorScope().then(h=>{--Pe,Et(()=>{var g=5;h?h instanceof GPUValidationError?g=2:h instanceof GPUOutOfMemoryError?g=3:h instanceof GPUInternalError&&(g=4):g=1;var b=ce(),M=h?sr(h.message):0;Zp(f,1,g,M),le(b)})},h=>{--Pe,Et(()=>{var g=ce(),b=sr(h.message);Zp(f,1,5,b),le(g)})}))}function $T(u,f,h,g){if(f=kt(f),g>>>=0,h>>>=0){var b={featureLevel:yT[(v(),R)[h+4>>>2>>>0]],powerPreference:bT[(v(),R)[h+8>>>2>>>0]],forceFallbackAdapter:!!(v(),C)[h+12>>>2>>>0]};(u=(v(),C)[h>>>2>>>0])!==0&&(v(),b.Fe=!!(v(),C)[u+8>>>2>>>0])}"gpu"in navigator?(Pe+=1,Ys(f,navigator.gpu.requestAdapter(b).then(M=>{--Pe,Et(()=>{if(M)mt[g>>>0]=M,oo(f,1,g,0);else{var I=ce(),z=sr("WebGPU not available on this browser (requestAdapter returned null)");oo(f,3,g,z),le(I)}})},M=>{--Pe,Et(()=>{var I=ce(),z=sr(M.message);oo(f,4,g,z),le(I)})}))):(b=ce(),u=sr("WebGPU not available on this browser (navigator.gpu is not available)"),oo(f,3,g,u),le(b))}function RT(u,f,h){return u>>>=0,f>>>=0,h>>>=0,cv(async()=>{var g=[];if(h){var b=(v(),R)[h>>>2>>>0];g.length=f+1,g[f]=new Promise(z=>setTimeout(z,b,0))}else g.length=f;for(var M=0;M<f;++M){var I=no(u+8*M);if(!(I in Ul))return I;g[M]=Ul[I]}return g=await Promise.race(g),delete Ul[g],g})}var Hp,Xp={},bv=()=>{if(!Hp){var u,f={USER:"web_user",LOGNAME:"web_user",PATH:"/",PWD:"/",HOME:"/home/web_user",LANG:(globalThis.navigator?.language??"C").replace("-","_")+".UTF-8",_:"./this.program"};for(u in Xp)Xp[u]===void 0?delete f[u]:f[u]=Xp[u];var h=[];for(u in f)h.push(`${u}=${f[u]}`);Hp=h}return Hp};function vv(u,f){if(n)return Be(19,1,u,f);u>>>=0,f>>>=0;var h,g=0,b=0;for(h of bv()){var M=f+g;(v(),C)[u+b>>>2>>>0]=M,g+=dr(h,M,1/0)+1,b+=4}return 0}function kv(u,f){if(n)return Be(20,1,u,f);u>>>=0,f>>>=0;var h=bv();for(var g of((v(),C)[u>>>2>>>0]=h.length,u=0,h))u+=fr(g)+1;return(v(),C)[f>>>2>>>0]=u,0}function Ev(u){return n?Be(21,1,u):52}function Av(u,f,h,g){return n?Be(22,1,u,f,h,g):52}function Mv(u,f,h,g){return n?Be(23,1,u,f,h,g):70}var DT=[null,[],[]];function Sv(u,f,h,g){if(n)return Be(24,1,u,f,h,g);f>>>=0,h>>>=0,g>>>=0;for(var b=0,M=0;M<h;M++){var I=(v(),C)[f>>>2>>>0],z=(v(),C)[f+4>>>2>>>0];f+=8;for(var U=0;U<z;U++){var Y=u,Se=(v(),H)[I+U>>>0],ze=DT[Y];Se===0||Se===10?((Y===1?T:S)(G1(ze)),ze.length=0):ze.push(Se)}b+=z}return(v(),C)[g>>>2>>>0]=b,0}function FT(u){return u>>>0}function BT(u,f){return xv(se(u>>>0).limits,f>>>0),1}function UT(u,f){return se(u>>>0).features.has(yv[f])}function jT(u){return BigInt(se(u>>>0).size)}function GT(u){return BigInt(se(u>>>0).usage)}function qT(u,f){if(u>>>=0,f>>>=0){var h=mr(f+4);h={label:h,timestampWrites:f=(f=(v(),C)[f+12>>>2>>>0])!==0?{querySet:se((v(),C)[f+4>>>2>>>0]),beginningOfPassWriteIndex:(v(),C)[f+8>>>2>>>0],endOfPassWriteIndex:(v(),C)[f+12>>>2>>>0]}:void 0}}return f=se(u),u=$v(0),h=f.beginComputePass(h),mt[u>>>0]=h,u}function WT(u,f,h,g,b,M){h=kt(h),b=kt(b),M=kt(M),se(u>>>0).copyBufferToBuffer(se(f>>>0),h,se(g>>>0),b,M)}function VT(u){var f=se(u>>>0);return u=zv(0),f=f.finish(),mt[u>>>0]=f,u}function HT(u,f,h,g,b,M){M=kt(M),se(u>>>0).resolveQuerySet(se(f>>>0),h,g,se(b>>>0),M)}function XT(u,f,h,g){se(u>>>0).dispatchWorkgroups(f,h,g)}function KT(u,f,h){h=kt(h),se(u>>>0).dispatchWorkgroupsIndirect(se(f>>>0),h)}function QT(u){se(u>>>0).end()}function YT(u,f,h,g,b){g>>>=0,b>>>=0,u=se(u>>>0),h=se(h>>>0),g==0?u.setBindGroup(f,h):u.setBindGroup(f,h,(v(),C),b>>>2,g)}function JT(u,f){se(u>>>0).setPipeline(se(f>>>0))}function ZT(u,f,h){se(u>>>0).Ee(se(f>>>0),h)}function eO(u,f){var h=se(u>>>0);return u=Pv(0),f=h.getBindGroupLayout(f),mt[u>>>0]=f,u}function tO(u,f){function h(b){var M=(v(),C)[b+8>>>2>>>0],I=(v(),C)[b+32>>>2>>>0],z=(v(),C)[b+36>>>2>>>0],U=0;return gT(b,{327681:Y=>{U=(v(),C)[Y+8>>>2>>>0]}}),M?((I=no(b+24))==-1&&(I=void 0),M={buffer:se(M),offset:no(b+16),size:I}):M=se(I||z||U),{binding:(v(),C)[b+4>>>2>>>0],resource:M}}u>>>=0,f={label:mr(4+(f>>>=0)),layout:se((v(),C)[f+12>>>2>>>0]),entries:(function(b,M){for(var I=[],z=0;z<b;++z)I.push(h(M+40*z));return I})((v(),C)[f+16>>>2>>>0],(v(),C)[f+20>>>2>>>0])},u=se(u);var g=Lv(0);return hT(g,u.createBindGroup(f)),g}function rO(u,f){var h;return u>>>=0,(f>>>=0)&&(h={label:mr(f+4)}),f=se(u),u=Nv(0),h=f.createCommandEncoder(h),mt[u>>>0]=h,u}function sO(u,f){u>>>=0,f>>>=0,f={type:vT[(v(),R)[f+12>>>2>>>0]],count:(v(),C)[f+16>>>2>>>0]};var h=se(u);return u=Rv(0),f=h.createQuerySet(f),mt[u>>>0]=f,u}function nO(u,f){u=se(u>>>0).adapterInfo,f>>>=0,(v(),C)[f+52>>>2>>>0]=u.subgroupMinSize,(v(),C)[f+56>>>2>>>0]=u.subgroupMaxSize;var h=u.vendor+u.architecture+u.device+u.description,g=fr(h)+1,b=Js(g);return b&&dr(h,b,g),h=b,g=fr(u.vendor),jl(f+4,h,g),h+=g,g=fr(u.architecture),jl(f+12,h,g),h+=g,g=fr(u.device),jl(f+20,h,g),jl(f+28,h+g,fr(u.description)),(v(),R)[f+36>>>2>>>0]=2,u=u.isFallbackAdapter?3:4,(v(),R)[f+40>>>2>>>0]=u,(v(),C)[f+44>>>2>>>0]=0,(v(),C)[f+48>>>2>>>0]=0,1}var oO={"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 aO(u,f){f>>>=0;var h=se(u>>>0);u=Js(4*h.features.size);var g=0,b=0;for(let M of h.features)0<=(h=oO[M])&&((v(),R)[u+g>>>2>>>0]=h,g+=4,b++);(v(),C)[f+4>>>2>>>0]=u,(v(),C)[f>>>2>>>0]=b}function iO(u,f){return xv(se(u>>>0).limits,f>>>0),1}function lO(u,f){se(u>>>0).pushErrorScope(xT[f])}function cO(u,f,h){f>>>=0,h>>>=0,u=se(u>>>0),f=Array.from((v(),R).subarray(h>>>2>>>0,h+4*f>>>2>>>0),g=>se(g)),u.submit(f)}function uO(u,f,h,g,b){h=kt(h),g>>>=0,b>>>=0,u=se(u>>>0),f=se(f>>>0),g=(v(),H).subarray(g>>>0,g+b>>>0),u.writeBuffer(f,h,g,0,b)}n||(function(){for(var u=e.numThreads-1;u--;)$1();Fe.push(async()=>{var f=(async function(){if(!n)return Promise.all(Ar.map(N1))})();Me++,await f,--Me==0&&Ze&&(f=Ze,Ze=null,f())})})(),n||(Mr=new WebAssembly.Memory({initial:256,maximum:65536,shared:!0}),xe()),e.wasmBinary&&(d=e.wasmBinary),e.stackSave=()=>ce(),e.stackRestore=u=>le(u),e.stackAlloc=u=>ql(u),e.setValue=function(u,f,h="i8"){switch(h.endsWith("*")&&(h="*"),h){case"i1":case"i8":(v(),B)[u>>>0]=f;break;case"i16":(v(),G)[u>>>1>>>0]=f;break;case"i32":(v(),R)[u>>>2>>>0]=f;break;case"i64":(v(),P)[u>>>3>>>0]=BigInt(f);break;case"float":(v(),te)[u>>>2>>>0]=f;break;case"double":(v(),ae)[u>>>3>>>0]=f;break;case"*":(v(),C)[u>>>2>>>0]=f;break;default:qe(`invalid type for setValue: ${h}`)}},e.getValue=function(u,f="i8"){switch(f.endsWith("*")&&(f="*"),f){case"i1":case"i8":return(v(),B)[u>>>0];case"i16":return(v(),G)[u>>>1>>>0];case"i32":return(v(),R)[u>>>2>>>0];case"i64":return(v(),P)[u>>>3>>>0];case"float":return(v(),te)[u>>>2>>>0];case"double":return(v(),ae)[u>>>3>>>0];case"*":return(v(),C)[u>>>2>>>0];default:qe(`invalid type for getValue: ${f}`)}},e.UTF8ToString=Ks,e.stringToUTF8=dr,e.lengthBytesUTF8=fr;var Tv,Ov,Kp,Gl,qt,Js,Iv,Cv,Lv,Pv,zv,Nv,$v,Rv,Dv,Fv,Bv,Qp,Yp,Jp,Zp,oo,ed,Uv,td,jv,Gv,qv,rd,Wv,Vv,sd,we,ao,Hv,le,ql,ce,Xv,nd,Kv,Qv,Yv,od,Jv,Zv,ek,tk,rk,sk,nk,ok,ak,ik,lk,ck,uk,pk,dk,fk,_k,mk,hk,gk,wk,xk,yk,bk,vk,kk,Ek,Ak,Mk,Sk,Tk,Ok,Ik,Ck,Lk,Pk,zk,Nk,$k,hr,pO=[Vs,to,F1,q1,W1,V1,H1,X1,K1,Q1,Y1,J1,Z1,ev,tv,rv,_v,mv,hv,vv,kv,Ev,Av,Mv,Sv],ad={925676:(u,f,h,g,b)=>{if(e===void 0||!e.Uc)return 1;if((u=Ks(Number(u>>>0))).startsWith("./")&&(u=u.substring(2)),!(u=e.Uc.get(u)))return 2;if(f=Number(f>>>0),h=Number(h>>>0),g=Number(g>>>0),f+h>u.byteLength)return 3;try{let M=u.subarray(f,f+h);switch(b){case 0:(v(),H).set(M,g>>>0);break;case 1:e.ad?e.ad(g,M):e.oe(g,M);break;default:return 4}return 0}catch{return 4}},926500:(u,f,h)=>{e.Sd(u,(v(),H).subarray(f>>>0,f+h>>>0))},926564:()=>e.me(),926606:u=>{e.jd(u)},926643:()=>typeof wasmOffsetConverter<"u"};function dO(u,f,h,g){var b=ce();try{return ok(u,f,h,g)}catch(M){if(le(b),M!==M+0)throw M;we(1,0)}}function fO(u,f,h){var g=ce();try{return rk(u,f,h)}catch(b){if(le(g),b!==b+0)throw b;we(1,0)}}function _O(u,f,h){var g=ce();try{Yv(u,f,h)}catch(b){if(le(g),b!==b+0)throw b;we(1,0)}}function mO(u,f){var h=ce();try{return od(u,f)}catch(g){if(le(h),g!==g+0)throw g;we(1,0)}}function hO(u){var f=ce();try{Jv(u)}catch(h){if(le(f),h!==h+0)throw h;we(1,0)}}function gO(u,f,h,g,b,M,I){var z=ce();try{return tk(u,f,h,g,b,M,I)}catch(U){if(le(z),U!==U+0)throw U;we(1,0)}}function wO(u,f){var h=ce();try{ak(u,f)}catch(g){if(le(h),g!==g+0)throw g;we(1,0)}}function xO(u,f,h,g,b,M){var I=ce();try{Zv(u,f,h,g,b,M)}catch(z){if(le(I),z!==z+0)throw z;we(1,0)}}function yO(u,f,h,g){var b=ce();try{nk(u,f,h,g)}catch(M){if(le(b),M!==M+0)throw M;we(1,0)}}function bO(u,f,h,g,b,M,I){var z=ce();try{lk(u,f,h,g,b,M,I)}catch(U){if(le(z),U!==U+0)throw U;we(1,0)}}function vO(u,f,h,g,b,M,I){var z=ce();try{ck(u,f,h,g,b,M,I)}catch(U){if(le(z),U!==U+0)throw U;we(1,0)}}function kO(u,f,h,g,b,M,I,z){var U=ce();try{wk(u,f,h,g,b,M,I,z)}catch(Y){if(le(U),Y!==Y+0)throw Y;we(1,0)}}function EO(u,f,h,g,b,M,I,z,U,Y,Se,ze){var Ue=ce();try{uk(u,f,h,g,b,M,I,z,U,Y,Se,ze)}catch(ne){if(le(Ue),ne!==ne+0)throw ne;we(1,0)}}function AO(u,f,h,g,b){var M=ce();try{return ik(u,f,h,g,b)}catch(I){if(le(M),I!==I+0)throw I;we(1,0)}}function MO(u,f,h,g,b){var M=ce();try{ek(u,f,h,g,b)}catch(I){if(le(M),I!==I+0)throw I;we(1,0)}}function SO(u,f,h,g,b,M,I,z){var U=ce();try{sk(u,f,h,g,b,M,I,z)}catch(Y){if(le(U),Y!==Y+0)throw Y;we(1,0)}}function TO(u){var f=ce();try{return xk(u)}catch(h){if(le(f),h!==h+0)throw h;we(1,0)}}function OO(u,f,h){var g=ce();try{return yk(u,f,h)}catch(b){if(le(g),b!==b+0)throw b;we(1,0)}}function IO(u,f){var h=ce();try{return Lk(u,f)}catch(g){if(le(h),g!==g+0)throw g;return we(1,0),0n}}function CO(u,f,h,g,b){var M=ce();try{bk(u,f,h,g,b)}catch(I){if(le(M),I!==I+0)throw I;we(1,0)}}function LO(u){var f=ce();try{return pk(u)}catch(h){if(le(f),h!==h+0)throw h;return we(1,0),0n}}function PO(u,f,h,g,b,M){var I=ce();try{return hk(u,f,h,g,b,M)}catch(z){if(le(I),z!==z+0)throw z;we(1,0)}}function zO(u,f,h,g,b,M){var I=ce();try{return vk(u,f,h,g,b,M)}catch(z){if(le(I),z!==z+0)throw z;we(1,0)}}function NO(u,f,h,g,b,M){var I=ce();try{return kk(u,f,h,g,b,M)}catch(z){if(le(I),z!==z+0)throw z;we(1,0)}}function $O(u,f,h,g,b,M,I,z){var U=ce();try{return gk(u,f,h,g,b,M,I,z)}catch(Y){if(le(U),Y!==Y+0)throw Y;we(1,0)}}function RO(u,f,h,g,b){var M=ce();try{return Ek(u,f,h,g,b)}catch(I){if(le(M),I!==I+0)throw I;return we(1,0),0n}}function DO(u,f,h,g){var b=ce();try{return Ak(u,f,h,g)}catch(M){if(le(b),M!==M+0)throw M;we(1,0)}}function FO(u,f,h,g){var b=ce();try{return Mk(u,f,h,g)}catch(M){if(le(b),M!==M+0)throw M;we(1,0)}}function BO(u,f,h,g,b,M,I,z,U,Y,Se,ze){var Ue=ce();try{return Sk(u,f,h,g,b,M,I,z,U,Y,Se,ze)}catch(ne){if(le(Ue),ne!==ne+0)throw ne;we(1,0)}}function UO(u,f,h,g,b,M,I,z,U,Y,Se){var ze=ce();try{Tk(u,f,h,g,b,M,I,z,U,Y,Se)}catch(Ue){if(le(ze),Ue!==Ue+0)throw Ue;we(1,0)}}function jO(u,f,h,g,b,M,I,z,U,Y,Se,ze,Ue,ne,it,At){var lt=ce();try{Ok(u,f,h,g,b,M,I,z,U,Y,Se,ze,Ue,ne,it,At)}catch(is){if(le(lt),is!==is+0)throw is;we(1,0)}}function GO(u,f,h,g){var b=ce();try{return Ik(u,f,h,g)}catch(M){if(le(b),M!==M+0)throw M;we(1,0)}}function qO(u,f,h,g,b){var M=ce();try{return Ck(u,f,h,g,b)}catch(I){if(le(M),I!==I+0)throw I;we(1,0)}}function WO(u,f,h){var g=ce();try{return fk(u,f,h)}catch(b){if(le(g),b!==b+0)throw b;return we(1,0),0n}}function VO(u,f,h){var g=ce();try{return dk(u,f,h)}catch(b){if(le(g),b!==b+0)throw b;we(1,0)}}function HO(u,f,h){var g=ce();try{return _k(u,f,h)}catch(b){if(le(g),b!==b+0)throw b;we(1,0)}}function XO(u,f,h,g){var b=ce();try{mk(u,f,h,g)}catch(M){if(le(b),M!==M+0)throw M;we(1,0)}}function Wl(){if(0<Me)Ze=Wl;else if(n)w?.(e),ue();else{for(var u=Fe;0<u.length;)u.shift()(e);0<Me?Ze=Wl:(e.calledRun=!0,L||(ue(),w?.(e)))}}return n||(hr=await _t(),Wl()),e.PTR_SIZE=4,e.webgpuInit=u=>{let f=new WeakMap,h,g,b=1;e.webgpuRegisterDevice=z=>{if(g!==void 0)throw Error("another WebGPU EP inference session is being created.");if(z){var U=f.get(z);if(!U){let Y=((Se,ze=0)=>{var Ue=Bv(ze);return ze=Fv(ze,Ue),mt[Ue>>>0]=Se.queue,mt[ze>>>0]=Se,ze})(z,U=Cv(0));U=[b++,U,Y],f.set(z,U)}return h=z,g=U[0],U}h=void 0,g=0};let M=new Map;e.webgpuOnCreateSession=z=>{if(g!==void 0){var U=g;if(g=void 0,z){let Y=Kp(U);M.set(z,Y),U===0&&u(h??se(Y))}h=void 0}},e.webgpuOnReleaseSession=z=>{M.delete(z)};let I=Symbol("gpuBufferMetadata");e.webgpuRegisterBuffer=(z,U,Y)=>{if(Y)return z[I]=[Y,NaN],Y;if(Y=z[I])return Y[1]++,Y[0];if((U=M.get(U))===void 0)throw Error("Invalid session handle passed to webgpuRegisterBuffer");return U=((Se,ze=0)=>(Se.mapState==="unmapped"||qe(),ze=Dv(ze),mt[ze>>>0]=Se,ze))(z,U),z[I]=[U,1],U},e.webgpuUnregisterBuffer=z=>{let U=z[I];if(!U)throw Error("Buffer is not registered");U[1]--,U[1]===0&&(Iv(U[0]),delete z[I])},e.webgpuGetBuffer=z=>se(z),e.webgpuCreateDownloader=(z,U,Y)=>{if((Y=M.get(Y))===void 0)throw Error("Invalid session handle passed to webgpuRegisterBuffer");let Se=se(Y),ze=16*Math.ceil(Number(U)/16);return async()=>{let Ue=Se.createBuffer({size:ze,usage:9});try{let ne=Se.createCommandEncoder();return ne.copyBufferToBuffer(z,0,Ue,0,ze),Se.queue.submit([ne.finish()]),await Ue.mapAsync(GPUMapMode.READ),Ue.getMappedRange().slice(0,U)}finally{Ue.destroy()}}},e.ad=(z,U)=>{var Y=U.buffer;let Se=U.byteOffset,ze=U.byteLength;if(U=16*Math.ceil(Number(ze)/16),z=se(z),!h){var Ue=Kp(g);h=se(Ue)}let ne=(Ue=h.createBuffer({mappedAtCreation:!0,size:U,usage:6})).getMappedRange();new Uint8Array(ne).set(new Uint8Array(Y,Se,ze)),Ue.unmap(),(Y=h.createCommandEncoder()).copyBufferToBuffer(Ue,0,z,0,U),h.queue.submit([Y.finish()]),Ue.destroy()}},e.webnnInit=u=>{let f=u[0];[e.me,e.jd,e.webnnEnsureTensor,e.Sd,e.webnnDownloadTensor,e.le,e.webnnEnableTraceEvent]=u.slice(1),e.webnnReleaseTensorId=e.jd,e.webnnUploadTensor=e.Sd,e.webnnRegisterMLContext=e.le,e.webnnOnRunStart=h=>f.onRunStart(h),e.webnnOnRunEnd=f.onRunEnd.bind(f),e.webnnOnReleaseSession=h=>{f.onReleaseSession(h)},e.webnnCreateMLTensorDownloader=(h,g)=>f.createMLTensorDownloader(h,g),e.webnnRegisterMLTensor=(h,g,b,M)=>f.registerMLTensor(h,g,b,M),e.webnnCreateMLContext=h=>f.createMLContext(h),e.webnnRegisterMLConstant=(h,g,b,M,I,z)=>f.registerMLConstant(h,g,b,M,I,e.Uc,z),e.webnnRegisterGraphInput=f.registerGraphInput.bind(f),e.webnnIsGraphInput=f.isGraphInput.bind(f),e.webnnRegisterGraphOutput=f.registerGraphOutput.bind(f),e.webnnIsGraphOutput=f.isGraphOutput.bind(f),e.webnnCreateTemporaryTensor=f.createTemporaryTensor.bind(f),e.webnnIsGraphInputOutputTypeSupported=f.isGraphInputOutputTypeSupported.bind(f)},J?e:new Promise((u,f)=>{w=u,x=f})}var zA,UE,qP=be(()=>{"use strict";zA=BE,UE=globalThis.self?.name?.startsWith("em-pthread"),UE&&BE()}),Od,Wd,jE,Ct,NA,ic,GE,qE,Id,WE,Cd,$A,Ld,RA,ef=be(()=>{"use strict";Zd(),Od=typeof location>"u"?void 0:location.origin,Wd=import.meta.url>"file:"&&import.meta.url<"file;",jE=()=>{if(Wd){let t=URL;return new URL(new t("ort.webgpu.bundle.min.mjs",import.meta.url).href,Od).href}return import.meta.url},Ct=jE(),NA=()=>{if(Ct&&!Ct.startsWith("blob:"))return Ct.substring(0,Ct.lastIndexOf("/")+1)},ic=(t,e)=>{try{let r=e??Ct;return(r?new URL(t,r):new URL(t)).origin===Od}catch{return!1}},GE=(t,e)=>{let r=e??Ct;try{return(r?new URL(t,r):new URL(t)).href}catch{return}},qE=(t,e)=>`${e??"./"}${t}`,Id=async t=>{let e=await(await fetch(t,{credentials:"same-origin"})).blob();return URL.createObjectURL(e)},WE=async t=>(await import(t)).default,Cd=(GP(),fc(CA)).default,$A=async()=>{if(!Ct)throw new Error("Failed to load proxy worker: cannot determine the script source URL.");if(ic(Ct))return[void 0,Cd()];let t=await Id(Ct);return[t,Cd(t)]},Ld=(qP(),fc(PA)).default,RA=async(t,e,r,s)=>{let n=Ld&&!(t||e);if(n)if(Ct)n=ic(Ct)||s&&!r;else if(s&&!r)n=!0;else throw new Error("cannot determine the script source URL.");if(n)return[void 0,Ld];{let o="ort-wasm-simd-threaded.asyncify.mjs",a=t??GE(o,e),i=r&&a&&!ic(a,e),l=i?await Id(a):a??qE(o,e);return[i?l:void 0,await WE(l)]}}}),Pd,lc,xo,zd,VE,HE,XE,tf,De,bs=be(()=>{"use strict";ef(),lc=!1,xo=!1,zd=!1,VE=()=>{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}},HE=()=>{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}},XE=()=>{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}},tf=async t=>{if(lc)return Promise.resolve();if(xo)throw new Error("multiple calls to 'initializeWebAssembly()' detected.");if(zd)throw new Error("previous call to 'initializeWebAssembly()' failed.");xo=!0;let e=t.initTimeout,r=t.numThreads;if(t.simd!==!1){if(t.simd==="relaxed"){if(!XE())throw new Error("Relaxed WebAssembly SIMD is not supported in the current environment.")}else if(!HE())throw new Error("WebAssembly SIMD is not supported in the current environment.")}let s=VE();r>1&&!s&&(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."),t.numThreads=r=1);let n=t.wasmPaths,o=typeof n=="string"?n:void 0,a=n?.mjs,i=a?.href??a,l=n?.wasm,c=l?.href??l,p=t.wasmBinary,[d,_]=await RA(i,o,r>1,!!p||!!c),m=!1,w=[];if(e>0&&w.push(new Promise(x=>{setTimeout(()=>{m=!0,x()},e)})),w.push(new Promise((x,E)=>{let k={numThreads:r};if(p)k.wasmBinary=p,k.locateFile=A=>A;else if(c||o)k.locateFile=A=>c??o+A;else if(i&&i.indexOf("blob:")!==0)k.locateFile=A=>new URL(A,i).href;else if(d){let A=NA();A&&(k.locateFile=T=>A+T)}_(k).then(A=>{xo=!1,lc=!0,Pd=A,x(),d&&URL.revokeObjectURL(d)},A=>{xo=!1,zd=!0,E(A)})})),await Promise.race(w),m)throw new Error(`WebAssembly backend initializing failed due to timeout: ${e}ms`)},De=()=>{if(lc&&Pd)return Pd;throw new Error("WebAssembly is not initialized yet.")}}),Lt,mc,Ie,rf=be(()=>{"use strict";bs(),Lt=(t,e)=>{let r=De(),s=r.lengthBytesUTF8(t)+1,n=r._malloc(s);return r.stringToUTF8(t,n,s),e.push(n),n},mc=(t,e,r,s)=>{if(typeof t=="object"&&t!==null){if(r.has(t))throw new Error("Circular reference in options");r.add(t)}Object.entries(t).forEach(([n,o])=>{let a=e?e+n:n;if(typeof o=="object")mc(o,a+".",r,s);else if(typeof o=="string"||typeof o=="number")s(a,o.toString());else if(typeof o=="boolean")s(a,o?"1":"0");else throw new Error(`Can't handle extra config type: ${typeof o}`)})},Ie=t=>{let e=De(),r=e.stackSave();try{let s=e.PTR_SIZE,n=e.stackAlloc(2*s);e._OrtGetLastError(n,n+s);let o=Number(e.getValue(n,s===4?"i32":"i64")),a=e.getValue(n+s,"*"),i=a?e.UTF8ToString(a):"";throw new Error(`${t} ERROR_CODE: ${o}, ERROR_MESSAGE: ${i}`)}finally{e.stackRestore(r)}}}),DA,WP=be(()=>{"use strict";bs(),rf(),DA=t=>{let e=De(),r=0,s=[],n=t||{};try{if(t?.logSeverityLevel===void 0)n.logSeverityLevel=2;else if(typeof t.logSeverityLevel!="number"||!Number.isInteger(t.logSeverityLevel)||t.logSeverityLevel<0||t.logSeverityLevel>4)throw new Error(`log severity level is not valid: ${t.logSeverityLevel}`);if(t?.logVerbosityLevel===void 0)n.logVerbosityLevel=0;else if(typeof t.logVerbosityLevel!="number"||!Number.isInteger(t.logVerbosityLevel))throw new Error(`log verbosity level is not valid: ${t.logVerbosityLevel}`);t?.terminate===void 0&&(n.terminate=!1);let o=0;return t?.tag!==void 0&&(o=Lt(t.tag,s)),r=e._OrtCreateRunOptions(n.logSeverityLevel,n.logVerbosityLevel,!!n.terminate,o),r===0&&Ie("Can't create run options."),t?.extra!==void 0&&mc(t.extra,"",new WeakSet,(a,i)=>{let l=Lt(a,s),c=Lt(i,s);e._OrtAddRunConfigEntry(r,l,c)!==0&&Ie(`Can't set a run config entry: ${a} - ${i}.`)}),[r,s]}catch(o){throw r!==0&&e._OrtReleaseRunOptions(r),s.forEach(a=>e._free(a)),o}}}),KE,QE,YE,cc,zr,JE,FA,VP=be(()=>{"use strict";bs(),rf(),KE=t=>{switch(t){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: ${t}`)}},QE=t=>{switch(t){case"sequential":return 0;case"parallel":return 1;default:throw new Error(`unsupported execution mode: ${t}`)}},YE=t=>{t.extra||(t.extra={}),t.extra.session||(t.extra.session={});let e=t.extra.session;e.use_ort_model_bytes_directly||(e.use_ort_model_bytes_directly="1"),t.executionProviders&&t.executionProviders.some(r=>(typeof r=="string"?r:r.name)==="webgpu")&&(t.enableMemPattern=!1)},cc=(t,e,r,s)=>{let n=Lt(e,s),o=Lt(r,s);De()._OrtAddSessionConfigEntry(t,n,o)!==0&&Ie(`Can't set a session config entry: ${e} - ${r}.`)},zr=(t,e,r,s)=>{let n=Lt(e,s),o=Lt(r,s);t.push([n,o])},JE=async(t,e,r)=>{let s=e.executionProviders;for(let n of s){let o=typeof n=="string"?n:n.name,a=[];switch(o){case"webnn":if(o="WEBNN",typeof n!="string"){let d=n?.deviceType;d&&cc(t,"deviceType",d,r)}break;case"webgpu":{o="WebGPU";let d;if(typeof n!="string"){let m=n;if(m.device)if(typeof GPUDevice<"u"&&m.device instanceof GPUDevice)d=m.device;else throw new Error("Invalid GPU device set in WebGPU EP options.");let{enableGraphCapture:w}=e;if(typeof w=="boolean"&&w&&zr(a,"enableGraphCapture","1",r),typeof m.preferredLayout=="string"&&zr(a,"preferredLayout",m.preferredLayout,r),m.forceCpuNodeNames){let x=Array.isArray(m.forceCpuNodeNames)?m.forceCpuNodeNames:[m.forceCpuNodeNames];zr(a,"forceCpuNodeNames",x.join(`
13
+ `),r)}m.validationMode&&zr(a,"validationMode",m.validationMode,r)}let _=De().webgpuRegisterDevice(d);if(_){let[m,w,x]=_;zr(a,"deviceId",m.toString(),r),zr(a,"webgpuInstance",w.toString(),r),zr(a,"webgpuDevice",x.toString(),r)}}break;case"wasm":case"cpu":continue;default:throw new Error(`not supported execution provider: ${o}`)}let i=Lt(o,r),l=a.length,c=0,p=0;if(l>0){c=De()._malloc(l*De().PTR_SIZE),r.push(c),p=De()._malloc(l*De().PTR_SIZE),r.push(p);for(let d=0;d<l;d++)De().setValue(c+d*De().PTR_SIZE,a[d][0],"*"),De().setValue(p+d*De().PTR_SIZE,a[d][1],"*")}await De()._OrtAppendExecutionProvider(t,i,c,p,l)!==0&&Ie(`Can't append execution provider: ${o}.`)}},FA=async t=>{let e=De(),r=0,s=[],n=t||{};YE(n);try{let o=KE(n.graphOptimizationLevel??"all"),a=QE(n.executionMode??"sequential"),i=typeof n.logId=="string"?Lt(n.logId,s):0,l=n.logSeverityLevel??2;if(!Number.isInteger(l)||l<0||l>4)throw new Error(`log severity level is not valid: ${l}`);let c=n.logVerbosityLevel??0;if(!Number.isInteger(c)||c<0||c>4)throw new Error(`log verbosity level is not valid: ${c}`);let p=typeof n.optimizedModelFilePath=="string"?Lt(n.optimizedModelFilePath,s):0;if(r=e._OrtCreateSessionOptions(o,!!n.enableCpuMemArena,!!n.enableMemPattern,a,!!n.enableProfiling,0,i,l,c,p),r===0&&Ie("Can't create session options."),n.executionProviders&&await JE(r,n,s),n.enableGraphCapture!==void 0){if(typeof n.enableGraphCapture!="boolean")throw new Error(`enableGraphCapture must be a boolean value: ${n.enableGraphCapture}`);cc(r,"enableGraphCapture",n.enableGraphCapture.toString(),s)}if(n.freeDimensionOverrides)for(let[d,_]of Object.entries(n.freeDimensionOverrides)){if(typeof d!="string")throw new Error(`free dimension override name must be a string: ${d}`);if(typeof _!="number"||!Number.isInteger(_)||_<0)throw new Error(`free dimension override value must be a non-negative integer: ${_}`);let m=Lt(d,s);e._OrtAddFreeDimensionOverride(r,m,_)!==0&&Ie(`Can't set a free dimension override: ${d} - ${_}.`)}return n.extra!==void 0&&mc(n.extra,"",new WeakSet,(d,_)=>{cc(r,d,_,s)}),[r,s]}catch(o){throw r!==0&&e._OrtReleaseSessionOptions(r)!==0&&Ie("Can't release session options."),s.forEach(a=>e._free(a)),o}}}),hs,dc,un,Eo,hc,sf,nf,Vd,pn=be(()=>{"use strict";hs=t=>{switch(t){case"int8":return 3;case"uint8":return 2;case"bool":return 9;case"int16":return 5;case"uint16":return 4;case"int32":return 6;case"uint32":return 12;case"float16":return 10;case"float32":return 1;case"float64":return 11;case"string":return 8;case"int64":return 7;case"uint64":return 13;case"int4":return 22;case"uint4":return 21;default:throw new Error(`unsupported data type: ${t}`)}},dc=t=>{switch(t){case 3:return"int8";case 2:return"uint8";case 9:return"bool";case 5:return"int16";case 4:return"uint16";case 6:return"int32";case 12:return"uint32";case 10:return"float16";case 1:return"float32";case 11:return"float64";case 8:return"string";case 7:return"int64";case 13:return"uint64";case 22:return"int4";case 21:return"uint4";default:throw new Error(`unsupported data type: ${t}`)}},un=(t,e)=>{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][t],s=typeof e=="number"?e:e.reduce((n,o)=>n*o,1);return r>0?Math.ceil(s*r):void 0},Eo=t=>{switch(t){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: ${t}`)}},hc=t=>{switch(t){case"verbose":return 0;case"info":return 1;case"warning":return 2;case"error":return 3;case"fatal":return 4;default:throw new Error(`unsupported logging level: ${t}`)}},sf=t=>t==="float32"||t==="float16"||t==="int32"||t==="int64"||t==="uint32"||t==="uint8"||t==="bool"||t==="uint4"||t==="int4",nf=t=>t==="float32"||t==="float16"||t==="int32"||t==="int64"||t==="uint32"||t==="uint64"||t==="int8"||t==="uint8"||t==="bool"||t==="uint4"||t==="int4",Vd=t=>{switch(t){case"none":return 0;case"cpu":return 1;case"cpu-pinned":return 2;case"texture":return 3;case"gpu-buffer":return 4;case"ml-tensor":return 5;default:throw new Error(`unsupported data location: ${t}`)}}}),of,BA=be(()=>{"use strict";Zd(),of=async t=>{if(typeof t=="string"){let e=await fetch(t);if(!e.ok)throw new Error(`failed to load external data file: ${t}`);let r=e.headers.get("Content-Length"),s=r?parseInt(r,10):0;if(s<1073741824)return new Uint8Array(await e.arrayBuffer());{if(!e.body)throw new Error(`failed to load external data file: ${t}, no response body.`);let n=e.body.getReader(),o;try{o=new ArrayBuffer(s)}catch(i){if(i instanceof RangeError){let l=Math.ceil(s/65536);o=new WebAssembly.Memory({initial:l,maximum:l}).buffer}else throw i}let a=0;for(;;){let{done:i,value:l}=await n.read();if(i)break;let c=l.byteLength;new Uint8Array(o,a,c).set(l),a+=c}return new Uint8Array(o,0,s)}}else return t instanceof Blob?new Uint8Array(await t.arrayBuffer()):t instanceof Uint8Array?t:new Uint8Array(t)}}),UA,HP=be(()=>{"use strict";pn(),UA=(t,e)=>new(Eo(e))(t)}),ZE,eA,tA,rA,jA,sA,xt,GA=be(()=>{"use strict";pn(),ZE=["V","I","W","E","F"],eA=(t,e)=>{console.log(`[${ZE[t]},${new Date().toISOString()}]${e}`)},jA=(t,e)=>{tA=t,rA=e},sA=(t,e)=>{let r=hc(t),s=hc(tA);r>=s&&eA(r,typeof e=="function"?e():e)},xt=(...t)=>{rA&&sA(...t)}}),Nd,Hd,$d,nA,Rd,oA,Dd,Fd,Bd,aA,qA,XP=be(()=>{"use strict";pn(),GA(),Nd=new Map([["float32",32],["float16",16],["int32",32],["uint32",32],["int64",64],["uint64",64],["int8",8],["uint8",8],["int4",4],["uint4",4]]),Hd=(t,e)=>{if(e==="int32")return t;let r=Nd.get(e);if(!r)throw new Error(`WebNN backend does not support data type: ${e}`);let s=r/8;if(t.byteLength%s!==0)throw new Error(`Invalid Uint8Array length - must be a multiple of ${s}.`);let n=t.byteLength/s,o=new(Eo(e))(t.buffer,t.byteOffset,n);switch(e){case"int64":case"uint64":{let a=new Int32Array(n);for(let i=0;i<n;i++){let l=o[i];if(l>2147483647n||l<-2147483648n)throw new Error("Can not convert int64 data to int32 - value out of range.");a[i]=Number(l)}return new Uint8Array(a.buffer)}case"int8":case"uint8":case"uint32":{if(e==="uint32"&&o.some(i=>i>2147483647))throw new Error("Can not convert uint32 data to int32 - value out of range.");let a=Int32Array.from(o,Number);return new Uint8Array(a.buffer)}default:throw new Error(`Unsupported data conversion from ${e} to 'int32'`)}},$d=(t,e)=>{if(e==="int32")return t;if(t.byteLength%4!==0)throw new Error("Invalid Uint8Array length - must be a multiple of 4 (int32).");let r=t.byteLength/4,s=new Int32Array(t.buffer,t.byteOffset,r);switch(e){case"int64":{let n=BigInt64Array.from(s,BigInt);return new Uint8Array(n.buffer)}case"uint64":{if(s.some(o=>o<0))throw new Error("Can not convert int32 data to uin64 - negative value found.");let n=BigUint64Array.from(s,BigInt);return new Uint8Array(n.buffer)}case"int8":{if(s.some(o=>o<-128||o>127))throw new Error("Can not convert int32 data to int8 - value out of range.");let n=Int8Array.from(s,Number);return new Uint8Array(n.buffer)}case"uint8":{if(s.some(n=>n<0||n>255))throw new Error("Can not convert int32 data to uint8 - value out of range.");return Uint8Array.from(s,Number)}case"uint32":{if(s.some(o=>o<0))throw new Error("Can not convert int32 data to uint32 - negative value found.");let n=Uint32Array.from(s,Number);return new Uint8Array(n.buffer)}default:throw new Error(`Unsupported data conversion from 'int32' to ${e}`)}},nA=1,Rd=()=>nA++,oA=new Map([["int8","int32"],["uint8","int32"],["uint32","int32"],["int64","int32"]]),Dd=(t,e)=>{let r=Nd.get(t);if(!r)throw new Error(`WebNN backend does not support data type: ${t}`);return e.length>0?Math.ceil(e.reduce((s,n)=>s*n)*r/8):0},Fd=class{constructor(t){this.isDataConverted=!1;let{sessionId:e,context:r,tensor:s,dataType:n,shape:o,fallbackDataType:a}=t;this.sessionId=e,this.mlContext=r,this.mlTensor=s,this.dataType=n,this.tensorShape=o,this.fallbackDataType=a}get tensor(){return this.mlTensor}get type(){return this.dataType}get fallbackType(){return this.fallbackDataType}get shape(){return this.tensorShape}get byteLength(){return Dd(this.dataType,this.tensorShape)}destroy(){xt("verbose",()=>"[WebNN] TensorWrapper.destroy"),this.mlTensor.destroy()}write(t){this.mlContext.writeTensor(this.mlTensor,t)}async read(t){if(this.fallbackDataType){let e=await this.mlContext.readTensor(this.mlTensor),r=$d(new Uint8Array(e),this.dataType);if(t){(t instanceof ArrayBuffer?new Uint8Array(t):new Uint8Array(t.buffer,t.byteOffset,t.byteLength)).set(r);return}else return r.buffer}else return t?this.mlContext.readTensor(this.mlTensor,t):this.mlContext.readTensor(this.mlTensor)}canReuseTensor(t,e,r){return this.mlContext===t&&this.dataType===e&&this.tensorShape.length===r.length&&this.tensorShape.every((s,n)=>s===r[n])}setIsDataConverted(t){this.isDataConverted=t}},Bd=class{constructor(t,e){this.tensorManager=t,this.wrapper=e}get tensorWrapper(){return this.wrapper}releaseTensor(){this.tensorWrapper&&(this.tensorManager.releaseTensor(this.tensorWrapper),this.wrapper=void 0)}async ensureTensor(t,e,r,s){let n=this.tensorManager.getMLContext(t),o=this.tensorManager.getMLOpSupportLimits(t),a;if(!o?.input.dataTypes.includes(e)){if(a=oA.get(e),!a||o?.input.dataTypes.includes(a))throw new Error(`WebNN backend does not support data type: ${e}`);xt("verbose",()=>`[WebNN] TensorIdTracker.ensureTensor: fallback dataType from ${e} to ${a}`)}if(this.wrapper){if(this.wrapper.canReuseTensor(n,e,r))return this.wrapper.tensor;if(s){if(this.wrapper.byteLength!==Dd(e,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(t,e,r,i,!0,!0,a),s&&this.activeUpload&&(this.wrapper.write(this.activeUpload),this.activeUpload=void 0),this.wrapper.tensor}upload(t){let e=t;if(this.wrapper){if(this.wrapper.fallbackType)if(this.wrapper.fallbackType==="int32")e=Hd(t,this.wrapper.type),this.wrapper.setIsDataConverted(!0);else throw new Error(`Unsupported fallback data type: ${this.wrapper.fallbackType}`);if(t.byteLength===this.wrapper.byteLength){this.wrapper.write(e);return}else xt("verbose",()=>"Data size does not match tensor size. Releasing tensor."),this.releaseTensor()}this.activeUpload?this.activeUpload.set(e):this.activeUpload=new Uint8Array(e)}async download(t){if(this.activeUpload){let e=this.wrapper?.isDataConverted?$d(this.activeUpload,this.wrapper?.type):this.activeUpload;if(t){t instanceof ArrayBuffer?new Uint8Array(t).set(e):new Uint8Array(t.buffer,t.byteOffset,t.byteLength).set(e);return}else return e.buffer}if(!this.wrapper)throw new Error("Tensor has not been created.");return t?this.wrapper.read(t):this.wrapper.read()}},aA=class{constructor(t){this.backend=t,this.tensorTrackersById=new Map,this.freeTensors=[],this.externalTensors=new Set}getMLContext(t){let e=this.backend.getMLContext(t);if(!e)throw new Error("MLContext not found for session.");return e}getMLOpSupportLimits(t){return this.backend.getMLOpSupportLimits(t)}reserveTensorId(){let t=Rd();return this.tensorTrackersById.set(t,new Bd(this)),t}releaseTensorId(t){let e=this.tensorTrackersById.get(t);e&&(this.tensorTrackersById.delete(t),e.tensorWrapper&&this.releaseTensor(e.tensorWrapper))}async ensureTensor(t,e,r,s,n){xt("verbose",()=>`[WebNN] TensorManager.ensureTensor {tensorId: ${e}, dataType: ${r}, shape: ${s}, copyOld: ${n}}`);let o=this.tensorTrackersById.get(e);if(!o)throw new Error("Tensor not found.");return o.ensureTensor(t,r,s,n)}upload(t,e){let r=this.tensorTrackersById.get(t);if(!r)throw new Error("Tensor not found.");r.upload(e)}async download(t,e){xt("verbose",()=>`[WebNN] TensorManager.download {tensorId: ${t}, dstBuffer: ${e?.byteLength}}`);let r=this.tensorTrackersById.get(t);if(!r)throw new Error("Tensor not found.");return r.download(e)}releaseTensorsForSession(t){for(let e of this.freeTensors)e.sessionId===t&&e.destroy();this.freeTensors=this.freeTensors.filter(e=>e.sessionId!==t)}registerTensor(t,e,r,s){let n=this.getMLContext(t),o=Rd(),a=new Fd({sessionId:t,context:n,tensor:e,dataType:r,shape:s});return this.tensorTrackersById.set(o,new Bd(this,a)),this.externalTensors.add(a),o}async getCachedTensor(t,e,r,s,n,o,a){let i=this.getMLContext(t);for(let[c,p]of this.freeTensors.entries())if(p.canReuseTensor(i,e,r)){xt("verbose",()=>`[WebNN] Reusing tensor {dataType: ${e}, ${a?`fallbackDataType: ${a},`:""} shape: ${r}`);let d=this.freeTensors.splice(c,1)[0];return d.sessionId=t,d}xt("verbose",()=>`[WebNN] MLContext.createTensor {dataType: ${e}, ${a?`fallbackDataType: ${a},`:""} shape: ${r}}`);let l=await i.createTensor({dataType:a??e,shape:r,dimensions:r,usage:s,writable:n,readable:o});return new Fd({sessionId:t,context:i,tensor:l,dataType:e,shape:r,fallbackDataType:a})}releaseTensor(t){this.externalTensors.has(t)&&this.externalTensors.delete(t),this.freeTensors.push(t)}},qA=(...t)=>new aA(...t)}),WA={};Ao(WA,{WebNNBackend:()=>VA});var yo,iA,VA,KP=be(()=>{"use strict";pn(),bs(),HP(),XP(),GA(),yo=new Map([[1,"float32"],[10,"float16"],[6,"int32"],[12,"uint32"],[7,"int64"],[13,"uint64"],[22,"int4"],[21,"uint4"],[3,"int8"],[2,"uint8"],[9,"uint8"]]),iA=(t,e)=>{if(t===e)return!0;if(t===void 0||e===void 0)return!1;let r=Object.keys(t).sort(),s=Object.keys(e).sort();return r.length===s.length&&r.every((n,o)=>n===s[o]&&t[n]===e[n])},VA=class{constructor(t){this.tensorManager=qA(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,jA(t.logLevel,!!t.debug)}get currentSessionId(){if(this.activeSessionId===void 0)throw new Error("No active session");return this.activeSessionId}onRunStart(t){xt("verbose",()=>`[WebNN] onRunStart {sessionId: ${t}}`),this.activeSessionId=t}onRunEnd(t){xt("verbose",()=>`[WebNN] onRunEnd {sessionId: ${t}}`);let e=this.temporarySessionTensorIds.get(t);if(e){for(let r of e)xt("verbose",()=>`[WebNN] releasing temporary tensor {tensorId: ${r}}`),this.tensorManager.releaseTensorId(r);this.temporarySessionTensorIds.delete(t),this.activeSessionId=void 0}}async createMLContext(t){if(t instanceof GPUDevice){let r=this.mlContextCache.findIndex(s=>s.gpuDevice===t);if(r!==-1)return this.mlContextCache[r].mlContext;{let s=await navigator.ml.createContext(t);return this.mlContextCache.push({gpuDevice:t,mlContext:s}),s}}else if(t===void 0){let r=this.mlContextCache.findIndex(s=>s.options===void 0&&s.gpuDevice===void 0);if(r!==-1)return this.mlContextCache[r].mlContext;{let s=await navigator.ml.createContext();return this.mlContextCache.push({mlContext:s}),s}}let e=this.mlContextCache.findIndex(r=>iA(r.options,t));if(e!==-1)return this.mlContextCache[e].mlContext;{let r=await navigator.ml.createContext(t);return this.mlContextCache.push({options:t,mlContext:r}),r}}registerMLContext(t,e){this.mlContextBySessionId.set(t,e);let r=this.sessionIdsByMLContext.get(e);r||(r=new Set,this.sessionIdsByMLContext.set(e,r)),r.add(t),this.mlOpSupportLimitsBySessionId.has(t)||this.mlOpSupportLimitsBySessionId.set(t,e.opSupportLimits()),this.temporaryGraphInputs.length>0&&(this.sessionGraphInputs.set(t,this.temporaryGraphInputs),this.temporaryGraphInputs=[]),this.temporaryGraphOutputs.length>0&&(this.sessionGraphOutputs.set(t,this.temporaryGraphOutputs),this.temporaryGraphOutputs=[])}onReleaseSession(t){this.sessionGraphInputs.delete(t),this.sessionGraphOutputs.delete(t);let e=this.mlContextBySessionId.get(t);if(!e)return;this.tensorManager.releaseTensorsForSession(t),this.mlContextBySessionId.delete(t),this.mlOpSupportLimitsBySessionId.delete(t);let r=this.sessionIdsByMLContext.get(e);if(r.delete(t),r.size===0){this.sessionIdsByMLContext.delete(e);let s=this.mlContextCache.findIndex(n=>n.mlContext===e);s!==-1&&this.mlContextCache.splice(s,1)}}getMLContext(t){return this.mlContextBySessionId.get(t)}getMLOpSupportLimits(t){return this.mlOpSupportLimitsBySessionId.get(t)}reserveTensorId(){return this.tensorManager.reserveTensorId()}releaseTensorId(t){xt("verbose",()=>`[WebNN] releaseTensorId {tensorId: ${t}}`),this.tensorManager.releaseTensorId(t)}async ensureTensor(t,e,r,s,n){let o=yo.get(r);if(!o)throw new Error(`Unsupported ONNX data type: ${r}`);return this.tensorManager.ensureTensor(t??this.currentSessionId,e,o,s,n)}async createTemporaryTensor(t,e,r){xt("verbose",()=>`[WebNN] createTemporaryTensor {onnxDataType: ${e}, shape: ${r}}`);let s=yo.get(e);if(!s)throw new Error(`Unsupported ONNX data type: ${e}`);let n=this.tensorManager.reserveTensorId();await this.tensorManager.ensureTensor(t,n,s,r,!1);let o=this.temporarySessionTensorIds.get(t);return o?o.push(n):this.temporarySessionTensorIds.set(t,[n]),n}uploadTensor(t,e){if(!De().shouldTransferToMLTensor)throw new Error("Trying to upload to a MLTensor while shouldTransferToMLTensor is false");xt("verbose",()=>`[WebNN] uploadTensor {tensorId: ${t}, data: ${e.byteLength}}`),this.tensorManager.upload(t,e)}async downloadTensor(t,e){return this.tensorManager.download(t,e)}createMLTensorDownloader(t,e){return async()=>{let r=await this.tensorManager.download(t);return UA(r,e)}}registerMLTensor(t,e,r,s){let n=yo.get(r);if(!n)throw new Error(`Unsupported ONNX data type: ${r}`);let o=this.tensorManager.registerTensor(t,e,n,s);return xt("verbose",()=>`[WebNN] registerMLTensor {tensor: ${e}, dataType: ${n}, dimensions: ${s}} -> {tensorId: ${o}}`),o}registerMLConstant(t,e,r,s,n,o,a=!1){if(!o)throw new Error("External mounted files are not available.");let i=t;t.startsWith("./")&&(i=t.substring(2));let l=o.get(i);if(!l)throw new Error(`File with name ${i} not found in preloaded files.`);if(e+r>l.byteLength)throw new Error("Out of bounds: data offset and length exceed the external file data size.");let c=l.slice(e,e+r).buffer,p;switch(n.dataType){case"float32":p=new Float32Array(c);break;case"float16":p=typeof Float16Array<"u"&&Float16Array.from?new Float16Array(c):new Uint16Array(c);break;case"int32":p=new Int32Array(c);break;case"uint32":p=new Uint32Array(c);break;case"int64":if(a){let d=Hd(new Uint8Array(c),"int64");p=new Int32Array(d.buffer),n.dataType="int32"}else p=new BigInt64Array(c);break;case"uint64":p=new BigUint64Array(c);break;case"int8":p=new Int8Array(c);break;case"int4":case"uint4":case"uint8":p=new Uint8Array(c);break;default:throw new Error(`Unsupported data type: ${n.dataType} in creating WebNN Constant from external data.`)}return xt("verbose",()=>`[WebNN] registerMLConstant {dataType: ${n.dataType}, shape: ${n.shape}}} ${a?"(Note: it was int64 data type and registered to int32 as workaround)":""}`),s.constant(n,p)}registerGraphInput(t){this.temporaryGraphInputs.push(t)}registerGraphOutput(t){this.temporaryGraphOutputs.push(t)}isGraphInput(t,e){let r=this.sessionGraphInputs.get(t);return r?r.includes(e):!1}isGraphOutput(t,e){let r=this.sessionGraphOutputs.get(t);return r?r.includes(e):!1}isGraphInputOutputTypeSupported(t,e,r=!0){let s=yo.get(hs(e)),n=this.mlOpSupportLimitsBySessionId.get(t);return typeof s>"u"?!1:r?!!n?.input.dataTypes.includes(s):!!n?.output.dataTypes.includes(s)}flush(){}}}),lA,af,lf,Nr,cA,Ud,gc,cf,uf,jd,pf,df,ff,HA=be(()=>{"use strict";ys(),WP(),VP(),pn(),bs(),rf(),BA(),lA=(t,e)=>{De()._OrtInit(t,e)!==0&&Ie("Can't initialize onnxruntime.")},af=async t=>{lA(t.wasm.numThreads,hc(t.logLevel))},lf=async(t,e)=>{De().asyncInit?.();let r=t.webgpu.adapter;if(e==="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 s=t.webgpu.powerPreference;if(s!==void 0&&s!=="low-power"&&s!=="high-performance")throw new Error(`Invalid powerPreference setting: "${s}"`);let n=t.webgpu.forceFallbackAdapter;if(n!==void 0&&typeof n!="boolean")throw new Error(`Invalid forceFallbackAdapter setting: "${n}"`);if(r=await navigator.gpu.requestAdapter({powerPreference:s,forceFallbackAdapter:n}),!r)throw new Error('Failed to get GPU adapter. You may need to enable flag "--enable-unsafe-webgpu" if you are using Chrome.')}}if(e==="webnn"&&(typeof navigator>"u"||!navigator.ml))throw new Error("WebNN is not supported in current environment");if(e==="webgpu"&&De().webgpuInit(s=>{t.webgpu.device=s}),e==="webnn"){let s=new(KP(),fc(WA)).WebNNBackend(t);De().webnnInit([s,()=>s.reserveTensorId(),n=>s.releaseTensorId(n),async(n,o,a,i,l)=>s.ensureTensor(n,o,a,i,l),(n,o)=>{s.uploadTensor(n,o)},async(n,o)=>s.downloadTensor(n,o),(n,o)=>s.registerMLContext(n,o),!!t.trace])}},Nr=new Map,cA=t=>{let e=De(),r=e.stackSave();try{let s=e.PTR_SIZE,n=e.stackAlloc(2*s);e._OrtGetInputOutputCount(t,n,n+s)!==0&&Ie("Can't get session input/output count.");let o=s===4?"i32":"i64";return[Number(e.getValue(n,o)),Number(e.getValue(n+s,o))]}finally{e.stackRestore(r)}},Ud=(t,e)=>{let r=De(),s=r.stackSave(),n=0;try{let o=r.PTR_SIZE,a=r.stackAlloc(2*o);r._OrtGetInputOutputMetadata(t,e,a,a+o)!==0&&Ie("Can't get session input/output metadata.");let i=Number(r.getValue(a,"*"));n=Number(r.getValue(a+o,"*"));let l=r.HEAP32[n/4];if(l===0)return[i,0];let c=r.HEAPU32[n/4+1],p=[];for(let d=0;d<c;d++){let _=Number(r.getValue(n+8+d*o,"*"));p.push(_!==0?r.UTF8ToString(_):Number(r.getValue(n+8+(d+c)*o,"*")))}return[i,l,p]}finally{r.stackRestore(s),n!==0&&r._OrtFree(n)}},gc=t=>{let e=De(),r=e._malloc(t.byteLength);if(r===0)throw new Error(`Can't create a session. failed to allocate a buffer of size ${t.byteLength}.`);return e.HEAPU8.set(t,r),[r,t.byteLength]},cf=async(t,e)=>{let r,s,n=De();Array.isArray(t)?[r,s]=t:t.buffer===n.HEAPU8.buffer?[r,s]=[t.byteOffset,t.byteLength]:[r,s]=gc(t);let o=0,a=0,i=0,l=[],c=[],p=[];try{if([a,l]=await FA(e),e?.externalData&&n.mountExternalData){let S=[];for(let L of e.externalData){let O=typeof L=="string"?L:L.path;S.push(of(typeof L=="string"?L:L.data).then(v=>{n.mountExternalData(O,v)}))}await Promise.all(S)}for(let S of e?.executionProviders??[])if((typeof S=="string"?S:S.name)==="webnn"){if(n.shouldTransferToMLTensor=!1,typeof S!="string"){let L=S,O=L?.context,v=L?.gpuDevice,W=L?.deviceType,X=L?.powerPreference;O?n.currentContext=O:v?n.currentContext=await n.webnnCreateMLContext(v):n.currentContext=await n.webnnCreateMLContext({deviceType:W,powerPreference:X})}else n.currentContext=await n.webnnCreateMLContext();break}o=await n._OrtCreateSession(r,s,a),n.webgpuOnCreateSession?.(o),o===0&&Ie("Can't create a session."),n.jsepOnCreateSession?.(),n.currentContext&&(n.webnnRegisterMLContext(o,n.currentContext),n.currentContext=void 0,n.shouldTransferToMLTensor=!0);let[d,_]=cA(o),m=!!e?.enableGraphCapture,w=[],x=[],E=[],k=[],A=[];for(let S=0;S<d;S++){let[L,O,v]=Ud(o,S);L===0&&Ie("Can't get an input name."),c.push(L);let W=n.UTF8ToString(L);w.push(W),E.push(O===0?{name:W,isTensor:!1}:{name:W,isTensor:!0,type:dc(O),shape:v})}for(let S=0;S<_;S++){let[L,O,v]=Ud(o,S+d);L===0&&Ie("Can't get an output name."),p.push(L);let W=n.UTF8ToString(L);x.push(W),k.push(O===0?{name:W,isTensor:!1}:{name:W,isTensor:!0,type:dc(O),shape:v});{if(m&&e?.preferredOutputLocation===void 0){A.push("gpu-buffer");continue}let X=typeof e?.preferredOutputLocation=="string"?e.preferredOutputLocation:e?.preferredOutputLocation?.[W]??"cpu",B=n.webnnIsGraphOutput;if(X==="cpu"&&B&&B(o,W)){A.push("ml-tensor-cpu-output");continue}if(X!=="cpu"&&X!=="cpu-pinned"&&X!=="gpu-buffer"&&X!=="ml-tensor")throw new Error(`Not supported preferred output location: ${X}.`);if(m&&X!=="gpu-buffer")throw new Error(`Not supported preferred output location: ${X}. Only 'gpu-buffer' location is supported when enableGraphCapture is true.`);A.push(X)}}let T=null;return A.some(S=>S==="gpu-buffer"||S==="ml-tensor"||S==="ml-tensor-cpu-output")&&(i=n._OrtCreateBinding(o),i===0&&Ie("Can't create IO binding."),T={handle:i,outputPreferredLocations:A,outputPreferredLocationsEncoded:A.map(S=>S==="ml-tensor-cpu-output"?"ml-tensor":S).map(S=>Vd(S))}),Nr.set(o,[o,c,p,T,m,!1]),[o,w,x,E,k]}catch(d){throw c.forEach(_=>n._OrtFree(_)),p.forEach(_=>n._OrtFree(_)),i!==0&&n._OrtReleaseBinding(i)!==0&&Ie("Can't release IO binding."),o!==0&&n._OrtReleaseSession(o)!==0&&Ie("Can't release session."),d}finally{n._free(r),a!==0&&n._OrtReleaseSessionOptions(a)!==0&&Ie("Can't release session options."),l.forEach(d=>n._free(d)),n.unmountExternalData?.()}},uf=t=>{let e=De(),r=Nr.get(t);if(!r)throw new Error(`cannot release session. invalid session id: ${t}`);let[s,n,o,a,i]=r;a&&(i&&e._OrtClearBoundOutputs(a.handle)!==0&&Ie("Can't clear bound outputs."),e._OrtReleaseBinding(a.handle)!==0&&Ie("Can't release IO binding.")),e.jsepOnReleaseSession?.(t),e.webnnOnReleaseSession?.(t),e.webgpuOnReleaseSession?.(t),n.forEach(l=>e._OrtFree(l)),o.forEach(l=>e._OrtFree(l)),e._OrtReleaseSession(s)!==0&&Ie("Can't release session."),Nr.delete(t)},jd=async(t,e,r,s,n,o,a=!1)=>{if(!t){e.push(0);return}let i=De(),l=i.PTR_SIZE,c=t[0],p=t[1],d=t[3],_=d,m,w;if(c==="string"&&(d==="gpu-buffer"||d==="ml-tensor"))throw new Error("String tensor is not supported on GPU.");if(a&&d!=="gpu-buffer")throw new Error(`External buffer must be provided for input/output index ${o} when enableGraphCapture is true.`);if(d==="gpu-buffer"){let k=t[2].gpuBuffer;w=un(hs(c),p);{let A=i.webgpuRegisterBuffer;if(!A)throw new Error('Tensor location "gpu-buffer" is not supported without using WebGPU.');m=A(k,s)}}else if(d==="ml-tensor"){let k=t[2].mlTensor;w=un(hs(c),p);let A=i.webnnRegisterMLTensor;if(!A)throw new Error('Tensor location "ml-tensor" is not supported without using WebNN.');m=A(s,k,hs(c),p)}else{let k=t[2];if(Array.isArray(k)){w=l*k.length,m=i._malloc(w),r.push(m);for(let A=0;A<k.length;A++){if(typeof k[A]!="string")throw new TypeError(`tensor data at index ${A} is not a string`);i.setValue(m+A*l,Lt(k[A],r),"*")}}else{let A=i.webnnIsGraphInput,T=i.webnnIsGraphOutput;if(c!=="string"&&A&&T){let S=i.UTF8ToString(n);if(A(s,S)||T(s,S)){let L=hs(c);w=un(L,p),_="ml-tensor";let O=i.webnnCreateTemporaryTensor,v=i.webnnUploadTensor;if(!O||!v)throw new Error('Tensor location "ml-tensor" is not supported without using WebNN.');let W=await O(s,L,p);v(W,new Uint8Array(k.buffer,k.byteOffset,k.byteLength)),m=W}else w=k.byteLength,m=i._malloc(w),r.push(m),i.HEAPU8.set(new Uint8Array(k.buffer,k.byteOffset,w),m)}else w=k.byteLength,m=i._malloc(w),r.push(m),i.HEAPU8.set(new Uint8Array(k.buffer,k.byteOffset,w),m)}}let x=i.stackSave(),E=i.stackAlloc(4*p.length);try{p.forEach((A,T)=>i.setValue(E+T*l,A,l===4?"i32":"i64"));let k=i._OrtCreateTensor(hs(c),m,w,E,p.length,Vd(_));k===0&&Ie(`Can't create tensor for input/output. session=${s}, index=${o}.`),e.push(k)}finally{i.stackRestore(x)}},pf=async(t,e,r,s,n,o)=>{let a=De(),i=a.PTR_SIZE,l=Nr.get(t);if(!l)throw new Error(`cannot run inference. invalid session id: ${t}`);let c=l[0],p=l[1],d=l[2],_=l[3],m=l[4],w=l[5],x=e.length,E=s.length,k=0,A=[],T=[],S=[],L=[],O=[],v=a.stackSave(),W=a.stackAlloc(x*i),X=a.stackAlloc(x*i),B=a.stackAlloc(E*i),H=a.stackAlloc(E*i);try{[k,A]=DA(o),Rr("wasm prepareInputOutputTensor");for(let C=0;C<x;C++)await jd(r[C],T,L,t,p[e[C]],e[C],m);for(let C=0;C<E;C++)await jd(n[C],S,L,t,d[s[C]],x+s[C],m);Dr("wasm prepareInputOutputTensor");for(let C=0;C<x;C++)a.setValue(W+C*i,T[C],"*"),a.setValue(X+C*i,p[e[C]],"*");for(let C=0;C<E;C++)a.setValue(B+C*i,S[C],"*"),a.setValue(H+C*i,d[s[C]],"*");if(_&&!w){let{handle:C,outputPreferredLocations:te,outputPreferredLocationsEncoded:ae}=_;if(p.length!==x)throw new Error(`input count from feeds (${x}) is expected to be always equal to model's input count (${p.length}).`);Rr("wasm bindInputsOutputs");for(let P=0;P<x;P++){let N=e[P];await a._OrtBindInput(C,p[N],T[P])!==0&&Ie(`Can't bind input[${P}] for session=${t}.`)}for(let P=0;P<E;P++){let N=s[P];n[P]?.[3]?(O.push(S[P]),a._OrtBindOutput(C,d[N],S[P],0)!==0&&Ie(`Can't bind pre-allocated output[${P}] for session=${t}.`)):a._OrtBindOutput(C,d[N],0,ae[N])!==0&&Ie(`Can't bind output[${P}] to ${te[P]} for session=${t}.`)}Dr("wasm bindInputsOutputs"),Nr.set(t,[c,p,d,_,m,!0])}a.jsepOnRunStart?.(c),a.webnnOnRunStart?.(c);let G;_?G=await a._OrtRunWithBinding(c,_.handle,E,B,k):G=await a._OrtRun(c,X,W,x,H,E,B,k),G!==0&&Ie("failed to call OrtRun().");let Q=[],R=[];Rr("wasm ProcessOutputTensor");for(let C=0;C<E;C++){let te=Number(a.getValue(B+C*i,"*"));if(te===S[C]||O.includes(S[C])){Q.push(n[C]),te!==S[C]&&a._OrtReleaseTensor(te)!==0&&Ie("Can't release tensor.");continue}let ae=a.stackSave(),P=a.stackAlloc(4*i),N=!1,F,J=0;try{a._OrtGetTensorData(te,P,P+i,P+2*i,P+3*i)!==0&&Ie(`Can't access output tensor data on index ${C}.`);let xe=i===4?"i32":"i64",ue=Number(a.getValue(P,xe));J=a.getValue(P+i,"*");let qe=a.getValue(P+i*2,"*"),ot=Number(a.getValue(P+i*3,xe)),_t=[];for(let Fe=0;Fe<ot;Fe++)_t.push(Number(a.getValue(qe+Fe*i,xe)));a._OrtFree(qe)!==0&&Ie("Can't free memory for tensor dims.");let at=_t.reduce((Fe,Me)=>Fe*Me,1);F=dc(ue);let vt=_?.outputPreferredLocations[s[C]];if(F==="string"){if(vt==="gpu-buffer"||vt==="ml-tensor")throw new Error("String tensor is not supported on GPU.");let Fe=[];for(let Me=0;Me<at;Me++){let Ze=a.getValue(J+Me*i,"*"),er=a.getValue(J+(Me+1)*i,"*"),Pe=Me===at-1?void 0:er-Ze;Fe.push(a.UTF8ToString(Ze,Pe))}Q.push([F,_t,Fe,"cpu"])}else if(vt==="gpu-buffer"&&at>0){let Fe=a.webgpuGetBuffer;if(!Fe)throw new Error('preferredLocation "gpu-buffer" is not supported without using WebGPU.');let Me=Fe(J),Ze=un(ue,at);if(Ze===void 0||!sf(F))throw new Error(`Unsupported data type: ${F}`);N=!0;{a.webgpuRegisterBuffer(Me,t,J);let er=a.webgpuCreateDownloader(Me,Ze,t);Q.push([F,_t,{gpuBuffer:Me,download:async()=>{let Pe=await er();return new(Eo(F))(Pe)},dispose:()=>{a._OrtReleaseTensor(te)!==0&&Ie("Can't release tensor.")}},"gpu-buffer"])}}else if(vt==="ml-tensor"&&at>0){let Fe=a.webnnEnsureTensor,Me=a.webnnIsGraphInputOutputTypeSupported;if(!Fe||!Me)throw new Error('preferredLocation "ml-tensor" is not supported without using WebNN.');if(un(ue,at)===void 0||!nf(F))throw new Error(`Unsupported data type: ${F}`);if(!Me(t,F,!1))throw new Error(`preferredLocation "ml-tensor" for ${F} output is not supported by current WebNN Context.`);let Ze=await Fe(t,J,ue,_t,!1);N=!0,Q.push([F,_t,{mlTensor:Ze,download:a.webnnCreateMLTensorDownloader(J,F),dispose:()=>{a.webnnReleaseTensorId(J),a._OrtReleaseTensor(te)}},"ml-tensor"])}else if(vt==="ml-tensor-cpu-output"&&at>0){let Fe=a.webnnCreateMLTensorDownloader(J,F)(),Me=Q.length;N=!0,R.push((async()=>{let Ze=[Me,await Fe];return a.webnnReleaseTensorId(J),a._OrtReleaseTensor(te),Ze})()),Q.push([F,_t,[],"cpu"])}else{let Fe=Eo(F),Me=new Fe(at);new Uint8Array(Me.buffer,Me.byteOffset,Me.byteLength).set(a.HEAPU8.subarray(J,J+Me.byteLength)),Q.push([F,_t,Me,"cpu"])}}finally{a.stackRestore(ae),F==="string"&&J&&a._free(J),N||a._OrtReleaseTensor(te)}}_&&!m&&(a._OrtClearBoundOutputs(_.handle)!==0&&Ie("Can't clear bound outputs."),Nr.set(t,[c,p,d,_,m,!1]));for(let[C,te]of await Promise.all(R))Q[C][2]=te;return Dr("wasm ProcessOutputTensor"),Q}finally{a.webnnOnRunEnd?.(c),a.stackRestore(v),r.forEach(G=>{G&&G[3]==="gpu-buffer"&&a.webgpuUnregisterBuffer(G[2].gpuBuffer)}),n.forEach(G=>{G&&G[3]==="gpu-buffer"&&a.webgpuUnregisterBuffer(G[2].gpuBuffer)}),T.forEach(G=>a._OrtReleaseTensor(G)),S.forEach(G=>a._OrtReleaseTensor(G)),L.forEach(G=>a._free(G)),k!==0&&a._OrtReleaseRunOptions(k),A.forEach(G=>a._free(G))}},df=t=>{let e=De(),r=Nr.get(t);if(!r)throw new Error("invalid session id");let s=r[0],n=e._OrtEndProfiling(s);n===0&&Ie("Can't get an profile file name."),e._OrtFree(n)},ff=t=>{let e=[];for(let r of t){let s=r[2];!Array.isArray(s)&&"buffer"in s&&e.push(s.buffer)}return e}}),$r,Dt,cn,bo,vo,uc,Gd,pc,fs,_s,uA,XA,KA,QA,YA,JA,ZA,e2,t2=be(()=>{"use strict";ys(),HA(),bs(),ef(),$r=()=>!!Ve.wasm.proxy&&typeof document<"u",cn=!1,bo=!1,vo=!1,pc=new Map,fs=(t,e)=>{let r=pc.get(t);r?r.push(e):pc.set(t,[e])},_s=()=>{if(cn||!bo||vo||!Dt)throw new Error("worker not ready")},uA=t=>{switch(t.data.type){case"init-wasm":cn=!1,t.data.err?(vo=!0,Gd[1](t.data.err)):(bo=!0,Gd[0]()),uc&&(URL.revokeObjectURL(uc),uc=void 0);break;case"init-ep":case"copy-from":case"create":case"release":case"run":case"end-profiling":{let e=pc.get(t.data.type);t.data.err?e.shift()[1](t.data.err):e.shift()[0](t.data.out);break}default:}},XA=async()=>{if(!bo){if(cn)throw new Error("multiple calls to 'initWasm()' detected.");if(vo)throw new Error("previous call to 'initWasm()' failed.");if(cn=!0,$r())return new Promise((t,e)=>{Dt?.terminate(),$A().then(([r,s])=>{try{Dt=s,Dt.onerror=o=>e(o),Dt.onmessage=uA,Gd=[t,e];let n={type:"init-wasm",in:Ve};!n.in.wasm.wasmPaths&&(r||Wd)&&(n.in.wasm.wasmPaths={wasm:new URL("ort-wasm-simd-threaded.asyncify.wasm",import.meta.url).href}),Dt.postMessage(n),uc=r}catch(n){e(n)}},e)});try{await tf(Ve.wasm),await af(Ve),bo=!0}catch(t){throw vo=!0,t}finally{cn=!1}}},KA=async t=>{if($r())return _s(),new Promise((e,r)=>{fs("init-ep",[e,r]);let s={type:"init-ep",in:{epName:t,env:Ve}};Dt.postMessage(s)});await lf(Ve,t)},QA=async t=>$r()?(_s(),new Promise((e,r)=>{fs("copy-from",[e,r]);let s={type:"copy-from",in:{buffer:t}};Dt.postMessage(s,[t.buffer])})):gc(t),YA=async(t,e)=>{if($r()){if(e?.preferredOutputLocation)throw new Error('session option "preferredOutputLocation" is not supported for proxy.');return _s(),new Promise((r,s)=>{fs("create",[r,s]);let n={type:"create",in:{model:t,options:{...e}}},o=[];t instanceof Uint8Array&&o.push(t.buffer),Dt.postMessage(n,o)})}else return cf(t,e)},JA=async t=>{if($r())return _s(),new Promise((e,r)=>{fs("release",[e,r]);let s={type:"release",in:t};Dt.postMessage(s)});uf(t)},ZA=async(t,e,r,s,n,o)=>{if($r()){if(r.some(a=>a[3]!=="cpu"))throw new Error("input tensor on GPU is not supported for proxy.");if(n.some(a=>a))throw new Error("pre-allocated output tensor is not supported for proxy.");return _s(),new Promise((a,i)=>{fs("run",[a,i]);let l=r,c={type:"run",in:{sessionId:t,inputIndices:e,inputs:l,outputIndices:s,options:o}};Dt.postMessage(c,ff(l))})}else return pf(t,e,r,s,n,o)},e2=async t=>{if($r())return _s(),new Promise((e,r)=>{fs("end-profiling",[e,r]);let s={type:"end-profiling",in:t};Dt.postMessage(s)});df(t)}}),qd,pA,r2,QP=be(()=>{"use strict";ys(),t2(),pn(),Zd(),BA(),qd=(t,e)=>{switch(t.location){case"cpu":return[t.type,t.dims,t.data,"cpu"];case"gpu-buffer":return[t.type,t.dims,{gpuBuffer:t.gpuBuffer},"gpu-buffer"];case"ml-tensor":return[t.type,t.dims,{mlTensor:t.mlTensor},"ml-tensor"];default:throw new Error(`invalid data location: ${t.location} for ${e()}`)}},pA=t=>{switch(t[3]){case"cpu":return new Qt(t[0],t[2],t[1]);case"gpu-buffer":{let e=t[0];if(!sf(e))throw new Error(`not supported data type: ${e} for deserializing GPU tensor`);let{gpuBuffer:r,download:s,dispose:n}=t[2];return Qt.fromGpuBuffer(r,{dataType:e,dims:t[1],download:s,dispose:n})}case"ml-tensor":{let e=t[0];if(!nf(e))throw new Error(`not supported data type: ${e} for deserializing MLTensor tensor`);let{mlTensor:r,download:s,dispose:n}=t[2];return Qt.fromMLTensor(r,{dataType:e,dims:t[1],download:s,dispose:n})}default:throw new Error(`invalid data location: ${t[3]}`)}},r2=class{async fetchModelAndCopyToWasmMemory(t){return QA(await of(t))}async loadModel(t,e){ws();let r;typeof t=="string"?r=await this.fetchModelAndCopyToWasmMemory(t):r=t,[this.sessionId,this.inputNames,this.outputNames,this.inputMetadata,this.outputMetadata]=await YA(r,e),xs()}async dispose(){return JA(this.sessionId)}async run(t,e,r){ws();let s=[],n=[];Object.entries(t).forEach(d=>{let _=d[0],m=d[1],w=this.inputNames.indexOf(_);if(w===-1)throw new Error(`invalid input '${_}'`);s.push(m),n.push(w)});let o=[],a=[];Object.entries(e).forEach(d=>{let _=d[0],m=d[1],w=this.outputNames.indexOf(_);if(w===-1)throw new Error(`invalid output '${_}'`);o.push(m),a.push(w)});let i=s.map((d,_)=>qd(d,()=>`input "${this.inputNames[n[_]]}"`)),l=o.map((d,_)=>d?qd(d,()=>`output "${this.outputNames[a[_]]}"`):null),c=await ZA(this.sessionId,n,i,a,l,r),p={};for(let d=0;d<c.length;d++)p[this.outputNames[a[d]]]=o[d]??pA(c[d]);return xs(),p}startProfiling(){}endProfiling(){e2(this.sessionId)}}}),s2={};Ao(s2,{OnnxruntimeWebAssemblyBackend:()=>Kd,initializeFlags:()=>Xd,wasmBackend:()=>n2});var Xd,Kd,n2,YP=be(()=>{"use strict";ys(),t2(),QP(),Xd=()=>{(typeof Ve.wasm.initTimeout!="number"||Ve.wasm.initTimeout<0)&&(Ve.wasm.initTimeout=0);let t=Ve.wasm.simd;if(typeof t!="boolean"&&t!==void 0&&t!=="fixed"&&t!=="relaxed"&&(console.warn(`Property "env.wasm.simd" is set to unknown value "${t}". Reset it to \`false\` and ignore SIMD feature checking.`),Ve.wasm.simd=!1),typeof Ve.wasm.proxy!="boolean"&&(Ve.wasm.proxy=!1),typeof Ve.wasm.trace!="boolean"&&(Ve.wasm.trace=!1),typeof Ve.wasm.numThreads!="number"||!Number.isInteger(Ve.wasm.numThreads)||Ve.wasm.numThreads<=0)if(typeof self<"u"&&!self.crossOriginIsolated)Ve.wasm.numThreads=1;else{let e=typeof navigator>"u"?TP("node:os").cpus().length:navigator.hardwareConcurrency;Ve.wasm.numThreads=Math.min(4,Math.ceil((e||1)/2))}},Kd=class{async init(t){Xd(),await XA(),await KA(t)}async createInferenceSessionHandler(t,e){let r=new r2;return await r.loadModel(t,e),r}},n2=new Kd});ys();ys();ys();var JP="1.25.0-dev.20260307-d626b568e0",ZP=IA;{let t=(YP(),fc(s2)).wasmBackend;gs("webgpu",t,5),gs("webnn",t,5),gs("cpu",t,10),gs("wasm",t,10)}Object.defineProperty(Ve.versions,"web",{value:JP,enumerable:!0});async function o2(t){let e=t.split("/").pop(),r;try{if(r=await Kt(),r){let n=await r.match(t);if(n)return n}}catch(n){Z.warn(`Failed to load ${e} from cache:`,n)}let s=await _e.fetch(t);if(!s.ok)throw new Error(`Failed to fetch ${e}: ${s.status} ${s.statusText}`);if(r)try{await r.put(t,s.clone())}catch(n){Z.warn(`Failed to cache ${e}:`,n)}return s}async function a2(t){let e=await o2(t);if(!e||typeof e=="string")return null;try{return await e.arrayBuffer()}catch(r){return Z.warn("Failed to read WASM binary:",r),null}}async function i2(t){if(ie.IS_SERVICE_WORKER_ENV||ie.IS_CHROME_AVAILABLE)return t;let e=await o2(t);if(!e||typeof e=="string")return null;try{let r=await e.text();r=r.replaceAll("globalThis.process?.versions?.node","false");let s=new Blob([r],{type:"text/javascript"});return URL.createObjectURL(s)}catch(r){return Z.warn("Failed to read WASM factory:",r),null}}import{Tensor as f2}from"onnxruntime-common";var tz=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 p2(t){return t<=Mt.DEBUG?0:t<=Mt.INFO?2:t<=Mt.WARNING||t<=Mt.ERROR?3:4}var rz={0:"verbose",1:"info",2:"warning",3:"error",4:"fatal"},Ft=[],mf,fn,l2=Symbol.for("onnxruntime");if(l2 in globalThis)fn=globalThis[l2];else if(ie.IS_NODE_ENV){switch(fn=ez,process.platform){case"win32":Ft.push("dml");break;case"linux":process.arch==="x64"&&Ft.push("cuda");break;case"darwin":Ft.push("coreml");break}Ft.push("webgpu"),Ft.push("cpu"),mf=["cpu"]}else fn=_f,ie.IS_WEBNN_AVAILABLE&&Ft.push("webnn-npu","webnn-gpu","webnn-cpu","webnn"),ie.IS_WEBGPU_AVAILABLE&&Ft.push("webgpu"),Ft.push("wasm"),mf=["wasm"];var sz=fn.InferenceSession;function d2(t=null){if(!t)return mf;switch(t){case"auto":return Ft;case"gpu":return Ft.filter(e=>["webgpu","cuda","dml","webnn-gpu"].includes(e))}if(Ft.includes(t))return[tz[t]??t];throw new Error(`Unsupported device: "${t}". Should be one of: ${Ft.join(", ")}.`)}var c2=Promise.resolve(),dn=null;async function nz(){if(dn)return dn;if(!(_e.useWasmCache&&typeof st?.wasm?.wasmPaths=="object"&&st?.wasm?.wasmPaths?.wasm&&st?.wasm?.wasmPaths?.mjs)){if(ie.IS_DENO_WEB_RUNTIME)throw new Error("env.useWasmCache=false is not supported in Deno's web runtime. Remove the useWasmCache override.");return dn=Promise.resolve(),dn}return dn=(async()=>{let e=st.wasm.wasmPaths,r=!1;await Promise.all([e.wasm&&!gd(e.wasm)?(async()=>{try{let s=await a2(wd(e.wasm));s&&(st.wasm.wasmBinary=s,r=!0)}catch(s){Z.warn("Failed to pre-load WASM binary:",s)}})():Promise.resolve(),e.mjs&&!gd(e.mjs)?(async()=>{try{let s=await i2(wd(e.mjs));s&&(st.wasm.wasmPaths.mjs=s)}catch(s){Z.warn("Failed to pre-load WASM factory:",s)}})():Promise.resolve()]),r||(st.wasm.wasmPaths.mjs=e.mjs)})(),dn}async function wc(t,e,r){await nz();let s=p2(_e.logLevel??Mt.WARNING),n=()=>sz.create(t,{logSeverityLevel:s,...e}),o=await(ie.IS_WEB_ENV?c2=c2.then(n):n());return o.config=r,o}var u2=Promise.resolve();async function xc(t,e){let r=()=>t.run(e);return ie.IS_WEB_ENV?u2=u2.then(r):r()}function yc(t){return t instanceof fn.Tensor}var st=fn?.env;function Mo(){return st?.wasm?.proxy}if(st){let t=function(e){let r=p2(e);st.logLevel=rz[r]};if(st.wasm){if(!(typeof ServiceWorkerGlobalScope<"u"&&self instanceof ServiceWorkerGlobalScope)&&st.versions?.web&&!st.wasm.wasmPaths){let e=`https://cdn.jsdelivr.net/npm/onnxruntime-web@${st.versions.web}/dist/`;st.wasm.wasmPaths=ie.IS_SAFARI?{mjs:`${e}ort-wasm-simd-threaded.mjs`,wasm:`${e}ort-wasm-simd-threaded.wasm`}:{mjs:`${e}ort-wasm-simd-threaded.asyncify.mjs`,wasm:`${e}ort-wasm-simd-threaded.asyncify.wasm`}}st.wasm.proxy=!1}st.webgpu&&(st.webgpu.powerPreference="high-performance"),t(_e.logLevel??Mt.WARNING),_e.backends.onnx={...st,setLogLevel:t}}var Fr=async(t,e,r)=>{let s=await wc(new Uint8Array(t),e);return(async n=>{let o=Mo(),a=Object.fromEntries(Object.entries(n).map(([l,c])=>[l,(o?c.clone():c).ort_tensor])),i=await xc(s,a);return Array.isArray(r)?r.map(l=>new $(i[l])):new $(i[r])})},ir=class{static session_options={};static get nearest_interpolate_4d(){return this._nearest_interpolate_4d||(this._nearest_interpolate_4d=Fr([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=Fr([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=Fr([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=Fr([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=Fr([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=Fr([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=Fr([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=Fr([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}};var _2=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"}),hf=ie.IS_NODE_ENV?"cpu":"wasm";function bc(t,e,{warn:r}={}){return t?typeof t=="string"?t:t.hasOwnProperty(e)?t[e]:(r&&r(`device not specified for "${e}". Using the default device (${hf}).`),hf):hf}var g2=(function(){let t;return async function(){if(t===void 0)if(!ie.IS_WEBGPU_AVAILABLE)t=!1;else try{t=(await navigator.gpu.requestAdapter()).features.has("shader-f16")}catch{t=!1}return t}})(),wt=Object.freeze({auto:"auto",fp32:"fp32",fp16:"fp16",q8:"q8",int8:"int8",uint8:"uint8",q4:"q4",bnb4:"bnb4",q4f16:"q4f16"}),m2=wt.fp32,h2=Object.freeze({[_2.wasm]:wt.q8}),So=Object.freeze({[wt.fp32]:"",[wt.fp16]:"_fp16",[wt.int8]:"_int8",[wt.uint8]:"_uint8",[wt.q8]:"_quantized",[wt.q4]:"_q4",[wt.q4f16]:"_q4f16",[wt.bnb4]:"_bnb4"});function vc(t,e,r,{configDtype:s=null,warn:n}={}){let o,a=!1;t&&typeof t!="string"?t.hasOwnProperty(e)?o=t[e]:(o=null,a=!0):o=t;let i;if(o===wt.auto){if(s){let l=typeof s=="string"?s:s?.[e];if(l&&l!==wt.auto&&wt.hasOwnProperty(l))return l}i=h2[r]??m2}else o&&wt.hasOwnProperty(o)?i=o:i=h2[r]??m2;return a&&n&&n(`dtype not specified for "${e}". Using the default dtype (${i}) for this device (${r}).`),i}var xr=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});var $=class t{get dims(){return this.ort_tensor.dims}set dims(e){this.ort_tensor.dims=e}get type(){return this.ort_tensor.type}get data(){return this.ort_tensor.data}get size(){return this.ort_tensor.size}get location(){return this.ort_tensor.location}ort_tensor;constructor(...e){return yc(e[0])?this.ort_tensor=e[0]:this.ort_tensor=new f2(e[0],e[1],e[2]),new Proxy(this,{get:(r,s)=>{if(typeof s=="string"){let n=Number(s);if(Number.isInteger(n))return r._getitem(n)}return r[s]},set:(r,s,n)=>r[s]=n})}dispose(){this.ort_tensor.dispose()}*[Symbol.iterator](){let[e,...r]=this.dims;if(r.length>0){let s=r.reduce((n,o)=>n*o);for(let n=0;n<e;++n)yield this._subarray(n,s,r)}else yield*this.data}_getitem(e){let[r,...s]=this.dims;if(e=lr(e,r),s.length>0){let n=s.reduce((o,a)=>o*a);return this._subarray(e,n,s)}else return new t(this.type,[this.data[e]],s)}indexOf(e){let r=this.data;for(let s=0;s<r.length;++s)if(r[s]==e)return s;return-1}_subarray(e,r,s){let n=e*r,o=(e+1)*r,a="subarray"in this.data?this.data.subarray(n,o):this.data.slice(n,o);return new t(this.type,a,s)}item(){let e=this.data;if(e.length!==1)throw new Error(`a Tensor with ${e.length} elements cannot be converted to Scalar`);return e[0]}tolist(){return oz(this.data,this.dims)}sigmoid(){return this.clone().sigmoid_()}sigmoid_(){let e=this.data;for(let r=0;r<e.length;++r)e[r]=1/(1+Math.exp(-e[r]));return this}map(e){return this.clone().map_(e)}map_(e){let r=this.data;for(let s=0;s<r.length;++s)r[s]=e(r[s],s,r);return this}mul(e){return this.clone().mul_(e)}mul_(e){let r=this.data;for(let s=0;s<r.length;++s)r[s]*=e;return this}div(e){return this.clone().div_(e)}div_(e){let r=this.data;for(let s=0;s<r.length;++s)r[s]/=e;return this}add(e){return this.clone().add_(e)}add_(e){let r=this.data;for(let s=0;s<r.length;++s)r[s]+=e;return this}sub(e){return this.clone().sub_(e)}sub_(e){let r=this.data;for(let s=0;s<r.length;++s)r[s]-=e;return this}clone(){return new t(this.type,this.data.slice(),this.dims.slice())}slice(...e){let r=[],s=[];for(let p=0;p<this.dims.length;++p){let d=e[p];if(d==null)s.push([0,this.dims[p]]),r.push(this.dims[p]);else if(typeof d=="number")d=lr(d,this.dims[p],p),s.push([d,d+1]);else if(Array.isArray(d)&&d.length===2){let[_,m]=d;if(_=_===null?0:lr(_,this.dims[p],p,!1),m=m===null?this.dims[p]:lr(m,this.dims[p],p,!1),_>m)throw new Error(`Invalid slice: ${d}`);let w=[Math.max(_,0),Math.min(m,this.dims[p])];s.push(w),r.push(w[1]-w[0])}else throw new Error(`Invalid slice: ${d}`)}let n=s.map(([p,d])=>d-p),o=n.reduce((p,d)=>p*d),a=this.data,i=new a.constructor(o),l=this.stride(),c=!0;for(let p=1;p<n.length;++p)if(s[p][0]!==0||s[p][1]!==this.dims[p]){c=!1;break}if(c){let p=s[0][0]*l[0],d=s[0][1]*l[0];if(ArrayBuffer.isView(a))i.set(a.subarray(p,d));else if(Array.isArray(a)){let _=a.slice(p,d);for(let m=0;m<_.length;++m)i[m]=_[m]}else throw new Error("Unsupported data type for slicing")}else for(let p=0;p<o;++p){let d=0;for(let _=n.length-1,m=p;_>=0;--_){let w=n[_];d+=(m%w+s[_][0])*l[_],m=Math.floor(m/w)}i[p]=a[d]}return new t(this.type,i,r)}permute(...e){return az(this,e)}transpose(...e){return this.permute(...e)}sum(e=null,r=!1){return this.norm(1,e,r)}norm(e="fro",r=null,s=!1){if(e==="fro")e=2;else if(typeof e=="string")throw Error(`Unsupported norm: ${e}`);let n=this.data,o=n instanceof BigInt64Array||n instanceof BigUint64Array;if(o&&e!==1)throw Error(`Expected a floating point tensor as input. Got ${this.type}`);let a,i;if(o?(a=(d,_)=>d+_,i=0n):(a=(d,_)=>d+_**e,i=0),r===null){let d=n.reduce(a,i);return e!==1&&(d=d**(1/e)),new t(this.type,[d],[])}let[l,c,p]=To(a,this,r,s);if(e!==1)for(let d=0;d<c.length;++d)c[d]=c[d]**(1/e);return new t(l,c,p)}normalize_(e=2,r=1){r=lr(r,this.dims.length);let s=this.norm(e,r,!0),n=this.data,o=s.data;for(let a=0;a<n.length;++a){let i=0;for(let l=this.dims.length-1,c=a,p=1;l>=0;--l){let d=this.dims[l];if(l!==r){let _=c%d;i+=_*p,p*=this.dims[l]}c=Math.floor(c/d)}n[a]/=o[i]}return this}normalize(e=2,r=1){return this.clone().normalize_(e,r)}stride(){return gf(this.dims)}squeeze(e=null){return new t(this.type,this.data,w2(this.dims,e))}squeeze_(e=null){return this.dims=w2(this.dims,e),this}unsqueeze(e){return new t(this.type,this.data,x2(this.dims,e))}unsqueeze_(e){return this.dims=x2(this.dims,e),this}flatten_(e=0,r=-1){r=(r+this.dims.length)%this.dims.length;let s=this.dims.slice(0,e),n=this.dims.slice(e,r+1),o=this.dims.slice(r+1);return this.dims=[...s,n.reduce((a,i)=>a*i,1),...o],this}flatten(e=0,r=-1){return this.clone().flatten_(e,r)}view(...e){let r=-1;for(let n=0;n<e.length;++n)if(e[n]===-1){if(r!==-1)throw new Error("Only one dimension can be inferred");r=n}let s=this.data;if(r!==-1){let n=e.reduce((o,a,i)=>i!==r?o*a:o,1);e[r]=s.length/n}return new t(this.type,s,e)}neg_(){let e=this.data;for(let r=0;r<e.length;++r)e[r]=-e[r];return this}neg(){return this.clone().neg_()}gt(e){let r=new Uint8Array(this.data.length),s=this.data;for(let n=0;n<s.length;++n)r[n]=s[n]>e?1:0;return new t("bool",r,this.dims)}lt(e){let r=new Uint8Array(this.data.length),s=this.data;for(let n=0;n<s.length;++n)r[n]=s[n]<e?1:0;return new t("bool",r,this.dims)}clamp_(e,r){let s=this.data;for(let n=0;n<s.length;++n)s[n]=Math.min(Math.max(s[n],e),r);return this}clamp(e,r){return this.clone().clamp_(e,r)}round_(){let e=this.data;for(let r=0;r<e.length;++r)e[r]=Math.round(e[r]);return this}round(){return this.clone().round_()}mean(e=null,r=!1){return Ac(this,e,r)}min(e=null,r=!1){if(e===null){let a=go(this.data)[0];return new t(this.type,[a],[])}let[s,n,o]=To((a,i)=>Math.min(a,i),this,e,r,1/0);return new t(s,n,o)}max(e=null,r=!1){if(e===null){let a=Oe(this.data)[0];return new t(this.type,[a],[])}let[s,n,o]=To((a,i)=>Math.max(a,i),this,e,r,-1/0);return new t(s,n,o)}argmin(e=null,r=!1){if(e!==null)throw new Error("`dim !== null` not yet implemented.");let s=go(this.data)[1];return new t("int64",[BigInt(s)],[])}argmax(e=null,r=!1){if(e!==null)throw new Error("`dim !== null` not yet implemented.");let s=Oe(this.data)[1];return new t("int64",[BigInt(s)],[])}repeat(...e){if(e.length<this.dims.length)throw new Error(`Number of dimensions of repeat dims (${e.length}) cannot be smaller than number of dimensions of tensor (${this.dims.length})`);if(e.every(p=>p===1)){if(e.length===this.dims.length)return this.clone();let p=e.length-this.dims.length,d=Array(p).fill(1).concat(this.dims);return new t(this.type,this.data.slice(),d)}let r=e.length-this.dims.length,s=Array(r).fill(1).concat(this.dims),n=s.map((p,d)=>p*e[d]),o=n.reduce((p,d)=>p*d,1),a=this.data,i=new a.constructor(o),l=gf(s),c=gf(n);for(let p=0;p<o;++p){let d=p,_=0;for(let m=0;m<n.length;++m){let w=Math.floor(d/c[m]);d=d%c[m];let x=w%s[m];_+=x*l[m]}i[p]=a[_]}return new t(this.type,i,n)}tile(...e){if(e.length<this.dims.length){let r=this.dims.length-e.length;e=Array(r).fill(1).concat(e)}return this.repeat(...e)}to(e){if(this.type===e)return this;if(!xr.hasOwnProperty(e))throw new Error(`Unsupported type: ${e}`);let r,s=["int64","uint64"].includes(this.type),n=["int64","uint64"].includes(e);if(s&&!n)r=Number;else if(!s&&n)["float16","float32","float64"].includes(this.type)?r=o=>BigInt(Math.floor(o)):r=BigInt;else if(this.type==="float16"&&e=="float32"&&this.data instanceof Uint16Array)return new t(e,DE(this.data),this.dims);return new t(e,xr[e].from(this.data,r),this.dims)}};function oz(t,e){let r=t.length,s=e.reduce((o,a)=>o*a);if(r!==s)throw Error(`cannot reshape array of size ${r} into shape (${e})`);let n=t;for(let o=e.length-1;o>=0;o--)n=n.reduce((a,i)=>{let l=a[a.length-1];return l.length<e[o]?l.push(i):a.push([i]),a},[[]]);return n[0]}function az(t,e){let[r,s]=LE(t.data,t.dims,e);return new $(t.type,r,s)}function wf(t,[e,r],s="bilinear",n=!1){let o=t.dims.at(-3)??1,a=t.dims.at(-2),i=t.dims.at(-1),l=CE(t.data,[o,a,i],[e,r],s,n);return new $(t.type,l,[o,e,r])}async function yt(t,{size:e=null,mode:r="bilinear"}={}){if(t.dims.length!==4)throw new Error("`interpolate_4d` currently only supports 4D input.");if(!e)throw new Error("`interpolate_4d` requires a `size` argument.");let s;if(e.length===2)s=[...t.dims.slice(0,2),...e];else if(e.length===3)s=[t.dims[0],...e];else if(e.length===4)s=e;else throw new Error("`size` must be of length 2, 3, or 4.");let n;if(r==="nearest")n=await ir.nearest_interpolate_4d;else if(r==="bilinear")n=await ir.bilinear_interpolate_4d;else if(r==="bicubic")n=await ir.bicubic_interpolate_4d;else throw new Error(`Unsupported mode: ${r}`);let o=new $("int64",new BigInt64Array(s.map(BigInt)),[s.length]);return await n({x:t,s:o})}async function y2(t,e){return await(await ir.matmul)({a:t,b:e})}async function XR(t,e){return await(await ir.rfft)({x:t,a:e})}async function Yt(t,e){let r=await ir.top_k;return e==null?e=t.dims.at(-1):e=Math.min(e,t.dims.at(-1)),await r({x:t,k:new $("int64",[BigInt(e)],[1])})}var kc=t=>new $("int64",t,[t.length]);async function Ec(t,e,r,s,n){return await(await ir.slice)({x:t,s:kc(e),e:kc(r),a:kc(s),t:kc(n??new Array(s.length).fill(1))})}function b2(t,e){let r=t.data,s=e.data,n=[t.dims[0],t.dims[2]],o=new r.constructor(n[0]*n[1]),[a,i,l]=t.dims,c=0;for(let p=0;p<a;++p){let d=p*l*i;for(let _=0;_<l;++_){let m=0,w=0,x=p*i,E=d+_;for(let A=0;A<i;++A){let T=Number(s[x+A]);w+=T,m+=r[E+A*l]*T}let k=m/w;o[c++]=k}}return new $(t.type,o,n)}function KR(t,e,{eps:r=1e-5}={}){if(t.dims.length!==2)throw new Error("`layer_norm` currently only supports 2D input.");let[s,n]=t.dims;if(e.length!==1&&e[0]!==n)throw new Error("`normalized_shape` must be a 1D array with shape `[input.dims[1]]`.");let[o,a]=xf(t,1,0,!0),i=o.data,l=a.data,c=t.data,p=new c.constructor(c.length);for(let d=0;d<s;++d){let _=d*n;for(let m=0;m<n;++m){let w=_+m;p[w]=(c[w]-l[d])/(i[d]+r)}}return new $(t.type,p,t.dims)}function w2(t,e){return t=t.slice(),e===null?t=t.filter(r=>r!==1):typeof e=="number"?t[e]===1&&t.splice(e,1):Array.isArray(e)&&(t=t.filter((r,s)=>r!==1||!e.includes(s))),t}function x2(t,e){return e=lr(e,t.length+1),t=t.slice(),t.splice(e,0,1),t}function lr(t,e,r=null,s=!0){if(t<-e||t>=e){if(s)throw new Error(`IndexError: index ${t} is out of bounds for dimension${r===null?"":" "+r} with size ${e}`);return t<-e?0:e}return t<0&&(t=(t%e+e)%e),t}function ke(t,e=0){e=lr(e,t[0].dims.length);let r=t[0].dims.slice();r[e]=t.reduce((a,i)=>a+i.dims[e],0);let s=r.reduce((a,i)=>a*i,1),n=new t[0].data.constructor(s),o=t[0].type;if(e===0){let a=0;for(let i of t){let l=i.data;n.set(l,a),a+=l.length}}else{let a=0;for(let i=0;i<t.length;++i){let{data:l,dims:c}=t[i];for(let p=0;p<l.length;++p){let d=0;for(let _=c.length-1,m=p,w=1;_>=0;--_){let x=c[_],E=m%x;_===e&&(E+=a),d+=E*w,w*=r[_],m=Math.floor(m/x)}n[d]=l[p]}a+=c[e]}}return new $(o,n,r)}function St(t,e=0){return ke(t.map(r=>r.unsqueeze(e)),e)}function To(t,e,r,s=!1,n=null){let o=e.data,a=e.dims;r=lr(r,a.length);let i=a.slice();i[r]=1;let l=new o.constructor(o.length/a[r]);n!==null&&l.fill(n);for(let c=0;c<o.length;++c){let p=0;for(let d=a.length-1,_=c,m=1;d>=0;--d){let w=a[d];if(d!==r){let x=_%w;p+=x*m,m*=i[d]}_=Math.floor(_/w)}l[p]=t(l[p],o[c],c,p)}return s||i.splice(r,1),[e.type,l,i]}function xf(t,e=null,r=1,s=!1){let n=t.data,o=t.dims;if(e===null){let m=n.reduce((k,A)=>k+A,0)/n.length,w=Math.sqrt(n.reduce((k,A)=>k+(A-m)**2,0)/(n.length-r)),x=new $(t.type,[m],[]);return[new $(t.type,[w],[]),x]}e=lr(e,o.length);let a=Ac(t,e,s),i=a.data,[l,c,p]=To((_,m,w,x)=>_+(m-i[x])**2,t,e,s);for(let _=0;_<c.length;++_)c[_]=Math.sqrt(c[_]/(o[e]-r));return[new $(l,c,p),a]}function Ac(t,e=null,r=!1){let s=t.dims,n=t.data;if(e===null){let l=n.reduce((c,p)=>c+p,0);return new $(t.type,[l/n.length],[])}e=lr(e,s.length);let[o,a,i]=To((l,c)=>l+c,t,e,r);if(s[e]!==1)for(let l=0;l<a.length;++l)a[l]/=s[e];return new $(o,a,i)}function gf(t){let e=new Array(t.length);for(let r=t.length-1,s=1;r>=0;--r)e[r]=s,s*=t[r];return e}function yf(t,e,r,s){let n=t.reduce((o,a)=>o*a,1);return new $(r,new s(n).fill(e),t)}function He(t,e){let r,s;if(typeof e=="number")r="float32",s=Float32Array;else if(typeof e=="bigint")r="int64",s=BigInt64Array;else if(typeof e=="boolean")r="bool",s=Uint8Array;else throw new Error(`Unsupported data type: ${typeof e}`);return yf(t,e,r,s)}function Oo(t,e){return He(t.dims,e)}function tt(t){return yf(t,1n,"int64",BigInt64Array)}function Mc(t){return tt(t.dims)}function bf(t){return yf(t,0n,"int64",BigInt64Array)}function vf(t){return bf(t.dims)}function QR(t){let e=t.reduce((r,s)=>r*s,1);return new $("float32",Float32Array.from({length:e},()=>ps.random()),t)}function v2(t){let e=t.reduce((r,s)=>r*s,1);return new $("float32",Float32Array.from({length:e},()=>ps.gauss()),t)}function k2(t,e){if(t.dims.length!==2)throw new Error("The tensor must have 2 dimensions");if(t.dims.at(-1)%8!==0)throw new Error("The last dimension of the tensor must be a multiple of 8");if(!["binary","ubinary"].includes(e))throw new Error("The precision must be either 'binary' or 'ubinary'");let r=e==="binary",s=r?"int8":"uint8",n=r?Int8Array:Uint8Array,o=t.data,a=new n(o.length/8);for(let i=0;i<o.length;++i){let l=o[i]>0?1:0,c=Math.floor(i/8),p=i%8;a[c]|=l<<7-p,r&&p===0&&(a[c]-=128)}return new $(s,a,[t.dims[0],t.dims[1]/8])}async function _n(t){if(!t)throw new Error("modelId is required for get_tokenizer_files");return(await ar(t,"tokenizer_config.json",{})).exists?["tokenizer.json","tokenizer_config.json"]:[]}async function kf(t,e){let r=await _n(t);return await Promise.all(r.map(s=>ut(t,s,!0,e)))}function Ef(t){let e=t.dims;switch(e.length){case 1:return t.tolist();case 2:if(e[0]!==1)throw new Error("Unable to decode tensor with `batch size !== 1`. Use `tokenizer.batch_decode(...)` for batched inputs.");return t.tolist()[0];default:throw new Error(`Expected tensor to have 1-2 dimensions, got ${e.length}.`)}}var iz=["bos_token","eos_token","unk_token","sep_token","pad_token","cls_token","mask_token"];function lz(t,e,r,s){for(let n of Object.keys(t)){let o=e-t[n].length,a=r(n),i=new Array(o).fill(a);t[n]=s==="right"?ht(t[n],i):ht(i,t[n])}}function cz(t,e){for(let r of Object.keys(t))t[r].length=e}function vs(t,...e){for(let r of e){if(!Object.hasOwn(t,r))continue;let s=t[r];if(s)if(typeof s=="object"){if(s.__type==="AddedToken")return s.content;throw Error(`Unknown token: ${s}`)}else return s}return null}function uz(t){let e=[];for(let r of t.get_added_tokens_decoder().values())r.special&&e.push(r);return e}var q=class extends et{return_token_type_ids=!1;padding_side="right";constructor(e,r){if(super(),this._tokenizerJSON=e,this._tokenizerConfig=r,this._tokenizer=new iE(e,r),this.config=r,this.padding_side=r.padding_side??this.padding_side,this.mask_token=vs(r,"mask_token"),this.mask_token_id=this._tokenizer.token_to_id(this.mask_token),this.pad_token=vs(r,"pad_token","eos_token"),this.pad_token_id=this._tokenizer.token_to_id(this.pad_token),this.sep_token=vs(r,"sep_token"),this.sep_token_id=this._tokenizer.token_to_id(this.sep_token),this.unk_token=vs(r,"unk_token"),this.unk_token_id=this._tokenizer.token_to_id(this.unk_token),this.bos_token=vs(r,"bos_token"),this.bos_token_id=this._tokenizer.token_to_id(this.bos_token),this.eos_token=vs(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)){let n=Object.create(null);for(let{name:o,template:a}of this.chat_template){if(typeof o!="string"||typeof a!="string")throw new Error('Chat template must be a list of objects with "name" and "template" properties');n[o]=a}this.chat_template=n}this._compiled_template_cache=new Map;let s=uz(this._tokenizer);this.all_special_ids=s.map(n=>n.id),this.all_special_tokens=s.map(n=>n.content)}static async from_pretrained(e,{progress_callback:r=null,config:s=null,cache_dir:n=null,local_files_only:o=!1,revision:a="main"}={}){let i=await kf(e,{progress_callback:r,config:s,cache_dir:n,local_files_only:o,revision:a});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(e){return typeof e=="string"?this._tokenizer.token_to_id(e):e.map(r=>this._tokenizer.token_to_id(r))}_call(e,{text_pair:r=null,add_special_tokens:s=!0,padding:n=!1,truncation:o=null,max_length:a=null,return_tensor:i=!0,return_token_type_ids:l=null}={}){let c=Array.isArray(e),p;if(c){if(e.length===0)throw Error("text array must be non-empty");if(r!==null){if(Array.isArray(r)){if(e.length!==r.length)throw Error("text and text_pair must have the same length")}else throw Error("text_pair must also be an array");p=e.map((_,m)=>this._encode_plus(_,{text_pair:r[m],add_special_tokens:s,return_token_type_ids:l}))}else p=e.map(_=>this._encode_plus(_,{add_special_tokens:s,return_token_type_ids:l}))}else{if(e==null)throw Error("text may not be null or undefined");if(Array.isArray(r))throw Error("When specifying `text_pair`, since `text` is a string, `text_pair` must also be a string (i.e., not an array).");p=[this._encode_plus(e,{text_pair:r,add_special_tokens:s,return_token_type_ids:l})]}if(a===null?a=this.model_max_length:o===null&&(n===!0?(Z.warn("`max_length` is ignored when `padding: true` and there is no truncation strategy. To pad to max length, use `padding: 'max_length'`."),a=this.model_max_length):n===!1&&(Z.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."),o=!0)),n===!0&&(a=Math.min(Oe(p.map(_=>_.input_ids.length))[0],a??1/0)),a=Math.min(a,this.model_max_length??1/0),n||o)for(let _=0;_<p.length;++_)p[_].input_ids.length!==a&&(p[_].input_ids.length>a?o&&cz(p[_],a):n&&lz(p[_],a,m=>m==="input_ids"?this.pad_token_id:0,this.padding_side));let d={};if(i){if(!(n&&o)&&p.some(m=>{for(let w of Object.keys(m))if(m[w].length!==p[0][w]?.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.");let _=[p.length,p[0].input_ids.length];for(let m of Object.keys(p[0]))d[m]=new $("int64",BigInt64Array.from(p.flatMap(w=>w[m]).map(BigInt)),_)}else{for(let _ of Object.keys(p[0]))d[_]=p.map(m=>m[_]);if(!c)for(let _ of Object.keys(d))d[_]=d[_][0]}return d}_encode_text(e){return e===null?null:this._tokenizer.encode(e).tokens}_encode_plus(e,{text_pair:r=null,add_special_tokens:s=!0,return_token_type_ids:n=null}={}){let{ids:o,attention_mask:a,token_type_ids:i}=this._tokenizer.encode(e,{text_pair:r,add_special_tokens:s,return_token_type_ids:n??this.return_token_type_ids});return{input_ids:o,attention_mask:a,...i?{token_type_ids:i}:{}}}tokenize(e,{pair:r=null,add_special_tokens:s=!1}={}){return this._tokenizer.tokenize(e,{text_pair:r,add_special_tokens:s})}encode(e,{text_pair:r=null,add_special_tokens:s=!0,return_token_type_ids:n=null}={}){return this._tokenizer.encode(e,{text_pair:r,add_special_tokens:s,return_token_type_ids:n}).ids}batch_decode(e,r={}){return e instanceof $&&(e=e.tolist()),e.map(s=>this.decode(s,r))}decode(e,r={}){if(e instanceof $&&(e=Ef(e)),!Array.isArray(e)||e.length===0||!Gk(e[0]))throw Error("token_ids must be a non-empty array of integers.");return this.decode_single(e,r)}decode_single(e,{skip_special_tokens:r=!1,clean_up_tokenization_spaces:s=null}){return this._tokenizer.decode(e,{skip_special_tokens:r,clean_up_tokenization_spaces:s})}get_chat_template({chat_template:e=null,tools:r=null}={}){if(this.chat_template&&typeof this.chat_template=="object"){let s=this.chat_template;if(e!==null&&Object.hasOwn(s,e))e=s[e];else if(e===null)if(r!==null&&"tool_use"in s)e=s.tool_use;else if("default"in s)e=s.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(s).sort()}.`)}else if(e===null)if(this.chat_template)e=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 e}apply_chat_template(e,{tools:r=null,documents:s=null,chat_template:n=null,add_generation_prompt:o=!1,tokenize:a=!0,padding:i=!1,truncation:l=!1,max_length:c=null,return_tensor:p=!0,return_dict:d=!0,tokenizer_kwargs:_={},...m}={}){if(n=this.get_chat_template({chat_template:n,tools:r}),typeof n!="string")throw Error(`chat_template must be a string, but got ${typeof n}`);let w=this._compiled_template_cache.get(n);w===void 0&&(w=new xE(n),this._compiled_template_cache.set(n,w));let x=Object.create(null);for(let k of iz){let A=vs(this.config,k);A&&(x[k]=A)}let E=w.render({messages:e,add_generation_prompt:o,tools:r,documents:s,...x,...m});if(a){let k=this._call(E,{add_special_tokens:!1,padding:i,truncation:l,max_length:c,return_tensor:p,..._});return d?k:k.input_ids}return E}};function mn(t,e,r,s){if(!("language_codes"in t)||!Array.isArray(t.language_codes))throw new Error("Tokenizer must have `language_codes` attribute set and it should be an array of language ids.");if(!("languageRegex"in t)||!(t.languageRegex instanceof RegExp))throw new Error("Tokenizer must have `languageRegex` attribute set and it should be a regular expression.");if(!("lang_to_token"in t)||typeof t.lang_to_token!="function")throw new Error("Tokenizer must have `lang_to_token` attribute set and it should be a function.");let n=s.src_lang,o=s.tgt_lang;if(!t.language_codes.includes(o))throw new Error(`Target language code "${o}" is not valid. Must be one of: {${t.language_codes.join(", ")}}`);if(n!==void 0){if(!t.language_codes.includes(n))throw new Error(`Source language code "${n}" is not valid. Must be one of: {${t.language_codes.join(", ")}}`);for(let a of t._tokenizer.post_processor.config.single)if("SpecialToken"in a&&t.languageRegex.test(a.SpecialToken.id)){a.SpecialToken.id=t.lang_to_token(n);break}}return s.forced_bos_token_id=t._tokenizer.token_to_id(t.lang_to_token(o)),t._call(e,r)}var m_={};Zs(m_,{AlbertTokenizer:()=>Af,AutoTokenizer:()=>oe,BartTokenizer:()=>Mf,BertTokenizer:()=>Sf,BlenderbotSmallTokenizer:()=>Tf,BlenderbotTokenizer:()=>Of,BloomTokenizer:()=>If,CLIPTokenizer:()=>Lf,CamembertTokenizer:()=>Cf,CodeGenTokenizer:()=>zf,CodeLlamaTokenizer:()=>Pf,CohereTokenizer:()=>Nf,ConvBertTokenizer:()=>$f,DebertaTokenizer:()=>Df,DebertaV2Tokenizer:()=>Rf,DistilBertTokenizer:()=>Ff,ElectraTokenizer:()=>Bf,EsmTokenizer:()=>Uf,FalconTokenizer:()=>jf,GPT2Tokenizer:()=>Wf,GPTNeoXTokenizer:()=>qf,GemmaTokenizer:()=>Gf,HerbertTokenizer:()=>Vf,LlamaTokenizer:()=>Hf,M2M100Tokenizer:()=>Xf,MBart50Tokenizer:()=>Qf,MBartTokenizer:()=>Io,MPNetTokenizer:()=>Zf,MarianTokenizer:()=>Kf,MgpstrTokenizer:()=>Yf,MobileBertTokenizer:()=>Jf,NllbTokenizer:()=>e_,NougatTokenizer:()=>t_,PreTrainedTokenizer:()=>q,Qwen2Tokenizer:()=>r_,RoFormerTokenizer:()=>n_,RobertaTokenizer:()=>s_,SiglipTokenizer:()=>o_,SpeechT5Tokenizer:()=>a_,SqueezeBertTokenizer:()=>i_,T5Tokenizer:()=>l_,TokenizersBackend:()=>q,VitsTokenizer:()=>u_,Wav2Vec2CTCTokenizer:()=>p_,WhisperTokenizer:()=>d_,XLMRobertaTokenizer:()=>f_,XLMTokenizer:()=>__});var Af=class extends q{return_token_type_ids=!0};var Mf=class extends q{};var Sf=class extends q{return_token_type_ids=!0};var Tf=class extends q{};var Of=class extends q{};var If=class extends q{};var Cf=class extends q{};var Lf=class extends q{};var Pf=class extends q{};var zf=class extends q{};var Nf=class extends q{};var $f=class extends q{return_token_type_ids=!0};var Rf=class extends q{return_token_type_ids=!0};var Df=class extends q{return_token_type_ids=!0};var Ff=class extends q{};var Bf=class extends q{return_token_type_ids=!0};var Uf=class extends q{};var jf=class extends q{};var Gf=class extends q{};var qf=class extends q{};var Wf=class extends q{};var Vf=class extends q{return_token_type_ids=!0};var Hf=class extends q{padding_side="left"};var Xf=class extends q{constructor(e,r){super(e,r),this.languageRegex=/^__[a-z]{2,3}__$/,this.language_codes=this.all_special_tokens.filter(s=>this.languageRegex.test(s)).map(s=>s.slice(2,-2)),this.lang_to_token=s=>`__${s}__`}_build_translation_inputs(e,r,s){return mn(this,e,r,s)}};var Kf=class extends q{constructor(e,r){super(e,r),this.languageRegex=/^(>>\w+<<)\s*/g,this.supported_language_codes=Array.from(this.get_vocab().keys()).filter(s=>this.languageRegex.test(s)),Z.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;let[r,...s]=e.trim().split(this.languageRegex);if(s.length===0)return super._encode_text(r);if(s.length===2){let[n,o]=s;return this.supported_language_codes.includes(n)||Z.warn(`Unsupported language code "${n}" detected, which may lead to unexpected behavior. Should be one of: ${JSON.stringify(this.supported_language_codes)}`),ht([n],super._encode_text(o))}}};var Io=class extends q{constructor(e,r){super(e,r),this.languageRegex=/^[a-z]{2}_[A-Z]{2}$/,this.language_codes=this.all_special_tokens.filter(s=>this.languageRegex.test(s)).map(s=>s),this.lang_to_token=s=>s}_build_translation_inputs(e,r,s){return mn(this,e,r,s)}};var Qf=class extends Io{};var Yf=class extends q{};var Jf=class extends q{return_token_type_ids=!0};var Zf=class extends q{};var e_=class extends q{constructor(e,r){super(e,r),this.languageRegex=/^[a-z]{3}_[A-Z][a-z]{3}$/,this.language_codes=this.all_special_tokens.filter(s=>this.languageRegex.test(s)),this.lang_to_token=s=>s}_build_translation_inputs(e,r,s){return mn(this,e,r,s)}};var t_=class extends q{};var r_=class extends q{};var s_=class extends q{};var n_=class extends q{return_token_type_ids=!0};var o_=class extends q{};var a_=class extends q{};var i_=class extends q{return_token_type_ids=!0};var l_=class extends q{};var c_=class extends $t{decode_chain(e){let r="";for(let s=1;s<e.length;s+=2)r+=e[s];return[r]}},u_=class extends q{constructor(e,r){super(e,r),this._tokenizer.decoder=new c_({type:"VitsDecoder"})}};var p_=class extends q{};var E2=[["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"]],Co=new Map(E2),pz=new Map([...E2.map(([t,e])=>[e,t]),["burmese","my"],["valencian","ca"],["flemish","nl"],["haitian","ht"],["letzeburgesch","lb"],["pushto","ps"],["panjabi","pa"],["moldavian","ro"],["moldovan","ro"],["sinhalese","si"],["castilian","es"]]);function A2(t){t=t.toLowerCase();let e=pz.get(t);if(e===void 0){let r=t.match(/^<\|([a-z]{2})\|>$/);if(r&&(t=r[1]),Co.has(t))e=t;else{let n=t.length===2?Co.keys():Co.values();throw new Error(`Language "${t}" is not supported. Must be one of: ${JSON.stringify(Array.from(n))}`)}}return e}var dz="\\p{P}\\u0021-\\u002F\\u003A-\\u0040\\u005B-\\u0060\\u007B-\\u007E",M2=new RegExp(`^[${dz}]+$`,"gu"),d_=class extends q{get timestamp_begin(){return this._tokenizer.token_to_id("<|notimestamps|>")+1}_decode_asr(e,{return_timestamps:r=!1,return_language:s=!1,time_precision:n=null,force_full_sequences:o=!0}={}){if(n===null)throw Error("Must specify time_precision");let a=null,i=r==="word";function l(){return{language:a,timestamp:[null,null],text:""}}let c=[],p=l(),d=0,_=this.timestamp_begin,w=_+1500,x=[],E=[],k=!1,A=null,T=new Set(this.all_special_ids);for(let O of e){let v=O.tokens,W=i?O.token_timestamps:null,X=null,B=_;if("stride"in O){let[Q,R,C]=O.stride;if(d-=R,A=Q-C,R&&(B=R/n+_),C)for(let te=v.length-1;te>=0;--te){let ae=Number(v[te]);if(ae>=_){if(X!==null&&(ae-_)*n<A)break;X=ae}}}let H=[],G=[];for(let Q=0;Q<v.length;++Q){let R=Number(v[Q]);if(T.has(R)){let C=this.decode([R]),te=Co.get(C.slice(2,-2));if(te!==void 0){if(a!==null&&te!==a&&!r){x.push(H);let ae=this.findLongestCommonSequence(x)[0],P=this.decode(ae);p.text=P,c.push(p),x=[],H=[],p=l()}a=p.language=te}}else if(R>=_&&R<=w){let C=(R-_)*n+d,te=ds(C,2);if(X!==null&&R>=X)k=!0;else if(k||x.length>0&&R<B)k=!1;else if(p.timestamp[0]===null)p.timestamp[0]=te;else if(te!==p.timestamp[0]){p.timestamp[1]=te,x.push(H),i&&E.push(G);let[ae,P]=this.findLongestCommonSequence(x,E),N=this.decode(ae);p.text=N,i&&(p.words=this.collateWordTimestamps(ae,P,a)),c.push(p),x=[],H=[],E=[],G=[],p=l()}}else if(H.push(R),i){let C=ds(W[Q]+d,2),te;if(Q+1<W.length){te=ds(W[Q+1]+d,2);let ae=this.decode([R]);M2.test(ae)&&(te=ds(Math.min(C+n,te),2))}else te=null;G.push([C,te])}}if("stride"in O){let[Q,R,C]=O.stride;d+=Q-C}H.length>0?(x.push(H),i&&E.push(G)):x.every(Q=>Q.length===0)&&(p=l(),x=[],H=[],E=[],G=[])}if(x.length>0){if(o&&r)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.");let[O,v]=this.findLongestCommonSequence(x,E),W=this.decode(O);p.text=W,i&&(p.words=this.collateWordTimestamps(O,v,a)),c.push(p)}let S=Object.create(null),L=c.map(O=>O.text).join("");if(r||s){for(let O=0;O<c.length;++O){let v=c[O];r||delete v.timestamp,s||delete v.language}if(i){let O=[];for(let v of c)for(let W of v.words)O.push(W);S={chunks:O}}else S={chunks:c}}return[L,S]}findLongestCommonSequence(e,r=null){let s=e[0],n=s.length,o=[],a=Array.isArray(r)&&r.length>0,i=a?[]:null,l=a?r[0]:null;for(let c=1;c<e.length;++c){let p=e[c],d=0,_=[n,n,0,0],m=p.length;for(let S=1;S<n+m;++S){let L=Math.max(0,n-S),O=Math.min(n,n+m-S),v=s.slice(L,O),W=Math.max(0,S-n),X=Math.min(m,S),B=p.slice(W,X);if(v.length!==B.length)throw new Error("There is a bug within whisper `decode_asr` function, please report it. Dropping to prevent bad inference.");let H;a?H=v.filter((R,C)=>R===B[C]&&l[L+C]<=r[c][W+C]).length:H=v.filter((R,C)=>R===B[C]).length;let G=S/1e4,Q=H/S+G;H>1&&Q>d&&(d=Q,_=[L,O,W,X])}let[w,x,E,k]=_,A=Math.floor((x+w)/2),T=Math.floor((k+E)/2);o.push(...s.slice(0,A)),s=p.slice(T),n=s.length,a&&(i.push(...l.slice(0,A)),l=r[c].slice(T))}return o.push(...s),a?(i.push(...l),[o,i]):[o,[]]}collateWordTimestamps(e,r,s){let[n,o,a]=this.combineTokensIntoWords(e,s),i=[];for(let l=0;l<n.length;++l){let c=a[l];i.push({text:n[l],timestamp:[r[c.at(0)][0],r[c.at(-1)][1]]})}return i}combineTokensIntoWords(e,r,s=`"'\u201C\xA1\xBF([{-`,n=`"'.\u3002,\uFF0C!\uFF01?\uFF1F:\uFF1A\u201D)]}\u3001`){r=r??"english";let o,a,i;return["chinese","japanese","thai","lao","myanmar"].includes(r)?[o,a,i]=this.splitTokensOnUnicode(e):[o,a,i]=this.splitTokensOnSpaces(e),this.mergePunctuations(o,a,i,s,n)}decode(e,r){let s;return r?.decode_with_timestamps?(e instanceof $&&(e=Ef(e)),s=this.decodeWithTimestamps(e,r)):s=super.decode(e,r),s}decodeWithTimestamps(e,r){let s=r?.time_precision??.02,n=this.all_special_ids.at(-1)+1,o=[[]];for(let a of e)if(a=Number(a),a>=n){let i=((a-n)*s).toFixed(2);o.push(`<|${i}|>`),o.push([])}else o[o.length-1].push(a);return o=o.map(a=>typeof a=="string"?a:super.decode(a,r)),o.join("")}splitTokensOnUnicode(e){let r=this.decode(e,{decode_with_timestamps:!0}),s="\uFFFD",n=[],o=[],a=[],i=[],l=[],c=0;for(let p=0;p<e.length;++p){let d=e[p];i.push(d),l.push(p);let _=this.decode(i,{decode_with_timestamps:!0});(!_.includes(s)||r[c+_.indexOf(s)]===s)&&(n.push(_),o.push(i),a.push(l),i=[],l=[],c+=_.length)}return[n,o,a]}splitTokensOnSpaces(e){let[r,s,n]=this.splitTokensOnUnicode(e),o=[],a=[],i=[];for(let l=0;l<r.length;++l){let c=r[l],p=s[l],d=n[l],_=p[0]>=this._tokenizer.token_to_id("<|endoftext|>"),m=c.startsWith(" "),w=c.trim(),x=M2.test(w);if(_||m||x||o.length===0)o.push(c),a.push(p),i.push(d);else{let E=o.length-1;o[E]+=c,a[E].push(...p),i[E].push(...d)}}return[o,a,i]}mergePunctuations(e,r,s,n,o){let a=structuredClone(e),i=structuredClone(r),l=structuredClone(s),c=a.length-2,p=a.length-1;for(;c>=0;)a[c].startsWith(" ")&&n.includes(a[c].trim())?(a[p]=a[c]+a[p],i[p]=ht(i[c],i[p]),l[p]=ht(l[c],l[p]),a[c]="",i[c]=[],l[c]=[]):p=c,--c;for(c=0,p=1;p<a.length;)!a[c].endsWith(" ")&&o.includes(a[p])?(a[c]+=a[p],i[c]=ht(i[c],i[p]),l[c]=ht(l[c],l[p]),a[p]="",i[p]=[],l[p]=[]):c=p,++p;return[a.filter(d=>d),i.filter(d=>d.length>0),l.filter(d=>d.length>0)]}};var f_=class extends q{};var __=class extends q{return_token_type_ids=!0;constructor(e,r){super(e,r),Z.warn('WARNING: `XLMTokenizer` is not yet supported by Hugging Face\'s "fast" tokenizers library. Therefore, you may experience slightly inaccurate results.')}};var oe=class{static async from_pretrained(e,{progress_callback:r=null,config:s=null,cache_dir:n=null,local_files_only:o=!1,revision:a="main"}={}){let[i,l]=await kf(e,{progress_callback:r,config:s,cache_dir:n,local_files_only:o,revision:a}),c=l.tokenizer_class?.replace(/Fast$/,"")??"PreTrainedTokenizer",p=m_[c];return p||(Z.warn(`Unknown tokenizer class "${c}", attempting to construct from base class.`),p=q),new p(i,l)}};var Br="https://github.com/huggingface/transformers.js/issues/new/choose";var Lo="preprocessor_config.json",yr=Lo,S2="processor_config.json",T2="chat_template.jinja";var re=class extends et{static classes=["image_processor_class","tokenizer_class","feature_extractor_class"];static uses_processor_config=!1;static uses_chat_template_file=!1;constructor(e,r,s){super(),this.config=e,this.components=r,this.chat_template=s}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,r={}){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,...r})}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,...r){for(let s of[this.image_processor,this.feature_extractor,this.tokenizer])if(s)return s(e,...r);throw new Error("No image processor, feature extractor, or tokenizer found.")}static async from_pretrained(e,r={}){let[s,n,o]=await Promise.all([this.uses_processor_config?ut(e,S2,!0,r):{},Promise.all(this.classes.filter(a=>a in this).map(async a=>{let i=await this[a].from_pretrained(e,r);return[a.replace(/_class$/,""),i]})).then(Object.fromEntries),this.uses_chat_template_file?bd(e,T2,!0,r):null]);return new this(s,n,o)}};var Yc={};Zs(Yc,{ChatterboxProcessor:()=>L_,Florence2Processor:()=>Em,Gemma3nProcessor:()=>Am,Glm46VProcessor:()=>Mm,GraniteSpeechProcessor:()=>Sm,GroundingDinoProcessor:()=>Tm,Idefics3Processor:()=>Hc,JinaCLIPProcessor:()=>Im,Lfm2VlProcessor:()=>Cm,LlavaProcessor:()=>Lm,MgpstrProcessor:()=>Pm,MoonshineProcessor:()=>zm,OwlViTProcessor:()=>Nm,PaliGemmaProcessor:()=>$m,Phi3VProcessor:()=>Rm,PixtralProcessor:()=>Dm,Processor:()=>re,PyAnnoteProcessor:()=>Fm,Qwen2VLProcessor:()=>Es,Qwen2_5_VLProcessor:()=>Bo,Qwen3VLProcessor:()=>Bm,Sam2Processor:()=>Xc,Sam2VideoProcessor:()=>Um,SamProcessor:()=>Uo,SmolVLMProcessor:()=>Hc,SpeechT5Processor:()=>jm,UltravoxProcessor:()=>Gm,VLChatProcessor:()=>Om,VoxtralProcessor:()=>qm,VoxtralRealtimeProcessor:()=>Vm,Wav2Vec2Processor:()=>Hm,Wav2Vec2ProcessorWithLM:()=>Xm,WhisperProcessor:()=>Km});var Ee=class extends et{constructor(e){super(),this.config=e}static async from_pretrained(e,r={}){let s=await ut(e,Lo,!0,r);return new this(s)}};function Re(t,e){if(!(t instanceof Float32Array||t instanceof Float64Array))throw new Error(`${e} expects input to be a Float32Array or a Float64Array, but got ${t?.constructor?.name??typeof t} instead. If using the feature extractor directly, remember to use \`read_audio(url, sampling_rate)\` to obtain the raw audio data of the file/url.`)}var Ro={};Zs(Ro,{ASTFeatureExtractor:()=>w_,ChatterboxFeatureExtractor:()=>x_,ClapFeatureExtractor:()=>y_,DacFeatureExtractor:()=>No,EncodecFeatureExtractor:()=>zo,FeatureExtractor:()=>Ee,Gemma3nAudioFeatureExtractor:()=>b_,GraniteSpeechFeatureExtractor:()=>v_,MoonshineFeatureExtractor:()=>k_,ParakeetFeatureExtractor:()=>E_,PyAnnoteFeatureExtractor:()=>$o,SeamlessM4TFeatureExtractor:()=>A_,SnacFeatureExtractor:()=>M_,SpeechT5FeatureExtractor:()=>S_,VoxtralRealtimeFeatureExtractor:()=>I_,Wav2Vec2FeatureExtractor:()=>T_,WeSpeakerFeatureExtractor:()=>O_,WhisperFeatureExtractor:()=>C_});import fz from"fs";import{Readable as _z}from"stream";import{pipeline as mz}from"stream/promises";async function Sc(t,e){if(ie.IS_BROWSER_ENV){if(ie.IS_WEBWORKER_ENV)throw new Error("Unable to save a file from a Web Worker.");let r=URL.createObjectURL(e),s=document.createElement("a");s.href=r,s.download=t,s.click(),s.remove(),URL.revokeObjectURL(r)}else if(ie.IS_FS_AVAILABLE){let r=e.stream(),s=_z.fromWeb(r),n=fz.createWriteStream(t);await mz(s,n)}else throw new Error("Unable to save because filesystem is disabled in this environment.")}async function g_(t,e){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.");let r=await(await Ir(t)).arrayBuffer(),s=new AudioContext({sampleRate:e});typeof e>"u"&&Z.warn(`No sampling rate provided, using default of ${s.sampleRate}Hz.`);let n=await s.decodeAudioData(r),o;if(n.numberOfChannels===2){let a=Math.sqrt(2),i=n.getChannelData(0),l=n.getChannelData(1);o=new Float32Array(i.length);for(let c=0;c<n.length;++c)o[c]=a*(i[c]+l[c])/2}else o=n.getChannelData(0);return o}function C2(t,e){if(t<1)return new Float64Array;if(t===1)return new Float64Array([1]);let r=1-e,s=2*Math.PI/(t-1),n=new Float64Array(t);for(let o=0;o<t;++o)n[o]=e-r*Math.cos(o*s);return n}function O2(t){return C2(t,.5)}function hz(t){return C2(t,.54)}var gz={htk:t=>2595*Math.log10(1+t/700),kaldi:t=>1127*Math.log(1+t/700),slaney:(t,e=1e3,r=15,s=27/Math.log(6.4))=>t>=e?r+Math.log(t/e)*s:3*t/200};function h_(t,e="htk"){let r=gz[e];if(!r)throw new Error('mel_scale should be one of "htk", "slaney" or "kaldi".');return typeof t=="number"?r(t):t.map(s=>r(s))}var wz={htk:t=>700*(10**(t/2595)-1),kaldi:t=>700*(Math.exp(t/1127)-1),slaney:(t,e=1e3,r=15,s=Math.log(6.4)/27)=>t>=r?e*Math.exp(s*(t-r)):200*t/3};function xz(t,e="htk"){let r=wz[e];if(!r)throw new Error('mel_scale should be one of "htk", "slaney" or "kaldi".');return typeof t=="number"?r(t):t.map(s=>r(s))}function yz(t,e){let r=Float64Array.from({length:e.length-1},(a,i)=>e[i+1]-e[i]),s=Array.from({length:t.length},()=>new Array(e.length));for(let a=0;a<t.length;++a){let i=s[a];for(let l=0;l<e.length;++l)i[l]=e[l]-t[a]}let n=e.length-2,o=Array.from({length:n},()=>new Array(t.length));for(let a=0;a<t.length;++a){let i=s[a];for(let l=0;l<n;++l){let c=-i[l]/r[l],p=i[l+2]/r[l+1];o[l][a]=Math.max(0,Math.min(c,p))}}return o}function I2(t,e,r){let s=(e-t)/(r-1);return Float64Array.from({length:r},(n,o)=>t+s*o)}function nt(t,e,r,s,n,o=null,a="htk",i=!1){if(o!==null&&o!=="slaney")throw new Error('norm must be one of null or "slaney"');if(t<2)throw new Error(`Require num_frequency_bins: ${t} >= 2`);if(r>s)throw new Error(`Require min_frequency: ${r} <= max_frequency: ${s}`);let l=h_(r,a),c=h_(s,a),p=I2(l,c,e+2),d=xz(p,a),_;if(i){let w=n/((t-1)*2);_=h_(Float64Array.from({length:t},(x,E)=>E*w),a),d=p}else _=I2(0,Math.floor(n/2),t);let m=yz(_,d);if(o!==null&&o==="slaney")for(let w=0;w<e;++w){let x=m[w],E=2/(d[w+2]-d[w]);for(let k=0;k<t;++k)x[k]*=E}return m}function bz(t,e,r){let s=new t.constructor(t.length+e+r),n=t.length-1;for(let o=0;o<t.length;++o)s[e+o]=t[o];for(let o=1;o<=e;++o)s[e-o]=t[rn(o,n)];for(let o=1;o<=r;++o)s[n+e+o]=t[rn(n-o,n)];return s}function L2(t,e,r,s,n){if(r<=0)throw new Error("reference must be greater than zero");if(s<=0)throw new Error("min_value must be greater than zero");r=Math.max(s,r);let o=Math.log10(r);for(let a=0;a<t.length;++a)t[a]=e*Math.log10(Math.max(s,t[a])-o);if(n!==null){if(n<=0)throw new Error("db_range must be greater than zero");let a=Oe(t)[0]-n;for(let i=0;i<t.length;++i)t[i]=Math.max(t[i],a)}return t}function vz(t,e=1,r=1e-5,s=null){return L2(t,20,e,r,s)}function kz(t,e=1,r=1e-10,s=null){return L2(t,10,e,r,s)}async function dt(t,e,r,s,{fft_length:n=null,power:o=1,center:a=!0,pad_mode:i="reflect",onesided:l=!0,preemphasis:c=null,preemphasis_htk_flavor:p=!0,mel_filters:d=null,mel_floor:_=1e-10,log_mel:m=null,max_log_mel:w=null,reference:x=1,min_value:E=1e-10,db_range:k=null,remove_dc_offset:A=null,min_num_frames:T=null,max_num_frames:S=null,do_pad:L=!0,transpose:O=!1,mel_offset:v=0}={}){let W=e.length;if(n===null&&(n=r),r>n)throw Error(`frame_length (${r}) may not be larger than fft_length (${n})`);if(W!==r)throw new Error(`Length of the window (${W}) must equal frame_length (${r})`);if(s<=0)throw new Error("hop_length must be greater than zero");if(o===null&&d!==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(!p)throw new Error("`preemphasis_htk_flavor=false` is not currently supported.");if(a)switch(i){case"reflect":{let F=Math.floor((n-1)/2)+1;t=bz(t,F,F);break}case"constant":{let F=Math.floor(n/2),J=new t.constructor(t.length+2*F);J.set(t,F),t=J;break}default:throw new Error(`pad_mode="${i}" not implemented yet.`)}let X=Math.floor(1+Math.floor((t.length-r)/s));T!==null&&X<T&&(X=T);let B=l?Math.floor(n/2)+1:n,H=X,G=X;S!==null&&(S>X?L&&(G=S):G=H=S);let Q=new oc(n),R=new Float64Array(n),C=new Float64Array(Q.outputBufferSize),te=new Float32Array(B*G);for(let F=0;F<H;++F){let J=F*s,xe=Math.min(t.length-J,r);xe!==r&&R.fill(0,0,r);for(let ue=0;ue<xe;++ue)R[ue]=t[J+ue];if(A){let ue=0;for(let ot=0;ot<xe;++ot)ue+=R[ot];let qe=ue/xe;for(let ot=0;ot<xe;++ot)R[ot]-=qe}if(c!==null){for(let ue=xe-1;ue>=1;--ue)R[ue]-=c*R[ue-1];R[0]*=1-c}for(let ue=0;ue<e.length;++ue)R[ue]*=e[ue];Q.realTransform(C,R);for(let ue=0;ue<B;++ue){let qe=ue<<1;te[ue*G+F]=C[qe]**2+C[qe+1]**2}}if(o!==null&&o!==2){let F=o/2;for(let J=0;J<te.length;++J)te[J]**=F}let ae=d.length,P=await y2(new $("float32",d.flat(),[ae,B]),new $("float32",te,[B,G]));O&&(P=P.transpose(1,0));let N=P.data;for(let F=0;F<N.length;++F)N[F]=v+Math.max(_,N[F]);if(o!==null&&m!==null){let F=Math.min(N.length,H*ae);switch(m){case"log":for(let J=0;J<F;++J)N[J]=Math.log(N[J]);break;case"log10":for(let J=0;J<F;++J)N[J]=Math.log10(N[J]);break;case"log10_max_norm":{for(let ue=0;ue<F;++ue)N[ue]=Math.log10(N[ue]);let xe=(w??Oe(N)[0])-8;for(let ue=0;ue<F;++ue)N[ue]=(Math.max(N[ue],xe)+4)/4;break}case"dB":if(o===1)vz(N,x,E,k);else if(o===2)kz(N,x,E,k);else throw new Error(`Cannot use log_mel option '${m}' with power ${o}`);break;default:throw new Error(`log_mel must be one of null, 'log', 'log10', 'log10_max_norm', or 'dB'. Got '${m}'`)}}return P}function ft(t,e,{periodic:r=!0,frame_length:s=null,center:n=!0}={}){let o=r?t+1:t,a;switch(e){case"boxcar":a=new Float64Array(o).fill(1);break;case"hann":case"hann_window":a=O2(o);break;case"hamming":a=hz(o);break;case"povey":a=O2(o).map(i=>Math.pow(i,.85));break;default:throw new Error(`Unknown window type ${e}.`)}if(r&&(a=a.subarray(0,t)),s===null)return a;if(t>s)throw new Error(`Length of the window (${t}) may not be larger than frame_length (${s})`);return a}function Ez(t,e){let r=t.reduce((o,a)=>o+a.length,0),s=new ArrayBuffer(44),n=new DataView(s);return Tc(n,0,"RIFF"),n.setUint32(4,36+r*4,!0),Tc(n,8,"WAVE"),Tc(n,12,"fmt "),n.setUint32(16,16,!0),n.setUint16(20,3,!0),n.setUint16(22,1,!0),n.setUint32(24,e,!0),n.setUint32(28,e*4,!0),n.setUint16(32,4,!0),n.setUint16(34,32,!0),Tc(n,36,"data"),n.setUint32(40,r*4,!0),new Blob([s,...t.map(o=>o.buffer)],{type:"audio/wav"})}function Tc(t,e,r){for(let s=0;s<r.length;++s)t.setUint8(e+s,r.charCodeAt(s))}var Po=class{constructor(e,r){this.audio=e,this.sampling_rate=r}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];let e=this.audio.reduce((n,o)=>n+o.length,0),r=new Float32Array(e),s=0;for(let n of this.audio)r.set(n,s),s+=n.length;return r}else return this.audio}toBlob(){let e=this.audio;return e instanceof Float32Array&&(e=[e]),Ez(e,this.sampling_rate)}async save(e){return Sc(e,this.toBlob())}};var w_=class extends Ee{constructor(e){super(e);let r=this.config.sampling_rate,s=nt(257,this.config.num_mel_bins,20,Math.floor(r/2),r,null,"kaldi",!0);this.mel_filters=s,this.window=ft(400,"hann",{periodic:!1}),this.mean=this.config.mean,this.std=this.config.std}async _extract_fbank_features(e,r){return dt(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:r,transpose:!0})}async _call(e){Re(e,"ASTFeatureExtractor");let r=await this._extract_fbank_features(e,this.config.max_length);if(this.config.do_normalize){let s=this.std*2,n=r.data;for(let o=0;o<n.length;++o)n[o]=(n[o]-this.mean)/s}return{input_values:r.unsqueeze_(0)}}};var zo=class extends Ee{async _call(e){Re(e,"EncodecFeatureExtractor"),e instanceof Float64Array&&(e=new Float32Array(e));let r=this.config.feature_size;if(e.length%r!==0)throw new Error(`The length of the audio data must be a multiple of the number of channels (${r}).`);let s=[1,r,e.length/r];return{input_values:new $("float32",e,s)}}};var x_=class extends Ee{async _call(e){Re(e,"ChatterboxFeatureExtractor"),e instanceof Float64Array&&(e=new Float32Array(e));let r=[1,e.length];return{input_values:new $("float32",e,r)}}};var y_=class extends Ee{constructor(e){super(e),this.mel_filters=nt(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=nt(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=ft(this.config.fft_window_size,"hann")}async _get_input_mel(e,r,s,n){let o,a=!1,i=e.length-r;if(i>0)if(s==="rand_trunc"){a=!0;let l=Math.floor(ps.random()*(i+1));e=e.subarray(l,l+r),o=await this._extract_fbank_features(e,this.mel_filters_slaney,this.config.nb_max_samples)}else throw new Error(`Truncation strategy "${s}" not implemented`);else{if(i<0){let l=new Float64Array(r);if(l.set(e),n==="repeat")for(let c=e.length;c<r;c+=e.length)l.set(e.subarray(0,Math.min(e.length,r-c)),c);else if(n==="repeatpad")for(let c=e.length;c<-i;c+=e.length)l.set(e,c);e=l}if(s==="fusion")throw new Error(`Truncation strategy "${s}" not implemented`);o=await this._extract_fbank_features(e,this.mel_filters_slaney,this.config.nb_max_samples)}return o.unsqueeze_(0)}async _extract_fbank_features(e,r,s=null){return dt(e,this.window,this.config.fft_window_size,this.config.hop_length,{power:2,mel_filters:r,log_mel:"dB",max_num_frames:s,do_pad:!1,transpose:!0})}async _call(e,{max_length:r=null}={}){return Re(e,"ClapFeatureExtractor"),{input_features:(await this._get_input_mel(e,r??this.config.nb_max_samples,this.config.truncation,this.config.padding)).unsqueeze_(0)}}};var No=class extends zo{};var b_=class extends Ee{constructor(e){super(e);let{fft_length:r,feature_size:s,min_frequency:n,max_frequency:o,sampling_rate:a,frame_length:i}=this.config,l=nt(Math.floor(1+r/2),s,n,o,a,null,"htk",!1);this.mel_filters=l,this.window=ft(i,"hann")}async _extract_fbank_features(e,r){return dt(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:r=48e4,truncation:s=!0,padding:n=!0,pad_to_multiple_of:o=128}={}){if(Re(e,"Gemma3nAudioFeatureExtractor"),s&&e.length>r&&(e=e.slice(0,r)),n&&e.length%o!==0){let l=o-e.length%o,c=new Float64Array(e.length+l);c.set(e),this.config.padding_value!==0&&c.fill(this.config.padding_value,e.length),e=c}let a=await this._extract_fbank_features(e,this.config.max_length),i=He([1,a.dims[0]],!0);return{input_features:a.unsqueeze_(0),input_features_mask:i}}};var v_=class extends Ee{constructor(e){super(e);let{n_fft:r,win_length:s,n_mels:n,sample_rate:o}=e.melspec_kwargs;this.mel_filters=nt(Math.floor(1+r/2),n,0,o/2,o,null,"htk");let a=ft(s,"hann");this.window=new Float64Array(r);let i=Math.floor((r-s)/2);this.window.set(a,i)}async _call(e){Re(e,"GraniteSpeechFeatureExtractor");let{n_fft:r,hop_length:s,n_mels:n}=this.config.melspec_kwargs,o=1+Math.floor((e.length-1)/s),a=o-o%2;return{input_features:(await dt(e,this.window,r,s,{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)}}};var k_=class extends Ee{async _call(e){Re(e,"MoonshineFeatureExtractor"),e instanceof Float64Array&&(e=new Float32Array(e));let r=[1,e.length];return{input_values:new $("float32",e,r)}}};var Az=1e-5,E_=class extends Ee{constructor(e){super(e),this.config.mel_filters??=nt(Math.floor(1+this.config.n_fft/2),this.config.feature_size,0,this.config.sampling_rate/2,this.config.sampling_rate,"slaney","slaney");let r=ft(this.config.win_length,"hann",{periodic:!1});this.window=new Float64Array(this.config.n_fft);let s=Math.floor((this.config.n_fft-this.config.win_length)/2);this.window.set(r,s)}async _extract_fbank_features(e){let r=this.config.preemphasis;e=new Float64Array(e);for(let n=e.length-1;n>=1;--n)e[n]-=r*e[n-1];return await dt(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){Re(e,"ParakeetFeatureExtractor");let r=await this._extract_fbank_features(e),s=Math.floor((e.length+Math.floor(this.config.n_fft/2)*2-this.config.n_fft)/this.config.hop_length),n=r.data;n.fill(0,s*r.dims[1]);let[o,a]=r.dims,i=new Float64Array(a),l=new Float64Array(a);for(let d=0;d<s;++d){let _=d*a;for(let m=0;m<a;++m){let w=n[_+m];i[m]+=w,l[m]+=w*w}}let c=s>1?s-1:1;for(let d=0;d<a;++d){let _=i[d]/s,m=(l[d]-s*_*_)/c,x=1/(Math.sqrt(m)+Az);for(let E=0;E<s;++E){let k=E*a+d;n[k]=(n[k]-_)*x}}let p=new BigInt64Array(o);return p.fill(1n,0,s),{input_features:r.unsqueeze_(0),attention_mask:new $("int64",p,[1,o])}}};var $o=class extends Ee{async _call(e){Re(e,"PyAnnoteFeatureExtractor"),e instanceof Float64Array&&(e=new Float32Array(e));let r=[1,1,e.length];return{input_values:new $("float32",e,r)}}samples_to_frames(e){return(e-this.config.offset)/this.config.step}post_process_speaker_diarization(e,r){let s=r/this.samples_to_frames(r)/this.config.sampling_rate,n=[];for(let o of e.tolist()){let a=[],i=-1;for(let l=0;l<o.length;++l){let c=Ne(o[l]),[p,d]=Oe(c),[_,m]=[l,l+1];d!==i?(i=d,a.push({id:d,start:_,end:m,score:p})):(a.at(-1).end=m,a.at(-1).score+=p)}n.push(a.map(({id:l,start:c,end:p,score:d})=>({id:l,start:c*s,end:p*s,confidence:d/(p-c)})))}return n}};var A_=class extends Ee{constructor(e){super(e);let r=this.config.sampling_rate,s=nt(257,this.config.num_mel_bins,20,Math.floor(r/2),r,null,"kaldi",!0);this.mel_filters=s,this.window=ft(400,"povey",{periodic:!1})}async _extract_fbank_features(e,r){return e=e.map(s=>s*32768),dt(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:r,transpose:!0})}async _call(e,{padding:r=!0,pad_to_multiple_of:s=2,do_normalize_per_mel_bins:n=!0,return_attention_mask:o=!0}={}){Re(e,"SeamlessM4TFeatureExtractor");let a=await this._extract_fbank_features(e,this.config.max_length);if(n){let[w,x]=a.dims,E=a.data;for(let k=0;k<x;++k){let A=0;for(let O=0;O<w;++O)A+=E[O*x+k];let T=A/w,S=0;for(let O=0;O<w;++O)S+=(E[O*x+k]-T)**2;S/=w-1;let L=Math.sqrt(S+1e-7);for(let O=0;O<w;++O){let v=O*x+k;E[v]=(E[v]-T)/L}}}let i;if(r){let[w,x]=a.dims,E=a.data,k=w%s;if(k>0){let A=new Float32Array(x*(w+k));A.set(E),A.fill(this.config.padding_value,E.length);let T=w+k;a=new $(a.type,A,[T,x]),o&&(i=new $("int64",new BigInt64Array(T),[1,T]),i.data.fill(1n,0,w))}}let[l,c]=a.dims,p=this.config.stride;if(l%p!==0)throw new Error(`The number of frames (${l}) must be a multiple of the stride (${p}).`);let _=a.view(1,Math.floor(l/p),c*p),m={input_features:_};if(o){let w=_.dims[1],x=new BigInt64Array(w);if(i){let E=i.data;for(let k=1,A=0;k<l;k+=p,++A)x[A]=E[k]}else x.fill(1n);m.attention_mask=new $("int64",x,[1,w])}return m}};var M_=class extends No{};var S_=class extends Ee{};var T_=class extends Ee{_zero_mean_unit_var_norm(e){let s=e.reduce((o,a)=>o+a,0)/e.length,n=e.reduce((o,a)=>o+(a-s)**2,0)/e.length;return e.map(o=>(o-s)/Math.sqrt(n+1e-7))}async _call(e){Re(e,"Wav2Vec2FeatureExtractor"),e instanceof Float64Array&&(e=new Float32Array(e));let r=e;this.config.do_normalize&&(r=this._zero_mean_unit_var_norm(r));let s=[1,r.length];return{input_values:new $("float32",r,s),attention_mask:new $("int64",new BigInt64Array(r.length).fill(1n),s)}}};var O_=class extends Ee{constructor(e){super(e);let r=this.config.sampling_rate,s=nt(257,this.config.num_mel_bins,20,Math.floor(r/2),r,null,"kaldi",!0);this.mel_filters=s,this.window=ft(400,"hamming",{periodic:!1}),this.min_num_frames=this.config.min_num_frames}async _extract_fbank_features(e){return e=e.map(r=>r*32768),dt(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){Re(e,"WeSpeakerFeatureExtractor");let r=(await this._extract_fbank_features(e)).unsqueeze_(0);if(this.config.fbank_centering_span===null){let s=r.mean(1).data,n=r.data,[o,a,i]=r.dims;for(let l=0;l<o;++l){let c=l*a*i,p=l*i;for(let d=0;d<a;++d){let _=c+d*i;for(let m=0;m<i;++m)n[_+m]-=s[p+m]}}}return{input_features:r}}};var I_=class extends Ee{constructor(e){super(e),this.config.mel_filters??=nt(Math.floor(1+this.config.n_fft/2),this.config.feature_size,0,8e3,this.config.sampling_rate,"slaney","slaney"),this.window=ft(this.config.n_fft,"hann")}async _extract_fbank_features(e,{center:r=!0}={}){let{n_fft:s,hop_length:n,mel_filters:o,global_log_mel_max:a}=this.config,i=Math.floor(r?e.length/n:(e.length-s)/n);return await dt(e,this.window,s,n,{power:2,mel_filters:o,log_mel:"log10_max_norm",max_log_mel:a,center:r,max_num_frames:i,do_pad:!1})}async _call(e,{center:r=!0}={}){return Re(e,"VoxtralRealtimeFeatureExtractor"),{input_features:(await this._extract_fbank_features(e,{center:r})).unsqueeze_(0)}}};var C_=class extends Ee{constructor(e){super(e),this.config.mel_filters??=nt(Math.floor(1+this.config.n_fft/2),this.config.feature_size,0,8e3,this.config.sampling_rate,"slaney","slaney"),this.window=ft(this.config.n_fft,"hann")}async _extract_fbank_features(e){return await dt(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:r=null}={}){Re(e,"WhisperFeatureExtractor");let s,n=r??this.config.n_samples;return e.length>n?(e.length>this.config.n_samples&&Z.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`."),s=e.slice(0,n)):(s=new Float32Array(n),s.set(e)),{input_features:(await this._extract_fbank_features(s)).unsqueeze_(0)}}};var Xe=class{static async from_pretrained(e,r={}){let s=await ut(e,Lo,!0,r),n=s.feature_extractor_type,o=Ro[n];if(!o)throw new Error(`Unknown feature_extractor_type: '${n}'. Please report this at ${Br}.`);return new o(s)}};var L_=class extends re{static tokenizer_class=oe;static feature_extractor_class=Xe;async _call(e,r=null){let s=this.tokenizer(e),n=r?await this.feature_extractor(r):{};return{...s,...n}}};import P_ from"sharp";var ks,P2,Ur;if(ie.IS_WEB_ENV)ks=(t,e)=>{if(!self.OffscreenCanvas)throw new Error("OffscreenCanvas not supported by this environment.");return new self.OffscreenCanvas(t,e)},Ur=self.createImageBitmap,P2=self.ImageData;else if(P_)Ur=async t=>{let r=(await t.metadata()).channels,{data:s,info:n}=await t.rotate().raw().toBuffer({resolveWithObject:!0}),o=new Qe(new Uint8ClampedArray(s),n.width,n.height,n.channels);return r!==void 0&&r!==n.channels&&o.convert(r),o};else throw new Error("Unable to load image processing library.");var Mz={0:"nearest",1:"lanczos",2:"bilinear",3:"bicubic",4:"box",5:"hamming"},Sz=new Map([["png","image/png"],["jpg","image/jpeg"],["jpeg","image/jpeg"],["gif","image/gif"]]),Qe=class t{constructor(e,r,s,n){this.data=e,this.width=r,this.height=s,this.channels=n}get size(){return[this.width,this.height]}static async read(e){if(e instanceof t)return e;if(typeof e=="string"||e instanceof URL)return await this.fromURL(e);if(e instanceof Blob)return await this.fromBlob(e);if(typeof HTMLCanvasElement<"u"&&e instanceof HTMLCanvasElement||typeof OffscreenCanvas<"u"&&e instanceof OffscreenCanvas)return this.fromCanvas(e);throw new Error(`Unsupported input type: ${typeof e}`)}static fromCanvas(e){if(!ie.IS_WEB_ENV)throw new Error("fromCanvas() is only supported in browser environments.");let s=e.getContext("2d").getImageData(0,0,e.width,e.height).data;return new t(s,e.width,e.height,4)}static async fromURL(e){let r=await Ir(e);if(r.status!==200)throw new Error(`Unable to read image from "${e}" (${r.status} ${r.statusText})`);let s=await r.blob();return this.fromBlob(s)}static async fromBlob(e){if(ie.IS_WEB_ENV){let r=await Ur(e),s=ks(r.width,r.height).getContext("2d");return s.drawImage(r,0,0),new this(s.getImageData(0,0,r.width,r.height).data,r.width,r.height,4)}else{let r=P_(await e.arrayBuffer());return await Ur(r)}}static fromTensor(e,r="CHW"){if(e.dims.length!==3)throw new Error(`Tensor should have 3 dimensions, but has ${e.dims.length} dimensions.`);if(r==="CHW")e=e.transpose(1,2,0);else if(r!=="HWC")throw new Error(`Unsupported channel format: ${r}`);if(!(e.data instanceof Uint8ClampedArray||e.data instanceof Uint8Array))throw new Error(`Unsupported tensor type: ${e.type}`);switch(e.dims[2]){case 1:case 2:case 3:case 4:return new t(e.data,e.dims[1],e.dims[0],e.dims[2]);default:throw new Error(`Unsupported number of channels: ${e.dims[2]}`)}}grayscale(){if(this.channels===1)return this;let e=new Uint8ClampedArray(this.width*this.height*1);switch(this.channels){case 3:case 4:for(let r=0,s=0;r<this.data.length;r+=this.channels){let n=this.data[r],o=this.data[r+1],a=this.data[r+2];e[s++]=Math.round(.2989*n+.587*o+.114*a)}break;default:throw new Error(`Conversion failed due to unsupported number of channels: ${this.channels}`)}return this._update(e,this.width,this.height,1)}rgb(){if(this.channels===3)return this;let e=new Uint8ClampedArray(this.width*this.height*3);switch(this.channels){case 1:for(let r=0,s=0;r<this.data.length;++r)e[s++]=this.data[r],e[s++]=this.data[r],e[s++]=this.data[r];break;case 4:for(let r=0,s=0;r<this.data.length;r+=4)e[s++]=this.data[r],e[s++]=this.data[r+1],e[s++]=this.data[r+2];break;default:throw new Error(`Conversion failed due to unsupported number of channels: ${this.channels}`)}return this._update(e,this.width,this.height,3)}rgba(){if(this.channels===4)return this;let e=new Uint8ClampedArray(this.width*this.height*4);switch(this.channels){case 1:for(let r=0,s=0;r<this.data.length;++r)e[s++]=this.data[r],e[s++]=this.data[r],e[s++]=this.data[r],e[s++]=255;break;case 3:for(let r=0,s=0;r<this.data.length;r+=3)e[s++]=this.data[r],e[s++]=this.data[r+1],e[s++]=this.data[r+2],e[s++]=255;break;default:throw new Error(`Conversion failed due to unsupported number of channels: ${this.channels}`)}return this._update(e,this.width,this.height,4)}putAlpha(e){if(e.width!==this.width||e.height!==this.height)throw new Error(`Expected mask size to be ${this.width}x${this.height}, but got ${e.width}x${e.height}`);if(e.channels!==1)throw new Error(`Expected mask to have 1 channel, but got ${e.channels}`);let r=this.data,s=e.data,n=this.width*this.height;if(this.channels===3){let o=new Uint8ClampedArray(n*4);for(let a=0,i=0,l=0;a<n;++a)o[l++]=r[i++],o[l++]=r[i++],o[l++]=r[i++],o[l++]=s[a];return this._update(o,this.width,this.height,4)}else if(this.channels===4){for(let o=0;o<n;++o)r[4*o+3]=s[o];return this}throw new Error(`Expected image to have 3 or 4 channels, but got ${this.channels}`)}async resize(e,r,{resample:s=2}={}){if(this.width===e&&this.height===r)return this;let n=Mz[s]??s,o=pd(e),a=pd(r);if(o&&a)return this;if(o?e=r/this.height*this.width:a&&(r=e/this.width*this.height),ie.IS_WEB_ENV){let i=this.channels,l=this.toCanvas(),c=ks(e,r).getContext("2d");return c.drawImage(l,0,0,e,r),new t(c.getImageData(0,0,e,r).data,e,r,4).convert(i)}else{let i=this.toSharp();switch(n){case"box":case"hamming":(n==="box"||n==="hamming")&&(Z.warn(`Resampling method ${n} is not yet supported. Using bilinear instead.`),n="bilinear");case"nearest":case"bilinear":case"bicubic":i=i.affine([e/this.width,0,0,r/this.height],{interpolator:n});break;case"lanczos":i=i.resize({width:e,height:r,fit:"fill",kernel:"lanczos3"});break;default:throw new Error(`Resampling method ${n} is not supported.`)}return await Ur(i)}}async pad([e,r,s,n]){if(e=Math.max(e,0),r=Math.max(r,0),s=Math.max(s,0),n=Math.max(n,0),e===0&&r===0&&s===0&&n===0)return this;if(ie.IS_WEB_ENV){let o=this.channels,a=this.toCanvas(),i=this.width+e+r,l=this.height+s+n,c=ks(i,l).getContext("2d");return c.drawImage(a,0,0,this.width,this.height,e,s,this.width,this.height),new t(c.getImageData(0,0,i,l).data,i,l,4).convert(o)}else{let o=this.toSharp().extend({left:e,right:r,top:s,bottom:n});return await Ur(o)}}async crop([e,r,s,n]){if(e=Math.max(e,0),r=Math.max(r,0),s=Math.min(s,this.width-1),n=Math.min(n,this.height-1),e===0&&r===0&&s===this.width-1&&n===this.height-1)return this;let o=s-e+1,a=n-r+1;if(ie.IS_WEB_ENV){let i=this.channels,l=this.toCanvas(),c=ks(o,a).getContext("2d");return c.drawImage(l,e,r,o,a,0,0,o,a),new t(c.getImageData(0,0,o,a).data,o,a,4).convert(i)}else{let i=this.toSharp().extract({left:e,top:r,width:o,height:a});return await Ur(i)}}async center_crop(e,r){if(this.width===e&&this.height===r)return this;let s=(this.width-e)/2,n=(this.height-r)/2;if(ie.IS_WEB_ENV){let o=this.channels,a=this.toCanvas(),i=ks(e,r).getContext("2d"),l=0,c=0,p=0,d=0;return s>=0?l=s:p=-s,n>=0?c=n:d=-n,i.drawImage(a,l,c,e,r,p,d,e,r),new t(i.getImageData(0,0,e,r).data,e,r,4).convert(o)}else{let o=this.toSharp();if(s>=0&&n>=0)o=o.extract({left:Math.floor(s),top:Math.floor(n),width:e,height:r});else if(s<=0&&n<=0){let a=Math.floor(-n),i=Math.floor(-s);o=o.extend({top:a,left:i,right:e-this.width-i,bottom:r-this.height-a})}else{let a=[0,0],i=0;n<0?(a[0]=Math.floor(-n),a[1]=r-this.height-a[0]):i=Math.floor(n);let l=[0,0],c=0;s<0?(l[0]=Math.floor(-s),l[1]=e-this.width-l[0]):c=Math.floor(s),o=o.extend({top:a[0],bottom:a[1],left:l[0],right:l[1]}).extract({left:c,top:i,width:e,height:r})}return await Ur(o)}}async toBlob(e="image/png",r=1){if(!ie.IS_WEB_ENV)throw new Error("toBlob() is only supported in browser environments.");return await this.toCanvas().convertToBlob({type:e,quality:r})}toTensor(e="CHW"){let r=new $("uint8",new Uint8Array(this.data),[this.height,this.width,this.channels]);if(e!=="HWC")if(e==="CHW")r=r.permute(2,0,1);else throw new Error(`Unsupported channel format: ${e}`);return r}toCanvas(){if(!ie.IS_WEB_ENV)throw new Error("toCanvas() is only supported in browser environments.");let e=this.clone().rgba(),r=ks(e.width,e.height),s=new P2(e.data,e.width,e.height);return r.getContext("2d").putImageData(s,0,0),r}split(){let{data:e,width:r,height:s,channels:n}=this,o=e.constructor,a=e.length/n,i=Array.from({length:n},()=>new o(a));for(let l=0;l<a;++l){let c=n*l;for(let p=0;p<n;++p)i[p][l]=e[c+p]}return i.map(l=>new t(l,r,s,1))}_update(e,r,s,n=null){return this.data=e,this.width=r,this.height=s,n!==null&&(this.channels=n),this}clone(){return new t(this.data.slice(),this.width,this.height,this.channels)}convert(e){if(this.channels===e)return this;switch(e){case 1:this.grayscale();break;case 3:this.rgb();break;case 4:this.rgba();break;default:throw new Error(`Conversion failed due to unsupported number of channels: ${this.channels}`)}return this}async save(e){if(ie.IS_WEB_ENV){if(ie.IS_WEBWORKER_ENV)throw new Error("Unable to save an image from a Web Worker.");let r=e.split(".").pop().toLowerCase(),s=Sz.get(r)??"image/png",n=await this.toBlob(s);return Sc(e,n)}else if(ie.IS_FS_AVAILABLE)await this.toSharp().toFile(e);else throw new Error("Unable to save the image because filesystem is disabled in this environment.")}toSharp(){if(ie.IS_WEB_ENV)throw new Error("toSharp() is only supported in server-side environments.");return P_(this.data,{raw:{width:this.width,height:this.height,channels:this.channels}})}},Tz=Qe.read.bind(Qe);function z2(t,e,r=0,s=null){let n=t/e,o=$E(n)*e;return s!==null&&o>s&&(o=Math.floor(n)*e),o<r&&(o=Math.ceil(n)*e),o}function N2([t,e],r){return[Math.max(Math.floor(t/r),1)*r,Math.max(Math.floor(e/r),1)*r]}function z_([t,e,r,s]){return[t-r/2,e-s/2,t+r/2,e+s/2]}function jr(t,e=.5,r=null,s=!1){let n=t.logits,o=t.pred_boxes,[a,i,l]=n.dims;if(r!==null&&r.length!==a)throw Error("Make sure that you pass in as many target sizes as the batch dimension of the logits");let c=[];for(let p=0;p<a;++p){let d=r!==null?r[p]:null,_={boxes:[],classes:[],scores:[]},m=n[p],w=o[p];for(let x=0;x<i;++x){let E=m[x],k=[],A;if(s){A=E.sigmoid().data;for(let T=0;T<A.length;++T)A[T]>e&&k.push(T)}else{let T=Oe(E.data)[1];if(T===l-1||(A=Ne(E.data),A[T]<e))continue;k.push(T)}for(let T of k){let S=w[x].data;S=z_(S),d!==null&&(S=S.map((L,O)=>L*d[(O+1)%2])),_.boxes.push(S),_.classes.push(T),_.scores.push(A[T])}}c.push(_)}return c}function Oc(t,e=null){let r=t.logits,s=r.dims[0];if(e!==null&&e.length!==s)throw Error("Make sure that you pass in as many target sizes as the batch dimension of the logits");let n=[];for(let o=0;o<s;++o){let a=e!==null?e[o]:null,i=r[o];a!==null&&(i=wf(i,a,"bilinear",!1));let[l,c]=a??i.dims.slice(-2),p=new $("int32",new Int32Array(l*c),[l,c]),d=i[0].data,_=p.data;for(let x=1;x<i.dims[0];++x){let E=i[x].data;for(let k=0;k<E.length;++k)E[k]>d[k]&&(d[k]=E[k],_[k]=x)}let m=new Array(i.dims[0]);for(let x=0;x<_.length;++x){let E=_[x];m[E]=E}let w=m.filter(x=>x!==void 0);n.push({segmentation:p,labels:w})}return n}function Oz(t,e,r,s){let n=[],o=[],a=[];for(let i=0;i<t.dims[0];++i){let l=t[i],c=e[i],p=Oe(l.data)[1];if(p===s)continue;let _=Ne(l.data)[p];_>r&&(n.push(c),o.push(_),a.push(p))}return[n,o,a]}function Iz(t,e,r,s=.5,n=.8){let o=[],a=0,i=0,l=e[r].data;for(let p=0;p<t.length;++p)t[p]===r&&(o.push(p),++a),l[p]>=s&&++i;let c=a>0&&i>0;return c&&(c=a/i>n),[c,o]}function Cz(t,e,r,s,n,o=null,a=null){let[i,l]=a??t[0].dims,c=new $("int32",new Int32Array(i*l),[i,l]),p=[];if(a!==null)for(let x=0;x<t.length;++x)t[x]=wf(t[x],a,"bilinear",!1);let d=new Int32Array(t[0].data.length),_=new Float32Array(t[0].data.length);for(let x=0;x<t.length;++x){let E=e[x],k=t[x].data;for(let A=0;A<k.length;++A)k[A]*=E,k[A]>_[A]&&(d[A]=x,_[A]=k[A])}let m=0,w=c.data;for(let x=0;x<r.length;++x){let E=r[x],[k,A]=Iz(d,t,x,s,n);if(k){++m;for(let T of A)w[T]=m;p.push({id:m,label_id:E,score:e[x]})}}return[c,p]}function hn(t,e,r=28,s=3136,n=784*1280,o=1){if(t<r||e<r){let l=Math.max(r/t,r/e);t=Math.round(t*l),e=Math.round(e*l)}if(Math.max(t,e)/Math.min(t,e)>200)throw new Error(`absolute aspect ratio must be smaller than 200, got ${Math.max(t,e)/Math.min(t,e)}`);let a=Math.round(t/r)*r,i=Math.round(e/r)*r;if(o*a*i>n){let l=Math.sqrt(o*t*e/n);a=Math.max(r,Math.floor(t/l/r)*r),i=Math.max(r,Math.floor(e/l/r)*r)}else if(o*a*i<s){let l=Math.sqrt(s/(o*t*e));a=Math.ceil(t*l/r)*r,i=Math.ceil(e*l/r)*r}return[i,a]}function Ic(t,e=.5,r=.5,s=.8,n=null,o=null){n===null&&(Z.warn("`label_ids_to_fuse` unset. No instance will be fused."),n=new Set);let a=t.class_queries_logits??t.logits,l=(t.masks_queries_logits??t.pred_masks).sigmoid(),[c,p,d]=a.dims;if(d-=1,o!==null&&o.length!==c)throw Error("Make sure that you pass in as many target sizes as the batch dimension of the logits");let _=[];for(let m=0;m<c;++m){let w=o!==null?o[m]:null,x=a[m],E=l[m],[k,A,T]=Oz(x,E,e,d);if(T.length===0){let[O,v]=w??E.dims.slice(-2),W=new $("int32",new Int32Array(O*v).fill(-1),[O,v]);_.push({segmentation:W,segments_info:[]});continue}let[S,L]=Cz(k,A,T,r,s,n,w);_.push({segmentation:S,segments_info:L})}return _}function Cc(t,e=.5,r=null){throw new Error("`post_process_instance_segmentation` is not yet implemented.")}var V=class extends et{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,r,s=2){let n=e.height,o=e.width,a=r.height,i=r.width,l=Math.min(n,a),c=Math.min(o,i);return l===n&&c===o?e:(n>o?c=Math.floor(o*l/n):o>n&&(l=Math.floor(n*c/o)),await e.resize(c,l,{resample:s}))}async crop_margin(e,r=200){let s=e.clone().grayscale(),n=go(s.data)[0],a=Oe(s.data)[0]-n;if(a===0)return e;let i=r/255,l=s.width,c=s.height,p=0,d=0,_=s.data;for(let m=0;m<s.height;++m){let w=m*s.width;for(let x=0;x<s.width;++x)(_[w+x]-n)/a<i&&(l=Math.min(l,x),c=Math.min(c,m),p=Math.max(p,x),d=Math.max(d,m))}return e=await e.crop([l,c,p,d]),e}pad_image(e,r,s,{mode:n="constant",center:o=!1,constant_values:a=0}={}){let[i,l,c]=r,p,d;if(typeof s=="number"?(p=s,d=s):s==="square"?p=d=Math.max(i,l):(p=s.width,d=s.height),p!==l||d!==i){let _=new Float32Array(p*d*c);if(Array.isArray(a))for(let x=0;x<_.length;++x)_[x]=a[x%c];else a!==0&&_.fill(a);let[m,w]=o?[Math.floor((p-l)/2),Math.floor((d-i)/2)]:[0,0];for(let x=0;x<i;++x){let E=(x+w)*p,k=x*l;for(let A=0;A<l;++A){let T=(E+A+m)*c,S=(k+A)*c;for(let L=0;L<c;++L)_[T+L]=e[S+L]}}if(n==="symmetric"){if(o)throw new Error("`center` padding is not supported when `mode` is set to `symmetric`.");let x=i-1,E=l-1;for(let k=0;k<d;++k){let A=k*p,T=rn(k,x)*l;for(let S=0;S<p;++S){if(k<i&&S<l)continue;let L=(A+S)*c,O=(T+rn(S,E))*c;for(let v=0;v<c;++v)_[L+v]=e[O+v]}}}e=_,r=[d,p,c]}return[e,r]}rescale(e){for(let r=0;r<e.length;++r)e[r]=this.rescale_factor*e[r]}get_resize_output_image_size(e,r){let[s,n]=e.size,o,a;if(this.do_thumbnail){let{height:i,width:l}=r;o=Math.min(i,l)}else Number.isInteger(r)?(o=r,a=this.config.max_size??o):r!==void 0&&(o=r.shortest_edge,a=r.longest_edge);if(o!==void 0||a!==void 0){let i=o===void 0?1:Math.max(o/s,o/n),l=s*i,c=n*i,p=a===void 0?1:Math.min(a/l,a/c),d=Math.floor(Number((l*p).toFixed(2))),_=Math.floor(Number((c*p).toFixed(2)));return this.size_divisibility!==void 0&&([d,_]=N2([d,_],this.size_divisibility)),[d,_]}else if(r!==void 0&&r.width!==void 0&&r.height!==void 0){let i=r.width,l=r.height;if(this.config.keep_aspect_ratio&&this.config.ensure_multiple_of){let c=l/n,p=i/s;Math.abs(1-p)<Math.abs(1-c)?c=p:p=c,l=z2(c*n,this.config.ensure_multiple_of),i=z2(p*s,this.config.ensure_multiple_of)}return[i,l]}else{if(this.size_divisibility!==void 0)return N2([s,n],this.size_divisibility);throw new Error(`Could not resize image due to unsupported \`this.size\` option in config: ${JSON.stringify(r)}`)}}async resize(e){let[r,s]=this.get_resize_output_image_size(e,this.size);return await e.resize(r,s,{resample:this.resample})}async preprocess(e,{do_normalize:r=null,do_pad:s=null,do_convert_rgb:n=null,do_convert_grayscale:o=null,do_flip_channel_order:a=null}={}){this.do_crop_margin&&(e=await this.crop_margin(e));let[i,l]=e.size;if(n??this.do_convert_rgb?e=e.rgb():o&&(e=e.grayscale()),this.do_resize&&(e=await this.resize(e)),this.do_thumbnail&&(e=await this.thumbnail(e,this.size,this.resample)),this.do_center_crop){let m,w;Number.isInteger(this.crop_size)?(m=this.crop_size,w=this.crop_size):(m=this.crop_size.width,w=this.crop_size.height),e=await e.center_crop(m,w)}let c=[e.height,e.width],p=Float32Array.from(e.data),d=[e.height,e.width,e.channels];if(this.do_rescale&&this.rescale(p),r??this.do_normalize){let m=this.image_mean;Array.isArray(this.image_mean)||(m=new Array(e.channels).fill(m));let w=this.image_std;if(Array.isArray(this.image_std)||(w=new Array(e.channels).fill(w)),m.length!==e.channels||w.length!==e.channels)throw new Error(`When set to arrays, the length of \`image_mean\` (${m.length}) and \`image_std\` (${w.length}) must match the number of channels in the image (${e.channels}).`);for(let x=0;x<p.length;x+=e.channels)for(let E=0;E<e.channels;++E)p[x+E]=(p[x+E]-m[E])/w[E]}if(s??this.do_pad){if(this.pad_size)[p,d]=this.pad_image(p,[e.height,e.width,e.channels],this.pad_size);else if(this.size_divisibility){let m=Math.ceil(d[1]/this.size_divisibility)*this.size_divisibility,w=Math.ceil(d[0]/this.size_divisibility)*this.size_divisibility;[p,d]=this.pad_image(p,d,{width:m,height:w})}}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 m=0;m<p.length;m+=3){let w=p[m];p[m]=p[m+2],p[m+2]=w}}let _=new $("float32",p,d).permute(2,0,1);return{original_size:[l,i],reshaped_input_size:c,pixel_values:_}}async _call(e,...r){Array.isArray(e)||(e=[e]);let s=await Promise.all(e.map(o=>this.preprocess(o)));return{pixel_values:St(s.map(o=>o.pixel_values),0),original_sizes:s.map(o=>o.original_size),reshaped_input_sizes:s.map(o=>o.reshaped_input_size)}}static async from_pretrained(e,r={}){let s=await ut(e,yr,!0,r);return new this(s)}};var bn={};Zs(bn,{BeitFeatureExtractor:()=>N_,BitImageProcessor:()=>$_,CHMv2ImageProcessor:()=>D_,CLIPFeatureExtractor:()=>F_,CLIPImageProcessor:()=>Lc,ChineseCLIPFeatureExtractor:()=>R_,ConvNextFeatureExtractor:()=>B_,ConvNextImageProcessor:()=>Pc,DINOv3ViTImageProcessor:()=>G_,DPTFeatureExtractor:()=>W_,DPTImageProcessor:()=>$c,DeiTFeatureExtractor:()=>U_,DeiTImageProcessor:()=>zc,DetrFeatureExtractor:()=>j_,DetrImageProcessor:()=>Nc,DonutFeatureExtractor:()=>q_,DonutImageProcessor:()=>gn,EfficientNetImageProcessor:()=>V_,GLPNFeatureExtractor:()=>X_,Glm46VImageProcessor:()=>H_,GroundingDinoImageProcessor:()=>K_,Idefics3ImageProcessor:()=>Rc,ImageFeatureExtractor:()=>V,ImageProcessor:()=>V,JinaCLIPImageProcessor:()=>Y_,Lfm2VlImageProcessor:()=>J_,LlavaOnevisionImageProcessor:()=>Z_,Mask2FormerImageProcessor:()=>tm,MaskFormerFeatureExtractor:()=>em,MaskFormerImageProcessor:()=>wn,MobileNetV1FeatureExtractor:()=>rm,MobileNetV1ImageProcessor:()=>Dc,MobileNetV2FeatureExtractor:()=>sm,MobileNetV2ImageProcessor:()=>Fc,MobileNetV3FeatureExtractor:()=>nm,MobileNetV3ImageProcessor:()=>Bc,MobileNetV4FeatureExtractor:()=>om,MobileNetV4ImageProcessor:()=>Uc,MobileViTFeatureExtractor:()=>am,MobileViTImageProcessor:()=>jc,NougatImageProcessor:()=>im,OwlViTFeatureExtractor:()=>lm,OwlViTImageProcessor:()=>xn,Owlv2ImageProcessor:()=>cm,Phi3VImageProcessor:()=>dm,PixtralImageProcessor:()=>fm,PvtImageProcessor:()=>_m,Qwen2VLImageProcessor:()=>Do,RTDetrImageProcessor:()=>mm,Sam2ImageProcessor:()=>Fo,Sam3ImageProcessor:()=>Fo,SamImageProcessor:()=>Fo,SapiensFeatureExtractor:()=>hm,SapiensImageProcessor:()=>Gc,SegformerFeatureExtractor:()=>gm,SegformerImageProcessor:()=>qc,SiglipImageProcessor:()=>wm,SmolVLMImageProcessor:()=>Rc,Swin2SRImageProcessor:()=>xm,VLMImageProcessor:()=>Q_,ViTFeatureExtractor:()=>ym,ViTImageProcessor:()=>Wc,VitMatteImageProcessor:()=>bm,VitPoseImageProcessor:()=>vm,YolosFeatureExtractor:()=>km,YolosImageProcessor:()=>Vc});var N_=class extends V{};var $_=class extends V{};var R_=class extends V{};var D_=class extends V{};var Lc=class extends V{},F_=class extends Lc{};var Pc=class extends V{constructor(e){super(e),this.crop_pct=this.config.crop_pct??224/256}async resize(e){let r=this.size?.shortest_edge;if(r===void 0)throw new Error("Size dictionary must contain 'shortest_edge' key.");if(r<384){let s=Math.floor(r/this.crop_pct),[n,o]=this.get_resize_output_image_size(e,{shortest_edge:s});e=await e.resize(n,o,{resample:this.resample}),e=await e.center_crop(r,r)}else e=await e.resize(r,r,{resample:this.resample});return e}},B_=class extends Pc{};var zc=class extends V{},U_=class extends zc{};var Nc=class extends V{async _call(e){let r=await super._call(e),s=[r.pixel_values.dims[0],64,64],n=He(s,1n);return{...r,pixel_mask:n}}post_process_object_detection(...e){return jr(...e)}post_process_panoptic_segmentation(...e){return Ic(...e)}post_process_instance_segmentation(...e){return Cc(...e)}},j_=class extends Nc{};var G_=class extends V{};var gn=class extends V{pad_image(e,r,s,n={}){let[o,a,i]=r,l=this.image_mean;Array.isArray(this.image_mean)||(l=new Array(i).fill(l));let c=this.image_std;Array.isArray(c)||(c=new Array(i).fill(l));let p=l.map((d,_)=>-d/c[_]);return super.pad_image(e,r,s,{center:!0,constant_values:p,...n})}},q_=class extends gn{};var $c=class extends V{},W_=class extends $c{};var V_=class extends V{constructor(e){super(e),this.include_top=this.config.include_top??!0,this.include_top&&(this.image_std=this.image_std.map(r=>r*r))}};var Do=class extends V{constructor(e){super(e),this.min_pixels=e.min_pixels??e.size?.shortest_edge,this.max_pixels=e.max_pixels??e.size?.longest_edge,this.patch_size=e.patch_size,this.merge_size=e.merge_size}get_resize_output_image_size(e,r){let s=this.patch_size*this.merge_size;return hn(e.height,e.width,s,this.min_pixels,this.max_pixels)}async _call(e,...r){let{pixel_values:s,original_sizes:n,reshaped_input_sizes:o}=await super._call(e,...r),a=s,{temporal_patch_size:i,merge_size:l,patch_size:c}=this.config;a.dims[0]===1&&(a=ke(Array.from({length:i},()=>a),0));let p=a.dims[0]/i,d=a.dims[1],_=Math.floor(a.dims[2]/c),m=Math.floor(a.dims[3]/c),w=a.view(p,i,d,Math.floor(_/l),l,c,Math.floor(m/l),l,c).permute(0,3,6,4,7,2,1,5,8).view(p*_*m,d*i*c*c),x=new $("int64",[p,_,m],[1,3]);return{pixel_values:w,image_grid_thw:x,original_sizes:n,reshaped_input_sizes:o}}};var H_=class extends Do{get_resize_output_image_size(e,r){let s=this.patch_size*this.merge_size,n=this.config.temporal_patch_size??2;return hn(e.height,e.width,s,this.min_pixels,this.max_pixels,n)}};var X_=class extends V{};var K_=class extends V{async _call(e){let r=await super._call(e),s=r.pixel_values.dims,n=tt([s[0],s[2],s[3]]);return{...r,pixel_mask:n}}};var Rc=class extends V{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,r){let[s,n]=e.dims.slice(-2),o=n/s;return n>=s?(n=Math.ceil(n/r)*r,s=Math.floor(n/o),s=Math.ceil(s/r)*r):(s=Math.ceil(s/r)*r,n=Math.floor(s*o),n=Math.ceil(n/r)*r),{height:s,width:n}}async _call(e,{do_image_splitting:r=null,return_row_col_info:s=!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 o=[],a=[],i=[],l=[],c=[];for(let k of n){let A=await Promise.all(k.map(L=>this.preprocess(L)));l.push(...A.map(L=>L.original_size)),c.push(...A.map(L=>L.reshaped_input_size)),A.forEach(L=>L.pixel_values.unsqueeze_(0));let{longest_edge:T}=this.max_image_size,S;if(r??this.do_image_splitting){let L=new Array(A.length),O=new Array(A.length);S=await Promise.all(A.map(async(v,W)=>{let X=this.get_resize_for_vision_encoder(v.pixel_values,T),B=await yt(v.pixel_values,{size:[X.height,X.width]}),{frames:H,num_splits_h:G,num_splits_w:Q}=await this.split_image(B,this.max_image_size);return L[W]=G,O[W]=Q,ke(H,0)})),a.push(L),i.push(O)}else{let L=[T,T];S=await Promise.all(A.map(O=>yt(O.pixel_values,{size:L}))),a.push(new Array(A.length).fill(0)),i.push(new Array(A.length).fill(0))}o.push(ke(S,0))}let p=o.length,[d,_,m,w]=o[0].dims,x,E;if(p===1)x=o[0].unsqueeze_(0),E=He([p,d,m,w],!0);else{let k=Math.max(...o.map(S=>S.dims.at(0)));E=He([p,k,m,w],!0);let A=E.data,T=k*m*w;for(let S=0;S<p;++S){let L=o[S].dims[0];if(L<k){o[S]=ke([o[S],He([k-L,_,m,w],0)],0);let O=S*T+L*m*w,v=(S+1)*T;A.fill(!1,O,v)}}x=St(o,0)}return{pixel_values:x,pixel_attention_mask:E,original_sizes:l,reshaped_input_sizes:c,...s?{rows:a,cols:i}:{}}}async split_image(e,{longest_edge:r}){let s=r,n=r,o=[],[a,i]=e.dims.slice(-2),l=0,c=0;if(a>s||i>n){l=Math.ceil(a/s),c=Math.ceil(i/n);let p=Math.ceil(a/l),d=Math.ceil(i/c);for(let w=0;w<l;++w)for(let x=0;x<c;++x){let E,k,A,T;w===l-1?(k=a-p,T=a):(k=w*p,T=(w+1)*p),x===c-1?(E=i-d,A=i):(E=x*d,A=(x+1)*d);let O=await Ec(e,[k,E],[T,A],[2,3]);o.push(O)}let _=s,m=n;(a!==_||i!==m)&&(e=await yt(e,{size:[_,m]}))}return o.push(e),{frames:o,num_splits_h:l,num_splits_w:c}}};var Q_=class extends V{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(r=>r*this.rescale_factor)}pad_image(e,r,s,n){return super.pad_image(e,r,s,{constant_values:this.constant_values,center:!0,...n})}};var Y_=class extends V{constructor(e){let{resize_mode:r,fill_color:s,interpolation:n,size:o,...a}=e,i=r==="squash"?{width:o,height:o}:r==="shortest"?{shortest_edge:o}:{longest_edge:o},l=n==="bicubic"?3:2;super({...a,size:i,resample:l,do_center_crop:!0,crop_size:o,do_normalize:!0})}};function $2(t,e){return Math.round(t/e)*e}function Lz(t,e,r,s,n){let o=1/0,a=[1,1],i=r*s;for(let l of e){let c=Math.abs(t-l[0]/l[1]);c<o?(o=c,a=l):c===o&&i>.5*n*n*l[0]*l[1]&&(a=l)}return a}function Pz(t,e){let r=[],s=new Set;for(let n=t;n<=e;++n)for(let o=1;o<=n;++o)for(let a=1;a<=n;++a){let i=o*a;if(i>=t&&i<=e){let l=o<<16|a;s.has(l)||(s.add(l),r.push([o,a]))}}return r.sort((n,o)=>n[0]*n[1]-o[0]*o[1])}function zz(t,e){let[r,s,n,o]=t.dims,a=Math.floor(n/e),i=Math.floor(o/e),l=e*e*s,c=t.data,p=new Float32Array(r*a*i*l),d=n*o;for(let _=0;_<r;++_){let m=_*s*d,w=_*a*i*l;for(let x=0;x<a;++x)for(let E=0;E<i;++E){let k=w+(x*i+E)*l;for(let A=0;A<e;++A){let T=(x*e+A)*o+E*e;for(let S=0;S<e;++S){let L=T+S;for(let O=0;O<s;++O)p[k++]=c[m+O*d+L]}}}}return new $("float32",p,[r,a*i,l])}function Nz(t,e){let[,r,s]=t.dims,n=new BigInt64Array(e);n.fill(1n,0,r);let o=t;if(r<e){let a=new Float32Array(e*s);a.set(t.data),o=new $("float32",a,[1,e,s])}return{padded:o,mask:new $("int64",n,[e])}}var J_=class extends V{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;let r=this.max_image_tokens*this.downsample_factor**2,s=this.do_image_splitting?(this.tile_size/this.encoder_patch_size)**2:0;this.max_num_patches=Math.max(r,s)}_is_image_too_large(e,r){let s=this.encoder_patch_size*this.downsample_factor,n=Math.max(this.encoder_patch_size,$2(e,s)),o=Math.max(this.encoder_patch_size,$2(r,s));return n*o>this.max_image_tokens*(this.encoder_patch_size*this.downsample_factor)**2*this.max_pixels_tolerance}_get_grid_layout(e,r){let s=Pz(this.min_tiles,this.max_tiles),[n,o]=Lz(r/e,s,r,e,this.tile_size);return{grid_width:n,grid_height:o,target_width:this.tile_size*n,target_height:this.tile_size*o}}async _call(e,{return_row_col_info:r=null}={}){let s;Array.isArray(e)?Array.isArray(e[0])?s=e:s=[e]:s=[[e]];let n=[],o=[],a=[],i=[],l=[],c=[];for(let d of s){let _=await Promise.all(d.map(m=>this.preprocess(m,{do_pad:!1})));for(let{pixel_values:m}of _){let[,w,x]=m.dims,E=m.unsqueeze_(0),k=this.encoder_patch_size*this.downsample_factor,A=k**2,[T,S]=hn(Math.max(k,w),Math.max(k,x),k,this.min_image_tokens*A,this.max_image_tokens*A).map(B=>Math.max(k,B)),L,O=1,v=1,W=this._is_image_too_large(w,x),X=this.do_image_splitting&&!(this.min_tiles===1&&this.max_tiles===1);if(W&&X){let{grid_width:B,grid_height:H,target_width:G,target_height:Q}=this._get_grid_layout(w,x);O=H,v=B;let R=await yt(E,{size:[Q,G]});L=[];for(let C=0;C<H;++C)for(let te=0;te<B;++te){let ae=C*this.tile_size,P=te*this.tile_size;L.push(R.slice(null,null,[ae,ae+this.tile_size],[P,P+this.tile_size]))}this.use_thumbnail&&B*H!==1&&L.push(await yt(E,{size:[S,T]}))}else L=[await yt(E,{size:[S,T]})];for(let B of L){let[,,H,G]=B.dims,Q=zz(B,this.encoder_patch_size),{padded:R,mask:C}=Nz(Q,this.max_num_patches);n.push(R),o.push(C),a.push([Math.floor(H/this.encoder_patch_size),Math.floor(G/this.encoder_patch_size)])}i.push(O),l.push(v),c.push([S,T])}}let p={pixel_values:ke(n,0),pixel_attention_mask:St(o,0),spatial_shapes:new $("int64",BigInt64Array.from(a.flat(),BigInt),[a.length,2])};return(r??this.return_row_col_info)&&(p.image_rows=i,p.image_cols=l,p.image_sizes=c),p}};var Z_=class extends V{};var wn=class extends V{post_process_panoptic_segmentation(...e){return Ic(...e)}post_process_instance_segmentation(...e){return Cc(...e)}},em=class extends wn{};var tm=class extends wn{};var Dc=class extends V{},rm=class extends Dc{};var Fc=class extends V{},sm=class extends Fc{};var Bc=class extends V{},nm=class extends Bc{};var Uc=class extends V{},om=class extends Uc{};var jc=class extends V{},am=class extends jc{};var im=class extends gn{};var xn=class extends V{post_process_object_detection(...e){return jr(...e)}},lm=class extends xn{};var cm=class extends xn{};var zt=336,$z=[2,3],{ceil:um,floor:yn,sqrt:pm}=Math,dm=class extends V{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,r){let{num_img_tokens:s}=this.config;return yn((yn(r/zt)*yn(e/zt)+1)*s+1+(yn(r/zt)+1)*pm(s))}get_resize_output_image_size(e,r){let s=this._num_crops,[n,o]=e.size,a=n/o,i=1;for(;i*Math.ceil(i/a)<=s;)i+=1;i-=1;let l=Math.floor(i*336),c=Math.floor(l/a);return[l,c]}pad_image(e,r,s,n={}){let[o,a]=r,i=zt*um(o/zt),l=zt*um(a/zt),c=[1,1,1].map((p,d)=>(p-this.image_mean[d])/this.image_std[d]);return super.pad_image(e,r,{width:l,height:i},{center:!0,constant_values:c,...n})}async _call(e,{num_crops:r=null}={}){if(this._num_crops=r??=this.config.num_crops,r<4||pm(r)%1!==0)throw new Error("num_crops must be a square number >= 4");Array.isArray(e)||(e=[e]);let s=e.length,n=await Promise.all(e.map(_=>this.preprocess(_))),o=n.map(_=>_.original_size),a=n.map(_=>_.reshaped_input_size),i=[];for(let{pixel_values:_}of n){_.unsqueeze_(0);let[m,w]=_.dims.slice(-2),x=await yt(_,{size:[zt,zt],mode:"bicubic"});if(r>0){let E=[],k=pm(r),A=yn(w/k),T=yn(m/k);for(let L=0;L<k;++L)for(let O=0;O<k;++O){let v,W,X,B;L===k-1?(W=m-T,B=m):(W=L*T,B=(L+1)*T),O===k-1?(v=w-A,X=w):(v=O*A,X=(O+1)*A);let Q=await Ec(_,[W,v],[B,X],$z);E.push(Q)}let S=await yt(ke(E,0),{size:[zt,zt],mode:"bicubic"});i.push(ke([x,S],0))}else i.push(x)}let l=St(i,0),c=a.map(_=>_.map(m=>zt*um(m/zt))),p=new $("int64",c.flat(),[s,2]),d=c.map(([_,m])=>this.calc_num_image_tokens_from_image_size(m,_));return{pixel_values:l,original_sizes:o,reshaped_input_sizes:a,image_sizes:p,num_img_tokens:d}}};var fm=class extends V{get_resize_output_image_size(e,r){let{longest_edge:s}=r;if(s===void 0)throw new Error("size must contain 'longest_edge'");let[n,o]=e.size,a=Math.max(n,o)/s,i=n,l=o;a>1&&(i=Math.floor(n/a),l=Math.floor(o/a));let{patch_size:c,spatial_merge_size:p}=this.config;if(!p)throw new Error("config must contain 'spatial_merge_size'");let d=c*p,_=Math.floor((i-1)/d)+1,m=Math.floor((l-1)/d)+1;return[_*d,m*d]}};var _m=class extends V{};var mm=class extends V{post_process_object_detection(...e){return jr(...e)}};var Fo=class extends V{reshape_input_points(e,r,s,n=!1){e=structuredClone(e);let o=dd(e);if(o.length===3)n||(o=[1,...o]),e=[e];else if(o.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){let[i,l]=r[a],[c,p]=s[a],d=[p/l,c/i];for(let _=0;_<e[a].length;++_)for(let m=0;m<e[a][_].length;++m)for(let w=0;w<e[a][_][m].length;++w)e[a][_][m][w]*=d[w%2]}return new $("float32",Float32Array.from(e.flat(1/0)),o)}add_input_labels(e,r){let s=dd(e);if(s.length===2)s=[1,...s],e=[e];else if(s.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(s.some((n,o)=>n!==r.dims[o]))throw Error(`The first ${s.length} dimensions of 'input_points' and 'input_labels' must be the same.`);return new $("int64",e.flat(1/0).map(BigInt),s)}async _call(e,{input_points:r=null,input_labels:s=null,input_boxes:n=null}={}){let o=await super._call(e);if(r&&(o.input_points=this.reshape_input_points(r,o.original_sizes,o.reshaped_input_sizes)),s){if(!o.input_points)throw Error("`input_points` must be provided if `input_labels` are provided.");o.input_labels=this.add_input_labels(s,o.input_points)}return n&&(o.input_boxes=this.reshape_input_points(n,o.original_sizes,o.reshaped_input_sizes,!0)),o}async post_process_masks(e,r,s,{mask_threshold:n=0,binarize:o=!0,pad_size:a=null}={}){let i=[];a=a??this.pad_size??this.size;let l=[a.height,a.width];for(let c=0;c<r.length;++c){let p=r[c],d=s[c],_=await yt(e[c],{mode:"bilinear",size:l});if(_=_.slice(null,null,[0,d[0]],[0,d[1]]),_=await yt(_,{mode:"bilinear",size:p}),o){let m=_.data,w=new Uint8Array(m.length);for(let x=0;x<m.length;++x)m[x]>n&&(w[x]=1);_=new $("bool",w,_.dims)}i.push(_)}return i}generate_crop_boxes(e,r,{crop_n_layers:s=0,overlap_ratio:n=512/1500,points_per_crop:o=32,crop_n_points_downscale_factor:a=1}={}){}};var Gc=class extends V{post_process_semantic_segmentation(...e){return Oc(...e)}},hm=class extends Gc{};var qc=class extends V{post_process_semantic_segmentation(...e){return Oc(...e)}},gm=class extends qc{};var wm=class extends V{};var xm=class extends V{pad_image(e,r,s,n={}){let[o,a,i]=r;return super.pad_image(e,r,{width:a+(s-a%s)%s,height:o+(s-o%s)%s},{mode:"symmetric",center:!1,constant_values:-1,...n})}};var Wc=class extends V{},ym=class extends Wc{};var bm=class extends V{async _call(e,r){Array.isArray(e)||(e=[e]),Array.isArray(r)||(r=[r]);let s=await Promise.all(e.map(a=>this.preprocess(a))),n=await Promise.all(r.map(a=>this.preprocess(a,{do_normalize:!1,do_convert_rgb:!1,do_convert_grayscale:!0})));return{pixel_values:St(s.map((a,i)=>ke([a.pixel_values,n[i].pixel_values],0)),0),original_sizes:s.map(a=>a.original_size),reshaped_input_sizes:s.map(a=>a.reshaped_input_size)}}};var vm=class extends V{post_process_pose_estimation(e,r,{threshold:s=null}={}){let n=e.tolist(),[o,a,i,l]=e.dims,c=[];for(let p=0;p<o;++p){let d=n[p],_=r[p],m=[];for(let w=0;w<_.length;++w){let x=_[w],E=[],k=[],A=[],T=x.at(-2)/l,S=x.at(-1)/i;for(let L=0;L<d.length;++L){let[O,v]=[0,0],W=0,X=-1/0,B=d[L];for(let G=0;G<B.length;++G){let Q=B[G];for(let R=0;R<Q.length;++R){let C=Q[R];W+=C,X=Math.max(X,C),O+=(R+.5)*C,v+=G*C}}if(s!=null&&X<s)continue;let H=[T*O/W,S*v/W];E.push(H),A.push(L),k.push(X)}m.push({bbox:x,scores:k,labels:A,keypoints:E})}c.push(m)}return c}};var Vc=class extends V{post_process_object_detection(...e){return jr(...e)}},km=class extends Vc{};var Ce=class{static async from_pretrained(e,r={}){let s=await ut(e,yr,!0,r),n=s.image_processor_type??s.feature_extractor_type,o=bn[n?.replace(/Fast$/,"")];return o||(n!==void 0&&Z.warn(`Image processor type '${n}' not found, assuming base ImageProcessor. Please report this at ${Br}.`),o=V),new o(s)}};var Em=class extends re{static tokenizer_class=oe;static image_processor_class=Ce;constructor(e,r,s){super(e,r,s);let{tasks_answer_post_processing_type:n,task_prompts_without_inputs:o,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(o??{})),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]);let r=[];for(let s of e)if(this.task_prompts_without_inputs.has(s))r.push(this.task_prompts_without_inputs.get(s));else{for(let[n,o]of this.task_prompts_with_input)if(s.includes(n)){r.push(o.replaceAll("{input}",s).replaceAll(n,""));break}r.length!==e.length&&r.push(s)}return r}post_process_generation(e,r,s){let n=this.tasks_answer_post_processing_type.get(r)??"pure_text";e=e.replaceAll("<s>","").replaceAll("</s>","");let o;switch(n){case"pure_text":o=e;break;case"description_with_bboxes":case"bboxes":case"phrase_grounding":case"ocr":let a=n==="ocr"?"quad_boxes":"bboxes",i=e.matchAll(this.regexes[a]),l=[],c=[];for(let[p,d,..._]of i)l.push(d?d.trim():l.at(-1)??""),c.push(_.map((m,w)=>(Number(m)+.5)/this.size_per_bin*s[w%2]));o={labels:l,[a]:c};break;default:throw new Error(`Task "${r}" (of type "${n}") not yet implemented.`)}return{[r]:o}}async _call(e,r=null,s={}){if(!e&&!r)throw new Error("Either text or images must be provided");let n=await this.image_processor(e,s),o=r?this.tokenizer(this.construct_prompts(r),s):{};return{...n,...o}}};var Am=class extends re{static image_processor_class=Ce;static feature_extractor_class=Xe;static tokenizer_class=oe;static uses_processor_config=!0;static uses_chat_template_file=!0;constructor(e,r,s){super(e,r,s),this.audio_seq_length=this.config.audio_seq_length,this.image_seq_length=this.config.image_seq_length;let{audio_token_id:n,boa_token:o,audio_token:a,eoa_token:i,image_token_id:l,boi_token:c,image_token:p,eoi_token:d}=this.tokenizer.config;this.audio_token_id=n,this.boa_token=o,this.audio_token=a;let _=a.repeat(this.audio_seq_length);this.full_audio_sequence=`
14
14
 
15
15
  ${o}${_}${i}
16
16
 
17
17
  `,this.image_token_id=l,this.boi_token=c,this.image_token=p;let m=p.repeat(this.image_seq_length);this.full_image_sequence=`
18
18
 
19
- ${c}${m}${f}
19
+ ${c}${m}${d}
20
20
 
21
- `}async _call(e,r=null,s=null,n={}){typeof e=="string"&&(e=[e]);let o;s&&(o=await this.feature_extractor(s,n),e=e.map(l=>l.replaceAll(this.audio_token,this.full_audio_sequence)));let a;return r&&(a=await this.image_processor(r,n),e=e.map(l=>l.replaceAll(this.image_token,this.full_image_sequence))),{...this.tokenizer(e,n),...a,...o}}};var wm=class extends re{static tokenizer_class=oe;static feature_extractor_class=Ke;static uses_processor_config=!0;_get_num_audio_features(e){let{hop_length:r}=this.feature_extractor.config.melspec_kwargs,{projector_window_size:s,projector_downsample_rate:n}=this.feature_extractor.config,o=Math.floor(s/n),a=Math.floor(e/r)+1,i=Math.floor(a/2);return Math.ceil(i/s)*o}async _call(e,r=null,s={}){if(Array.isArray(e))throw new Error("Batched inputs are not supported yet.");let n={};if(r){let{input_features:a}=await this.feature_extractor(r);n.input_features=a;let i=this._get_num_audio_features(r.length),l=new Uint8Array(i).fill(1);n.input_features_mask=new $("bool",l,[1,i]);let c=this.config.audio_token??"<|audio|>";if(!e.includes(c))throw new Error(`The input text does not contain the audio token ${c}.`);e=e.replaceAll(c,c.repeat(i))}return{...this.tokenizer(e,{add_special_tokens:!1,...s}),...n}}};function uz(t,e){let s=t.dims.at(-1)-1,n=t.tolist();n.fill(!1,0,1),n.fill(!1,s);let o=e.tolist();return n.map((a,i)=>a?i:null).filter(a=>a!==null).map(a=>o[a])}var xm=class extends re{static tokenizer_class=oe;static image_processor_class=Pe;async _call(e,r,s={}){let n=e?await this.image_processor(e,s):{};return{...r?this.tokenizer(r,s):{},...n}}post_process_grounded_object_detection(e,r,{box_threshold:s=.25,text_threshold:n=.25,target_sizes:o=null}={}){let{logits:a,pred_boxes:i}=e,l=a.dims[0];if(o!==null&&o.length!==l)throw Error("Make sure that you pass in as many target sizes as the batch dimension of the logits");let c=a.dims.at(1),p=a.sigmoid(),f=p.max(-1).tolist(),_=i.tolist().map(w=>w.map(x=>S_(x))),m=[];for(let w=0;w<l;++w){let x=o!==null?o[w]:null;x!==null&&(_[w]=_[w].map(S=>S.map((P,O)=>P*x[(O+1)%2])));let k=f[w],E=[],A=[],T=[];for(let S=0;S<c;++S){let P=k[S];if(P<=s)continue;let O=_[w][S],v=p[w][S];E.push(P),T.push(O);let j=uz(v.gt(n),r[w]);A.push(j)}m.push({scores:E,boxes:T,labels:this.batch_decode(A)})}return m}};function pz(t,e,r,s,n,o){let a="";for(let i=0;i<e;++i){for(let l=0;l<r;++l)a+=s+`<row_${i+1}_col_${l+1}>`+n.repeat(t);a+=`
21
+ `}async _call(e,r=null,s=null,n={}){typeof e=="string"&&(e=[e]);let o;s&&(o=await this.feature_extractor(s,n),e=e.map(l=>l.replaceAll(this.audio_token,this.full_audio_sequence)));let a;return r&&(a=await this.image_processor(r,n),e=e.map(l=>l.replaceAll(this.image_token,this.full_image_sequence))),{...this.tokenizer(e,n),...a,...o}}};var Es=class extends re{static image_processor_class=Ce;static tokenizer_class=oe;static image_token="<|image_pad|>";async _call(e,r=null,...s){Array.isArray(e)||(e=[e]);let n,o;if(r&&(n=await this.image_processor(r),o=n.image_grid_thw),o){let i=this.image_processor.config.merge_size**2,l=0,c=this.constructor.image_token,p=o.tolist();e=e.map(d=>{for(;d.includes(c);){let _=Number(p[l++].reduce((m,w)=>m*w,1n));d=d.replace(c,"<|placeholder|>".repeat(Math.floor(_/i)))}return d.replaceAll("<|placeholder|>",c)})}return{...this.tokenizer(e),...n}}};var Mm=class extends Es{static image_token="<|image|>"};var Sm=class extends re{static tokenizer_class=oe;static feature_extractor_class=Xe;static uses_processor_config=!0;_get_num_audio_features(e){let{hop_length:r}=this.feature_extractor.config.melspec_kwargs,{projector_window_size:s,projector_downsample_rate:n}=this.feature_extractor.config,o=Math.floor(s/n),a=Math.floor(e/r)+1,i=Math.floor(a/2);return Math.ceil(i/s)*o}async _call(e,r=null,s={}){if(Array.isArray(e))throw new Error("Batched inputs are not supported yet.");let n={};if(r){let{input_features:a}=await this.feature_extractor(r);n.input_features=a;let i=this._get_num_audio_features(r.length),l=new Uint8Array(i).fill(1);n.input_features_mask=new $("bool",l,[1,i]);let c=this.config.audio_token??"<|audio|>";if(!e.includes(c))throw new Error(`The input text does not contain the audio token ${c}.`);e=e.replaceAll(c,c.repeat(i))}return{...this.tokenizer(e,{add_special_tokens:!1,...s}),...n}}};function Rz(t,e){let s=t.dims.at(-1)-1,n=t.tolist();n.fill(!1,0,1),n.fill(!1,s);let o=e.tolist();return n.map((a,i)=>a?i:null).filter(a=>a!==null).map(a=>o[a])}var Tm=class extends re{static tokenizer_class=oe;static image_processor_class=Ce;async _call(e,r,s={}){let n=e?await this.image_processor(e,s):{};return{...r?this.tokenizer(r,s):{},...n}}post_process_grounded_object_detection(e,r,{box_threshold:s=.25,text_threshold:n=.25,target_sizes:o=null}={}){let{logits:a,pred_boxes:i}=e,l=a.dims[0];if(o!==null&&o.length!==l)throw Error("Make sure that you pass in as many target sizes as the batch dimension of the logits");let c=a.dims.at(1),p=a.sigmoid(),d=p.max(-1).tolist(),_=i.tolist().map(w=>w.map(x=>z_(x))),m=[];for(let w=0;w<l;++w){let x=o!==null?o[w]:null;x!==null&&(_[w]=_[w].map(S=>S.map((L,O)=>L*x[(O+1)%2])));let E=d[w],k=[],A=[],T=[];for(let S=0;S<c;++S){let L=E[S];if(L<=s)continue;let O=_[w][S],v=p[w][S];k.push(L),T.push(O);let W=Rz(v.gt(n),r[w]);A.push(W)}m.push({scores:k,boxes:T,labels:this.batch_decode(A)})}return m}};function Dz(t,e,r,s,n,o){let a="";for(let i=0;i<e;++i){for(let l=0;l<r;++l)a+=s+`<row_${i+1}_col_${l+1}>`+n.repeat(t);a+=`
22
22
  `}return a+=`
23
- ${s}${o}`+n.repeat(t)+`${s}`,a}function dz(t,e,r,s){return`${e}${s}`+r.repeat(t)+`${e}`}function fz(t,e,r,s,n,o){return t===0&&e===0?dz(r,s,n,o):pz(r,t,e,s,n,o)}var Bc=class extends re{static image_processor_class=Pe;static tokenizer_class=oe;static uses_processor_config=!0;fake_image_token="<fake_token_around_image>";image_token="<image>";global_img_token="<global-img>";async _call(e,r=null,s={}){s.return_row_col_info??=!0;let n;r&&(n=await this.image_processor(r,s)),Array.isArray(e)||(e=[e]);let o=n.rows??[new Array(e.length).fill(0)],a=n.cols??[new Array(e.length).fill(0)],i=this.config.image_seq_len,l=[],c=[];for(let f=0;f<e.length;++f){let _=e[f],m=o[f],w=a[f];l.push(xk(_,this.image_token));let x=m.map((A,T)=>fz(A,w[T],i,this.fake_image_token,this.image_token,this.global_img_token)),k=_.split(this.image_token);if(k.length===0)throw new Error("The image token should be present in the text.");let E=k[0];for(let A=0;A<x.length;++A)E+=x[A]+k[A+1];c.push(E)}return{...this.tokenizer(c),...n}}};var ym=class extends re{static image_processor_class=Pe;static tokenizer_class=oe;static uses_processor_config=!0;constructor(e,r,s){super(e,r,s),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:r=null,chat_template:s="default"}={}){r?Array.isArray(r)||(r=[r]):r=await Promise.all(e.filter(k=>k.images).flatMap(k=>k.images).map(k=>Ye.read(k)));let n=this.tokenizer,o=n.apply_chat_template(e,{tokenize:!1,add_generation_prompt:!0,chat_template:s}),a=k=>n.encode(k,{add_special_tokens:!1}),i=o.split(this.image_tag),l=i.length-1;if(r.length!==l)throw new Error(`Number of images provided (${r.length}) does not match number of "${this.image_tag}" image tags (${l})`);let[c,p,f]=n.convert_tokens_to_ids([this.image_tag,this.image_start_tag,this.image_end_tag]),_=a(i[0]),m=new Array(_.length).fill(!1);for(let k=1;k<i.length;++k){let E=new Array(this.num_image_tokens).fill(c),A=a(i[k]);_=wt(_,[p],E,[f],A);let T=new Array(this.num_image_tokens).fill(!0);m=wt(m,[!1],T,[!1],new Array(A.length).fill(!1))}let w=[1,_.length],x={input_ids:new $("int64",_,w),attention_mask:new $("int64",new Array(_.length).fill(1),w),images_seq_mask:new $("bool",m,w),images_emb_mask:new $("bool",new Array(l*this.num_image_tokens).fill(!0),[1,l,this.num_image_tokens])};if(r&&r.length>0){let k=await this.image_processor(r);return k.pixel_values.unsqueeze_(0),{...x,...k}}return x}};var bm=class extends re{static tokenizer_class=oe;static image_processor_class=Pe;async _call(e=null,r=null,s={}){if(!e&&!r)throw new Error("Either text or images must be provided");let n=e?this.tokenizer(e,s):{},o=r?await this.image_processor(r,s):{};return{...n,...o}}};var vm=class extends re{static tokenizer_class=oe;static image_processor_class=Pe;async _call(e,r=null,s={}){let{image_rows:n,image_cols:o,image_sizes:a,...i}=await this.image_processor(e,{...s,return_row_col_info:!0});if(r){let l=this.config.image_token??"<image>",{tile_size:c=512,downsample_factor:p=2,encoder_patch_size:f=16,use_thumbnail:_=!0}=this.image_processor.config,m=T=>Math.ceil(Math.floor(T/f)/p),w=m(c)**2,x=this.config.image_start_token??"<|image_start|>",k=this.config.image_end_token??"<|image_end|>",E=this.config.image_thumbnail??"<|img_thumbnail|>";Array.isArray(r)||(r=[r]);let A=0;r=r.map(T=>{let S=T.split(l);return S[0]+S.slice(1).map(P=>{let O=A++,[v,j]=a[O],H=n[O],B=o[O],V=m(v)*m(j),q=x;if(H>1||B>1){let Q=l.repeat(w);for(let F=0;F<H;++F)for(let C=0;C<B;++C)q+=`<|img_row_${F+1}_col_${C+1}|>`+Q;_&&(q+=E+l.repeat(V))}else q+=l.repeat(V);return q+k+P}).join("")})}return{...i,...r?this.tokenizer(r,s):{}}}};var km=class extends re{static tokenizer_class=oe;static image_processor_class=Pe;static uses_processor_config=!0;async _call(e,r=null,s={}){let n=await this.image_processor(e,s);if(r){let[a,i]=n.pixel_values.dims.slice(-2),{image_token:l,patch_size:c,num_additional_image_tokens:p}=this.config,f=Math.floor(a/c)*Math.floor(i/c)+p;r=structuredClone(r),Array.isArray(r)||(r=[r]);for(let _=0;_<r.length;++_)r[_]=r[_].replace(l,l.repeat(f))}let o=r?this.tokenizer(r,s):{};return{...n,...o}}};var u2={char:["char_decode",1],bpe:["bpe_decode",2],wp:["wp_decode",102]},Em=class extends re{static tokenizer_class=oe;static image_processor_class=Pe;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,r){if(!u2.hasOwnProperty(r))throw new Error(`Format ${r} is not supported.`);let[s,n]=u2[r],o=this[s].bind(this),[a,i]=e.dims,l=[],c=[],p=e.tolist();for(let _=0;_<a;++_){let m=p[_],w=[],x=[];for(let E=1;E<i;++E){let[A,T]=Ce($e(m[E]));if(x.push(A),T==n)break;w.push(T)}let k=x.length>0?x.reduce((E,A)=>E*A,1):0;c.push(w),l.push(k)}return[o(c),l]}char_decode(e){return this.char_tokenizer.batch_decode(e).map(r=>r.replaceAll(" ",""))}bpe_decode(e){return this.bpe_tokenizer.batch_decode(e)}wp_decode(e){return this.wp_tokenizer.batch_decode(e).map(r=>r.replaceAll(" ",""))}batch_decode([e,r,s]){let[n,o]=this._decode_helper(e,"char"),[a,i]=this._decode_helper(r,"bpe"),[l,c]=this._decode_helper(s,"wp"),p=[],f=[];for(let _=0;_<n.length;++_){let[m,w]=Ce([o[_],i[_],c[_]]);p.push([n[_],a[_],l[_]][w]),f.push(m)}return{generated_text:p,scores:f,char_preds:n,bpe_preds:a,wp_preds:l}}static async from_pretrained(...e){let r=await super.from_pretrained(...e),s=await oe.from_pretrained("Xenova/gpt2"),n=await oe.from_pretrained("Xenova/bert-base-uncased");return r.components={image_processor:r.image_processor,char_tokenizer:r.tokenizer,bpe_tokenizer:s,wp_tokenizer:n},r}async _call(e,r=null){let s=await this.image_processor(e);return r&&(s.labels=this.tokenizer(r).input_ids),s}};var Am=class extends re{static tokenizer_class=oe;static feature_extractor_class=Ke;async _call(e){return await this.feature_extractor(e)}};var Mm=class extends re{static tokenizer_class=oe;static image_processor_class=Pe};var xn="<image>";function _z(t,e,r,s,n){return`${s.repeat(r*n)}${e}${t}
24
- `}var Sm=class extends re{static tokenizer_class=oe;static image_processor_class=Pe;static uses_processor_config=!1;async _call(e,r=null,s={}){r||(Z.warn("You are using PaliGemma without a text prefix. It will perform as a picture-captioning model."),r=""),Array.isArray(e)||(e=[e]),Array.isArray(r)||(r=[r]);let n=this.tokenizer.bos_token,o=this.image_processor.config.image_seq_length,a;r.some(c=>c.includes(xn))?a=r.map(c=>{let p=c.replaceAll(xn,xn.repeat(o)),f=p.lastIndexOf(xn),_=f===-1?0:f+xn.length;return p.slice(0,_)+n+p.slice(_)+`
25
- `}):(Z.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=r.map(c=>_z(c,n,o,xn,e.length)));let i=this.tokenizer(a,s);return{...await this.image_processor(e,s),...i}}};var p2="<|image|>",mz=/<\|image_\d+\|>/g,Tm=class extends re{static image_processor_class=Pe;static tokenizer_class=oe;async _call(e,r=null,{padding:s=!0,truncation:n=!0,num_crops:o=null}={}){Array.isArray(e)||(e=[e]);let a,i;if(r){i=await this.image_processor(r,{num_crops:o});let{num_img_tokens:l}=i,c=e.map((f,_)=>f.split(mz).join(p2.repeat(l[_])));a=this.tokenizer(c,{padding:s,truncation:n});let p=this.tokenizer._tokenizer.token_to_id(p2);a.input_ids.map_(f=>f==p?-f:f)}else a=this.tokenizer(e);return{...a,...i}}};var Om=class extends re{static tokenizer_class=oe;static image_processor_class=Pe;static uses_processor_config=!0;async _call(e,r=null,s={}){let n=await this.image_processor(e,s);if(r){let[a,i]=n.pixel_values.dims.slice(-2),{image_token:l,image_break_token:c,image_end_token:p,patch_size:f,spatial_merge_size:_}=this.config,m=f*_,w=Math.floor(a/m),x=Math.floor(i/m);r=structuredClone(r),Array.isArray(r)||(r=[r]);for(let k=0;k<r.length;++k){let E=l.repeat(x),A=E+c,T=E+p,S=A.repeat(w-1)+T;r[k]=r[k].replace(l,S)}}let o=r?this.tokenizer(r,s):{};return{...n,...o}}};var Im=class extends re{static feature_extractor_class=Lo;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}};var No=class extends re{static image_processor_class=Pe;static tokenizer_class=oe;async _call(e,r=null,...s){Array.isArray(e)||(e=[e]);let n,o;if(r&&(n=await this.image_processor(r),o=n.image_grid_thw),o){let i=this.image_processor.config.merge_size**2,l=0,c=o.tolist();e=e.map(p=>{for(;p.includes("<|image_pad|>");){let f=Number(c[l++].reduce((_,m)=>_*m,1n));p=p.replace("<|image_pad|>","<|placeholder|>".repeat(Math.floor(f/i)))}return p.replaceAll("<|placeholder|>","<|image_pad|>")})}return{...this.tokenizer(e),...n}}};var $o=class extends No{};var Cm=class extends $o{};var Ro=class extends re{static image_processor_class=Pe;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)}};var Uc=class extends Ro{},Lm=class extends Uc{};var Pm=class extends re{static tokenizer_class=oe;static feature_extractor_class=Ke;async _call(e){return await this.feature_extractor(e)}};var zm=class extends re{static tokenizer_class=oe;static feature_extractor_class=Ke;static uses_processor_config=!0;async _call(e,r=null,s={}){if(Array.isArray(e))throw new Error("Batched inputs are not supported yet.");let n={};if(r){let a=r.length,{input_features:i}=await this.feature_extractor(r,{...s,max_length:a}),l=Math.round(a/this.config.encoder_ds_factor+1e-4),c=1+Math.ceil(l/this.config.stack_factor);n.audio_token_len=[c],n.audio_values=i;let p=this.config.audio_placeholder;if(!e.includes(p))throw new Error(`The input text does not contain the image token ${p}.`);e=e.replaceAll(p,p.repeat(c))}return{...this.tokenizer(e,{add_special_tokens:!1,...s}),...n}}};var jc="[AUDIO]",hz="[BEGIN_AUDIO]",gz=375;function wz(t,e){let r=[];for(let s=0;s<t.length;s+=e)r.push(t.subarray(s,Math.min(s+e,t.length)));return r}var Nm=class extends re{static tokenizer_class=oe;static feature_extractor_class=Ke;static uses_processor_config=!1;async _call(e,r=null,s={}){if(Array.isArray(e))throw new Error("Batched inputs are not supported yet.");let n={};if(r){if(!e.includes(jc))throw new Error(`The input text does not contain the audio token ${jc}.`);Array.isArray(r)||(r=[r]);let a=e.split(jc),i=a.length-1;if(i!==r.length)throw new Error(`The number of audio inputs (${r.length}) does not match the number of audio tokens in the text (${i}).`);let l=this.feature_extractor.config.n_samples,c=r.map(w=>wz(w,l)),p=c.map(w=>w.length),f=c.flat(),_=(await Promise.all(f.map(w=>this.feature_extractor(w,s)))).map(w=>w.input_features);n.audio_values=_.length>1?Ee(_,0):_[0];let m=a[0];for(let w=0;w<p.length;++w){m+=hz;for(let x=0;x<p[w];++x)m+=jc.repeat(gz);m+=a[w+1]}e=m}return{...this.tokenizer(e,{add_special_tokens:!1,...s}),...n}}};var d2=32,$m=6,Gc=8,xz=10,yz=32,Rm=class extends re{static tokenizer_class=oe;static feature_extractor_class=Ke;static uses_processor_config=!1;get num_mel_frames_first_audio_chunk(){return($m+1)*Gc}get num_samples_first_audio_chunk(){let{hop_length:e,n_fft:r}=this.feature_extractor.config;return(this.num_mel_frames_first_audio_chunk-1)*e+Math.floor(r/2)}get num_samples_per_audio_chunk(){let{hop_length:e,n_fft:r}=this.feature_extractor.config;return Gc*e+r}get num_right_pad_tokens(){return $m+1+xz}get audio_length_per_tok(){return Gc}get raw_audio_length_per_tok(){return Gc*this.feature_extractor.config.hop_length}async _call(e,{is_streaming:r=!1,is_first_audio_chunk:s=!0}={}){if(Fe(e,"VoxtralRealtimeProcessor"),!r&&!s)throw new Error("In non-streaming mode (`is_streaming=false`), `is_first_audio_chunk` must be `true`.");if(s)if(r){let n=d2*this.raw_audio_length_per_tok,o=new Float32Array(n+e.length);o.set(e,n);let a=await this.feature_extractor(o,{center:!0}),l=1+(d2+$m),c=new BigInt64Array(l).fill(BigInt(yz));return c[0]=1n,{input_ids:new $("int64",c,[1,l]),...a}}else{let n=this.num_right_pad_tokens*this.raw_audio_length_per_tok,o=new Float32Array(e.length+n);return o.set(e),await this.feature_extractor(o,{center:!0})}else return await this.feature_extractor(e,{center:!1})}};var Dm=class extends re{static tokenizer_class=oe;static feature_extractor_class=Ke;async _call(e){return await this.feature_extractor(e)}};var Fm=class extends re{static tokenizer_class=oe;static feature_extractor_class=Ke;async _call(e){return await this.feature_extractor(e)}};var Bm=class extends re{static tokenizer_class=oe;static feature_extractor_class=Ke;async _call(e){return await this.feature_extractor(e)}};var Wc=class{static async from_pretrained(e,r={}){let s=await ft(e,vr,!0,r),{image_processor_type:n,feature_extractor_type:o,processor_class:a}=s;if(a&&qc[a])return qc[a].from_pretrained(e,r);if(!n&&!o)throw new Error("No `image_processor_type` or `feature_extractor_type` found in the config.");let i={};if(n){let c=wn[n.replace(/Fast$/,"")];if(!c)throw new Error(`Unknown image_processor_type: '${n}'.`);i.image_processor=new c(s)}if(o){let c=wn[o];if(c)i.image_processor=new c(s);else{let p=Po[o];if(!p)throw new Error(`Unknown feature_extractor_type: '${o}'.`);i.feature_extractor=new p(s)}}let l={};return new re(l,i,null)}};async function bz(t,e){return await ft(t,"config.json",!0,e)}function yn(t){let e={},r={};switch(t.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"lfm2_vl":case"chatterbox":case"mistral3":case"qwen2_5_vl":case"qwen3_vl":case"qwen3_vl_moe":r=yn(t.text_config);break;case"moondream1":r=yn(t.phi_config);break;case"musicgen":r=yn(t.decoder);break;case"multi_modality":r=yn(t.language_config);break;case"gpt2":case"gptj":case"jais":case"codegen":case"gpt_bigcode":e.num_heads="n_head",e.num_layers="n_layer",e.hidden_size="n_embd";break;case"gpt_neox":case"stablelm":case"opt":case"falcon":case"modernbert-decoder":e.num_heads="num_attention_heads",e.num_layers="num_hidden_layers",e.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":e.num_heads="num_key_value_heads",e.num_layers="num_hidden_layers",e.hidden_size="hidden_size",e.num_attention_heads="num_attention_heads",e.dim_kv="head_dim";break;case"qwen3":case"gemma":case"gemma2":case"vaultgemma":case"gemma3_text":case"gemma3n_text":case"glm":case"helium":case"ernie4_5":case"hunyuan_v1_dense":case"falcon_h1":case"ministral":case"ministral3":e.num_heads="num_key_value_heads",e.num_layers="num_hidden_layers",e.dim_kv="head_dim";break;case"openelm":e.num_heads="num_kv_heads",e.num_layers="num_transformer_layers",e.dim_kv="head_dim";break;case"gpt_neo":case"donut-swin":e.num_heads="num_heads",e.num_layers="num_layers",e.hidden_size="hidden_size";break;case"bloom":e.num_heads="n_head",e.num_layers="n_layer",e.hidden_size="hidden_size";break;case"mpt":e.num_heads="n_heads",e.num_layers="n_layers",e.hidden_size="d_model";break;case"exaone":e.num_heads="num_key_value_heads",e.num_layers="num_layers",e.dim_kv="head_dim",e.num_attention_heads="num_attention_heads";break;case"youtu":e.num_heads="num_key_value_heads",e.num_layers="num_hidden_layers",e.dim_kv="qk_head_dim",e.num_attention_heads="num_attention_heads";break;case"t5":case"mt5":case"longt5":e.num_decoder_layers="num_decoder_layers",e.num_decoder_heads="num_heads",e.decoder_dim_kv="d_kv",e.num_encoder_layers="num_layers",e.num_encoder_heads="num_heads",e.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":e.num_decoder_layers="decoder_layers",e.num_decoder_heads="decoder_attention_heads",e.decoder_hidden_size="d_model",e.num_encoder_layers="encoder_layers",e.num_encoder_heads="encoder_attention_heads",e.encoder_hidden_size="d_model";break;case"speecht5":e.num_decoder_layers="decoder_layers",e.num_decoder_heads="decoder_attention_heads",e.decoder_hidden_size="hidden_size",e.num_encoder_layers="encoder_layers",e.num_encoder_heads="encoder_attention_heads",e.encoder_hidden_size="hidden_size";break;case"trocr":e.num_encoder_layers=e.num_decoder_layers="decoder_layers",e.num_encoder_heads=e.num_decoder_heads="decoder_attention_heads",e.encoder_hidden_size=e.decoder_hidden_size="d_model";break;case"musicgen_decoder":e.num_encoder_layers=e.num_decoder_layers="num_hidden_layers",e.num_encoder_heads=e.num_decoder_heads="num_attention_heads",e.encoder_hidden_size=e.decoder_hidden_size="hidden_size";break;case"moonshine":e.num_decoder_layers="decoder_num_hidden_layers",e.num_decoder_heads="decoder_num_key_value_heads",e.num_encoder_layers="encoder_num_hidden_layers",e.num_encoder_heads="encoder_num_key_value_heads",e.encoder_hidden_size=e.decoder_hidden_size="hidden_size";break;case"vision-encoder-decoder":let n=yn(t.decoder),o="num_decoder_layers"in n,a=Qe(t,["model_type","is_encoder_decoder"]);return o?(a.num_decoder_layers=n.num_decoder_layers,a.num_decoder_heads=n.num_decoder_heads,a.decoder_hidden_size=n.decoder_hidden_size,a.num_encoder_layers=n.num_encoder_layers,a.num_encoder_heads=n.num_encoder_heads,a.encoder_hidden_size=n.encoder_hidden_size):(a.num_layers=n.num_layers,a.num_heads=n.num_heads,a.hidden_size=n.hidden_size),a}let s={...r,...Qe(t,["model_type","multi_query","is_encoder_decoder"])};for(let n in e)s[n]=t[e[n]];return s}function Ss(t,e){if(t instanceof bn||(t=new bn(t)),["lfm2","lfm2_moe"].includes(t.model_type)){let r=e?.prefix??"past_key_values",s=r==="present"?"present":"past",n={},{layer_types:o,num_attention_heads:a,num_key_value_heads:i,hidden_size:l,conv_L_cache:c}=t,p=l/a,f=e?.batch_size??1;for(let _=0;_<o.length;++_)if(o[_]==="full_attention")for(let m of["key","value"])n[`${r}.${_}.${m}`]=[f,i,0,p];else if(o[_]==="conv")n[`${s}_conv.${_}`]=[f,l,c];else throw new Error(`Unsupported layer type: ${o[_]}`);return n}else if(["granitemoehybrid","falcon_h1"].includes(t.model_type)){let r=e?.prefix??"past_key_values",s=r==="present"?"present":"past",n={},{layer_types:o,num_hidden_layers:a,num_attention_heads:i,num_key_value_heads:l,hidden_size:c,mamba_d_conv:p,mamba_n_heads:f,mamba_d_head:_,mamba_d_state:m,mamba_n_groups:w,mamba_expand:x,mamba_d_ssm:k}=t,E=c/i,A=e?.batch_size??1,T=(k??x*c)+2*w*m;for(let S=0;S<a;++S)if((!o||o[S]==="mamba")&&(n[`${s}_conv.${S}`]=[A,T,p],n[`${s}_ssm.${S}`]=[A,f,_,m]),!o||o[S]==="attention")for(let P of["key","value"])n[`${r}.${S}.${P}`]=[A,l,0,E];return n}else if(["qwen3_next","qwen3_5_text","qwen3_5_moe_text","olmo_hybrid"].includes(t.model_type)){let r=e?.prefix??"past_key_values",s=r==="present"?"present":"past",n={},{head_dim:o,layer_types:a,num_attention_heads:i,num_key_value_heads:l,hidden_size:c,linear_num_value_heads:p,linear_num_key_heads:f,linear_key_head_dim:_,linear_value_head_dim:m,linear_conv_kernel_dim:w}=t,x=_*f,k=m*p,E=o??c/i,A=e?.batch_size??1;for(let T=0;T<a.length;++T)if(a[T]==="full_attention")for(let S of["key","value"])n[`${r}.${T}.${S}`]=[A,l,0,E];else if(a[T]==="linear_attention"){if(t.model_type==="olmo_hybrid")n[`${s}_conv.${T}.key`]=[A,x,w],n[`${s}_conv.${T}.value`]=[A,k,w],n[`${s}_conv.${T}.query`]=[A,x,w];else{let S=x*2+k;n[`${s}_conv.${T}`]=[A,S,w]}n[`${s}_recurrent.${T}`]=[A,p,_,m]}else throw new Error(`Unsupported layer type: ${a[T]}`);return n}else if(["lfm2_vl","qwen3_5","qwen3_5_moe","voxtral_realtime"].includes(t.model_type)){let r;return t.model_type==="voxtral_realtime"&&e?.session_name==="audio_encoder"?r=t.audio_config:r=t.text_config,Ss(r,e)}return vz(t,e)}function vz(t,{prefix:e="past_key_values",batch_size:r=1}={}){let s={},n=t.normalized_config;if(n.is_encoder_decoder&&"num_encoder_heads"in n&&"num_decoder_heads"in n){let o=n.encoder_dim_kv??n.encoder_hidden_size/n.num_encoder_heads,a=n.decoder_dim_kv??n.decoder_hidden_size/n.num_decoder_heads,i=[r,n.num_encoder_heads,0,o],l=[r,n.num_decoder_heads,0,a];for(let c=0;c<n.num_decoder_layers;++c)s[`${e}.${c}.encoder.key`]=i,s[`${e}.${c}.encoder.value`]=i,s[`${e}.${c}.decoder.key`]=l,s[`${e}.${c}.decoder.value`]=l}else{let o=n.num_heads,a=n.num_layers,i=n.dim_kv??n.hidden_size/(n.num_attention_heads??o);if(n.model_type==="falcon"){let l=[r*o,0,i];for(let c=0;c<a;++c)s[`${e}.${c}.key`]=l,s[`${e}.${c}.value`]=l}else if(n.multi_query){let l=[r*o,0,2*i];for(let c=0;c<a;++c)s[`${e}.${c}.key_value`]=l}else if(n.model_type==="bloom"){let l=[r*o,i,0],c=[r*o,0,i];for(let p=0;p<a;++p)s[`${e}.${p}.key`]=l,s[`${e}.${p}.value`]=c}else if(n.model_type==="openelm")for(let l=0;l<a;++l){let c=[r,o[l],0,i];s[`${e}.${l}.key`]=c,s[`${e}.${l}.value`]=c}else{let l=[r,o,0,i];for(let c=0;c<a;++c)s[`${e}.${c}.key`]=l,s[`${e}.${c}.value`]=l}}return s}var bn=class t{model_type=null;is_encoder_decoder=!1;max_position_embeddings;"transformers.js_config";constructor(e){Object.assign(this,e),this.normalized_config=yn(this)}static async from_pretrained(e,{progress_callback:r=null,config:s=null,cache_dir:n=null,local_files_only:o=!1,revision:a="main"}={}){s&&!(s instanceof t)&&(s=new t(s));let i=s??await bz(e,{progress_callback:r,config:s,cache_dir:n,local_files_only:o,revision:a});return new this(i)}},jt=class{static async from_pretrained(...e){return bn.from_pretrained(...e)}};function Um(t,e,r){return t?typeof t=="object"&&t!==null?t.hasOwnProperty(e)?+t[e]:t.hasOwnProperty(r)?+t[r]:0:+t:0}function jm(t,e){let r=[];for(let s=0;s<e;++s)r.push(`${t}_data${s===0?"":"_"+s}`);return r}async function f2(t,e,r,s){let n=`${e}${s}.onnx`,o=`${r.subfolder??""}/${n}`;return await po(t,o,!0,r,ie.IS_NODE_ENV)}async function _2(t,e,r,s,n,o={}){let a=`${e}${r}.onnx`,i=ie.IS_NODE_ENV,l=[],c=Um(n,a,e);if(c>0){if(c>Hl)throw new Error(`The number of external data chunks (${c}) exceeds the maximum allowed value (${Hl}).`);let p=jm(a,c);for(let f of p){let _=`${s.subfolder??""}/${f}`;l.push(new Promise(async(m,w)=>{let x=await po(t,_,!0,s,i);m(x instanceof Uint8Array?{path:f,data:x}:f)}))}}else o.externalData!==void 0&&(l=o.externalData.map(async p=>{if(typeof p.data=="string"){let f=await po(t,p.data,!0,s);return{...p,data:f}}return p}));return Promise.all(l)}async function kz(t,e,r,s=!1,n=void 0){let o=r.config?.["transformers.js_config"]??{},a=fc(r.device??o.device,e,{warn:S=>Z.info(S)}),i=BA(a),l=o.device_config??{};l.hasOwnProperty(a)&&(o={...o,...l[a]});let c=_c(r.dtype??o.dtype,e,a,{configDtype:o.dtype,warn:S=>Z.info(S)});if(ko.hasOwnProperty(c)){if(a==="webgpu"&&!ie.IS_NODE_ENV&&c===yt.fp16&&!await WA())throw new Error(`The device (${a}) does not support fp16.`)}else throw new Error(`Invalid dtype: ${c}. Should be one of: ${Object.keys(yt).join(", ")}`);let p=o.kv_cache_dtype,f=p?typeof p=="string"?p:p[c]??"float32":void 0;if(f&&!["float32","float16"].includes(f))throw new Error(`Invalid kv_cache_dtype: ${f}. Should be one of: float32, float16`);let _=ko[c],m={...r.session_options};m.executionProviders??=i;let w=o.free_dimension_overrides;w?m.freeDimensionOverrides??=w:a.startsWith("webnn")&&!m.freeDimensionOverrides&&Z.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"]["${a}"]. When 'free_dimension_overrides' is not set, you may experience significant performance degradation.`);let x=f2(t,e,r,_),k=r.use_external_data_format??o.use_external_data_format,E=await _2(t,e,_,r,k,m);if(E.length>0&&!ie.IS_NODE_ENV&&(m.externalData=E),s&&a==="webgpu"&&p!==!1){let S=Ss(r.config,{prefix:"present",session_name:n});if(Object.keys(S).length>0&&!vo()){let P={};for(let O in S)P[O]="gpu-buffer";m.preferredOutputLocation=P}}return{buffer_or_path:await x,session_options:m,session_config:{dtype:c,kv_cache_dtype:f,device:a}}}async function m2(t,e,r,s=void 0){return Object.fromEntries(await Promise.all(Object.keys(e).map(async n=>{let o=s?.[n]??!1,{buffer_or_path:a,session_options:i,session_config:l}=await kz(t,e[n],r,o,n),c=await uc(a,i,l);return[n,c]})))}function h2(t){for(let e in t)dc(t[e])?t[e]=new $(t[e]):typeof t[e]=="object"&&h2(t[e]);return t}async function de(t,e){let r=Ez(t,e);try{let s=Object.fromEntries(Object.entries(r).map(([o,a])=>{let i=a.ort_tensor;return ie.IS_NODE_ENV&&typeof Float16Array<"u"&&i.cpuData instanceof Float16Array&&(i.cpuData=new Uint16Array(i.cpuData.buffer)),[o,i]})),n=await pc(t,s);return h2(n)}catch(s){let n=Object.fromEntries(Object.entries(r).map(([o,a])=>{let i={type:a.type,dims:a.dims,location:a.location};return i.location!=="gpu-buffer"&&(i.data=a.data),[o,i]}));throw Z.error(`An error occurred during model execution: "${s}".`),Z.error("Inputs given to model:",n),s}}function Ez(t,e){let r=Object.create(null),s=[];for(let a of t.inputNames){let i=e[a];if(!(i instanceof $)){s.push(a);continue}r[a]=vo()?i.clone():i}if(s.length>0)throw new Error(`An error occurred during model execution: "Missing the following inputs: ${s.join(", ")}.`);let n=Object.keys(e).length,o=t.inputNames.length;if(n>o){let a=Object.keys(e).filter(i=>!t.inputNames.includes(i));Z.warn(`WARNING: Too many inputs were provided (${n} > ${o}). The following inputs will be ignored: "${a.join(", ")}".`)}return r}var Re=class{};var G=class extends Re{constructor({logits:e,...r}){super(),this.logits=e;let s=Object.values(r);s.length>0&&(this.attentions=s)}},he=class extends Re{constructor({logits:e}){super(),this.logits=e}},we=class extends Re{constructor({logits:e}){super(),this.logits=e}},Me=class extends Re{constructor({start_logits:e,end_logits:r}){super(),this.start_logits=e,this.end_logits=r}},kt=class extends Re{constructor({logits:e}){super(),this.logits=e}};var Vc=class extends Re{constructor({alphas:e}){super(),this.alphas=e}};var Gt=class extends rt{_call(e,r){throw Error("`_call` should be implemented in a subclass")}},Do=class extends rt{_call(e,r){throw Error("`_call` should be implemented in a subclass")}},Ts=class extends rt{constructor(){super(),this.processors=[]}push(e){this.processors.push(e)}extend(e){this.processors.push(...e)}_call(e,r){let s=r;for(let n of this.processors)s=n(e,s);return s}[Symbol.iterator](){return this.processors.values()}},Hc=class extends Gt{constructor(e){super(),this.bos_token_id=e}_call(e,r){for(let s=0;s<e.length;++s)if(e[s].length===1){let n=r[s].data;n.fill(-1/0),n[this.bos_token_id]=0}return r}},Xc=class extends Gt{constructor(e,r){super(),this.max_length=e,this.eos_token_id=Array.isArray(r)?r:[r]}_call(e,r){for(let s=0;s<e.length;++s)if(e[s].length===this.max_length-1){let n=r[s].data;n.fill(-1/0);for(let o of this.eos_token_id)n[o]=0}return r}},vn=class extends Gt{constructor(e,r){super(),this.begin_suppress_tokens=e,this.begin_index=r}_call(e,r){for(let s=0;s<e.length;++s)if(e[s].length===this.begin_index){let n=r[s].data;for(let o of this.begin_suppress_tokens)n[o]=-1/0}return r}},Kc=class extends Gt{constructor(e,r){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=r.length,r.at(-1)===this.no_timestamps_token_id&&(this.begin_index-=1),this.max_initial_timestamp_index=e.max_initial_timestamp_index}_call(e,r){for(let s=0;s<e.length;++s){let n=r[s].data;if(n[this.no_timestamps_token_id]=-1/0,e[s].length===this.begin_index-1){n.fill(-1/0),n[this.timestamp_begin]=0;continue}let o=e[s].slice(this.begin_index),a=o.length>=1&&o[o.length-1]>=this.timestamp_begin,i=o.length<2||o[o.length-2]>=this.timestamp_begin;if(a&&(i?n.subarray(this.timestamp_begin).fill(-1/0):n.subarray(0,this.eos_token_id).fill(-1/0)),e[s].length===this.begin_index&&this.max_initial_timestamp_index!==null){let f=this.timestamp_begin+this.max_initial_timestamp_index;n.subarray(f+1).fill(-1/0)}let l=md(n),c=Math.log(l.subarray(this.timestamp_begin).map(Math.exp).reduce((f,_)=>f+_)),p=Ce(l.subarray(0,this.timestamp_begin))[0];c>p&&n.subarray(0,this.timestamp_begin).fill(-1/0)}return r}},Qc=class extends Gt{constructor(e){super(),this.no_repeat_ngram_size=e}getNgrams(e){let r=e.length,s=[];for(let o=0;o<r+1-this.no_repeat_ngram_size;++o){let a=[];for(let i=0;i<this.no_repeat_ngram_size;++i)a.push(e[o+i]);s.push(a.map(Number))}let n=new Map;for(let o of s){let a=o.slice(0,o.length-1),i=JSON.stringify(a),l=n.get(i)??[];l.push(o[o.length-1]),n.set(i,l)}return n}getGeneratedNgrams(e,r){let s=r.slice(r.length+1-this.no_repeat_ngram_size,r.length);return e.get(JSON.stringify(s.map(Number)))??[]}calcBannedNgramTokens(e){let r=[];if(e.length+1<this.no_repeat_ngram_size)return r;{let s=this.getNgrams(e);return this.getGeneratedNgrams(s,e)}}_call(e,r){for(let s=0;s<e.length;++s){let n=r[s].data,o=this.calcBannedNgramTokens(e[s]);for(let a of o)n[a]=-1/0}return r}},Yc=class extends Gt{constructor(e){super(),this.penalty=e}_call(e,r){for(let s=0;s<e.length;++s){let n=r[s].data;for(let o of new Set(e[s])){let a=Number(o);n[a]<0?n[a]*=this.penalty:n[a]/=this.penalty}}return r}},Jc=class extends Gt{constructor(e,r){super(),this.min_length=e,this.eos_token_id=Array.isArray(r)?r:[r]}_call(e,r){for(let s=0;s<e.length;++s)if(e[s].length<this.min_length){let n=r[s].data;for(let o of this.eos_token_id)n[o]=-1/0}return r}},Zc=class extends Gt{constructor(e,r,s){super(),this.prompt_length_to_skip=e,this.min_new_tokens=r,this.eos_token_id=Array.isArray(s)?s:[s]}_call(e,r){for(let s=0;s<e.length;++s)if(e[s].length-this.prompt_length_to_skip<this.min_new_tokens){let o=r[s].data;for(let a of this.eos_token_id)o[a]=-1/0}return r}},eu=class extends Gt{constructor(e,r){super(),this.bad_words_ids=e,this.eos_token_id=Array.isArray(r)?r:[r]}_call(e,r){for(let s=0;s<e.length;++s){let n=r[s].data,o=e[s];for(let a of this.bad_words_ids){if(o.length<a.length-1)continue;let i=!0;for(let l=1;l<=a.length-1;++l)if(a.at(-l-1)!=o.at(-l)){i=!1;break}i&&(n[a.at(-1)]=-1/0)}}return r}},tu=class extends Gt{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,r){if(r.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 ${r.dims[0]} for the logits and ${e.length} for the input ids.`);let s=e.length,n=r.slice([0,s],null),o=r.slice([s,r.dims[0]],null);for(let a=0;a<o.data.length;++a)o.data[a]+=(n.data[a]-o.data[a])*this.guidance_scale;return o}},ru=class extends Do{constructor(e){if(super(),typeof e!="number"||e<=0){let r=`\`temperature\` (=${e}) must be a strictly positive float, otherwise your next token scores will be invalid.`;e===0&&(r+=" If you're looking for greedy decoding strategies, set `do_sample=false`.")}this.temperature=e}_call(e,r){let s=r.data;for(let n=0;n<s.length;++n)s[n]/=this.temperature;return r}},g2=class extends Do{constructor(e,{filter_value:r=-1/0,min_tokens_to_keep:s=1}={}){if(super(),e<0||e>1)throw new Error(`\`top_p\` must be a float > 0 and < 1, but is ${e}`);if(!Number.isInteger(s)||s<1)throw new Error(`\`min_tokens_to_keep\` must be a positive integer, but is ${s}`);this.top_p=e,this.filter_value=r,this.min_tokens_to_keep=s}},w2=class extends Do{constructor(e,{filter_value:r=-1/0,min_tokens_to_keep:s=1}={}){if(super(),!Number.isInteger(e)||e<0)throw new Error(`\`top_k\` must be a positive integer, but is ${e}`);this.top_k=Math.max(e,s),this.filter_value=r}};var kn=class{max_length=20;max_new_tokens=null;min_length=0;min_new_tokens=null;early_stopping=!1;max_time=null;do_sample=!1;num_beams=1;num_beam_groups=1;penalty_alpha=null;use_cache=!0;temperature=1;top_k=50;top_p=1;typical_p=1;epsilon_cutoff=0;eta_cutoff=0;diversity_penalty=0;repetition_penalty=1;encoder_repetition_penalty=1;length_penalty=1;no_repeat_ngram_size=0;bad_words_ids=null;force_words_ids=null;renormalize_logits=!1;constraints=null;forced_bos_token_id=null;forced_eos_token_id=null;remove_invalid_values=!1;exponential_decay_length_penalty=null;suppress_tokens=null;streamer=null;begin_suppress_tokens=null;forced_decoder_ids=null;guidance_scale=null;num_return_sequences=1;output_attentions=!1;output_hidden_states=!1;output_scores=!1;return_dict_in_generate=!1;pad_token_id=null;bos_token_id=null;eos_token_id=null;encoder_no_repeat_ngram_size=0;decoder_start_token_id=null;generation_kwargs={};constructor(e){Object.assign(this,Qe(e,Object.getOwnPropertyNames(this)))}};var Wr=class extends rt{_call(e,r){throw Error("StoppingCriteria needs to be subclassed")}},En=class t extends rt{constructor(){super(),this.criteria=[]}push(e){this.criteria.push(e)}extend(e){e instanceof t?e=e.criteria:e instanceof Wr&&(e=[e]),this.criteria.push(...e)}_call(e,r){let s=new Array(e.length).fill(!1);for(let n of this.criteria){let o=n(e,r);for(let a=0;a<s.length;++a)s[a]||=o[a]}return s}[Symbol.iterator](){return this.criteria.values()}},su=class extends Wr{constructor(e,r=null){super(),this.max_length=e,this.max_position_embeddings=r}_call(e){return e.map(r=>r.length>=this.max_length)}},nu=class extends Wr{constructor(e){super(),Array.isArray(e)||(e=[e]),this.eos_token_id=e}_call(e,r){return e.map(s=>{let n=s.at(-1);return this.eos_token_id.some(o=>n==o)})}},x2=class extends Wr{constructor(){super(),this.interrupted=!1}interrupt(){this.interrupted=!0}reset(){this.interrupted=!1}_call(e,r){return new Array(e.length).fill(this.interrupted)}};var Os=class extends rt{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,r){let s=e.dims.at(-1),n=e.data;if(r===-1)n=n.slice(-s);else{let o=r*s;n=n.slice(o,o+s)}return n}randomSelect(e){return Kk(e)}static getSampler(e){if(e.do_sample)return new qm(e);if(e.num_beams>1)return new Wm(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 Gm(e)}},Gm=class extends Os{async sample(e){let r=Ce(e.data)[1];return[[BigInt(r),0]]}},qm=class extends Os{async sample(e){let r=e.dims.at(-1);this.generation_config.top_k>0&&(r=Math.min(this.generation_config.top_k,r));let[s,n]=await er(e,r),o=$e(s.data);return Array.from({length:this.generation_config.num_beams},()=>{let a=this.randomSelect(o);return[n.data[a],Math.log(o[a])]})}},Wm=class extends Os{async sample(e){let r=e.dims.at(-1);this.generation_config.top_k>0&&(r=Math.min(this.generation_config.top_k,r));let[s,n]=await er(e,r),o=$e(s.data);return Array.from({length:this.generation_config.num_beams},(a,i)=>[n.data[i],Math.log(o[i])])}};var Vm=class{constructor(e){if(e)for(let r in e){if(r in this)throw new TypeError(`Key "${r}" conflicts with an existing property on DynamicCache`);let s=e[r];if(!(s instanceof $))throw new TypeError(`Expected a Tensor for key "${r}", got ${typeof s}`);this[r]=s}}get_seq_length(){let e=this;for(let r in e)if(r.startsWith("past_key_values."))return e[r].dims.at(-2);throw new Error("Unable to determine sequence length from the cache.")}async dispose(){let e=[];for(let r of Object.values(this))r.location==="gpu-buffer"&&e.push(r.dispose());await Promise.all(e)}},Fo=Vm;var Is=null;function b2(t){Is=t}function Hm(t){if(t instanceof $)return t;if(t.length===0)throw Error("items must be non-empty");if(Array.isArray(t[0])){if(t.some(e=>e.length!==t[0].length))throw Error("Unable to create tensor, you should probably activate truncation and/or padding with 'padding=True' and/or 'truncation=True' to have batched tensors with the same length.");return new $("int64",BigInt64Array.from(t.flat().map(e=>BigInt(e))),[t.length,t[0].length])}else return new $("int64",BigInt64Array.from(t.map(e=>BigInt(e))),[1,t.length])}function Xm(t){return new $("bool",[t],[1])}var K={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,MultimodalLanguageModelOnly:16,VoxtralRealtime:17},An={[K.DecoderOnly]:{can_generate:!0,forward:Ct,prepare_inputs:Mn,sessions:(t,e)=>({model:e.model_file_name??"model"}),cache_sessions:{model:!0},optional_configs:{generation_config:"generation_config.json"}},[K.DecoderOnlyWithoutHead]:{can_generate:!1,forward:Ct,prepare_inputs:Mn,sessions:(t,e)=>({model:e.model_file_name??"model"})},[K.Seq2Seq]:{can_generate:!0,forward:ou,prepare_inputs:Uo,sessions:()=>({model:"encoder_model",decoder_model_merged:"decoder_model_merged"}),cache_sessions:{decoder_model_merged:!0},optional_configs:{generation_config:"generation_config.json"}},[K.Vision2Seq]:{can_generate:!0,forward:ou,prepare_inputs:Uo,sessions:()=>({model:"encoder_model",decoder_model_merged:"decoder_model_merged"}),cache_sessions:{decoder_model_merged:!0},optional_configs:{generation_config:"generation_config.json"}},[K.Musicgen]:{can_generate:!0,forward:ou,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"}},[K.EncoderDecoder]:{can_generate:!1,forward:ou,sessions:()=>({model:"encoder_model",decoder_model_merged:"decoder_model_merged"}),cache_sessions:{decoder_model_merged:!0}},[K.MaskGeneration]:{sessions:()=>({model:"vision_encoder",prompt_encoder_mask_decoder:"prompt_encoder_mask_decoder"})},[K.ImageTextToText]:{can_generate:!0,forward:y2,prepare_inputs:Bo,sessions:t=>{let e={embed_tokens:"embed_tokens",vision_encoder:"vision_encoder",decoder_model_merged:"decoder_model_merged"};return t.is_encoder_decoder&&(e.model="encoder_model"),e},cache_sessions:{decoder_model_merged:!0},optional_configs:{generation_config:"generation_config.json"}},[K.AudioTextToText]:{can_generate:!0,forward:Mz,prepare_inputs:Bo,sessions:()=>({embed_tokens:"embed_tokens",audio_encoder:"audio_encoder",decoder_model_merged:"decoder_model_merged"}),cache_sessions:{decoder_model_merged:!0},optional_configs:{generation_config:"generation_config.json"}},[K.ImageAudioTextToText]:{can_generate:!0,prepare_inputs:Bo,sessions:()=>({embed_tokens:"embed_tokens",audio_encoder:"audio_encoder",vision_encoder:"vision_encoder",decoder_model_merged:"decoder_model_merged"}),optional_configs:{generation_config:"generation_config.json"}},[K.Phi3V]:{can_generate:!0,prepare_inputs:Bo,sessions:()=>({prepare_inputs_embeds:"prepare_inputs_embeds",model:"model",vision_encoder:"vision_encoder"}),cache_sessions:{model:!0},optional_configs:{generation_config:"generation_config.json"}},[K.MultiModality]:{can_generate:!0,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"}},[K.AutoEncoder]:{can_generate:!1,forward:Az,sessions:()=>({encoder_model:"encoder_model",decoder_model:"decoder_model"})},[K.Supertonic]:{sessions:()=>({text_encoder:"text_encoder",latent_denoiser:"latent_denoiser",voice_decoder:"voice_decoder"})},[K.Chatterbox]:{can_generate:!0,forward:qt,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"}},[K.MultimodalLanguageModelOnly]:{can_generate:!0,forward:y2,prepare_inputs:Bo,sessions:()=>({embed_tokens:"embed_tokens",decoder_model_merged:"decoder_model_merged"}),cache_sessions:{decoder_model_merged:!0},optional_configs:{generation_config:"generation_config.json"}},[K.VoxtralRealtime]:{can_generate:!0,prepare_inputs:Mn,sessions:()=>({embed_tokens:"embed_tokens",audio_encoder:"audio_encoder",decoder_model_merged:"decoder_model_merged"}),cache_sessions:{decoder_model_merged:!0,audio_encoder:!0},optional_configs:{generation_config:"generation_config.json"}},default:{can_generate:!1,forward:qt,sessions:(t,e)=>({model:e.model_file_name??"model"})}};function v2(t,e,r={}){let s=An[t]??An.default;return{sessions:s.sessions(e,r),cache_sessions:s.cache_sessions,optional_configs:s.optional_configs}}var tr=new Map,au=new Map,Cs=new Map,y=class extends rt{main_input_name="input_ids";forward_params=["input_ids","attention_mask"];_return_dict_in_generate_keys=null;constructor(e,r,s){super(),this.config=e,this.sessions=r,this.configs=s;let n=Cs.get(this.constructor),o=tr.get(n),a=An[o]??An.default;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(){let e=[];for(let r of Object.values(this.sessions))e.push(r.release?.());return await Promise.all(e)}static async from_pretrained(e,{progress_callback:r=null,config:s=null,cache_dir:n=null,local_files_only:o=!1,revision:a="main",model_file_name:i=null,subfolder:l="onnx",device:c=null,dtype:p=null,use_external_data_format:f=null,session_options:_={}}={}){let m={progress_callback:r,config:s,cache_dir:n,local_files_only:o,revision:a,model_file_name:i,subfolder:l,device:c,dtype:p,use_external_data_format:f,session_options:_},w=Cs.get(this),x=tr.get(w);s=m.config=await jt.from_pretrained(e,m);let k=An[x]??An.default;if(x===void 0){let S=w??s?.model_type;S!=="custom"&&Z.warn(`Model type for '${S}' not found, assuming encoder-only architecture. Please report this at ${jr}.`)}let E=k.sessions(s,m),A=[m2(e,E,m,k.cache_sessions)];k.optional_configs&&A.push(Tz(e,k.optional_configs,m));let T=await Promise.all(A);return new this(s,...T)}async _call(e){return await this.forward(e)}async forward(e){return await this._forward(this,e)}get generation_config(){return this.configs?.generation_config??null}_get_logits_processor(e,r,s=null){let n=new Ts;if(e.repetition_penalty!==null&&e.repetition_penalty!==1&&n.push(new Yc(e.repetition_penalty)),e.no_repeat_ngram_size!==null&&e.no_repeat_ngram_size>0&&n.push(new Qc(e.no_repeat_ngram_size)),e.bad_words_ids!==null&&n.push(new eu(e.bad_words_ids,e.eos_token_id)),e.min_length!==null&&e.eos_token_id!==null&&e.min_length>0&&n.push(new Jc(e.min_length,e.eos_token_id)),e.min_new_tokens!==null&&e.eos_token_id!==null&&e.min_new_tokens>0&&n.push(new Zc(r,e.min_new_tokens,e.eos_token_id)),e.forced_bos_token_id!==null&&n.push(new Hc(e.forced_bos_token_id)),e.forced_eos_token_id!==null&&n.push(new Xc(e.max_length,e.forced_eos_token_id)),e.begin_suppress_tokens!==null){let o=r>1||e.forced_bos_token_id===null?r:r+1;n.push(new vn(e.begin_suppress_tokens,o))}return e.guidance_scale!==null&&e.guidance_scale>1&&n.push(new tu(e.guidance_scale)),e.temperature===0&&e.do_sample&&(Z.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`."),e.do_sample=!1),e.do_sample&&e.temperature!==null&&e.temperature!==1&&n.push(new ru(e.temperature)),s!==null&&n.extend(s),n}_prepare_generation_config(e,r,s=kn){let n={...this.config};for(let a of["decoder","generator","text_config"])a in n&&Object.assign(n,n[a]);let o=new s(n);return Object.assign(o,this.generation_config??{}),e&&Object.assign(o,e),r&&Object.assign(o,Qe(r,Object.getOwnPropertyNames(o))),o}_get_stopping_criteria(e,r=null){let s=new En;return e.max_length!==null&&s.push(new su(e.max_length,this.config.max_position_embeddings??null)),e.eos_token_id!==null&&s.push(new nu(e.eos_token_id)),r&&s.extend(r),s}_validate_model_class(){if(!this.can_generate){let e=[Is.MODEL_FOR_CAUSAL_LM_MAPPING_NAMES,Is.MODEL_FOR_VISION_2_SEQ_MAPPING_NAMES,Is.MODEL_FOR_SEQ_TO_SEQ_CAUSAL_LM_MAPPING_NAMES,Is.MODEL_FOR_SPEECH_SEQ_2_SEQ_MAPPING_NAMES].filter(Boolean),r=Cs.get(this.constructor),s=new Set,n=this.config.model_type;for(let a of e){let i=a?.get(n);i&&s.add(i)}let o=`The current model class (${r}) is not compatible with \`.generate()\`, as it doesn't have a language model head.`;throw s.size>0&&(o+=` Please use the following class instead: ${[...s].join(", ")}`),Error(o)}}prepare_inputs_for_generation(...e){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,...e)}_update_model_kwargs_for_generation({generated_input_ids:e,outputs:r,model_inputs:s,is_encoder_decoder:n}){return s.past_key_values=this.getPastKeyValues(r,s.past_key_values),s.input_ids=new $("int64",e.flat(),[e.length,1]),n?"decoder_attention_mask"in s:s.attention_mask=Ee([s.attention_mask,st([s.attention_mask.dims[0],1])],1),s.position_ids=null,s}_prepare_model_inputs({inputs:e,bos_token_id:r,model_kwargs:s}){let n=Qe(s,this.forward_params),o=this.main_input_name;if(o in n){if(e)throw new Error("`inputs`: {inputs}` were passed alongside {input_name} which is not allowed. Make sure to either pass {inputs} or {input_name}=...")}else n[o]=e;return{inputs_tensor:n[o],model_inputs:n,model_input_name:o}}async _prepare_encoder_decoder_kwargs_for_generation({inputs_tensor:e,model_inputs:r,model_input_name:s,generation_config:n}){if(this.sessions.model.inputNames.includes("inputs_embeds")&&!r.inputs_embeds&&"_prepare_inputs_embeds"in this){let{input_ids:a,pixel_values:i,attention_mask:l,...c}=r,p=await this._prepare_inputs_embeds(r);r={...c,...Qe(p,["inputs_embeds","attention_mask"])}}let{last_hidden_state:o}=await qt(this,r);if(n.guidance_scale!==null&&n.guidance_scale>1)o=Ee([o,Ao(o,0)],0),"attention_mask"in r&&(r.attention_mask=Ee([r.attention_mask,_f(r.attention_mask)],0));else if(r.decoder_input_ids){let a=Hm(r.decoder_input_ids).dims[0];if(a!==o.dims[0]){if(o.dims[0]!==1)throw new Error(`The encoder outputs have a different batch size (${o.dims[0]}) than the decoder inputs (${a}).`);o=Ee(Array.from({length:a},()=>o),0)}}return r.encoder_outputs=o,r}_prepare_decoder_input_ids_for_generation({batch_size:e,model_input_name:r,model_kwargs:s,decoder_start_token_id:n,bos_token_id:o,generation_config:a}){let{decoder_input_ids:i,...l}=s;if(!(i instanceof $)){if(i)Array.isArray(i[0])||(i=Array.from({length:e},()=>i));else if(n??=o,this.config.model_type==="musicgen")i=Array.from({length:e*this.config.decoder.num_codebooks},()=>[n]);else if(Array.isArray(n)){if(n.length!==e)throw new Error(`\`decoder_start_token_id\` expcted to have length ${e} but got ${n.length}`);i=n}else i=Array.from({length:e},()=>[n]);i=Hm(i)}return s.decoder_attention_mask=wc(i),{input_ids:i,model_inputs:l}}async generate({inputs:e=null,generation_config:r=null,logits_processor:s=null,stopping_criteria:n=null,streamer:o=null,...a}){this._validate_model_class(),r=this._prepare_generation_config(r,a);let{inputs_tensor:i,model_inputs:l,model_input_name:c}=this._prepare_model_inputs({inputs:e,model_kwargs:a}),p=this.config.is_encoder_decoder;p&&("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 f;p?{input_ids:f,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}):f=l[c];let _=f.dims.at(-1);r.max_new_tokens!==null&&(r.max_length=_+r.max_new_tokens);let m=this._get_logits_processor(r,_,s),w=this._get_stopping_criteria(r,n),x=l[c].dims.at(0),k=Os.getSampler(r),E=new Array(x).fill(0),A=f.tolist();o&&o.put(A);let T,S={},P={};for(;;){if(l=this.prepare_inputs_for_generation(A,l,r),T=await this.forward(l),r.return_dict_in_generate)if(r.output_attentions){let q=this.getAttentions(T);for(let Q in q)Q in S||(S[Q]=[]),S[Q].push(q[Q])}else this._return_dict_in_generate_keys&&Object.assign(P,Qe(T,this._return_dict_in_generate_keys));let j=T.logits.slice(null,-1,null).to("float32"),H=m(A,j),B=[];for(let q=0;q<H.dims.at(0);++q){let Q=H[q],F=await k(Q);for(let[C,te]of F){let le=BigInt(C);E[q]+=te,A[q].push(le),B.push([le]);break}}if(o&&o.put(B),w(A).every(q=>q))break;l=this._update_model_kwargs_for_generation({generated_input_ids:B,outputs:T,model_inputs:l,is_encoder_decoder:p})}o&&o.end();let O=this.getPastKeyValues(T,l.past_key_values,!0),v=new $("int64",A.flat(),[A.length,A[0].length]);if(r.return_dict_in_generate)return{sequences:v,past_key_values:O,...S,...P};for(let j of Object.values(T))j.location==="gpu-buffer"&&j.dispose();return v}getPastKeyValues(e,r,s=!1){let n=Object.create(null);for(let o in e)if(o.startsWith("present")){let a=o.replace("present_ssm","past_ssm").replace("present_conv","past_conv").replace("present_recurrent","past_recurrent").replace("present","past_key_values"),i=o.includes("encoder");if(i&&r?n[a]=r[a]:n[a]=e[o],r&&(!i||s)){let l=r[a];l.location==="gpu-buffer"&&l.dispose()}}return new Fo(n)}getAttentions(e){let r={};for(let s of["cross_attentions","encoder_attentions","decoder_attentions"])for(let n in e)n.startsWith(s)&&(s in r||(r[s]=[]),r[s].push(e[n]));return r}addPastKeyValues(e,r){if(r)Object.assign(e,r);else{let s=this.sessions.decoder_model_merged??this.sessions.model,n=(e[this.main_input_name]??e.attention_mask)?.dims?.[0]??1,o=s?.config?.kv_cache_dtype??"float32",a=o==="float16"?br.float16:br.float32,i=Ss(this.config,{batch_size:n});for(let l in i){let c=i[l].reduce((p,f)=>p*f,1);e[l]=new $(o,new a(c),i[l])}}}async _encode_input(e,r,s){if(!Object.hasOwn(this.sessions,e))throw new Error(`Model does not have a ${e} session.`);let n=this.sessions[e];return(await de(n,Qe(r,n.inputNames)))[s]}async encode_image(e){return this._encode_input("vision_encoder",e,"image_features")}async encode_text(e){return this._encode_input("embed_tokens",e,"inputs_embeds")}async encode_audio(e){return this._encode_input("audio_encoder",e,"audio_features")}};async function ou(t,e){let{encoder_outputs:r,input_ids:s,decoder_input_ids:n,...o}=e;if(!r){let a=Qe(e,t.sessions.model.inputNames);r=(await qt(t,a)).last_hidden_state}return o.input_ids=n,o.encoder_hidden_states=r,t.sessions.decoder_model_merged.inputNames.includes("encoder_attention_mask")&&(o.encoder_attention_mask=e.attention_mask),await Ct(t,o,!0)}async function qt(t,e){let r=t.sessions.model,s=Qe(e,r.inputNames);if(r.inputNames.includes("inputs_embeds")&&!s.inputs_embeds){if(!e.input_ids)throw new Error("Both `input_ids` and `inputs_embeds` are missing in the model inputs.");s.inputs_embeds=await t.encode_text({input_ids:e.input_ids})}if(r.inputNames.includes("token_type_ids")&&!s.token_type_ids){if(!s.input_ids)throw new Error("Both `input_ids` and `token_type_ids` are missing in the model inputs.");s.token_type_ids=_f(s.input_ids)}if(r.inputNames.includes("pixel_mask")&&!s.pixel_mask){if(!s.pixel_values)throw new Error("Both `pixel_values` and `pixel_mask` are missing in the model inputs.");let n=s.pixel_values.dims;s.pixel_mask=st([n[0],n[2],n[3]])}return await de(r,s)}async function Az(t,e){let r=await t.encode(e);return await t.decode(r)}async function Ct(t,e,r=!1){let s=t.sessions[r?"decoder_model_merged":"model"],{past_key_values:n,...o}=e;if(s.inputNames.includes("use_cache_branch")&&(o.use_cache_branch=Xm(!!n)),s.inputNames.includes("position_ids")&&o.attention_mask&&!o.position_ids){let i=["paligemma","gemma3_text","gemma3"].includes(t.config.model_type)?1:0;o.position_ids=Sz(o,n,i)}s.inputNames.includes("num_logits_to_keep")&&!o.num_logits_to_keep&&(o.num_logits_to_keep=new $("int64",[0n],[])),t.addPastKeyValues(o,n);let a=Qe(o,s.inputNames);return await de(s,a)}async function k2(t,{encode_function:e,merge_function:r,modality_input_names:s,modality_output_name:n,input_ids:o=null,attention_mask:a=null,position_ids:i=null,inputs_embeds:l=null,past_key_values:c=null,generation_config:p=null,logits_processor:f=null,..._}){if(!l){l=await t.encode_text({input_ids:o,..._});let w=Qe(_,s);if(Object.keys(w).length>0){if(o.dims[1]!==1){let x=await e({...w,..._});({inputs_embeds:l,attention_mask:a}=r({[n]:x,inputs_embeds:l,input_ids:o,attention_mask:a}))}else if(c&&o.dims[1]===1){let x=o.dims[1],k=c.get_seq_length();a=Ee([st([o.dims[0],k]),a.slice(null,[a.dims[1]-x,a.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"].includes(t.config.model_type)){let{image_grid_thw:w,video_grid_thw:x}=_;[i]=t.get_rope_index(o,w,x,a)}return await Ct(t,{inputs_embeds:l,past_key_values:c,attention_mask:a,position_ids:i,generation_config:p,logits_processor:f},!0)}async function Mz(t,e){return await k2(t,{...e,modality_input_names:["audio_values","input_features"],modality_output_name:"audio_features",encode_function:t.encode_audio.bind(t),merge_function:t._merge_input_ids_with_audio_features.bind(t)})}async function y2(t,e){return await k2(t,{...e,modality_input_names:["pixel_values"],modality_output_name:"image_features",encode_function:t.encode_image.bind(t),merge_function:t._merge_input_ids_with_image_features.bind(t)})}function Km(t,e=0){let[r,s]=t.dims,n=t.data,o=new BigInt64Array(n.length);for(let a=0;a<r;++a){let i=a*s,l=BigInt(e);for(let c=0;c<s;++c){let p=i+c;n[p]===0n?o[p]=BigInt(1):(o[p]=l,l+=n[p])}}return{data:o,dims:t.dims}}function Sz(t,e=null,r=0){let{input_ids:s,inputs_embeds:n,attention_mask:o}=t,{data:a,dims:i}=Km(o,r),l=new $("int64",a,i);if(e){let c=-(s??n).dims.at(1);l=l.slice(null,[c,null])}return l}function Mn(t,e,r,s){let n=r.past_key_values?r.past_key_values.get_seq_length():0;if((t.sessions.decoder_model_merged??t.sessions.model)?.inputNames.includes("num_logits_to_keep")&&!r.num_logits_to_keep&&(r.num_logits_to_keep=new $("int64",[1n],[])),!r.attention_mask){let a;for(let i of["input_ids","inputs_embeds","position_ids"])if(r[i]){a=r[i].dims;break}if(!a)throw new Error("attention_mask is not provided, and unable to infer its shape from model inputs.");r.attention_mask=st([a[0],n+a[1]])}if(r.past_key_values){let{input_ids:a,attention_mask:i}=r;i&&i.dims[1]>a.dims[1]||n<a.dims[1]&&(r.input_ids=a.slice(null,[n,null]))}return r}function Uo(t,e,r,s){return r.past_key_values&&(e=e.map(n=>[n.at(-1)])),{...r,decoder_input_ids:Hm(e)}}function Bo(t,...e){return t.config.is_encoder_decoder?Uo(t,...e):Mn(t,...e)}function E2({modality_token_id:t,inputs_embeds:e,modality_features:r,input_ids:s,attention_mask:n}){let o=s.tolist().map(c=>c.reduce((p,f,_)=>(f==t&&p.push(_),p),[])),a=o.reduce((c,p)=>c+p.length,0),i=r.dims[0];if(a!==i)throw new Error(`Number of tokens and features do not match: tokens: ${a}, features ${i}`);let l=0;for(let c=0;c<o.length;++c){let p=o[c],f=e[c];for(let _=0;_<p.length;++_)f[p[_]].data.set(r[l++].data)}return{inputs_embeds:e,attention_mask:n}}function Sn({image_token_id:t,inputs_embeds:e,image_features:r,input_ids:s,attention_mask:n}){return E2({modality_token_id:t,inputs_embeds:e,modality_features:r,input_ids:s,attention_mask:n})}function iu({audio_token_id:t,inputs_embeds:e,audio_features:r,input_ids:s,attention_mask:n}){return E2({modality_token_id:t,inputs_embeds:e,modality_features:r,input_ids:s,attention_mask:n})}async function Tz(t,e,r){return Object.fromEntries(await Promise.all(Object.keys(e).map(async s=>{let n=await ft(t,e[s],!1,r);return[s,n]})))}var Yi={};Ys(Yi,{ASTForAudioClassification:()=>ih,ASTModel:()=>ah,ASTPreTrainedModel:()=>Wo,AfmoeForCausalLM:()=>sh,AfmoeModel:()=>rh,AfmoePreTrainedModel:()=>Go,AlbertForMaskedLM:()=>Zm,AlbertForQuestionAnswering:()=>Jm,AlbertForSequenceClassification:()=>Ym,AlbertModel:()=>Qm,AlbertPreTrainedModel:()=>Ls,ApertusForCausalLM:()=>th,ApertusModel:()=>eh,ApertusPreTrainedModel:()=>jo,ArceeForCausalLM:()=>oh,ArceeModel:()=>nh,ArceePreTrainedModel:()=>qo,BartForConditionalGeneration:()=>ch,BartForSequenceClassification:()=>uh,BartModel:()=>lh,BartPretrainedModel:()=>Tn,BeitForImageClassification:()=>dh,BeitModel:()=>ph,BeitPreTrainedModel:()=>Vo,BertForMaskedLM:()=>_h,BertForQuestionAnswering:()=>gh,BertForSequenceClassification:()=>mh,BertForTokenClassification:()=>hh,BertModel:()=>fh,BertPreTrainedModel:()=>Vr,BlenderbotForConditionalGeneration:()=>xh,BlenderbotModel:()=>wh,BlenderbotPreTrainedModel:()=>Ho,BlenderbotSmallForConditionalGeneration:()=>bh,BlenderbotSmallModel:()=>yh,BlenderbotSmallPreTrainedModel:()=>Xo,BloomForCausalLM:()=>kh,BloomModel:()=>vh,BloomPreTrainedModel:()=>Ko,CLIPModel:()=>Ch,CLIPPreTrainedModel:()=>pr,CLIPSegForImageSegmentation:()=>$h,CLIPSegModel:()=>Nh,CLIPSegPreTrainedModel:()=>ea,CLIPTextModel:()=>Lh,CLIPTextModelWithProjection:()=>Zo,CLIPVisionModel:()=>Ph,CLIPVisionModelWithProjection:()=>zh,CamembertForMaskedLM:()=>Ah,CamembertForQuestionAnswering:()=>Th,CamembertForSequenceClassification:()=>Mh,CamembertForTokenClassification:()=>Sh,CamembertModel:()=>Eh,CamembertPreTrainedModel:()=>Hr,ChatterboxModel:()=>Qo,ChatterboxPreTrainedModel:()=>lu,ChineseCLIPModel:()=>Oh,ChineseCLIPPreTrainedModel:()=>cu,ClapAudioModelWithProjection:()=>Jo,ClapModel:()=>Ih,ClapPreTrainedModel:()=>On,ClapTextModelWithProjection:()=>Yo,CodeGenForCausalLM:()=>Dh,CodeGenModel:()=>Rh,CodeGenPreTrainedModel:()=>ta,Cohere2ForCausalLM:()=>jh,Cohere2Model:()=>Uh,Cohere2PreTrainedModel:()=>sa,CohereForCausalLM:()=>Bh,CohereModel:()=>Fh,CoherePreTrainedModel:()=>ra,ConvBertForMaskedLM:()=>qh,ConvBertForQuestionAnswering:()=>Hh,ConvBertForSequenceClassification:()=>Wh,ConvBertForTokenClassification:()=>Vh,ConvBertModel:()=>Gh,ConvBertPreTrainedModel:()=>Xr,ConvNextForImageClassification:()=>Kh,ConvNextModel:()=>Xh,ConvNextPreTrainedModel:()=>na,ConvNextV2ForImageClassification:()=>Yh,ConvNextV2Model:()=>Qh,ConvNextV2PreTrainedModel:()=>oa,DFineForObjectDetection:()=>tg,DFineModel:()=>eg,DFinePreTrainedModel:()=>ia,DINOv3ConvNextModel:()=>Ag,DINOv3ConvNextPreTrainedModel:()=>hu,DINOv3ViTModel:()=>Mg,DINOv3ViTPreTrainedModel:()=>gu,DPTForDepthEstimation:()=>zg,DPTModel:()=>Pg,DPTPreTrainedModel:()=>fa,DacDecoderModel:()=>ca,DacDecoderOutput:()=>pu,DacEncoderModel:()=>la,DacEncoderOutput:()=>uu,DacModel:()=>rg,DacPreTrainedModel:()=>In,DebertaForMaskedLM:()=>ng,DebertaForQuestionAnswering:()=>ig,DebertaForSequenceClassification:()=>og,DebertaForTokenClassification:()=>ag,DebertaModel:()=>sg,DebertaPreTrainedModel:()=>Kr,DebertaV2ForMaskedLM:()=>cg,DebertaV2ForQuestionAnswering:()=>dg,DebertaV2ForSequenceClassification:()=>ug,DebertaV2ForTokenClassification:()=>pg,DebertaV2Model:()=>lg,DebertaV2PreTrainedModel:()=>Qr,DecisionTransformerModel:()=>fg,DecisionTransformerPreTrainedModel:()=>du,DeiTForImageClassification:()=>mg,DeiTModel:()=>_g,DeiTPreTrainedModel:()=>ua,DepthAnythingForDepthEstimation:()=>hg,DepthAnythingPreTrainedModel:()=>fu,DepthProForDepthEstimation:()=>gg,DepthProPreTrainedModel:()=>_u,DetrForObjectDetection:()=>xg,DetrForSegmentation:()=>yg,DetrModel:()=>wg,DetrObjectDetectionOutput:()=>Ln,DetrPreTrainedModel:()=>Cn,DetrSegmentationOutput:()=>mu,Dinov2ForImageClassification:()=>vg,Dinov2Model:()=>bg,Dinov2PreTrainedModel:()=>pa,Dinov2WithRegistersForImageClassification:()=>Eg,Dinov2WithRegistersModel:()=>kg,Dinov2WithRegistersPreTrainedModel:()=>da,DistilBertForMaskedLM:()=>Cg,DistilBertForQuestionAnswering:()=>Ig,DistilBertForSequenceClassification:()=>Tg,DistilBertForTokenClassification:()=>Og,DistilBertModel:()=>Sg,DistilBertPreTrainedModel:()=>Yr,DonutSwinModel:()=>Lg,DonutSwinPreTrainedModel:()=>wu,EdgeTamModel:()=>T0,EfficientNetForImageClassification:()=>$g,EfficientNetModel:()=>Ng,EfficientNetPreTrainedModel:()=>_a,ElectraForMaskedLM:()=>Dg,ElectraForQuestionAnswering:()=>Ug,ElectraForSequenceClassification:()=>Fg,ElectraForTokenClassification:()=>Bg,ElectraModel:()=>Rg,ElectraPreTrainedModel:()=>Jr,Ernie4_5ForCausalLM:()=>Gg,Ernie4_5Model:()=>jg,Ernie4_5PretrainedModel:()=>ma,EsmForMaskedLM:()=>Wg,EsmForSequenceClassification:()=>Vg,EsmForTokenClassification:()=>Hg,EsmModel:()=>qg,EsmPreTrainedModel:()=>Ps,ExaoneForCausalLM:()=>Kg,ExaoneModel:()=>Xg,ExaonePreTrainedModel:()=>ha,FalconForCausalLM:()=>Yg,FalconH1ForCausalLM:()=>Zg,FalconH1Model:()=>Jg,FalconH1PreTrainedModel:()=>wa,FalconModel:()=>Qg,FalconPreTrainedModel:()=>ga,FastViTForImageClassification:()=>tw,FastViTModel:()=>ew,FastViTPreTrainedModel:()=>xa,Florence2ForConditionalGeneration:()=>rw,Florence2PreTrainedModel:()=>xu,GLPNForDepthEstimation:()=>dw,GLPNModel:()=>pw,GLPNPreTrainedModel:()=>Aa,GPT2LMHeadModel:()=>vw,GPT2Model:()=>bw,GPT2PreTrainedModel:()=>Ia,GPTBigCodeForCausalLM:()=>_w,GPTBigCodeModel:()=>fw,GPTBigCodePreTrainedModel:()=>Ma,GPTJForCausalLM:()=>Ew,GPTJModel:()=>kw,GPTJPreTrainedModel:()=>Ca,GPTNeoForCausalLM:()=>hw,GPTNeoModel:()=>mw,GPTNeoPreTrainedModel:()=>Sa,GPTNeoXForCausalLM:()=>ww,GPTNeoXModel:()=>gw,GPTNeoXPreTrainedModel:()=>Ta,Gemma2ForCausalLM:()=>aw,Gemma2Model:()=>ow,Gemma2PreTrainedModel:()=>ba,Gemma3ForCausalLM:()=>lw,Gemma3Model:()=>iw,Gemma3PreTrainedModel:()=>va,Gemma3nForCausalLM:()=>ka,Gemma3nForConditionalGeneration:()=>Pn,Gemma3nPreTrainedModel:()=>yu,GemmaForCausalLM:()=>nw,GemmaModel:()=>sw,GemmaPreTrainedModel:()=>ya,GlmForCausalLM:()=>uw,GlmModel:()=>cw,GlmPreTrainedModel:()=>Ea,GptOssForCausalLM:()=>yw,GptOssModel:()=>xw,GptOssPreTrainedModel:()=>Oa,GraniteForCausalLM:()=>Mw,GraniteModel:()=>Aw,GraniteMoeHybridForCausalLM:()=>Tw,GraniteMoeHybridModel:()=>Sw,GraniteMoeHybridPreTrainedModel:()=>Pa,GranitePreTrainedModel:()=>La,GraniteSpeechForConditionalGeneration:()=>Ow,GroundingDinoForObjectDetection:()=>Iw,GroundingDinoPreTrainedModel:()=>vu,GroupViTModel:()=>Cw,GroupViTPreTrainedModel:()=>ku,HeliumForCausalLM:()=>Pw,HeliumModel:()=>Lw,HeliumPreTrainedModel:()=>za,HieraForImageClassification:()=>Nw,HieraModel:()=>zw,HieraPreTrainedModel:()=>Na,HubertForCTC:()=>jw,HubertForSequenceClassification:()=>Gw,HubertModel:()=>Uw,HubertPreTrainedModel:()=>Bw,HunYuanDenseV1ForCausalLM:()=>Ww,HunYuanDenseV1Model:()=>qw,HunYuanDenseV1PreTrainedModel:()=>$a,IJepaForImageClassification:()=>Qw,IJepaModel:()=>Kw,IJepaPreTrainedModel:()=>Ra,Idefics3ForConditionalGeneration:()=>Xw,JAISLMHeadModel:()=>Jw,JAISModel:()=>Yw,JAISPreTrainedModel:()=>Da,JinaCLIPModel:()=>Zw,JinaCLIPPreTrainedModel:()=>zn,JinaCLIPTextModel:()=>Fa,JinaCLIPVisionModel:()=>ex,Lfm2ForCausalLM:()=>rx,Lfm2Model:()=>tx,Lfm2MoeForCausalLM:()=>nx,Lfm2MoeModel:()=>sx,Lfm2MoePreTrainedModel:()=>Ua,Lfm2PreTrainedModel:()=>Ba,Lfm2VlForConditionalGeneration:()=>ox,LiteWhisperForConditionalGeneration:()=>Ub,Llama4ForCausalLM:()=>lx,Llama4PreTrainedModel:()=>Au,LlamaForCausalLM:()=>ix,LlamaModel:()=>ax,LlamaPreTrainedModel:()=>ja,LlavaForConditionalGeneration:()=>Wt,LlavaOnevisionForConditionalGeneration:()=>Wt,LlavaPreTrainedModel:()=>Eu,LlavaQwen2ForCausalLM:()=>Hw,LongT5ForConditionalGeneration:()=>ux,LongT5Model:()=>cx,LongT5PreTrainedModel:()=>Ga,M2M100ForConditionalGeneration:()=>dx,M2M100Model:()=>px,M2M100PreTrainedModel:()=>qa,MBartForCausalLM:()=>yx,MBartForConditionalGeneration:()=>wx,MBartForSequenceClassification:()=>xx,MBartModel:()=>gx,MBartPreTrainedModel:()=>Ns,MPNetForMaskedLM:()=>ny,MPNetForQuestionAnswering:()=>iy,MPNetForSequenceClassification:()=>oy,MPNetForTokenClassification:()=>ay,MPNetModel:()=>sy,MPNetPreTrainedModel:()=>Zr,MT5ForConditionalGeneration:()=>py,MT5Model:()=>uy,MT5PreTrainedModel:()=>ri,MarianMTModel:()=>_x,MarianModel:()=>fx,MarianPreTrainedModel:()=>Wa,MaskFormerForInstanceSegmentation:()=>hx,MaskFormerModel:()=>mx,MaskFormerPreTrainedModel:()=>Va,Metric3DForDepthEstimation:()=>bx,Metric3DPreTrainedModel:()=>Mu,Metric3Dv2ForDepthEstimation:()=>vx,Metric3Dv2PreTrainedModel:()=>Su,MgpstrForSceneTextRecognition:()=>kx,MgpstrModelOutput:()=>Tu,MgpstrPreTrainedModel:()=>Ou,MimiDecoderModel:()=>Xa,MimiDecoderOutput:()=>Cu,MimiEncoderModel:()=>Ha,MimiEncoderOutput:()=>Iu,MimiModel:()=>Ex,MimiPreTrainedModel:()=>Nn,MistralForCausalLM:()=>Mx,MistralModel:()=>Ax,MistralPreTrainedModel:()=>Ka,MobileBertForMaskedLM:()=>Tx,MobileBertForQuestionAnswering:()=>Ix,MobileBertForSequenceClassification:()=>Ox,MobileBertModel:()=>Sx,MobileBertPreTrainedModel:()=>$s,MobileLLMForCausalLM:()=>Lx,MobileLLMModel:()=>Cx,MobileLLMPreTrainedModel:()=>Qa,MobileNetV1ForImageClassification:()=>zx,MobileNetV1ForSemanticSegmentation:()=>Nx,MobileNetV1Model:()=>Px,MobileNetV1PreTrainedModel:()=>$n,MobileNetV2ForImageClassification:()=>Rx,MobileNetV2ForSemanticSegmentation:()=>Dx,MobileNetV2Model:()=>$x,MobileNetV2PreTrainedModel:()=>Rn,MobileNetV3ForImageClassification:()=>Bx,MobileNetV3ForSemanticSegmentation:()=>Ux,MobileNetV3Model:()=>Fx,MobileNetV3PreTrainedModel:()=>Dn,MobileNetV4ForImageClassification:()=>Gx,MobileNetV4ForSemanticSegmentation:()=>qx,MobileNetV4Model:()=>jx,MobileNetV4PreTrainedModel:()=>Fn,MobileViTForImageClassification:()=>Vx,MobileViTModel:()=>Wx,MobileViTPreTrainedModel:()=>Ya,MobileViTV2ForImageClassification:()=>Xx,MobileViTV2Model:()=>Hx,MobileViTV2PreTrainedModel:()=>Ja,ModernBertDecoderForCausalLM:()=>ey,ModernBertDecoderModel:()=>Zx,ModernBertDecoderPreTrainedModel:()=>Za,ModernBertForMaskedLM:()=>Qx,ModernBertForSequenceClassification:()=>Yx,ModernBertForTokenClassification:()=>Jx,ModernBertModel:()=>Kx,ModernBertPreTrainedModel:()=>Rs,Moondream1ForConditionalGeneration:()=>Vw,MoonshineForConditionalGeneration:()=>ry,MoonshineModel:()=>ty,MoonshinePreTrainedModel:()=>ei,MptForCausalLM:()=>cy,MptModel:()=>ly,MptPreTrainedModel:()=>ti,MultiModalityCausalLM:()=>dy,MultiModalityPreTrainedModel:()=>Lu,MusicgenForCausalLM:()=>_y,MusicgenForConditionalGeneration:()=>ni,MusicgenModel:()=>fy,MusicgenPreTrainedModel:()=>si,NanoChatForCausalLM:()=>hy,NanoChatModel:()=>my,NanoChatPreTrainedModel:()=>oi,NeoBertForMaskedLM:()=>wy,NeoBertForQuestionAnswering:()=>by,NeoBertForSequenceClassification:()=>xy,NeoBertForTokenClassification:()=>yy,NeoBertModel:()=>gy,NeoBertPreTrainedModel:()=>es,NomicBertModel:()=>vy,NomicBertPreTrainedModel:()=>Pu,OPTForCausalLM:()=>zy,OPTModel:()=>Py,OPTPreTrainedModel:()=>pi,Olmo2ForCausalLM:()=>My,Olmo2Model:()=>Ay,Olmo2PreTrainedModel:()=>ii,Olmo3ForCausalLM:()=>Ty,Olmo3Model:()=>Sy,Olmo3PreTrainedModel:()=>li,OlmoForCausalLM:()=>Ey,OlmoHybridForCausalLM:()=>Iy,OlmoHybridModel:()=>Oy,OlmoHybridPreTrainedModel:()=>ci,OlmoModel:()=>ky,OlmoPreTrainedModel:()=>ai,OpenELMForCausalLM:()=>Ly,OpenELMModel:()=>Cy,OpenELMPreTrainedModel:()=>ui,OwlViTForObjectDetection:()=>Dy,OwlViTModel:()=>Ry,OwlViTPreTrainedModel:()=>fi,Owlv2ForObjectDetection:()=>$y,Owlv2Model:()=>Ny,Owlv2PreTrainedModel:()=>di,PaliGemmaForConditionalGeneration:()=>Fy,ParakeetForCTC:()=>By,ParakeetPreTrainedModel:()=>zu,PatchTSMixerForPrediction:()=>jy,PatchTSMixerModel:()=>Uy,PatchTSMixerPreTrainedModel:()=>_i,PatchTSTForPrediction:()=>qy,PatchTSTModel:()=>Gy,PatchTSTPreTrainedModel:()=>mi,Phi3ForCausalLM:()=>Xy,Phi3Model:()=>Hy,Phi3PreTrainedModel:()=>gi,Phi3VForCausalLM:()=>wi,Phi3VPreTrainedModel:()=>Nu,PhiForCausalLM:()=>Vy,PhiModel:()=>Wy,PhiPreTrainedModel:()=>hi,PreTrainedModel:()=>y,PvtForImageClassification:()=>Qy,PvtModel:()=>Ky,PvtPreTrainedModel:()=>xi,PyAnnoteForAudioFrameClassification:()=>Jy,PyAnnoteModel:()=>Yy,PyAnnotePreTrainedModel:()=>yi,Qwen2ForCausalLM:()=>e0,Qwen2Model:()=>Zy,Qwen2MoeForCausalLM:()=>r0,Qwen2MoeModel:()=>t0,Qwen2MoePreTrainedModel:()=>vi,Qwen2PreTrainedModel:()=>bi,Qwen2VLForCausalLM:()=>Ds,Qwen2VLForConditionalGeneration:()=>Bn,Qwen2VLPreTrainedModel:()=>$u,Qwen2_5_VLForCausalLM:()=>Fs,Qwen2_5_VLForConditionalGeneration:()=>ki,Qwen3ForCausalLM:()=>n0,Qwen3Model:()=>s0,Qwen3MoeForCausalLM:()=>a0,Qwen3MoeModel:()=>o0,Qwen3MoePreTrainedModel:()=>Ai,Qwen3NextForCausalLM:()=>l0,Qwen3NextModel:()=>i0,Qwen3NextPreTrainedModel:()=>Mi,Qwen3PreTrainedModel:()=>Ei,Qwen3VLForCausalLM:()=>Us,Qwen3VLForConditionalGeneration:()=>Bs,Qwen3VLMoeForCausalLM:()=>Si,Qwen3VLMoeForConditionalGeneration:()=>c0,Qwen3_5ForCausalLM:()=>js,Qwen3_5ForConditionalGeneration:()=>Un,Qwen3_5MoeForCausalLM:()=>Ti,Qwen3_5MoeForConditionalGeneration:()=>u0,RFDetrForObjectDetection:()=>_0,RFDetrModel:()=>f0,RFDetrObjectDetectionOutput:()=>Ru,RFDetrPreTrainedModel:()=>Ii,RTDetrForObjectDetection:()=>Zh,RTDetrModel:()=>Jh,RTDetrObjectDetectionOutput:()=>dr,RTDetrPreTrainedModel:()=>aa,RTDetrV2ForObjectDetection:()=>M0,RTDetrV2Model:()=>A0,RTDetrV2ObjectDetectionOutput:()=>Du,RTDetrV2PreTrainedModel:()=>Ci,ResNetForImageClassification:()=>d0,ResNetModel:()=>p0,ResNetPreTrainedModel:()=>Oi,RoFormerForMaskedLM:()=>b0,RoFormerForQuestionAnswering:()=>E0,RoFormerForSequenceClassification:()=>v0,RoFormerForTokenClassification:()=>k0,RoFormerModel:()=>y0,RoFormerPreTrainedModel:()=>rs,RobertaForMaskedLM:()=>h0,RobertaForQuestionAnswering:()=>x0,RobertaForSequenceClassification:()=>g0,RobertaForTokenClassification:()=>w0,RobertaModel:()=>m0,RobertaPreTrainedModel:()=>ts,Sam2ImageSegmentationOutput:()=>Uu,Sam2Model:()=>Li,Sam2PreTrainedModel:()=>ju,Sam3TrackerModel:()=>O0,SamImageSegmentationOutput:()=>Fu,SamModel:()=>S0,SamPreTrainedModel:()=>Bu,SapiensForDepthEstimation:()=>C0,SapiensForNormalEstimation:()=>L0,SapiensForSemanticSegmentation:()=>I0,SapiensPreTrainedModel:()=>jn,SegformerForImageClassification:()=>z0,SegformerForSemanticSegmentation:()=>N0,SegformerModel:()=>P0,SegformerPreTrainedModel:()=>Gn,SiglipModel:()=>$0,SiglipPreTrainedModel:()=>Pi,SiglipTextModel:()=>zi,SiglipVisionModel:()=>R0,SmolLM3ForCausalLM:()=>F0,SmolLM3Model:()=>D0,SmolLM3PreTrainedModel:()=>Ni,SnacDecoderModel:()=>Ri,SnacEncoderModel:()=>$i,SnacModel:()=>B0,SnacPreTrainedModel:()=>qn,SpeechT5ForSpeechToText:()=>j0,SpeechT5ForTextToSpeech:()=>G0,SpeechT5HifiGan:()=>q0,SpeechT5Model:()=>U0,SpeechT5PreTrainedModel:()=>Wn,SqueezeBertForMaskedLM:()=>V0,SqueezeBertForQuestionAnswering:()=>X0,SqueezeBertForSequenceClassification:()=>H0,SqueezeBertModel:()=>W0,SqueezeBertPreTrainedModel:()=>Gs,StableLmForCausalLM:()=>Q0,StableLmModel:()=>K0,StableLmPreTrainedModel:()=>Di,Starcoder2ForCausalLM:()=>J0,Starcoder2Model:()=>Y0,Starcoder2PreTrainedModel:()=>Fi,StyleTextToSpeech2Model:()=>Z0,StyleTextToSpeech2PreTrainedModel:()=>Gu,SupertonicForConditionalGeneration:()=>Bi,SupertonicPreTrainedModel:()=>qu,Swin2SRForImageSuperResolution:()=>nb,Swin2SRModel:()=>sb,Swin2SRPreTrainedModel:()=>Ui,SwinForImageClassification:()=>tb,SwinForSemanticSegmentation:()=>rb,SwinModel:()=>eb,SwinPreTrainedModel:()=>Vn,T5ForConditionalGeneration:()=>ab,T5Model:()=>ob,T5PreTrainedModel:()=>ji,TableTransformerForObjectDetection:()=>lb,TableTransformerModel:()=>ib,TableTransformerObjectDetectionOutput:()=>Wu,TableTransformerPreTrainedModel:()=>Gi,TrOCRForCausalLM:()=>cb,TrOCRPreTrainedModel:()=>Vu,UltravoxModel:()=>zs,UltravoxPreTrainedModel:()=>bu,UniSpeechForCTC:()=>pb,UniSpeechForSequenceClassification:()=>db,UniSpeechModel:()=>ub,UniSpeechPreTrainedModel:()=>Hn,UniSpeechSatForAudioFrameClassification:()=>hb,UniSpeechSatForCTC:()=>_b,UniSpeechSatForSequenceClassification:()=>mb,UniSpeechSatModel:()=>fb,UniSpeechSatPreTrainedModel:()=>qs,VaultGemmaForCausalLM:()=>wb,VaultGemmaModel:()=>gb,VaultGemmaPreTrainedModel:()=>qi,ViTForImageClassification:()=>bb,ViTMAEModel:()=>vb,ViTMAEPreTrainedModel:()=>Hu,ViTMSNForImageClassification:()=>Eb,ViTMSNModel:()=>kb,ViTMSNPreTrainedModel:()=>Vi,ViTModel:()=>yb,ViTPreTrainedModel:()=>Wi,VisionEncoderDecoderModel:()=>xb,VitMatteForImageMatting:()=>Ab,VitMattePreTrainedModel:()=>Xu,VitPoseForPoseEstimation:()=>Mb,VitPosePreTrainedModel:()=>Ku,VitsModel:()=>Sb,VitsModelOutput:()=>Qu,VitsPreTrainedModel:()=>Yu,VoxtralForConditionalGeneration:()=>Tb,VoxtralRealtimeForConditionalGeneration:()=>Hi,VoxtralRealtimePreTrainedModel:()=>Ju,Wav2Vec2BertForCTC:()=>Lb,Wav2Vec2BertForSequenceClassification:()=>Pb,Wav2Vec2BertModel:()=>Cb,Wav2Vec2BertPreTrainedModel:()=>Xn,Wav2Vec2ForAudioFrameClassification:()=>Fw,Wav2Vec2ForCTC:()=>Rw,Wav2Vec2ForSequenceClassification:()=>Dw,Wav2Vec2Model:()=>$w,Wav2Vec2PreTrainedModel:()=>rr,WavLMForAudioFrameClassification:()=>Db,WavLMForCTC:()=>Nb,WavLMForSequenceClassification:()=>$b,WavLMForXVector:()=>Rb,WavLMModel:()=>zb,WavLMPreTrainedModel:()=>ss,WeSpeakerResNetModel:()=>Fb,WeSpeakerResNetPreTrainedModel:()=>ep,WhisperForConditionalGeneration:()=>rp,WhisperModel:()=>Bb,WhisperPreTrainedModel:()=>Xi,XLMForQuestionAnswering:()=>Vb,XLMForSequenceClassification:()=>qb,XLMForTokenClassification:()=>Wb,XLMModel:()=>jb,XLMPreTrainedModel:()=>ns,XLMRobertaForMaskedLM:()=>Xb,XLMRobertaForQuestionAnswering:()=>Yb,XLMRobertaForSequenceClassification:()=>Kb,XLMRobertaForTokenClassification:()=>Qb,XLMRobertaModel:()=>Hb,XLMRobertaPreTrainedModel:()=>os,XLMWithLMHeadModel:()=>Gb,XVectorOutput:()=>Zu,YolosForObjectDetection:()=>Zb,YolosModel:()=>Jb,YolosObjectDetectionOutput:()=>sp,YolosPreTrainedModel:()=>Ki,YoutuForCausalLM:()=>t1,YoutuModel:()=>e1,YoutuPreTrainedModel:()=>Qi});var Ls=class extends y{},Qm=class extends Ls{},Ym=class extends Ls{async _call(e){return new G(await super._call(e))}},Jm=class extends Ls{async _call(e){return new Me(await super._call(e))}},Zm=class extends Ls{async _call(e){return new we(await super._call(e))}};var jo=class extends y{},eh=class extends jo{},th=class extends jo{};var Go=class extends y{},rh=class extends Go{},sh=class extends Go{};var qo=class extends y{},nh=class extends qo{},oh=class extends qo{};var Wo=class extends y{},ah=class extends Wo{},ih=class extends Wo{};var Tn=class extends y{},lh=class extends Tn{},ch=class extends Tn{},uh=class extends Tn{async _call(e){return new G(await super._call(e))}};var Vo=class extends y{},ph=class extends Vo{},dh=class extends Vo{async _call(e){return new G(await super._call(e))}};var Vr=class extends y{},fh=class extends Vr{},_h=class extends Vr{async _call(e){return new we(await super._call(e))}},mh=class extends Vr{async _call(e){return new G(await super._call(e))}},hh=class extends Vr{async _call(e){return new he(await super._call(e))}},gh=class extends Vr{async _call(e){return new Me(await super._call(e))}};var Ho=class extends y{},wh=class extends Ho{},xh=class extends Ho{};var Xo=class extends y{},yh=class extends Xo{},bh=class extends Xo{};var Ko=class extends y{},vh=class extends Ko{},kh=class extends Ko{};var Hr=class extends y{},Eh=class extends Hr{},Ah=class extends Hr{async _call(e){return new we(await super._call(e))}},Mh=class extends Hr{async _call(e){return new G(await super._call(e))}},Sh=class extends Hr{async _call(e){return new he(await super._call(e))}},Th=class extends Hr{async _call(e){return new Me(await super._call(e))}};var Oz=4299n,A2=6561n,lu=class extends y{forward_params=["input_ids","inputs_embeds","attention_mask","position_ids","audio_values","exaggeration","audio_features","audio_tokens","speaker_embeddings","speaker_features","past_key_values"];main_input_name="input_ids";_return_dict_in_generate_keys=["audio_tokens","speaker_embeddings","speaker_features"]},Qo=class extends lu{async encode_speech(e){return de(this.sessions.speech_encoder,{audio_values:e})}async forward({input_ids:e=null,attention_mask:r=null,audio_values:s=null,exaggeration:n=null,position_ids:o=null,inputs_embeds:a=null,past_key_values:i=null,generation_config:l=null,logits_processor:c=null,audio_features:p=null,audio_tokens:f=null,speaker_embeddings:_=null,speaker_features:m=null,...w}){let x;if(!a){let E=this.sessions.embed_tokens.inputNames,A={input_ids:e};if(E.includes("exaggeration")){if(!(n instanceof $)){let T=e.dims[0];if(n==null)n=Xe([T],.5);else if(typeof n=="number")n=Xe([T],n);else if(Array.isArray(n))n=new $("float32",n,[T]);else throw new Error("Unsupported type for `exaggeration` input")}A.exaggeration=n}if(E.includes("position_ids")&&(A.position_ids=o),{inputs_embeds:a}=await de(this.sessions.embed_tokens,A),p&&f&&_&&m&&(x={audio_features:p,audio_tokens:f,speaker_embeddings:_,speaker_features:m}),x||s)x??=await this.encode_speech(s),a=Ee([x.audio_features,a],1),r=st([a.dims[0],a.dims[1]]);else{let T=a.dims[1];if(!i||T!==1)throw new Error("Incorrect state encountered during generation.");let S=i.get_seq_length();r=st([a.dims[0],S+T])}}return{...await Ct(this,{inputs_embeds:a,past_key_values:i,attention_mask:r,generation_config:l,logits_processor:c},!1),...x}}prepare_inputs_for_generation(e,r,s){if(!r.position_ids&&this.sessions.embed_tokens.inputNames.includes("position_ids"))if(r.input_ids.dims[1]===1){let n=Array.from({length:e.length},(o,a)=>e[a].length-e[a].findLastIndex(i=>i==A2)-1);r.position_ids=new $("int64",n,[e.length,1])}else{let o=r.input_ids.tolist().map(a=>{let i=0;return a.map(l=>l>=A2?0:i++)});r.position_ids=new $("int64",o.flat(),r.input_ids.dims)}return r.input_ids.dims[1]===1&&(delete r.audio_values,delete r.audio_features,delete r.audio_tokens,delete r.speaker_embeddings,delete r.speaker_features),Mn(this,e,r,s)}async generate(e){let{sequences:r,audio_tokens:s,speaker_embeddings:n,speaker_features:o}=await super.generate({...e,return_dict_in_generate:!0}),a=r.slice(null,[e.input_ids.dims[1],-1]),i=Xe([a.dims[0],3],Oz),l=Ee([s,a,i],1),{waveform:c}=await de(this.sessions.conditional_decoder,{speech_tokens:l,speaker_features:o,speaker_embeddings:n});return c}};var cu=class extends y{},Oh=class extends cu{};var On=class extends y{},Ih=class extends On{},Yo=class extends On{static async from_pretrained(e,r={}){return super.from_pretrained(e,{...r,model_file_name:r.model_file_name??"text_model"})}},Jo=class extends On{static async from_pretrained(e,r={}){return super.from_pretrained(e,{...r,model_file_name:r.model_file_name??"audio_model"})}};var pr=class extends y{},Ch=class extends pr{},Lh=class extends pr{static async from_pretrained(e,r={}){return super.from_pretrained(e,{...r,model_file_name:r.model_file_name??"text_model"})}},Zo=class extends pr{static async from_pretrained(e,r={}){return super.from_pretrained(e,{...r,model_file_name:r.model_file_name??"text_model"})}},Ph=class extends pr{static async from_pretrained(e,r={}){return super.from_pretrained(e,{...r,model_file_name:r.model_file_name??"vision_model"})}},zh=class extends pr{static async from_pretrained(e,r={}){return super.from_pretrained(e,{...r,model_file_name:r.model_file_name??"vision_model"})}};var ea=class extends y{},Nh=class extends ea{},$h=class extends ea{};var ta=class extends y{},Rh=class extends ta{},Dh=class extends ta{};var ra=class extends y{},Fh=class extends ra{},Bh=class extends ra{};var sa=class extends y{},Uh=class extends sa{},jh=class extends sa{};var Xr=class extends y{},Gh=class extends Xr{},qh=class extends Xr{async _call(e){return new we(await super._call(e))}},Wh=class extends Xr{async _call(e){return new G(await super._call(e))}},Vh=class extends Xr{async _call(e){return new he(await super._call(e))}},Hh=class extends Xr{async _call(e){return new Me(await super._call(e))}};var na=class extends y{},Xh=class extends na{},Kh=class extends na{async _call(e){return new G(await super._call(e))}};var oa=class extends y{},Qh=class extends oa{},Yh=class extends oa{async _call(e){return new G(await super._call(e))}};var aa=class extends y{},Jh=class extends aa{},Zh=class extends aa{async _call(e){return new dr(await super._call(e))}},dr=class extends Re{constructor({logits:e,pred_boxes:r}){super(),this.logits=e,this.pred_boxes=r}};var ia=class extends y{},eg=class extends ia{},tg=class extends ia{async _call(e){return new dr(await super._call(e))}};var uu=class extends Re{constructor({audio_codes:e}){super(),this.audio_codes=e}},pu=class extends Re{constructor({audio_values:e}){super(),this.audio_values=e}},In=class extends y{main_input_name="input_values";forward_params=["input_values"]},rg=class extends In{async encode(e){return new uu(await de(this.sessions.encoder_model,e))}async decode(e){return new pu(await de(this.sessions.decoder_model,e))}},la=class extends In{static async from_pretrained(e,r={}){return super.from_pretrained(e,{...r,model_file_name:r.model_file_name??"encoder_model"})}},ca=class extends In{static async from_pretrained(e,r={}){return super.from_pretrained(e,{...r,model_file_name:r.model_file_name??"decoder_model"})}};var Kr=class extends y{},sg=class extends Kr{},ng=class extends Kr{async _call(e){return new we(await super._call(e))}},og=class extends Kr{async _call(e){return new G(await super._call(e))}},ag=class extends Kr{async _call(e){return new he(await super._call(e))}},ig=class extends Kr{async _call(e){return new Me(await super._call(e))}};var Qr=class extends y{},lg=class extends Qr{},cg=class extends Qr{async _call(e){return new we(await super._call(e))}},ug=class extends Qr{async _call(e){return new G(await super._call(e))}},pg=class extends Qr{async _call(e){return new he(await super._call(e))}},dg=class extends Qr{async _call(e){return new Me(await super._call(e))}};var du=class extends y{},fg=class extends du{};var ua=class extends y{},_g=class extends ua{},mg=class extends ua{async _call(e){return new G(await super._call(e))}};var fu=class extends y{},hg=class extends fu{};var _u=class extends y{},gg=class extends _u{};var Cn=class extends y{},wg=class extends Cn{},xg=class extends Cn{async _call(e){return new Ln(await super._call(e))}},yg=class extends Cn{async _call(e){return new mu(await super._call(e))}},Ln=class extends Re{constructor({logits:e,pred_boxes:r}){super(),this.logits=e,this.pred_boxes=r}},mu=class extends Re{constructor({logits:e,pred_boxes:r,pred_masks:s}){super(),this.logits=e,this.pred_boxes=r,this.pred_masks=s}};var pa=class extends y{},bg=class extends pa{},vg=class extends pa{async _call(e){return new G(await super._call(e))}};var da=class extends y{},kg=class extends da{},Eg=class extends da{async _call(e){return new G(await super._call(e))}};var hu=class extends y{},Ag=class extends hu{};var gu=class extends y{},Mg=class extends gu{};var Yr=class extends y{},Sg=class extends Yr{},Tg=class extends Yr{async _call(e){return new G(await super._call(e))}},Og=class extends Yr{async _call(e){return new he(await super._call(e))}},Ig=class extends Yr{async _call(e){return new Me(await super._call(e))}},Cg=class extends Yr{async _call(e){return new we(await super._call(e))}};var wu=class extends y{},Lg=class extends wu{};var fa=class extends y{},Pg=class extends fa{},zg=class extends fa{};var _a=class extends y{},Ng=class extends _a{},$g=class extends _a{async _call(e){return new G(await super._call(e))}};var Jr=class extends y{},Rg=class extends Jr{},Dg=class extends Jr{async _call(e){return new we(await super._call(e))}},Fg=class extends Jr{async _call(e){return new G(await super._call(e))}},Bg=class extends Jr{async _call(e){return new he(await super._call(e))}},Ug=class extends Jr{async _call(e){return new Me(await super._call(e))}};var ma=class extends y{},jg=class extends ma{},Gg=class extends ma{};var Ps=class extends y{},qg=class extends Ps{},Wg=class extends Ps{async _call(e){return new we(await super._call(e))}},Vg=class extends Ps{async _call(e){return new G(await super._call(e))}},Hg=class extends Ps{async _call(e){return new he(await super._call(e))}};var ha=class extends y{},Xg=class extends ha{},Kg=class extends ha{};var ga=class extends y{},Qg=class extends ga{},Yg=class extends ga{};var wa=class extends y{},Jg=class extends wa{},Zg=class extends wa{};var xa=class extends y{},ew=class extends xa{},tw=class extends xa{async _call(e){return new G(await super._call(e))}};var xu=class extends y{forward_params=["input_ids","inputs_embeds","attention_mask","pixel_values","encoder_outputs","decoder_input_ids","decoder_inputs_embeds","decoder_attention_mask","past_key_values"];main_input_name="inputs_embeds"},rw=class extends xu{_merge_input_ids_with_image_features({inputs_embeds:e,image_features:r,input_ids:s,attention_mask:n}){return{inputs_embeds:Ee([r,e],1),attention_mask:Ee([st(r.dims.slice(0,2)),n],1)}}async _prepare_inputs_embeds({input_ids:e,pixel_values:r,inputs_embeds:s,attention_mask:n}){if(!e&&!r)throw new Error("Either `input_ids` or `pixel_values` should be provided.");let o,a;return e&&(o=await this.encode_text({input_ids:e})),r&&(a=await this.encode_image({pixel_values:r})),o&&a?{inputs_embeds:s,attention_mask:n}=this._merge_input_ids_with_image_features({inputs_embeds:o,image_features:a,input_ids:e,attention_mask:n}):s=o||a,{inputs_embeds:s,attention_mask:n}}async forward({input_ids:e,pixel_values:r,attention_mask:s,decoder_input_ids:n,decoder_attention_mask:o,encoder_outputs:a,past_key_values:i,inputs_embeds:l,decoder_inputs_embeds:c}){if(l||({inputs_embeds:l,attention_mask:s}=await this._prepare_inputs_embeds({input_ids:e,pixel_values:r,inputs_embeds:l,attention_mask:s})),!a){let{last_hidden_state:f}=await qt(this,{inputs_embeds:l,attention_mask:s});a=f}if(!c){if(!n)throw new Error("Either `decoder_input_ids` or `decoder_inputs_embeds` should be provided.");c=await this.encode_text({input_ids:n})}return await Ct(this,{inputs_embeds:c,attention_mask:o,encoder_attention_mask:s,encoder_hidden_states:a,past_key_values:i},!0)}};var ya=class extends y{},sw=class extends ya{},nw=class extends ya{};var ba=class extends y{},ow=class extends ba{},aw=class extends ba{};var va=class extends y{},iw=class extends va{},lw=class extends va{};var yu=class extends y{forward_params=["input_ids","attention_mask","inputs_embeds","per_layer_inputs","position_ids","pixel_values","input_features","input_features_mask","past_key_values"]},Pn=class extends yu{async forward({input_ids:e=null,attention_mask:r=null,pixel_values:s=null,input_features:n=null,input_features_mask:o=null,position_ids:a=null,inputs_embeds:i=null,per_layer_inputs:l=null,past_key_values:c=null,generation_config:p=null,logits_processor:f=null,..._}){if((!i||!l)&&({inputs_embeds:i,per_layer_inputs:l}=await de(this.sessions.embed_tokens,{input_ids:e}),e.dims[1]!==1)){if(s){let{image_features:w}=await de(this.sessions.vision_encoder,{pixel_values:s});({inputs_embeds:i,attention_mask:r}=this._merge_input_ids_with_image_features({image_features:w,inputs_embeds:i,input_ids:e,attention_mask:r}))}if(n){let{audio_features:w}=await de(this.sessions.audio_encoder,{input_features:n,input_features_mask:o});({inputs_embeds:i,attention_mask:r}=this._merge_input_ids_with_audio_features({audio_features:w,inputs_embeds:i,input_ids:e,attention_mask:r}))}}return await Ct(this,{inputs_embeds:i,per_layer_inputs:l,past_key_values:c,attention_mask:r,position_ids:a,generation_config:p,logits_processor:f},!0)}_merge_input_ids_with_image_features(e){let r=e.image_features.dims.at(-1),s=e.image_features.view(-1,r);return Sn({image_token_id:this.config.image_token_id,...e,image_features:s})}_merge_input_ids_with_audio_features(e){let r=e.audio_features.dims.at(-1),s=e.audio_features.view(-1,r);return iu({audio_token_id:this.config.audio_token_id,...e,audio_features:s})}},ka=class extends Pn{};var Ea=class extends y{},cw=class extends Ea{},uw=class extends Ea{};var Aa=class extends y{},pw=class extends Aa{},dw=class extends Aa{};var Ma=class extends y{},fw=class extends Ma{},_w=class extends Ma{};var Sa=class extends y{},mw=class extends Sa{},hw=class extends Sa{};var Ta=class extends y{},gw=class extends Ta{},ww=class extends Ta{};var Oa=class extends y{},xw=class extends Oa{},yw=class extends Oa{};var Ia=class extends y{},bw=class extends Ia{},vw=class extends Ia{};var Ca=class extends y{},kw=class extends Ca{},Ew=class extends Ca{};var La=class extends y{},Aw=class extends La{},Mw=class extends La{};var Pa=class extends y{},Sw=class extends Pa{},Tw=class extends Pa{};var bu=class extends y{forward_params=["input_ids","attention_mask","position_ids","audio_values","past_key_values"]},zs=class extends bu{_merge_input_ids_with_audio_features(e){let r=e.audio_features.dims.at(-1),s=e.audio_features.view(-1,r);return iu({audio_token_id:this.config.ignore_index??this.config.audio_token_id??this.config.audio_token_index,...e,audio_features:s})}};var Ow=class extends zs{forward_params=["input_ids","attention_mask","input_features","past_key_values"]};var vu=class extends y{},Iw=class extends vu{};var ku=class extends y{},Cw=class extends ku{};var za=class extends y{},Lw=class extends za{},Pw=class extends za{};var Na=class extends y{},zw=class extends Na{},Nw=class extends Na{async _call(e){return new G(await super._call(e))}};var rr=class extends y{},$w=class extends rr{},Rw=class extends rr{async _call(e){return new kt(await super._call(e))}},Dw=class extends rr{async _call(e){return new G(await super._call(e))}},Fw=class extends rr{async _call(e){return new he(await super._call(e))}};var Bw=class extends y{},Uw=class extends rr{},jw=class extends rr{async _call(e){return new kt(await super._call(e))}},Gw=class extends rr{async _call(e){return new G(await super._call(e))}};var $a=class extends y{},qw=class extends $a{},Ww=class extends $a{};var Eu=class extends y{forward_params=["input_ids","attention_mask","pixel_values","position_ids","past_key_values"]},Wt=class extends Eu{_merge_input_ids_with_image_features(e){let r=e.image_features.dims.at(-1),s=e.image_features.view(-1,r);return Sn({image_token_id:this.config.image_token_index??this.config.image_token_id,...e,image_features:s})}},Vw=class extends Wt{},Hw=class extends Wt{};var Xw=class extends Wt{forward_params=["input_ids","attention_mask","pixel_values","pixel_attention_mask","position_ids","past_key_values"]};var Ra=class extends y{},Kw=class extends Ra{},Qw=class extends Ra{async _call(e){return new G(await super._call(e))}};var Da=class extends y{},Yw=class extends Da{},Jw=class extends Da{};var zn=class extends y{},Zw=class extends zn{async forward(e){let r=!e.input_ids,s=!e.pixel_values;if(r&&s)throw new Error("Either `input_ids` or `pixel_values` should be provided.");if(r&&(e.input_ids=st([e.pixel_values.dims[0],1])),s){let{image_size:c}=this.config.vision_config;e.pixel_values=Xe([0,3,c,c],0)}let{text_embeddings:n,image_embeddings:o,l2norm_text_embeddings:a,l2norm_image_embeddings:i}=await super.forward(e),l={};return r||(l.text_embeddings=n,l.l2norm_text_embeddings=a),s||(l.image_embeddings=o,l.l2norm_image_embeddings=i),l}},Fa=class extends zn{static async from_pretrained(e,r={}){return super.from_pretrained(e,{...r,model_file_name:r.model_file_name??"text_model"})}},ex=class extends zn{static async from_pretrained(e,r={}){return super.from_pretrained(e,{...r,model_file_name:r.model_file_name??"vision_model"})}};var Ba=class extends y{},tx=class extends Ba{},rx=class extends Ba{};var Ua=class extends y{},sx=class extends Ua{},nx=class extends Ua{};var ox=class extends Wt{forward_params=["input_ids","attention_mask","pixel_values","pixel_attention_mask","spatial_shapes","position_ids","past_key_values"]};var ja=class extends y{},ax=class extends ja{},ix=class extends ja{};var Au=class extends y{},lx=class extends Au{};var Ga=class extends y{},cx=class extends Ga{},ux=class extends Ga{};var qa=class extends y{},px=class extends qa{},dx=class extends qa{};var Wa=class extends y{},fx=class extends Wa{},_x=class extends Wa{};var Va=class extends y{},mx=class extends Va{},hx=class extends Va{};var Ns=class extends y{},gx=class extends Ns{},wx=class extends Ns{},xx=class extends Ns{async _call(e){return new G(await super._call(e))}},yx=class extends Ns{};var Mu=class extends y{},bx=class extends Mu{};var Su=class extends y{},vx=class extends Su{};var Tu=class extends Re{constructor({char_logits:e,bpe_logits:r,wp_logits:s}){super(),this.char_logits=e,this.bpe_logits=r,this.wp_logits=s}get logits(){return[this.char_logits,this.bpe_logits,this.wp_logits]}},Ou=class extends y{},kx=class extends Ou{async _call(e){return new Tu(await super._call(e))}};var Iu=class extends Re{constructor({audio_codes:e}){super(),this.audio_codes=e}},Cu=class extends Re{constructor({audio_values:e}){super(),this.audio_values=e}},Nn=class extends y{main_input_name="input_values";forward_params=["input_values"]},Ex=class extends Nn{async encode(e){return new Iu(await de(this.sessions.encoder_model,e))}async decode(e){return new Cu(await de(this.sessions.decoder_model,e))}},Ha=class extends Nn{static async from_pretrained(e,r={}){return super.from_pretrained(e,{...r,model_file_name:r.model_file_name??"encoder_model"})}},Xa=class extends Nn{static async from_pretrained(e,r={}){return super.from_pretrained(e,{...r,model_file_name:r.model_file_name??"decoder_model"})}};var Ka=class extends y{},Ax=class extends Ka{},Mx=class extends Ka{};var $s=class extends y{},Sx=class extends $s{},Tx=class extends $s{async _call(e){return new we(await super._call(e))}},Ox=class extends $s{async _call(e){return new G(await super._call(e))}},Ix=class extends $s{async _call(e){return new Me(await super._call(e))}};var Qa=class extends y{},Cx=class extends Qa{},Lx=class extends Qa{};var $n=class extends y{},Px=class extends $n{},zx=class extends $n{async _call(e){return new G(await super._call(e))}},Nx=class extends $n{};var Rn=class extends y{},$x=class extends Rn{},Rx=class extends Rn{async _call(e){return new G(await super._call(e))}},Dx=class extends Rn{};var Dn=class extends y{},Fx=class extends Dn{},Bx=class extends Dn{async _call(e){return new G(await super._call(e))}},Ux=class extends Dn{};var Fn=class extends y{},jx=class extends Fn{},Gx=class extends Fn{async _call(e){return new G(await super._call(e))}},qx=class extends Fn{};var Ya=class extends y{},Wx=class extends Ya{},Vx=class extends Ya{async _call(e){return new G(await super._call(e))}};var Ja=class extends y{},Hx=class extends Ja{},Xx=class extends Ja{async _call(e){return new G(await super._call(e))}};var Rs=class extends y{},Kx=class extends Rs{},Qx=class extends Rs{async _call(e){return new we(await super._call(e))}},Yx=class extends Rs{async _call(e){return new G(await super._call(e))}},Jx=class extends Rs{async _call(e){return new he(await super._call(e))}};var Za=class extends y{},Zx=class extends Za{},ey=class extends Za{};var ei=class extends y{requires_attention_mask=!1;main_input_name="input_values";forward_params=["input_values","decoder_input_ids","past_key_values"]},ty=class extends ei{},ry=class extends ei{};var Zr=class extends y{},sy=class extends Zr{},ny=class extends Zr{async _call(e){return new we(await super._call(e))}},oy=class extends Zr{async _call(e){return new G(await super._call(e))}},ay=class extends Zr{async _call(e){return new he(await super._call(e))}},iy=class extends Zr{async _call(e){return new Me(await super._call(e))}};var ti=class extends y{},ly=class extends ti{},cy=class extends ti{};var ri=class extends y{},uy=class extends ri{},py=class extends ri{};var Lu=class extends y{},dy=class extends Lu{forward_params=["input_ids","pixel_values","images_seq_mask","images_emb_mask","attention_mask","position_ids","past_key_values"];constructor(...e){super(...e),this._generation_mode="text"}async forward(e){let r=this._generation_mode??"text",s;if(r==="text"||!e.past_key_values){let l=this.sessions.prepare_inputs_embeds,c=Qe(e,l.inputNames);s=await de(l,c)}else{let l=this.sessions.gen_img_embeds,c=Qe({image_ids:e.input_ids},l.inputNames);s=await de(l,c)}let n={...e,...s},o=await Ct(this,n),a=this.sessions[r==="text"?"lm_head":"gen_head"];if(!a)throw new Error(`Unable to find "${a}" generation head`);let i=await de(a,Qe(o,a.inputNames));return{...s,...o,...i}}prepare_inputs_for_generation(e,r,s){let n=!!r.past_key_values;return s.guidance_scale!==null&&s.guidance_scale>1&&(n?r.input_ids=Ee([r.input_ids,r.input_ids],0):(r.input_ids=Ee([r.input_ids,Ao(r.input_ids,BigInt(s.pad_token_id))],0),r.attention_mask=Ee([r.attention_mask,Ao(r.attention_mask,0n)],0))),(n||!r.pixel_values)&&(r.pixel_values=Xe([0,0,3,384,384],1)),n&&(r.images_seq_mask=new $("bool",new Array(1).fill(!0).fill(!1,0,1),[1,1]),r.images_emb_mask=new $("bool",new Array(0).fill(!1),[1,1,0])),r}async generate(e){return this._generation_mode="text",super.generate(e)}async generate_images(e){this._generation_mode="image";let r=(e.inputs??e[this.main_input_name]).dims[1],n=(await super.generate(e)).slice(null,[r,null]),o=this.sessions.image_decode,{decoded_image:a}=await de(o,{generated_tokens:n}),i=a.add_(1).mul_(255/2).clamp_(0,255).to("uint8"),l=[];for(let c of i){let p=Ye.fromTensor(c);l.push(p)}return l}};var si=class extends y{},fy=class extends si{},_y=class extends si{},ni=class extends y{forward_params=["input_ids","attention_mask","encoder_outputs","decoder_input_ids","decoder_attention_mask","past_key_values"];_apply_and_filter_by_delay_pattern_mask(e){let[r,s]=e.dims,n=this.config.decoder.num_codebooks,o=s-n,a=0;for(let c=0;c<e.size;++c){if(e.data[c]==this.config.decoder.pad_token_id)continue;let p=c%s,f=Math.floor(c/s)%n,_=p-f;_>0&&_<=o&&(e.data[a++]=e.data[c])}let i=Math.floor(r/n),l=a/(i*n);return new $(e.type,e.data.slice(0,a),[i,n,l])}prepare_inputs_for_generation(e,r,s){let n=BigInt(this.config.decoder.pad_token_id),o=structuredClone(e);for(let a=0;a<o.length;++a)for(let i=0;i<o[a].length;++i)a%this.config.decoder.num_codebooks>=i&&(o[a][i]=n);return s.guidance_scale!==null&&s.guidance_scale>1&&(o=o.concat(o)),Uo(this,o,r,s)}async generate(e){let r=await super.generate(e),s=this._apply_and_filter_by_delay_pattern_mask(r).unsqueeze_(0),{audio_values:n}=await de(this.sessions.encodec_decode,{audio_codes:s});return n}};var oi=class extends y{},my=class extends oi{},hy=class extends oi{};var es=class extends y{},gy=class extends es{},wy=class extends es{async _call(e){return new we(await super._call(e))}},xy=class extends es{async _call(e){return new G(await super._call(e))}},yy=class extends es{async _call(e){return new he(await super._call(e))}},by=class extends es{async _call(e){return new Me(await super._call(e))}};var Pu=class extends y{},vy=class extends Pu{};var ai=class extends y{},ky=class extends ai{},Ey=class extends ai{};var ii=class extends y{},Ay=class extends ii{},My=class extends ii{};var li=class extends y{},Sy=class extends li{},Ty=class extends li{};var ci=class extends y{},Oy=class extends ci{},Iy=class extends ci{};var ui=class extends y{},Cy=class extends ui{},Ly=class extends ui{};var pi=class extends y{},Py=class extends pi{},zy=class extends pi{};var di=class extends y{},Ny=class extends di{},$y=class extends di{};var fi=class extends y{},Ry=class extends fi{},Dy=class extends fi{};var Fy=class extends Wt{};var zu=class extends y{},By=class extends zu{async _call(e){return new kt(await super._call(e))}};var _i=class extends y{},Uy=class extends _i{},jy=class extends _i{};var mi=class extends y{},Gy=class extends mi{},qy=class extends mi{};var hi=class extends y{},Wy=class extends hi{},Vy=class extends hi{};var gi=class extends y{},Hy=class extends gi{},Xy=class extends gi{};var Nu=class extends y{forward_params=["input_ids","inputs_embeds","attention_mask","position_ids","pixel_values","image_sizes","past_key_values"]},wi=class extends Nu{async forward({input_ids:e=null,attention_mask:r=null,pixel_values:s=null,image_sizes:n=null,position_ids:o=null,inputs_embeds:a=null,past_key_values:i=null,generation_config:l=null,logits_processor:c=null,...p}){if(!a){let _;if(s&&e.dims[1]!==1){if(!n)throw new Error("`image_sizes` must be provided when `pixel_values` is provided.");({image_features:_}=await de(this.sessions.vision_encoder,{pixel_values:s,image_sizes:n}))}else{let m=this.config.normalized_config.hidden_size;_=new $("float32",[],[0,m])}({inputs_embeds:a}=await de(this.sessions.prepare_inputs_embeds,{input_ids:e,image_features:_}))}return await Ct(this,{inputs_embeds:a,past_key_values:i,attention_mask:r,position_ids:o,generation_config:l,logits_processor:c},!1)}};var xi=class extends y{},Ky=class extends xi{},Qy=class extends xi{async _call(e){return new G(await super._call(e))}};var yi=class extends y{},Yy=class extends yi{},Jy=class extends yi{async _call(e){return new he(await super._call(e))}};var bi=class extends y{},Zy=class extends bi{},e0=class extends bi{};var vi=class extends y{},t0=class extends vi{},r0=class extends vi{};var $u=class extends y{forward_params=["input_ids","attention_mask","position_ids","past_key_values","pixel_values","image_grid_thw"]},Bn=class extends $u{image_grid_thw_name="grid_thw";get_rope_index(e,r,s,n){let{vision_config:o,image_token_id:a,video_token_id:i,vision_start_token_id:l}=this.config,c=o.spatial_merge_size??2,p=[];if(r||s){let f=e.tolist();n||(n=wc(e));let _=n.tolist(),m=Array.from({length:3},A=>Array.from({length:e.dims[0]},T=>Array.from({length:e.dims[1]},S=>1))),w=r?r.tolist():[],x=s?s.tolist():[],k=0,E=0;for(let A=0;A<f.length;++A){let T=f[A].filter((L,z)=>_[A][z]==1),P=T.reduce((L,z,R)=>(z==l&&L.push(R),L),[]).map(L=>T[L+1]),O=P.filter(L=>L==a).length,v=P.filter(L=>L==i).length,j=[],H=0,B=O,V=v;for(let L=0;L<P.length;++L){let z=T.findIndex((Tt,ot)=>ot>H&&Tt==a),R=T.findIndex((Tt,ot)=>ot>H&&Tt==i),J=B>0&&z!==-1?z:T.length+1,Ie=V>0&&R!==-1?R:T.length+1,ae,Ue,Je,tt;J<Ie?([Ue,Je,tt]=w[k],++k,--B,ae=J):([Ue,Je,tt]=x[E],++E,--V,ae=Ie);let[nt,at,Se]=[Number(Ue),Math.floor(Number(Je)/c),Math.floor(Number(tt)/c)],xe=ae-H,We=j.length>0?Ce(j.at(-1))[0]+1:0;j.push(Array.from({length:3*xe},(Tt,ot)=>We+ot%xe));let St=xe+We,ve=nt*at*Se,De=Array.from({length:ve},(Tt,ot)=>St+Math.floor(ot/(at*Se))),Sr=Array.from({length:ve},(Tt,ot)=>St+Math.floor(ot/Se)%at),is=Array.from({length:ve},(Tt,ot)=>St+ot%Se);j.push([De,Sr,is].flat()),H=ae+ve}if(H<T.length){let L=j.length>0?Ce(j.at(-1))[0]+1:0,z=T.length-H;j.push(Array.from({length:3*z},(R,J)=>L+J%z))}let q=j.reduce((L,z)=>L+z.length,0),Q=new Array(q),F=0;for(let L=0;L<3;++L)for(let z=0;z<j.length;++z){let R=j[z],J=R.length/3;for(let Ie=L*J;Ie<(L+1)*J;++Ie)Q[F++]=R[Ie]}let C=0,te=_[A];for(let L=0;L<te.length;++L)if(te[L]==1){for(let z=0;z<3;++z)m[z][A][L]=Q[z*q/3+C];++C}let le=Ce(Q)[0];p.push(le+1-f[A].length)}return[new $("int64",m.flat(1/0),[3,e.dims[0],e.dims[1]]),new $("int64",p,[p.length,1])]}else if(n){let{data:f,dims:_}=Km(n),m=BigInt64Array.from({length:3*f.length},(x,k)=>f[k%f.length]),w=Array.from({length:_[0]},(x,k)=>Ce(f.subarray(_[1]*k,_[1]*(k+1)))[0]+1n+BigInt(_[1]));return[new $("int64",m,[3,..._]),new $("int64",w,[w.length,1])]}else{let[f,_]=e.dims,m=BigInt64Array.from({length:3*f*_},(w,x)=>BigInt(Math.floor(x%_/f)));return[new $("int64",m,[3,...e.dims]),ff([f,1])]}}async encode_image({pixel_values:e,image_grid_thw:r}){return(await de(this.sessions.vision_encoder,{pixel_values:e,[this.image_grid_thw_name]:r})).image_features}_merge_input_ids_with_image_features(e){return Sn({image_token_id:this.config.image_token_id,...e})}prepare_inputs_for_generation(e,r,s){if(r.attention_mask&&!r.position_ids)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;let n=r.past_key_values.get_seq_length();if(n<r.input_ids.dims[1]){let[o,a]=this.get_rope_index(r.input_ids,r.image_grid_thw,r.video_grid_thw,r.attention_mask);r.rope_deltas=a,r.position_ids=o.slice(null,null,[n,null]),r.input_ids=r.input_ids.slice(null,[n,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));let o=BigInt(n),a=r.rope_deltas.map(i=>o+i);r.position_ids=It([a,a,a],0)}}return r}},Ds=class extends Bn{};var ki=class extends Bn{image_grid_thw_name="image_grid_thw"},Fs=class extends Ds{image_grid_thw_name="image_grid_thw"};var Ei=class extends y{},s0=class extends Ei{},n0=class extends Ei{};var Ai=class extends y{},o0=class extends Ai{},a0=class extends Ai{};var Mi=class extends y{},i0=class extends Mi{},l0=class extends Mi{};var Bs=class extends ki{},Us=class extends Fs{};var c0=class extends Bs{},Si=class extends Us{};var Un=class extends Bs{},js=class extends Un{};var u0=class extends Un{},Ti=class extends js{};var Oi=class extends y{},p0=class extends Oi{},d0=class extends Oi{async _call(e){return new G(await super._call(e))}};var Ii=class extends y{},f0=class extends Ii{},_0=class extends Ii{async _call(e){return new Ru(await super._call(e))}},Ru=class extends dr{};var ts=class extends y{},m0=class extends ts{},h0=class extends ts{async _call(e){return new we(await super._call(e))}},g0=class extends ts{async _call(e){return new G(await super._call(e))}},w0=class extends ts{async _call(e){return new he(await super._call(e))}},x0=class extends ts{async _call(e){return new Me(await super._call(e))}};var rs=class extends y{},y0=class extends rs{},b0=class extends rs{async _call(e){return new we(await super._call(e))}},v0=class extends rs{async _call(e){return new G(await super._call(e))}},k0=class extends rs{async _call(e){return new he(await super._call(e))}},E0=class extends rs{async _call(e){return new Me(await super._call(e))}};var Ci=class extends y{},A0=class extends Ci{},M0=class extends Ci{async _call(e){return new Du(await super._call(e))}},Du=class extends dr{};var Fu=class extends Re{constructor({iou_scores:e,pred_masks:r}){super(),this.iou_scores=e,this.pred_masks=r}},Bu=class extends y{},S0=class extends Bu{async get_image_embeddings({pixel_values:e}){return await qt(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??=st(e.input_points.dims.slice(0,-1));let r={image_embeddings:e.image_embeddings,image_positional_embeddings:e.image_positional_embeddings};return e.input_points&&(r.input_points=e.input_points),e.input_labels&&(r.input_labels=e.input_labels),e.input_boxes&&(r.input_boxes=e.input_boxes),await de(this.sessions.prompt_encoder_mask_decoder,r)}async _call(e){return new Fu(await super._call(e))}};var Uu=class extends Re{constructor({iou_scores:e,pred_masks:r,object_score_logits:s}){super(),this.iou_scores=e,this.pred_masks=r,this.object_score_logits=s}},ju=class extends y{},Li=class extends ju{async get_image_embeddings({pixel_values:e}){return await qt(this,{pixel_values:e})}async forward(e){let{num_feature_levels:r}=this.config.vision_config;if(Array.from({length:r},(a,i)=>`image_embeddings.${i}`).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.");let a=e.input_points.dims;e.input_labels??=st(a.slice(0,-1)),e.input_boxes??=Xe([a[0],0,4],0)}else if(e.input_boxes){let a=e.input_boxes.dims;e.input_labels=Xe([a[0],a[1],0],-1n),e.input_points=Xe([a[0],1,0,2],0)}else throw new Error("At least one of `input_points` or `input_boxes` must be provided.");let n=this.sessions.prompt_encoder_mask_decoder,o=Qe(e,n.inputNames);return await de(n,o)}async _call(e){return new Uu(await super._call(e))}},T0=class extends Li{},O0=class extends Li{};var jn=class extends y{},I0=class extends jn{},C0=class extends jn{},L0=class extends jn{};var Gn=class extends y{},P0=class extends Gn{},z0=class extends Gn{},N0=class extends Gn{};var Pi=class extends y{},$0=class extends Pi{},zi=class extends Pi{static async from_pretrained(e,r={}){return super.from_pretrained(e,{...r,model_file_name:r.model_file_name??"text_model"})}},R0=class extends pr{static async from_pretrained(e,r={}){return super.from_pretrained(e,{...r,model_file_name:r.model_file_name??"vision_model"})}};var Ni=class extends y{},D0=class extends Ni{},F0=class extends Ni{};var qn=class extends y{main_input_name="input_values";forward_params=["input_values"]},B0=class extends qn{async encode(e){return await de(this.sessions.encoder_model,e)}async decode(e){return await de(this.sessions.decoder_model,e)}},$i=class extends qn{static async from_pretrained(e,r={}){return super.from_pretrained(e,{...r,model_file_name:r.model_file_name??"encoder_model"})}},Ri=class extends qn{static async from_pretrained(e,r={}){return super.from_pretrained(e,{...r,model_file_name:r.model_file_name??"decoder_model"})}};var Wn=class extends y{},U0=class extends Wn{},j0=class extends Wn{},G0=class extends Wn{async generate_speech(e,r,{threshold:s=.5,minlenratio:n=0,maxlenratio:o=20,vocoder:a=null}={}){let i={input_ids:e},{encoder_outputs:l,encoder_attention_mask:c}=await qt(this,i),p=l.dims[1]/this.config.reduction_factor,f=Math.floor(p*o),_=Math.floor(p*n),m=this.config.num_mel_bins,w=[],x=null,k=null,E=0;for(;;){++E;let S=Xm(!!k),P;k?P=k.output_sequence_out:P=new $("float32",new Float32Array(m),[1,1,m]);let O={use_cache_branch:S,output_sequence:P,encoder_attention_mask:c,speaker_embeddings:r,encoder_hidden_states:l};this.addPastKeyValues(O,x),k=await de(this.sessions.decoder_model_merged,O),x=this.getPastKeyValues(k,x);let{prob:v,spectrum:j}=k;if(w.push(j),E>=_&&(Array.from(v.data).filter(H=>H>=s).length>0||E>=f))break}let A=Ee(w),{waveform:T}=await de(a.sessions.model,{spectrogram:A});return{spectrogram:A,waveform:T}}},q0=class extends y{main_input_name="spectrogram"};var Gs=class extends y{},W0=class extends Gs{},V0=class extends Gs{async _call(e){return new we(await super._call(e))}},H0=class extends Gs{async _call(e){return new G(await super._call(e))}},X0=class extends Gs{async _call(e){return new Me(await super._call(e))}};var Di=class extends y{},K0=class extends Di{},Q0=class extends Di{};var Fi=class extends y{},Y0=class extends Fi{},J0=class extends Fi{};var Gu=class extends y{},Z0=class extends Gu{};var qu=class extends y{},Bi=class extends qu{async generate_speech({input_ids:e,attention_mask:r,style:s,num_inference_steps:n=5,speed:o=1.05}){let{sampling_rate:a,chunk_compress_factor:i,base_chunk_size:l,latent_dim:c}=this.config,{last_hidden_state:p,durations:f}=await de(this.sessions.text_encoder,{input_ids:e,attention_mask:r,style:s}),_=f.div(o).mul_(a),m=l*i,w=_.data,x=Int32Array.from(w,B=>Math.ceil(B/m)),k=Math.max(...x),E=e.dims[0],A=new BigInt64Array(E*k);for(let B=0;B<E;++B)A.fill(1n,B*k,B*k+x[B]);let T=new $("int64",A,[E,k]),S=c*i,P=S*k,O=QA([E,S,k]),v=O.data;for(let B=0;B<E;++B)if(x[B]!==k)for(let V=0;V<S;++V)v.fill(0,B*P+V*k+x[B],B*P+(V+1)*k);let j=Xe([E],n);for(let B=0;B<n;++B){let V=Xe([E],B);({denoised_latents:O}=await de(this.sessions.latent_denoiser,{style:s,noisy_latents:O,latent_mask:T,encoder_outputs:p,attention_mask:r,timestep:V,num_inference_steps:j}))}let{waveform:H}=await de(this.sessions.voice_decoder,{latents:O});return{waveform:H,durations:_}}};var Vn=class extends y{},eb=class extends Vn{},tb=class extends Vn{async _call(e){return new G(await super._call(e))}},rb=class extends Vn{};var Ui=class extends y{},sb=class extends Ui{},nb=class extends Ui{};var ji=class extends y{forward_params=["input_ids","attention_mask","encoder_outputs","decoder_input_ids","decoder_attention_mask","past_key_values"]},ob=class extends ji{},ab=class extends ji{};var Gi=class extends y{},ib=class extends Gi{},lb=class extends Gi{async _call(e){return new Wu(await super._call(e))}},Wu=class extends Ln{};var Vu=class extends y{},cb=class extends Vu{};var Hn=class extends y{},ub=class extends Hn{},pb=class extends Hn{async _call(e){return new kt(await super._call(e))}},db=class extends Hn{async _call(e){return new G(await super._call(e))}};var qs=class extends y{},fb=class extends qs{},_b=class extends qs{async _call(e){return new kt(await super._call(e))}},mb=class extends qs{async _call(e){return new G(await super._call(e))}},hb=class extends qs{async _call(e){return new he(await super._call(e))}};var qi=class extends y{},gb=class extends qi{},wb=class extends qi{};var xb=class extends y{main_input_name="pixel_values";forward_params=["pixel_values","decoder_input_ids","encoder_hidden_states","past_key_values"]};var Wi=class extends y{},yb=class extends Wi{},bb=class extends Wi{async _call(e){return new G(await super._call(e))}};var Hu=class extends y{},vb=class extends Hu{};var Vi=class extends y{},kb=class extends Vi{},Eb=class extends Vi{async _call(e){return new G(await super._call(e))}};var Xu=class extends y{},Ab=class extends Xu{async _call(e){return new Vc(await super._call(e))}};var Ku=class extends y{},Mb=class extends Ku{};var Qu=class extends Re{constructor({waveform:e,spectrogram:r}){super(),this.waveform=e,this.spectrogram=r}},Yu=class extends y{},Sb=class extends Yu{async _call(e){return new Qu(await super._call(e))}};var Tb=class extends zs{};var M2=2,Iz=1,Ob=new WeakMap;function Cz(t,e){let{text_config:r,audio_config:s}=t.config,n=t.sessions.audio_encoder,{num_mel_bins:o,hidden_size:a}=s,i=o+a,l=new Fo,c=n?.config?.kv_cache_dtype??"float32",p=c==="float16"?br.float16:br.float32,f=Ss(s,{batch_size:1});for(let w in f){let x=f[w].reduce((k,E)=>k*E,1);l[w]=new $(c,new p(x),f[w])}let _=new $(c,new p(i*M2),[1,i,M2]),m=e[Symbol.asyncIterator]?.()??e[Symbol.iterator]?.();if(!m)throw new Error("input_features must be iterable or async iterable");return{encoder_session:n,enc_kv_cache:l,enc_padding_cache:_,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:m,text_hidden_size:r.hidden_size}}async function Lz(t,e){let r=e.dims[2],s=Math.floor((Iz+r-3)/2)+1,n=new $("int64",BigInt64Array.from({length:s},(p,f)=>BigInt(t.enc_past_seq_len+f)),[1,s]),o=t.enc_past_seq_len+s,a=st([1,o]),{audio_embeds:i,present_padding_cache:l,...c}=await de(t.encoder_session,{input_features:e,attention_mask:a,position_ids:n,past_padding_cache:t.enc_padding_cache,...t.enc_kv_cache});t.enc_padding_cache.location==="gpu-buffer"&&t.enc_padding_cache.dispose(),t.enc_padding_cache=l;for(let p in c)if(p.startsWith("present.")){let f=p.replace("present","past_key_values"),_=t.enc_kv_cache[f];_?.location==="gpu-buffer"&&_.dispose(),t.enc_kv_cache[f]=c[p]}return t.enc_past_seq_len=o,i}async function Pz(t,e){for(;t.audio_embed_total_tokens<e&&!t.stream_exhausted;){let r=await t.chunks_iter.next();if(r.done){t.stream_exhausted=!0;break}let s=await Lz(t,r.value);t.audio_embed_queue.push({data:s.data,tokens:s.dims[1]}),t.audio_embed_total_tokens+=s.dims[1]}}function zz(t,e,r){if(t.audio_embed_queue.length===0)return;let s=e.data,n=0,o=r;for(;o>0&&t.audio_embed_queue.length>0;){let a=t.audio_embed_queue[0],i=a.tokens-t.audio_queue_offset,l=Math.min(o,i),c=t.audio_queue_offset*t.text_hidden_size;for(let p=0;p<l*t.text_hidden_size;++p)s[n*t.text_hidden_size+p]+=a.data[c+p];n+=l,o-=l,t.audio_queue_offset+=l,t.audio_queue_offset>=a.tokens&&(t.audio_embed_queue.shift(),t.audio_queue_offset=0)}t.audio_consumed+=r-o}var Ib=class extends Wr{constructor(e){super(),this._s=e}_call(e){let r=this._s.stream_exhausted&&this._s.audio_embed_queue.length===0;return e.map(()=>r)}},Ju=class extends y{forward_params=["input_ids","attention_mask","position_ids","past_key_values"]},Hi=class extends Ju{async forward({input_ids:e,past_key_values:r,...s}){let n=e.dims[1],o=Ob.get(this);o&&await Pz(o,o.audio_consumed+n);let{inputs_embeds:a}=await de(this.sessions.embed_tokens,{input_ids:e});o&&zz(o,a,n);let i={inputs_embeds:a,...s};this.addPastKeyValues(i,r);let l=this.sessions.decoder_model_merged,c=Qe(i,l.inputNames);return await de(l,c)}async generate({input_features:e,stopping_criteria:r,...s}){if(!e)throw new Error("input_features (generator/iterable) must be provided");let n=Cz(this,e);Ob.set(this,n);let o=new En;o.push(new Ib(n)),r&&o.extend(r);try{return await super.generate({...s,stopping_criteria:o})}finally{n.enc_kv_cache.dispose(),Ob.delete(this)}}};var Xn=class extends y{},Cb=class extends Xn{},Lb=class extends Xn{async _call(e){return new kt(await super._call(e))}},Pb=class extends Xn{async _call(e){return new G(await super._call(e))}};var Zu=class extends Re{constructor({logits:e,embeddings:r}){super(),this.logits=e,this.embeddings=r}},ss=class extends y{},zb=class extends ss{},Nb=class extends ss{async _call(e){return new kt(await super._call(e))}},$b=class extends ss{async _call(e){return new G(await super._call(e))}},Rb=class extends ss{async _call(e){return new Zu(await super._call(e))}},Db=class extends ss{async _call(e){return new he(await super._call(e))}};var ep=class extends y{},Fb=class extends ep{};var tp=class extends kn{return_timestamps=null;return_token_timestamps=null;num_frames=null;alignment_heads=null;task=null;language=null;no_timestamps_token_id=null;prompt_ids=null;is_multilingual=null;lang_to_id=null;task_to_id=null;max_initial_timestamp_index=1};var Xi=class extends y{requires_attention_mask=!1;main_input_name="input_features";forward_params=["input_features","attention_mask","decoder_input_ids","decoder_attention_mask","past_key_values"]},Bb=class extends Xi{},rp=class extends Xi{_prepare_generation_config(e,r){return super._prepare_generation_config(e,r,tp)}_retrieve_init_tokens(e){let r=[e.decoder_start_token_id],s=e.language,n=e.task;if(e.is_multilingual){s||(Z.warn("No language specified - defaulting to English (en)."),s="en");let a=`<|${ZA(s)}|>`;r.push(e.lang_to_id[a]),r.push(e.task_to_id[n??"transcribe"])}else if(s||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&&r.at(-1)!==e.no_timestamps_token_id?r.push(e.no_timestamps_token_id):e.return_timestamps&&r.at(-1)===e.no_timestamps_token_id&&(Z.warn("<|notimestamps|> prompt token is removed from generation_config since `return_timestamps` is set to `true`."),r.pop()),r.filter(o=>o!=null)}async generate({inputs:e=null,generation_config:r=null,logits_processor:s=null,stopping_criteria:n=null,...o}){r=this._prepare_generation_config(r,o);let a=o.decoder_input_ids??this._retrieve_init_tokens(r);if(r.return_timestamps&&(s??=new Ts,s.push(new Kc(r,a))),r.begin_suppress_tokens&&(s??=new Ts,s.push(new vn(r.begin_suppress_tokens,a.length))),r.return_token_timestamps){if(!r.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.");r.task==="translate"&&Z.warn("Token-level timestamps may not be reliable for task 'translate'."),r.output_attentions=!0,r.return_dict_in_generate=!0}let i=await super.generate({inputs:e,generation_config:r,logits_processor:s,decoder_input_ids:a,...o});return r.return_token_timestamps&&(i.token_timestamps=this._extract_token_timestamps(i,r.alignment_heads,r.num_frames)),i}_extract_token_timestamps(e,r,s=null,n=.02){if(!e.cross_attentions)throw new Error("Model outputs must contain cross attentions to extract timestamps. This is most likely because the model was not exported with `output_attentions=True`.");s==null&&Z.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 o=this.config.median_filter_width;o===void 0&&(Z.warn("Model config has no `median_filter_width`, using default value of 7."),o=7);let a=e.cross_attentions,i=Array.from({length:this.config.decoder_layers},(x,k)=>Ee(a.map(E=>E[k]),2)),l=It(r.map(([x,k])=>{if(x>=i.length)throw new Error(`Layer index ${x} is out of bounds for cross attentions (length ${i.length}).`);return s?i[x].slice(null,k,null,[0,s]):i[x].slice(null,k)})).transpose(1,0,2,3),[c,p]=pf(l,-2,0,!0),f=l.clone();for(let x=0;x<f.dims[0];++x){let k=f[x];for(let E=0;E<k.dims[0];++E){let A=k[E],T=c[x][E][0].data,S=p[x][E][0].data;for(let P=0;P<A.dims[0];++P){let O=A[P].data;for(let v=0;v<O.length;++v)O[v]=(O[v]-S[v])/T[v];O.set(cE(O,o))}}}let _=[gc(f,1)],m=e.sequences.dims,w=new $("float32",new Float32Array(m[0]*m[1]),m);for(let x=0;x<m[0];++x){let k=_[x].neg().squeeze_(0),[E,A]=pE(k.tolist()),T=Array.from({length:E.length-1},(O,v)=>E[v+1]-E[v]),S=wt([1],T).map(O=>!!O),P=[];for(let O=0;O<S.length;++O)S[O]&&P.push(A[O]*n);w[x].data.set(P,1)}return w}},Ub=class extends rp{};var ns=class extends y{},jb=class extends ns{},Gb=class extends ns{async _call(e){return new we(await super._call(e))}},qb=class extends ns{async _call(e){return new G(await super._call(e))}},Wb=class extends ns{async _call(e){return new he(await super._call(e))}},Vb=class extends ns{async _call(e){return new Me(await super._call(e))}};var os=class extends y{},Hb=class extends os{},Xb=class extends os{async _call(e){return new we(await super._call(e))}},Kb=class extends os{async _call(e){return new G(await super._call(e))}},Qb=class extends os{async _call(e){return new he(await super._call(e))}},Yb=class extends os{async _call(e){return new Me(await super._call(e))}};var Ki=class extends y{},Jb=class extends Ki{},Zb=class extends Ki{async _call(e){return new sp(await super._call(e))}},sp=class extends Re{constructor({logits:e,pred_boxes:r}){super(),this.logits=e,this.pred_boxes=r}};var Qi=class extends y{},e1=class extends Qi{},t1=class extends Qi{};var Nz=new Map([["bert","BertModel"],["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"]]),$z=new Map([["t5","T5Model"],["longt5","LongT5Model"],["mt5","MT5Model"],["bart","BartModel"],["mbart","MBartModel"],["marian","MarianModel"],["whisper","WhisperModel"],["m2m_100","M2M100Model"],["blenderbot","BlenderbotModel"],["blenderbot-small","BlenderbotSmallModel"]]),Rz=new Map([["mimi","MimiModel"],["dac","DacModel"],["snac","SnacModel"]]),Dz=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"],["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"],["ministral","MinistralModel"],["ministral3","Ministral3Model"],["ernie4_5","Ernie4_5ForCausalLM"],["starcoder2","Starcoder2Model"],["falcon","FalconModel"],["falcon_h1","FalconH1Model"],["stablelm","StableLmModel"],["modernbert-decoder","ModernBertDecoderModel"],["hunyuan_v1_dense","HunYuanDenseV1Model"],["youtu","YoutuModel"]]),S2=new Map([["speecht5","SpeechT5ForSpeechToText"],["whisper","WhisperForConditionalGeneration"],["lite-whisper","LiteWhisperForConditionalGeneration"],["moonshine","MoonshineForConditionalGeneration"]]),T2=new Map([["speecht5","SpeechT5ForTextToSpeech"]]),O2=new Map([["vits","VitsModel"],["musicgen","MusicgenForConditionalGeneration"],["supertonic","SupertonicForConditionalGeneration"]]),I2=new Map([["bert","BertForSequenceClassification"],["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"]]),C2=new Map([["bert","BertForTokenClassification"],["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"]]),L2=new Map([["t5","T5ForConditionalGeneration"],["longt5","LongT5ForConditionalGeneration"],["mt5","MT5ForConditionalGeneration"],["bart","BartForConditionalGeneration"],["mbart","MBartForConditionalGeneration"],["marian","MarianMTModel"],["m2m_100","M2M100ForConditionalGeneration"],["blenderbot","BlenderbotForConditionalGeneration"],["blenderbot-small","BlenderbotSmallForConditionalGeneration"]]),P2=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"],["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_moe","Qwen3_5MoeForCausalLM"],["gemma3n","Gemma3nForCausalLM"],["phi","PhiForCausalLM"],["phi3","Phi3ForCausalLM"],["mpt","MptForCausalLM"],["opt","OPTForCausalLM"],["mbart","MBartForCausalLM"],["mistral","MistralForCausalLM"],["ministral","MinistralForCausalLM"],["ministral3","Ministral3ForCausalLM"],["ernie4_5","Ernie4_5ForCausalLM"],["starcoder2","Starcoder2ForCausalLM"],["falcon","FalconForCausalLM"],["falcon_h1","FalconH1ForCausalLM"],["trocr","TrOCRForCausalLM"],["stablelm","StableLmForCausalLM"],["modernbert-decoder","ModernBertDecoderForCausalLM"],["hunyuan_v1_dense","HunYuanDenseV1ForCausalLM"],["youtu","YoutuForCausalLM"],["phi3_v","Phi3VForCausalLM"]]),Fz=new Map([["multi_modality","MultiModalityCausalLM"]]),z2=new Map([["bert","BertForMaskedLM"],["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"]]),N2=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"]]),$2=new Map([["vision-encoder-decoder","VisionEncoderDecoderModel"],["idefics3","Idefics3ForConditionalGeneration"],["smolvlm","SmolVLMForConditionalGeneration"]]),R2=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"],["gemma3n","Gemma3nForConditionalGeneration"],["mistral3","Mistral3ForConditionalGeneration"]]),D2=new Map([["granite_speech","GraniteSpeechForConditionalGeneration"],["ultravox","UltravoxModel"],["voxtral","VoxtralForConditionalGeneration"],["voxtral_realtime","VoxtralRealtimeForConditionalGeneration"]]),Bz=new Map([["vision-encoder-decoder","VisionEncoderDecoderModel"]]),F2=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"]]),B2=new Map([["detr","DetrForObjectDetection"],["rt_detr","RTDetrForObjectDetection"],["rt_detr_v2","RTDetrV2ForObjectDetection"],["rf_detr","RFDetrForObjectDetection"],["d_fine","DFineForObjectDetection"],["table-transformer","TableTransformerForObjectDetection"],["yolos","YolosForObjectDetection"]]),U2=new Map([["owlvit","OwlViTForObjectDetection"],["owlv2","Owlv2ForObjectDetection"],["grounding-dino","GroundingDinoForObjectDetection"]]),Kn=new Map([["detr","DetrForSegmentation"],["clipseg","CLIPSegForImageSegmentation"]]),j2=new Map([["segformer","SegformerForSemanticSegmentation"],["sapiens","SapiensForSemanticSegmentation"],["swin","SwinForSemanticSegmentation"],["mobilenet_v1","MobileNetV1ForSemanticSegmentation"],["mobilenet_v2","MobileNetV2ForSemanticSegmentation"],["mobilenet_v3","MobileNetV3ForSemanticSegmentation"],["mobilenet_v4","MobileNetV4ForSemanticSegmentation"]]),G2=new Map([["detr","DetrForSegmentation"],["maskformer","MaskFormerForInstanceSegmentation"]]),q2=new Map([["sam","SamModel"],["sam2","Sam2Model"],["edgetam","EdgeTamModel"],["sam3_tracker","Sam3TrackerModel"]]),W2=new Map([["wav2vec2","Wav2Vec2ForCTC"],["wav2vec2-bert","Wav2Vec2BertForCTC"],["unispeech","UniSpeechForCTC"],["unispeech-sat","UniSpeechSatForCTC"],["wavlm","WavLMForCTC"],["hubert","HubertForCTC"],["parakeet_ctc","ParakeetForCTC"]]),V2=new Map([["wav2vec2","Wav2Vec2ForSequenceClassification"],["wav2vec2-bert","Wav2Vec2BertForSequenceClassification"],["unispeech","UniSpeechForSequenceClassification"],["unispeech-sat","UniSpeechSatForSequenceClassification"],["wavlm","WavLMForSequenceClassification"],["hubert","HubertForSequenceClassification"],["audio-spectrogram-transformer","ASTForAudioClassification"]]),H2=new Map([["wavlm","WavLMForXVector"]]),X2=new Map([["unispeech-sat","UniSpeechSatForAudioFrameClassification"],["wavlm","WavLMForAudioFrameClassification"],["wav2vec2","Wav2Vec2ForAudioFrameClassification"],["pyannote","PyAnnoteForAudioFrameClassification"]]),K2=new Map([["vitmatte","VitMatteForImageMatting"]]),Uz=new Map([["patchtst","PatchTSTForPrediction"],["patchtsmixer","PatchTSMixerForPrediction"]]),Q2=new Map([["swin2sr","Swin2SRForImageSuperResolution"]]),Y2=new Map([["dpt","DPTForDepthEstimation"],["depth_anything","DepthAnythingForDepthEstimation"],["glpn","GLPNForDepthEstimation"],["sapiens","SapiensForDepthEstimation"],["depth_pro","DepthProForDepthEstimation"],["metric3d","Metric3DForDepthEstimation"],["metric3dv2","Metric3Dv2ForDepthEstimation"]]),J2=new Map([["sapiens","SapiensForNormalEstimation"]]),Z2=new Map([["vitpose","VitPoseForPoseEstimation"]]),eM=new Map([["clip","CLIPVisionModelWithProjection"],["siglip","SiglipVisionModel"],["jina_clip","JinaCLIPVisionModel"]]),r1=[[Nz,K.EncoderOnly],[$z,K.EncoderDecoder],[Dz,K.DecoderOnlyWithoutHead],[Rz,K.AutoEncoder],[I2,K.EncoderOnly],[C2,K.EncoderOnly],[L2,K.Seq2Seq],[S2,K.Seq2Seq],[P2,K.DecoderOnly],[Fz,K.MultiModality],[z2,K.EncoderOnly],[N2,K.EncoderOnly],[$2,K.Vision2Seq],[R2,K.ImageTextToText],[D2,K.AudioTextToText],[F2,K.EncoderOnly],[Kn,K.EncoderOnly],[G2,K.EncoderOnly],[j2,K.EncoderOnly],[K2,K.EncoderOnly],[Uz,K.EncoderOnly],[Q2,K.EncoderOnly],[Y2,K.EncoderOnly],[J2,K.EncoderOnly],[Z2,K.EncoderOnly],[B2,K.EncoderOnly],[U2,K.EncoderOnly],[q2,K.MaskGeneration],[W2,K.EncoderOnly],[V2,K.EncoderOnly],[T2,K.Seq2Seq],[O2,K.EncoderOnly],[H2,K.EncoderOnly],[X2,K.EncoderOnly],[eM,K.EncoderOnly]];for(let[t,e]of r1)for(let r of t.values()){tr.set(r,e);let s=Yi[r];Cs.set(s,r),au.set(r,s)}var jz=[["MusicgenForConditionalGeneration",ni,K.Musicgen],["Phi3VForCausalLM",wi,K.Phi3V],["CLIPTextModelWithProjection",Zo,K.EncoderOnly],["SiglipTextModel",zi,K.EncoderOnly],["JinaCLIPTextModel",Fa,K.EncoderOnly],["ClapTextModelWithProjection",Yo,K.EncoderOnly],["ClapAudioModelWithProjection",Jo,K.EncoderOnly],["DacEncoderModel",la,K.EncoderOnly],["DacDecoderModel",ca,K.EncoderOnly],["MimiEncoderModel",Ha,K.EncoderOnly],["MimiDecoderModel",Xa,K.EncoderOnly],["SnacEncoderModel",$i,K.EncoderOnly],["SnacDecoderModel",Ri,K.EncoderOnly],["Gemma3nForConditionalGeneration",Pn,K.ImageAudioTextToText],["SupertonicForConditionalGeneration",Bi,K.Supertonic],["ChatterboxModel",Qo,K.Chatterbox],["Qwen2VLForCausalLM",Ds,K.MultimodalLanguageModelOnly],["Qwen2_5_VLForCausalLM",Fs,K.MultimodalLanguageModelOnly],["Qwen3VLForCausalLM",Us,K.MultimodalLanguageModelOnly],["Qwen3VLMoeForCausalLM",Si,K.MultimodalLanguageModelOnly],["Qwen3_5ForCausalLM",js,K.MultimodalLanguageModelOnly],["Qwen3_5MoeForCausalLM",Ti,K.MultimodalLanguageModelOnly],["Gemma3nForCausalLM",ka,K.MultimodalLanguageModelOnly],["VoxtralRealtimeForConditionalGeneration",Hi,K.VoxtralRealtime]];for(let[t,e,r]of jz)tr.set(t,r),Cs.set(e,t),au.set(t,e);var tM=new Map([["modnet",Kn],["birefnet",Kn],["isnet",Kn],["ben",Kn]]);for(let[t,e]of tM.entries())e.set(t,"PreTrainedModel"),tr.set(t,K.EncoderOnly),au.set(t,y);var rM=new Set(tM.keys());tr.set("PreTrainedModel",K.EncoderOnly);Cs.set(y,"PreTrainedModel");var ze={MODEL_FOR_SEQUENCE_CLASSIFICATION_MAPPING_NAMES:I2,MODEL_FOR_TOKEN_CLASSIFICATION_MAPPING_NAMES:C2,MODEL_FOR_TEXT_TO_SPECTROGRAM_MAPPING_NAMES:T2,MODEL_FOR_TEXT_TO_WAVEFORM_MAPPING_NAMES:O2,MODEL_FOR_MASKED_LM_MAPPING_NAMES:z2,MODEL_FOR_QUESTION_ANSWERING_MAPPING_NAMES:N2,MODEL_FOR_IMAGE_CLASSIFICATION_MAPPING_NAMES:F2,MODEL_FOR_IMAGE_SEGMENTATION_MAPPING_NAMES:Kn,MODEL_FOR_SEMANTIC_SEGMENTATION_MAPPING_NAMES:j2,MODEL_FOR_UNIVERSAL_SEGMENTATION_MAPPING_NAMES:G2,MODEL_FOR_OBJECT_DETECTION_MAPPING_NAMES:B2,MODEL_FOR_ZERO_SHOT_OBJECT_DETECTION_MAPPING_NAMES:U2,MODEL_FOR_MASK_GENERATION_MAPPING_NAMES:q2,MODEL_FOR_CTC_MAPPING_NAMES:W2,MODEL_FOR_AUDIO_CLASSIFICATION_MAPPING_NAMES:V2,MODEL_FOR_AUDIO_XVECTOR_MAPPING_NAMES:H2,MODEL_FOR_AUDIO_FRAME_CLASSIFICATION_MAPPING_NAMES:X2,MODEL_FOR_DOCUMENT_QUESTION_ANSWERING_MAPPING_NAMES:Bz,MODEL_FOR_IMAGE_MATTING_MAPPING_NAMES:K2,MODEL_FOR_IMAGE_TO_IMAGE_MAPPING_NAMES:Q2,MODEL_FOR_DEPTH_ESTIMATION_MAPPING_NAMES:Y2,MODEL_FOR_NORMAL_ESTIMATION_MAPPING_NAMES:J2,MODEL_FOR_POSE_ESTIMATION_MAPPING_NAMES:Z2,MODEL_FOR_IMAGE_FEATURE_EXTRACTION_MAPPING_NAMES:eM,MODEL_FOR_IMAGE_TEXT_TO_TEXT_MAPPING_NAMES:R2,MODEL_FOR_AUDIO_TEXT_TO_TEXT_MAPPING_NAMES:D2,MODEL_FOR_SEQ_TO_SEQ_CAUSAL_LM_MAPPING_NAMES:L2,MODEL_FOR_SPEECH_SEQ_2_SEQ_MAPPING_NAMES:S2,MODEL_FOR_CAUSAL_LM_MAPPING_NAMES:P2,MODEL_FOR_VISION_2_SEQ_MAPPING_NAMES:$2};b2(ze);var Oe=class{static MODEL_CLASS_MAPPINGS=null;static BASE_IF_FAIL=!1;static supports(e){if(!this.MODEL_CLASS_MAPPINGS)return!1;for(let r of this.MODEL_CLASS_MAPPINGS)if(r.has(e))return!0;return this.BASE_IF_FAIL}static async from_pretrained(e,{progress_callback:r=null,config:s=null,cache_dir:n=null,local_files_only:o=!1,revision:a="main",model_file_name:i=null,subfolder:l="onnx",device:c=null,dtype:p=null,use_external_data_format:f=null,session_options:_={}}={}){let m={progress_callback:r,config:s,cache_dir:n,local_files_only:o,revision:a,model_file_name:i,subfolder:l,device:c,dtype:p,use_external_data_format:f,session_options:_};if(m.config=await jt.from_pretrained(e,m),!this.MODEL_CLASS_MAPPINGS)throw new Error("`MODEL_CLASS_MAPPINGS` not implemented for this type of `AutoClass`: "+this.name);let{model_type:w}=m.config;for(let x of this.MODEL_CLASS_MAPPINGS){let k=x.get(w);if(!k){for(let E of x.values())if(E[0]===w){k=E;break}if(!k)continue}return await Yi[k].from_pretrained(e,m)}if(this.BASE_IF_FAIL)return rM.has(w)||Z.warn(`Unknown model class "${w}", attempting to construct from base class.`),await y.from_pretrained(e,m);throw Error(`Unsupported model type: ${w}`)}},kr=class extends Oe{static MODEL_CLASS_MAPPINGS=r1.map(e=>e[0]);static BASE_IF_FAIL=!0},Ji=class extends Oe{static MODEL_CLASS_MAPPINGS=[ze.MODEL_FOR_SEQUENCE_CLASSIFICATION_MAPPING_NAMES]},np=class extends Oe{static MODEL_CLASS_MAPPINGS=[ze.MODEL_FOR_TOKEN_CLASSIFICATION_MAPPING_NAMES]},Qn=class extends Oe{static MODEL_CLASS_MAPPINGS=[ze.MODEL_FOR_SEQ_TO_SEQ_CAUSAL_LM_MAPPING_NAMES]},op=class extends Oe{static MODEL_CLASS_MAPPINGS=[ze.MODEL_FOR_SPEECH_SEQ_2_SEQ_MAPPING_NAMES]},ap=class extends Oe{static MODEL_CLASS_MAPPINGS=[ze.MODEL_FOR_TEXT_TO_SPECTROGRAM_MAPPING_NAMES]},ip=class extends Oe{static MODEL_CLASS_MAPPINGS=[ze.MODEL_FOR_TEXT_TO_WAVEFORM_MAPPING_NAMES]},lp=class extends Oe{static MODEL_CLASS_MAPPINGS=[ze.MODEL_FOR_CAUSAL_LM_MAPPING_NAMES]},cp=class extends Oe{static MODEL_CLASS_MAPPINGS=[ze.MODEL_FOR_MASKED_LM_MAPPING_NAMES]},up=class extends Oe{static MODEL_CLASS_MAPPINGS=[ze.MODEL_FOR_QUESTION_ANSWERING_MAPPING_NAMES]},pp=class extends Oe{static MODEL_CLASS_MAPPINGS=[ze.MODEL_FOR_VISION_2_SEQ_MAPPING_NAMES]},dp=class extends Oe{static MODEL_CLASS_MAPPINGS=[ze.MODEL_FOR_IMAGE_CLASSIFICATION_MAPPING_NAMES]},Zi=class extends Oe{static MODEL_CLASS_MAPPINGS=[ze.MODEL_FOR_IMAGE_SEGMENTATION_MAPPING_NAMES]},el=class extends Oe{static MODEL_CLASS_MAPPINGS=[ze.MODEL_FOR_SEMANTIC_SEGMENTATION_MAPPING_NAMES]},tl=class extends Oe{static MODEL_CLASS_MAPPINGS=[ze.MODEL_FOR_UNIVERSAL_SEGMENTATION_MAPPING_NAMES]},fp=class extends Oe{static MODEL_CLASS_MAPPINGS=[ze.MODEL_FOR_OBJECT_DETECTION_MAPPING_NAMES]},_p=class extends Oe{static MODEL_CLASS_MAPPINGS=[ze.MODEL_FOR_ZERO_SHOT_OBJECT_DETECTION_MAPPING_NAMES]},sM=class extends Oe{static MODEL_CLASS_MAPPINGS=[ze.MODEL_FOR_MASK_GENERATION_MAPPING_NAMES]},mp=class extends Oe{static MODEL_CLASS_MAPPINGS=[ze.MODEL_FOR_CTC_MAPPING_NAMES]},hp=class extends Oe{static MODEL_CLASS_MAPPINGS=[ze.MODEL_FOR_AUDIO_CLASSIFICATION_MAPPING_NAMES]},nM=class extends Oe{static MODEL_CLASS_MAPPINGS=[ze.MODEL_FOR_AUDIO_XVECTOR_MAPPING_NAMES]},oM=class extends Oe{static MODEL_CLASS_MAPPINGS=[ze.MODEL_FOR_AUDIO_FRAME_CLASSIFICATION_MAPPING_NAMES]},gp=class extends Oe{static MODEL_CLASS_MAPPINGS=[ze.MODEL_FOR_DOCUMENT_QUESTION_ANSWERING_MAPPING_NAMES]},aM=class extends Oe{static MODEL_CLASS_MAPPINGS=[ze.MODEL_FOR_IMAGE_MATTING_MAPPING_NAMES]},wp=class extends Oe{static MODEL_CLASS_MAPPINGS=[ze.MODEL_FOR_IMAGE_TO_IMAGE_MAPPING_NAMES]},xp=class extends Oe{static MODEL_CLASS_MAPPINGS=[ze.MODEL_FOR_DEPTH_ESTIMATION_MAPPING_NAMES]},iM=class extends Oe{static MODEL_CLASS_MAPPINGS=[ze.MODEL_FOR_NORMAL_ESTIMATION_MAPPING_NAMES]},lM=class extends Oe{static MODEL_CLASS_MAPPINGS=[ze.MODEL_FOR_POSE_ESTIMATION_MAPPING_NAMES]},yp=class extends Oe{static MODEL_CLASS_MAPPINGS=[ze.MODEL_FOR_IMAGE_FEATURE_EXTRACTION_MAPPING_NAMES]},cM=class extends Oe{static MODEL_CLASS_MAPPINGS=[ze.MODEL_FOR_IMAGE_TEXT_TO_TEXT_MAPPING_NAMES]},uM=class extends Oe{static MODEL_CLASS_MAPPINGS=[ze.MODEL_FOR_AUDIO_TEXT_TO_TEXT_MAPPING_NAMES]};async function et(t){return Array.isArray(t)||(t=[t]),await Promise.all(t.map(e=>Ye.read(e)))}async function as(t,e){return Array.isArray(t)||(t=[t]),await Promise.all(t.map(r=>typeof r=="string"||r instanceof URL?c_(r,e):r instanceof Float64Array?new Float32Array(r):r))}function rl(t,e){e&&(t=t.map(a=>a|0));let[r,s,n,o]=t;return{xmin:r,ymin:s,xmax:n,ymax:o}}var fe=class extends rt{constructor({task:e,model:r,tokenizer:s=null,processor:n=null}){super(),this.task=e,this.model=r,this.tokenizer=s,this.processor=n}async dispose(){await this.model.dispose()}};var sl=class extends fe{async _call(e,{top_k:r=1}={}){let s=this.tokenizer(e,{padding:!0,truncation:!0}),n=await this.model(s),{problem_type:o,id2label:a}=this.model.config,i=o==="multi_label_classification"?c=>c.sigmoid():c=>new $("float32",$e(c.data),c.dims),l=[];for(let c of n.logits){let p=i(c),f=await er(p,r),_=f[0].tolist(),w=f[1].tolist().map((x,k)=>({label:a?a[x]:`LABEL_${x}`,score:_[k]}));r===1?l.push(...w):l.push(w)}return Array.isArray(e)||r===1?l:l[0]}};var nl=class extends fe{async _call(e,{ignore_labels:r=["O"]}={}){let s=Array.isArray(e),n=this.tokenizer(s?e:[e],{padding:!0,truncation:!0}),a=(await this.model(n)).logits,i=this.model.config.id2label,l=[];for(let c=0;c<a.dims[0];++c){let p=n.input_ids[c],f=a[c],_=[];for(let m=0;m<f.dims[0];++m){let w=f[m],x=Ce(w.data)[1],k=i?i[x]:`LABEL_${x}`;if(r.includes(k))continue;let E=this.tokenizer.decode([p[m].item()],{skip_special_tokens:!0});if(E==="")continue;let A=$e(w.data);_.push({entity:k,score:A[x],index:m,word:E})}l.push(_)}return s?l:l[0]}};var ol=class extends fe{async _call(e,r,{top_k:s=1}={}){let n=this.tokenizer(e,{text_pair:r,padding:!0,truncation:!0}),o=Array.isArray(e),{start_logits:a,end_logits:i}=await this.model(n),l=n.input_ids.tolist(),c=n.attention_mask.tolist(),{all_special_ids:p,sep_token_id:f}=this.tokenizer,_=[];for(let m=0;m<a.dims[0];++m){let w=l[m],x=w.findIndex(O=>O==f),k=a[m].tolist(),E=i[m].tolist();for(let O=1;O<k.length;++O)(c[m]==0||O<=x||p.findIndex(v=>v==w[O])!==-1)&&(k[O]=-1/0,E[O]=-1/0);let A=$e(k).map((O,v)=>[O,v]),T=$e(E).map((O,v)=>[O,v]);A[0][0]=0,T[0][0]=0;let S=wk(A,T).filter(O=>O[0][1]<=O[1][1]).map(O=>[O[0][1],O[1][1],O[0][0]*O[1][0]]).sort((O,v)=>v[2]-O[2]),P=[];for(let O=0;O<Math.min(S.length,s);++O){let[v,j,H]=S[O],B=w.slice(v,j+1),V=this.tokenizer.decode(B,{skip_special_tokens:!0});P.push({answer:V,score:H})}s===1?_.push(...P):_.push(P)}return o?_:_[0]}};var al=class extends fe{async _call(e,{top_k:r=5}={}){let{mask_token_id:s,mask_token:n}=this.tokenizer,o=this.tokenizer(e,{padding:!0,truncation:!0}),{logits:a}=await this.model(o),i=[],l=o.input_ids.tolist();for(let c=0;c<l.length;++c){let p=l[c],f=p.findIndex(k=>k==s);if(f===-1)throw Error(`Mask token (${n}) not found in text.`);let _=a[c][f],m=await er(new $("float32",$e(_.data),_.dims),r),w=m[0].tolist(),x=m[1].tolist();i.push(x.map((k,E)=>{let A=p.slice();return A[f]=k,{score:w[E],token:Number(k),token_str:this.tokenizer.decode([k]),sequence:this.tokenizer.decode(A,{skip_special_tokens:!0})}}))}return Array.isArray(e)?i:i[0]}};var Er=class extends fe{_key="generated_text";async _call(e,r={}){Array.isArray(e)||(e=[e]),this.model.config.prefix&&(e=e.map(l=>this.model.config.prefix+l));let s=this.model.config.task_specific_params;s&&s[this.task]&&s[this.task].prefix&&(e=e.map(l=>s[this.task].prefix+l));let n=this.tokenizer,o={padding:!0,truncation:!0},a;this.task==="translation"&&"_build_translation_inputs"in n?a=n._build_translation_inputs(e,o,r):a=n(e,o);let i=await this.model.generate({...a,...r});return n.batch_decode(i,{skip_special_tokens:!0}).map(l=>({[this._key]:l}))}};var il=class extends Er{_key="summary_text"};var ll=class extends Er{_key="translation_text"};function pM(t){return Array.isArray(t)&&t.every(e=>"role"in e&&"content"in e)}var cl=class extends fe{async _call(e,r={}){let s=!1,n=!1,o=r.add_special_tokens??(this.tokenizer.add_bos_token||this.tokenizer.add_eos_token)??!1,a=r.tokenizer_encode_kwargs,i;if(typeof e=="string")i=e=[e];else if(Array.isArray(e)&&e.every(w=>typeof w=="string"))s=!0,i=e;else{if(pM(e))e=[e];else if(Array.isArray(e)&&e.every(pM))s=!0;else throw new Error("Input must be a string, an array of strings, a Chat, or an array of Chats");n=!0,i=e.map(w=>this.tokenizer.apply_chat_template(w,{tokenize:!1,add_generation_prompt:!0,...a})),o=!1,a=void 0}let l=n?!1:r.return_full_text??!0;this.tokenizer.padding_side="left";let c=this.tokenizer(i,{add_special_tokens:o,padding:!0,truncation:!0,...a}),p=await this.model.generate({...c,...r}),f=this.tokenizer.batch_decode(p,{skip_special_tokens:!0}),_;!l&&c.input_ids.dims.at(-1)>0&&(_=this.tokenizer.batch_decode(c.input_ids,{skip_special_tokens:!0}).map(w=>w.length));let m=Array.from({length:e.length},w=>[]);for(let w=0;w<f.length;++w){let x=Math.floor(w/p.dims[0]*e.length);_&&(f[w]=f[w].slice(_[x])),m[x].push({generated_text:n?[...e[x],{role:"assistant",content:f[w]}]:f[w]})}return!s&&m.length===1?m[0]:m}};var ul=class extends fe{constructor(e){super(e),this.label2id=Object.fromEntries(Object.entries(this.model.config.label2id).map(([r,s])=>[r.toLowerCase(),s])),this.entailment_id=this.label2id.entailment,this.entailment_id===void 0&&(Z.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&&(Z.warn("Could not find 'contradiction' in label2id mapping. Using 0 as contradiction_id."),this.contradiction_id=0)}async _call(e,r,{hypothesis_template:s="This example is {}.",multi_label:n=!1}={}){let o=Array.isArray(e);o||(e=[e]),Array.isArray(r)||(r=[r]);let a=r.map(c=>s.replace("{}",c)),i=n||r.length===1,l=[];for(let c of e){let p=[];for(let m of a){let w=this.tokenizer(c,{text_pair:m,padding:!0,truncation:!0}),x=await this.model(w);i?p.push([x.logits.data[this.contradiction_id],x.logits.data[this.entailment_id]]):p.push(x.logits.data[this.entailment_id])}let _=(i?p.map(m=>$e(m)[1]):$e(p)).map((m,w)=>[m,w]).sort((m,w)=>w[0]-m[0]);l.push({sequence:c,labels:_.map(m=>r[m[1]]),scores:_.map(m=>m[0])})}return o?l:l[0]}};var pl=class extends fe{async _call(e,{top_k:r=5}={}){let s=this.processor.feature_extractor.config.sampling_rate,n=await as(e,s),o=this.model.config.id2label,a=[];for(let i of n){let l=await this.processor(i),p=(await this.model(l)).logits[0],f=await er(new $("float32",$e(p.data),p.dims),r),_=f[0].tolist(),w=f[1].tolist().map((x,k)=>({label:o?o[x]:`LABEL_${x}`,score:_[k]}));a.push(w)}return Array.isArray(e)?a:a[0]}};var dl=class extends fe{async _call(e,r,{hypothesis_template:s="This is a sound of {}."}={}){let n=!Array.isArray(e);n&&(e=[e]);let o=r.map(p=>s.replace("{}",p)),a=this.tokenizer(o,{padding:!0,truncation:!0}),i=this.processor.feature_extractor.config.sampling_rate,l=await as(e,i),c=[];for(let p of l){let f=await this.processor(p),_=await this.model({...a,...f}),m=$e(_.logits_per_audio.data);c.push([...m].map((w,x)=>({score:w,label:r[x]})))}return n?c[0]:c}};var fl=class extends fe{async _call(e,r={}){switch(this.model.config.model_type){case"whisper":case"lite-whisper":return this._call_whisper(e,r);case"wav2vec2":case"wav2vec2-bert":case"unispeech":case"unispeech-sat":case"hubert":case"parakeet_ctc":return this._call_wav2vec2(e,r);case"moonshine":return this._call_moonshine(e,r);default:throw new Error(`AutomaticSpeechRecognitionPipeline does not support model type '${this.model.config.model_type}'.`)}}async _call_wav2vec2(e,r){r.language&&Z.warn('`language` parameter is not yet supported for `wav2vec2` models, defaulting to "English".'),r.task&&Z.warn('`task` parameter is not yet supported for `wav2vec2` models, defaulting to "transcribe".');let s=!Array.isArray(e),n=s?[e]:e,o=this.processor.feature_extractor.config.sampling_rate,a=await as(n,o),i=[];for(let l of a){let c=await this.processor(l),f=(await this.model(c)).logits[0],_=[];for(let w of f)_.push(Ce(w.data)[1]);let m=this.tokenizer.decode(_,{skip_special_tokens:!0}).trim();i.push({text:m})}return s?i[0]:i}async _call_whisper(e,r){let s=r.return_timestamps??!1,n=r.chunk_length_s??0,o=r.force_full_sequences??!1,a=r.stride_length_s??null,i={...r};s==="word"&&(i.return_token_timestamps=!0,i.return_timestamps=!1);let l=!Array.isArray(e),c=l?[e]:e,p=this.processor.feature_extractor.config,f=p.chunk_length/this.model.config.max_source_positions,_=p.hop_length,m=p.sampling_rate,w=await as(c,m),x=[];for(let k of w){let E=[];if(n>0){if(a===null)a=n/6;else if(n<=a)throw Error("`chunk_length_s` must be larger than `stride_length_s`.");let S=m*n,P=m*a,O=S-2*P,v=0;for(;;){let j=v+S,H=k.subarray(v,j),B=await this.processor(H),V=v===0,q=j>=k.length;if(E.push({stride:[H.length,V?0:P,q?0:P],input_features:B.input_features,is_last:q}),q)break;v+=O}}else E=[{stride:[k.length,0,0],input_features:(await this.processor(k)).input_features,is_last:!0}];for(let S of E){i.num_frames=Math.floor(S.stride[0]/_);let P=await this.model.generate({inputs:S.input_features,...i});s==="word"?(S.tokens=P.sequences.tolist()[0],S.token_timestamps=P.token_timestamps.tolist()[0].map(O=>ms(O,2))):S.tokens=P[0].tolist(),S.stride=S.stride.map(O=>O/m)}let[A,T]=this.tokenizer._decode_asr(E,{time_precision:f,return_timestamps:s,force_full_sequences:o});x.push({text:A,...T})}return l?x[0]:x}async _call_moonshine(e,r){let s=!Array.isArray(e),n=s?[e]:e,o=this.processor.feature_extractor.config.sampling_rate,a=await as(n,o),i=[];for(let l of a){let c=await this.processor(l),p=Math.floor(l.length/o)*6,f=await this.model.generate({max_new_tokens:p,...r,...c}),_=this.processor.batch_decode(f,{skip_special_tokens:!0})[0];i.push({text:_})}return s?i[0]:i}};var _l=class extends fe{DEFAULT_VOCODER_ID="Xenova/speecht5_hifigan";constructor(e){super(e),this.vocoder=e.vocoder??null}async _prepare_speaker_embeddings(e,r){if((typeof e=="string"||e instanceof URL)&&(e=new Float32Array(await(await _e.fetch(e)).arrayBuffer())),e instanceof Float32Array)e=new $("float32",e,[e.length]);else if(!(e instanceof $))throw new Error("Speaker embeddings must be a `Tensor`, `Float32Array`, `string`, or `URL`.");if(r>1){if(e.dims[0]===1)e=e.repeat(r,1);else if(e.dims[0]!==r)throw new Error(`Expected speaker embeddings batch size to be 1 or ${r}, but got ${e.dims[0]}.`)}return e}_postprocess_waveform(e,r,s,n=null){let o=r.data,[a,i]=r.dims,l=n?n.data:null,c=[];for(let p=0;p<a;++p){let f=l?Math.min(Math.ceil(l[p]),i):i,_=p*i;c.push(new Oo(o.slice(_,_+f),s))}return Array.isArray(e)?c:c[0]}async _call(e,r){return this.processor?this._call_text_to_spectrogram(e,r):this.model.config.model_type==="supertonic"?this._call_supertonic(e,r):this._call_text_to_waveform(e)}async _call_supertonic(e,{speaker_embeddings:r,num_inference_steps:s,speed:n}){if(!r)throw new Error("Speaker embeddings must be provided for Supertonic models.");let{sampling_rate:o,style_dim:a}=this.model.config,i=this.tokenizer(e,{padding:!0,truncation:!0}),l=i.input_ids.dims[0];r=await this._prepare_speaker_embeddings(r,l),r=r.view(l,-1,a);let{waveform:c,durations:p}=await this.model.generate_speech({...i,style:r,num_inference_steps:s,speed:n});return this._postprocess_waveform(e,c,o,p)}async _call_text_to_waveform(e){let r=this.tokenizer(e,{padding:!0,truncation:!0}),{waveform:s}=await this.model(r),n=this.model.config.sampling_rate;return this._postprocess_waveform(e,s,n)}async _call_text_to_spectrogram(e,{speaker_embeddings:r}){this.vocoder||(Z.info("No vocoder specified, using default HifiGan vocoder."),this.vocoder=await kr.from_pretrained(this.DEFAULT_VOCODER_ID,{dtype:"fp32"}));let{input_ids:s}=this.tokenizer(e,{padding:!0,truncation:!0}),n=s.dims[0];r=await this._prepare_speaker_embeddings(r,n),r=r.view(n,-1);let{waveform:o}=await this.model.generate_speech(s,r,{vocoder:this.vocoder}),a=this.processor.feature_extractor.config.sampling_rate;return this._postprocess_waveform(e,o,a)}};var ml=class extends fe{async _call(e,r={}){let s=Array.isArray(e),n=await et(e),{pixel_values:o}=await this.processor(n),a=[];for(let i of o){i.dims=[1,...i.dims];let l=await this.model.generate({inputs:i,...r}),c=this.tokenizer.batch_decode(l,{skip_special_tokens:!0}).map(p=>({generated_text:p.trim()}));a.push(c)}return s?a:a[0]}};var hl=class extends fe{async _call(e,{top_k:r=5}={}){let s=await et(e),{pixel_values:n}=await this.processor(s),o=await this.model({pixel_values:n}),{id2label:a}=this.model.config,i=[];for(let l of o.logits){let c=await er(new $("float32",$e(l.data),l.dims),r),p=c[0].tolist(),_=c[1].tolist().map((m,w)=>({label:a?a[m]:`LABEL_${m}`,score:p[w]}));i.push(_)}return Array.isArray(e)?i:i[0]}};var dM={panoptic:"post_process_panoptic_segmentation",instance:"post_process_instance_segmentation",semantic:"post_process_semantic_segmentation"},Ws=class extends fe{async _call(e,{threshold:r=.5,mask_threshold:s=.5,overlap_mask_area_threshold:n=.8,label_ids_to_fuse:o=null,target_sizes:a=null,subtask:i=null}={}){if(Array.isArray(e)&&e.length!==1)throw Error("Image segmentation pipeline currently only supports a batch size of 1.");let c=await et(e),p=c.map(A=>[A.height,A.width]),f=await this.processor(c),{inputNames:_,outputNames:m}=this.model.sessions.model;if(!_.includes("pixel_values")){if(_.length!==1)throw Error(`Expected a single input name, but got ${_.length} inputs: ${_}.`);let A=_[0];if(A in f)throw Error(`Input name ${A} already exists in the inputs.`);f[A]=f.pixel_values}let w=await this.model(f),x=null;if(i!==null)x=dM[i];else if(this.processor.image_processor){for(let[A,T]of Object.entries(dM))if(T in this.processor.image_processor){x=this.processor.image_processor[T].bind(this.processor.image_processor),i=A;break}}let k=this.model.config.id2label,E=[];if(i)if(i==="panoptic"||i==="instance"){let A=x(w,r,s,n,o,a??p)[0],T=A.segmentation;for(let S of A.segments_info){let P=new Uint8ClampedArray(T.data.length);for(let v=0;v<T.data.length;++v)T.data[v]===S.id&&(P[v]=255);let O=new Ye(P,T.dims[1],T.dims[0],1);E.push({score:S.score,label:k[S.label_id],mask:O})}}else if(i==="semantic"){let{segmentation:A,labels:T}=x(w,a??p)[0];for(let S of T){let P=new Uint8ClampedArray(A.data.length);for(let v=0;v<A.data.length;++v)A.data[v]===S&&(P[v]=255);let O=new Ye(P,A.dims[1],A.dims[0],1);E.push({score:null,label:k[S],mask:O})}}else throw Error(`Subtask ${i} not supported.`);else{let T=w[m[0]];for(let S=0;S<p.length;++S){let P=p[S],O=T[S];O.data.some(j=>j<-1e-5||j>1+1e-5)&&O.sigmoid_();let v=await Ye.fromTensor(O.mul_(255).to("uint8")).resize(P[1],P[0]);E.push({label:null,score:null,mask:v})}}return E}};var gl=class extends Ws{async _call(e,r={}){let s=await et(e),n=await super._call(e,r),o=s.map((a,i)=>{let l=a.clone();return l.putAlpha(n[i].mask),l});return Array.isArray(e)?o:o[0]}};var wl=class extends fe{async _call(e,r,{hypothesis_template:s="This is a photo of {}"}={}){let n=Array.isArray(e),o=await et(e),a=r.map(_=>s.replace("{}",_)),i=this.tokenizer(a,{padding:this.model.config.model_type==="siglip"?"max_length":!0,truncation:!0}),{pixel_values:l}=await this.processor(o),c=await this.model({...i,pixel_values:l}),p=this.model.config.model_type==="siglip"?_=>_.sigmoid().data:_=>$e(_.data),f=[];for(let _ of c.logits_per_image){let w=[...p(_)].map((x,k)=>({score:x,label:r[k]}));w.sort((x,k)=>k.score-x.score),f.push(w)}return n?f:f[0]}};var xl=class extends fe{async _call(e,{threshold:r=.9,percentage:s=!1}={}){let n=Array.isArray(e);if(n&&e.length!==1)throw Error("Object detection pipeline currently only supports a batch size of 1.");let o=await et(e),a=s?null:o.map(m=>[m.height,m.width]),{pixel_values:i,pixel_mask:l}=await this.processor(o),c=await this.model({pixel_values:i,pixel_mask:l}),p=this.processor.image_processor.post_process_object_detection(c,r,a),{id2label:f}=this.model.config,_=p.map(m=>m.boxes.map((w,x)=>({score:m.scores[x],label:f[m.classes[x]],box:rl(w,!s)})));return n?_:_[0]}};var yl=class extends fe{async _call(e,r,{threshold:s=.1,top_k:n=null,percentage:o=!1}={}){let a=Array.isArray(e),i=await et(e),l=this.tokenizer(r,{padding:!0,truncation:!0}),c=await this.processor(i),p=[];for(let f=0;f<i.length;++f){let _=i[f],m=o?null:[[_.height,_.width]],w=c.pixel_values[f].unsqueeze_(0),x=await this.model({...l,pixel_values:w}),k;if("post_process_grounded_object_detection"in this.processor){let E=this.processor.post_process_grounded_object_detection(x,l.input_ids,{box_threshold:s,text_threshold:s,target_sizes:m})[0];k=E.boxes.map((A,T)=>({score:E.scores[T],label:E.labels[T],box:rl(A,!o)}))}else{let E=this.processor.image_processor.post_process_object_detection(x,s,m,!0)[0];k=E.boxes.map((A,T)=>({score:E.scores[T],label:r[E.classes[T]],box:rl(A,!o)}))}k.sort((E,A)=>A.score-E.score),n!==null&&(k=k.slice(0,n)),p.push(k)}return a?p:p[0]}};var bl=class extends fe{async _call(e,r,s={}){if(Array.isArray(e)){if(e.length!==1)throw Error("Document Question Answering pipeline currently only supports a batch size of 1.");e=e[0]}let n=(await et(e))[0],{pixel_values:o}=await this.processor(n),a=`<s_docvqa><s_question>${r}</s_question><s_answer>`,i=this.tokenizer(a,{add_special_tokens:!1,padding:!0,truncation:!0}).input_ids,l=await this.model.generate({inputs:o,max_length:this.model.config.decoder.max_position_embeddings,decoder_input_ids:i,...s}),p=this.tokenizer.batch_decode(l)[0].match(/<s_answer>(.*?)<\/s_answer>/),f=null;return p&&p.length>=2&&(f=p[1].trim()),[{answer:f}]}};var vl=class extends fe{async _call(e){let r=await et(e),s=await this.processor(r),n=await this.model(s),o=[];for(let a of n.reconstruction){let i=a.squeeze().clamp_(0,1).mul_(255).round_().to("uint8");o.push(Ye.fromTensor(i))}return Array.isArray(e)?o:o[0]}};var kl=class extends fe{async _call(e){let r=await et(e),s=await this.processor(r),{predicted_depth:n}=await this.model(s),o=[];for(let a=0;a<r.length;++a){let i=n[a],[l,c]=i.dims.slice(-2),[p,f]=r[a].size,_=(await vt(i.view(1,1,l,c),{size:[f,p],mode:"bilinear"})).view(f,p),m=_.min().item(),w=_.max().item(),x=_.sub(m).div_(w-m).mul_(255).to("uint8").unsqueeze(0),k=Ye.fromTensor(x);o.push({predicted_depth:_,depth:k})}return Array.isArray(e)?o:o[0]}};var El=class extends fe{async _call(e,{pooling:r="none",normalize:s=!1,quantize:n=!1,precision:o="binary"}={}){let a=this.tokenizer(e,{padding:!0,truncation:!0}),i=await this.model(a),l=i.last_hidden_state??i.logits??i.token_embeddings;switch(r){case"none":break;case"mean":l=KA(l,a.attention_mask);break;case"first_token":case"cls":l=l.slice(null,0);break;case"last_token":case"eos":l=l.slice(null,-1);break;default:throw Error(`Pooling method '${r}' not supported.`)}return s&&(l=l.normalize(2,-1)),n&&(l=YA(l,o)),l}};var Al=class extends fe{async _call(e,{pool:r=null}={}){let s=await et(e),{pixel_values:n}=await this.processor(s),o=await this.model({pixel_values:n}),a;if(r){if(!("pooler_output"in o))throw Error("No pooled output was returned. Make sure the model has a 'pooler' layer when using the 'pool' option.");a=o.pooler_output}else a=o.last_hidden_state??o.logits??o.image_embeds;return a}};var Yn=Object.freeze({"text-classification":{pipeline:sl,model:Ji,default:{model:"Xenova/distilbert-base-uncased-finetuned-sst-2-english"},type:"text"},"token-classification":{pipeline:nl,model:np,default:{model:"Xenova/bert-base-multilingual-cased-ner-hrl"},type:"text"},"question-answering":{pipeline:ol,model:up,default:{model:"Xenova/distilbert-base-cased-distilled-squad"},type:"text"},"fill-mask":{pipeline:al,model:cp,default:{model:"onnx-community/ettin-encoder-32m-ONNX",dtype:"fp32"},type:"text"},summarization:{pipeline:il,model:Qn,default:{model:"Xenova/distilbart-cnn-6-6"},type:"text"},translation:{pipeline:ll,model:Qn,default:{model:"Xenova/t5-small"},type:"text"},"text2text-generation":{pipeline:Er,model:Qn,default:{model:"Xenova/flan-t5-small"},type:"text"},"text-generation":{pipeline:cl,model:lp,default:{model:"onnx-community/Qwen3-0.6B-ONNX",dtype:"q4"},type:"text"},"zero-shot-classification":{pipeline:ul,model:Ji,default:{model:"Xenova/distilbert-base-uncased-mnli"},type:"text"},"audio-classification":{pipeline:pl,model:hp,default:{model:"Xenova/wav2vec2-base-superb-ks"},type:"audio"},"zero-shot-audio-classification":{pipeline:dl,model:kr,default:{model:"Xenova/clap-htsat-unfused"},type:"multimodal"},"automatic-speech-recognition":{pipeline:fl,model:[op,mp],default:{model:"Xenova/whisper-tiny.en"},type:"multimodal"},"text-to-audio":{pipeline:_l,model:[ip,ap],default:{model:"onnx-community/Supertonic-TTS-ONNX",dtype:"fp32"},type:"text"},"image-to-text":{pipeline:ml,model:pp,default:{model:"Xenova/vit-gpt2-image-captioning"},type:"multimodal"},"image-classification":{pipeline:hl,model:dp,default:{model:"Xenova/vit-base-patch16-224"},type:"multimodal"},"image-segmentation":{pipeline:Ws,model:[Zi,el,tl],default:{model:"Xenova/detr-resnet-50-panoptic"},type:"multimodal"},"background-removal":{pipeline:gl,model:[Zi,el,tl],default:{model:"Xenova/modnet"},type:"image"},"zero-shot-image-classification":{pipeline:wl,model:kr,default:{model:"Xenova/clip-vit-base-patch32"},type:"multimodal"},"object-detection":{pipeline:xl,model:fp,default:{model:"Xenova/detr-resnet-50"},type:"multimodal"},"zero-shot-object-detection":{pipeline:yl,model:_p,default:{model:"Xenova/owlvit-base-patch32"},type:"multimodal"},"document-question-answering":{pipeline:bl,model:gp,default:{model:"Xenova/donut-base-finetuned-docvqa"},type:"multimodal"},"image-to-image":{pipeline:vl,model:wp,default:{model:"Xenova/swin2SR-classical-sr-x2-64"},type:"image"},"depth-estimation":{pipeline:kl,model:xp,default:{model:"onnx-community/depth-anything-v2-small"},type:"image"},"feature-extraction":{pipeline:El,model:kr,default:{model:"onnx-community/all-MiniLM-L6-v2-ONNX",dtype:"fp32"},type:"text"},"image-feature-extraction":{pipeline:Al,model:[yp,kr],default:{model:"onnx-community/dinov3-vits16-pretrain-lvd1689m-ONNX",dtype:"fp32"},type:"image"}}),bp=Object.freeze({"sentiment-analysis":"text-classification",ner:"token-classification",asr:"automatic-speech-recognition","text-to-speech":"text-to-audio",embeddings:"feature-extraction"});function Gz(t,{config:e=null,cache_dir:r=null,local_files_only:s=!1,revision:n="main"}={}){if(e!==null)return jt.from_pretrained(t,{config:e,cache_dir:r,local_files_only:s,revision:n});let o=JSON.stringify([t,r,s,n]);return Kl(o,()=>jt.from_pretrained(t,{config:e,cache_dir:r,local_files_only:s,revision:n}))}async function vp(t,{config:e=null,dtype:r=null,device:s=null,model_file_name:n=null}={}){e=await Gz(t,{config:e});let o=["config.json"],a=e["transformers.js_config"]??{},i=a.use_external_data_format,l="onnx",c=s??a.device,p=r??a.dtype,f,_=e.architectures||[],m=!1;for(let E of _){let A=tr.get(E);if(A!==void 0){f=A,m=!0;break}}if(!m&&e.model_type){let E=tr.get(e.model_type);if(E!==void 0&&(f=E,m=!0),!m){for(let A of Object.values(Is))if(A.has(e.model_type)){f=tr.get(A.get(e.model_type)),m=!0;break}}}if(!m){let E=_.length>0?_.join(", "):"(none)";Z.warn(`[get_model_files] Architecture(s) not found in MODEL_TYPE_MAPPING: [${E}] for model type '${e.model_type}'. Falling back to EncoderOnly (single model.onnx file). If you encounter issues, please report at: ${jr}`),f=K.EncoderOnly}let w=(E,A=null)=>{A=A??E;let T=fc(c,E),S=_c(p,E,T),P=ko[S]??"",O=`${A}${P}.onnx`,v=l?`${l}/${O}`:O;o.push(v);let j=Um(i,O,E);for(let H of jm(O,j)){let B=l?`${l}/${H}`:H;o.push(B)}},{sessions:x,optional_configs:k}=v2(f,e,{model_file_name:n});for(let[E,A]of Object.entries(x))w(E,A);if(k)for(let E of Object.values(k))o.push(E);return o}async function kp(t){if(!t)throw new Error("modelId is required");return(await lr(t,vr,{})).exists?[vr]:[]}async function Ar(t,{config:e=null,dtype:r=null,device:s=null,model_file_name:n=null,include_tokenizer:o=!0,include_processor:a=!0}={}){let i=await vp(t,{config:e,dtype:r,device:s,model_file_name:n});if(o){let l=await dn(t);i.push(...l)}if(a){let l=await kp(t);i.push(...l)}return i}async function Mr(t,e,r={}){t=bp[t]??t;let s=Yn[t];if(!s)throw new Error(`Unsupported pipeline task: ${t}. Must be one of [${Object.keys(Yn).join(", ")}]`);let{type:n}=s;return Ar(e,{...r,include_tokenizer:n!=="audio"&&n!=="image",include_processor:n!=="text"})}async function Moe(t,e=null,{progress_callback:r=null,config:s=null,cache_dir:n=null,local_files_only:o=!1,revision:a="main",device:i=null,dtype:l=null,subfolder:c="onnx",use_external_data_format:p=null,model_file_name:f=null,session_options:_={}}={}){t=bp[t]??t;let m=Yn[t.split("_",1)[0]];if(!m)throw Error(`Unsupported pipeline: ${t}. Must be one of [${Object.keys(Yn)}]`);e||(e=m.default.model,Z.info(`No model specified. Using default model: "${e}".`),!l&&m.default.dtype&&(l=m.default.dtype));let w=await Mr(t,e,{device:i,dtype:l}),x={};r&&(await Promise.all(w.map(async V=>lr(e,V)))).forEach((V,q)=>{V.exists&&(x[w[q]]={loaded:0,total:V.size??0})});let k={progress_callback:r?B=>{if(B.status==="progress"){x[B.file]={loaded:B.loaded,total:B.total};let V=Object.values(x).reduce((F,C)=>F+C.loaded,0),q=Object.values(x).reduce((F,C)=>F+C.total,0),Q=q>0?V/q*100:0;r({status:"progress_total",name:B.name,progress:Q,loaded:V,total:q,files:structuredClone(x)})}r(B)}:void 0,config:s,cache_dir:n,local_files_only:o,revision:a,device:i,dtype:l,subfolder:c,use_external_data_format:p,model_file_name:f,session_options:_},E=w.includes("tokenizer.json"),A=w.includes("preprocessor_config.json"),T=m.model,S;if(Array.isArray(T)){let B=s??await jt.from_pretrained(e,k),{model_type:V}=B,q=T.find(Q=>Q.supports(V));if(!q)throw Error(`Unsupported model type "${V}" for task "${t}". None of the candidate model classes support this type.`);S=q.from_pretrained(e,{...k,config:B})}else S=T.from_pretrained(e,k);let[P,O,v]=await Promise.all([E?oe.from_pretrained(e,k):null,A?Wc.from_pretrained(e,k):null,S]),j={task:t,model:v};P&&(j.tokenizer=P),O&&(j.processor=O),xr(r,{status:"ready",task:t,model:e});let H=m.pipeline;return new H(j)}var qz=t=>t>=19968&&t<=40959||t>=13312&&t<=19903||t>=131072&&t<=173791||t>=173824&&t<=177983||t>=177984&&t<=178207||t>=178208&&t<=183983||t>=63744&&t<=64255||t>=194560&&t<=195103,s1=class{put(e){throw Error("Not implemented")}end(){throw Error("Not implemented")}},fM=ie.IS_PROCESS_AVAILABLE?t=>process.stdout.write(t):t=>console.log(t),n1=class extends s1{constructor(e,{skip_prompt:r=!1,callback_function:s=null,token_callback_function:n=null,skip_special_tokens:o=!0,decode_kwargs:a={},...i}={}){super(),this.tokenizer=e,this.skip_prompt=r,this.callback_function=s??fM,this.token_callback_function=n,this.decode_kwargs={skip_special_tokens:o,...a,...i},this.token_cache=[],this.print_len=0,this.next_tokens_are_prompt=!0,this.special_ids=new Set(this.tokenizer.all_special_ids.map(BigInt))}put(e){if(e.length>1)throw Error("TextStreamer only supports batch size of 1");let r=this.next_tokens_are_prompt;if(r&&(this.next_tokens_are_prompt=!1,this.skip_prompt))return;let s=e[0];if(this.token_callback_function?.(s),s.length===1&&this.special_ids.has(s[0])){if(this.decode_kwargs.skip_special_tokens)return;if(this.token_cache.length>0){let l=this.tokenizer.decode(this.token_cache,this.decode_kwargs).slice(this.print_len);this.on_finalized_text(l,!1),this.token_cache=[],this.print_len=0}let a=this.tokenizer.decode(s,this.decode_kwargs);this.on_finalized_text(a,!1);return}this.token_cache=wt(this.token_cache,s);let n=this.tokenizer.decode(this.token_cache,this.decode_kwargs),o;r||n.endsWith(`
26
- `)?(o=n.slice(this.print_len),this.token_cache=[],this.print_len=0):n.length>0&&qz(n.charCodeAt(n.length-1))?(o=n.slice(this.print_len),this.print_len+=o.length):(o=n.slice(this.print_len,n.lastIndexOf(" ")+1),this.print_len+=o.length),this.on_finalized_text(o,!1)}end(){let e;this.token_cache.length>0?(e=this.tokenizer.decode(this.token_cache,this.decode_kwargs).slice(this.print_len),this.token_cache=[],this.print_len=0):e="",this.next_tokens_are_prompt=!0,this.on_finalized_text(e,!0)}on_finalized_text(e,r){e.length>0&&this.callback_function?.(e),r&&this.callback_function===fM&&ie.IS_PROCESS_AVAILABLE&&this.callback_function?.(`
27
- `)}},_M=class extends n1{constructor(e,{skip_prompt:r=!1,callback_function:s=null,token_callback_function:n=null,on_chunk_start:o=null,on_chunk_end:a=null,on_finalize:i=null,time_precision:l=.02,skip_special_tokens:c=!0,decode_kwargs:p={}}={}){super(e,{skip_prompt:r,skip_special_tokens:c,callback_function:s,token_callback_function:n,decode_kwargs:p}),this.timestamp_begin=e.timestamp_begin,this.on_chunk_start=o,this.on_chunk_end=a,this.on_finalize=i,this.time_precision=l,this.waiting_for_timestamp=!1}put(e){if(e.length>1)throw Error("WhisperTextStreamer only supports batch size of 1");let r=e[0];if(r.length===1){let s=Number(r[0])-this.timestamp_begin;if(s>=0){let n=s*this.time_precision;this.waiting_for_timestamp?this.on_chunk_end?.(n):this.on_chunk_start?.(n),this.waiting_for_timestamp=!this.waiting_for_timestamp,this.token_callback_function?.(r);return}}return super.put(e)}end(){super.end(),this.on_finalize?.()}};var Ml=class{constructor(e,r){this.image=e,this.timestamp=r}},Ep=class{constructor(e,r){e.length>0&&e[0]instanceof Ye&&(e=e.map((s,n)=>new Ml(s,(n+1)/(e.length+1)*r))),this.frames=e,this.duration=r}get width(){return this.frames[0].image.width}get height(){return this.frames[0].image.height}get fps(){return this.frames.length/this.duration}};async function Wz(t,{num_frames:e=null,fps:r=null}={}){if(!ie.IS_BROWSER_ENV)throw new Error("`load_video` is currently only supported in browser environments.");if(e==null&&r==null)throw new Error("Either num_frames or fps must be provided.");let s=[],n=document.createElement("video");if(n.crossOrigin="anonymous",n.muted=!0,typeof t=="string")n.src=t;else if(t instanceof Blob)n.src=URL.createObjectURL(t);else if(t instanceof HTMLVideoElement)n.src=t.src;else throw new Error("Invalid URL or video element provided.");if(await new Promise(f=>n.onloadedmetadata=f),n.seekable.start(0)===n.seekable.end(0)){let _=await(await _e.fetch(n.src)).blob();n.src=URL.createObjectURL(_),await new Promise(m=>n.onloadedmetadata=m)}let o=n.duration,a,i;e!=null?(a=e,i=e===1?0:o/(e-1)):(i=1/r,a=Math.floor(o/i));let l=[];for(let f=0;f<a;++f)l.push(e===1?o/2:f*i);let c=document.createElement("canvas");c.width=n.videoWidth,c.height=n.videoHeight;let p=c.getContext("2d",{willReadFrequently:!0});for(let f of l){n.currentTime=f,await new Promise(x=>{n.onseeked=x}),p.drawImage(n,0,0,c.width,c.height);let _=p.getImageData(0,0,c.width,c.height),m=new Ye(_.data,c.width,c.height,4),w=new Ml(m,f);s.push(w)}return n.remove(),new Ep(s,o)}async function Ap(t,e,r={}){let s=await Jt(r?.cache_dir);if(!s)return{allCached:!1,files:e.map(a=>({file:a,cached:!1}))};let n=await Promise.all(e.map(async o=>{let{localPath:a,proposedCacheKey:i}=Pr(t,o,r,s),l=await zr(s,a,i);return{file:o,cached:!!l}}));return{allCached:n.every(o=>o.cached),files:n}}async function mM(t,e,r={}){let s=await Jt(r?.cache_dir);if(!s)return!1;let{localPath:n,proposedCacheKey:o}=Pr(t,e,r,s);return!!await zr(s,n,o)}async function hM(t,e={}){if(!t)throw new Error("modelId is required");if(!await mM(t,"config.json",e))return!1;let r=await Ar(t,e);return(await Ap(t,r,e)).allCached}async function gM(t,e={}){if(!t)throw new Error("modelId is required");let r=await Ar(t,e);return await Ap(t,r,e)}async function wM(t,e,r={}){if(!t)throw new Error("task is required");if(!e)throw new Error("modelId is required");if(!await mM(e,"config.json",r))return!1;let s=await Mr(t,e,r);return(await Ap(e,s,r)).allCached}async function xM(t,e,r={}){if(!t)throw new Error("task is required");if(!e)throw new Error("modelId is required");let s=await Mr(t,e,r);return await Ap(e,s,r)}async function yM(t,e,r={}){let s=await Jt(r?.cache_dir);if(!s)return{filesDeleted:0,filesCached:0,files:e.map(o=>({file:o,deleted:!1,wasCached:!1}))};if(!s.delete)throw new Error("Cache does not support delete operation");let n=await Promise.all(e.map(async o=>{let{localPath:a,proposedCacheKey:i}=Pr(t,o,r,s),c=!!await zr(s,a,i),p=!1;if(c){let f=await s.delete(i),_=!f&&i!==a?await s.delete(a):!1;p=f||_}return{file:o,deleted:p,wasCached:c}}));return{filesDeleted:n.filter(o=>o.deleted).length,filesCached:n.filter(o=>o.wasCached).length,files:n}}async function bM(t,e={}){if(!t)throw new Error("modelId is required");let r=await Ar(t,e);return await yM(t,r,e)}async function vM(t,e,r={}){if(!t)throw new Error("task is required");if(!e)throw new Error("modelId is required");let s=await Mr(t,e,r);return await yM(e,s,r)}var o1=class{static async get_files(e,r={}){return Ar(e,r)}static async get_pipeline_files(e,r,s={}){return Mr(e,r,s)}static async get_model_files(e,r={}){return vp(e,r)}static async get_tokenizer_files(e){return dn(e)}static async get_processor_files(e){return kp(e)}static async is_cached(e,r={}){return hM(e,r)}static async is_cached_files(e,r={}){return gM(e,r)}static async is_pipeline_cached(e,r,s={}){return wM(e,r,s)}static async is_pipeline_cached_files(e,r,s={}){return xM(e,r,s)}static async get_file_metadata(e,r,s={}){return lr(e,r,s)}static async clear_cache(e,r={}){return bM(e,r)}static async clear_pipeline_cache(e,r,s={}){return vM(e,r,s)}};export{u_ as ASTFeatureExtractor,ih as ASTForAudioClassification,ah as ASTModel,Wo as ASTPreTrainedModel,sh as AfmoeForCausalLM,rh as AfmoeModel,Go as AfmoePreTrainedModel,Zm as AlbertForMaskedLM,Jm as AlbertForQuestionAnswering,Ym as AlbertForSequenceClassification,Qm as AlbertModel,Ls as AlbertPreTrainedModel,gf as AlbertTokenizer,th as ApertusForCausalLM,eh as ApertusModel,jo as ApertusPreTrainedModel,oh as ArceeForCausalLM,nh as ArceeModel,qo as ArceePreTrainedModel,pl as AudioClassificationPipeline,jt as AutoConfig,Ke as AutoFeatureExtractor,Pe as AutoImageProcessor,kr as AutoModel,hp as AutoModelForAudioClassification,oM as AutoModelForAudioFrameClassification,uM as AutoModelForAudioTextToText,mp as AutoModelForCTC,lp as AutoModelForCausalLM,xp as AutoModelForDepthEstimation,gp as AutoModelForDocumentQuestionAnswering,dp as AutoModelForImageClassification,yp as AutoModelForImageFeatureExtraction,aM as AutoModelForImageMatting,Zi as AutoModelForImageSegmentation,cM as AutoModelForImageTextToText,wp as AutoModelForImageToImage,sM as AutoModelForMaskGeneration,cp as AutoModelForMaskedLM,iM as AutoModelForNormalEstimation,fp as AutoModelForObjectDetection,lM as AutoModelForPoseEstimation,up as AutoModelForQuestionAnswering,el as AutoModelForSemanticSegmentation,Qn as AutoModelForSeq2SeqLM,Ji as AutoModelForSequenceClassification,op as AutoModelForSpeechSeq2Seq,ap as AutoModelForTextToSpectrogram,ip as AutoModelForTextToWaveform,np as AutoModelForTokenClassification,tl as AutoModelForUniversalSegmentation,pp as AutoModelForVision2Seq,nM as AutoModelForXVector,_p as AutoModelForZeroShotObjectDetection,Wc as AutoProcessor,oe as AutoTokenizer,fl as AutomaticSpeechRecognitionPipeline,gl as BackgroundRemovalPipeline,ch as BartForConditionalGeneration,uh as BartForSequenceClassification,lh as BartModel,Tn as BartPretrainedModel,wf as BartTokenizer,s1 as BaseStreamer,T_ as BeitFeatureExtractor,dh as BeitForImageClassification,ph as BeitModel,Vo as BeitPreTrainedModel,_h as BertForMaskedLM,gh as BertForQuestionAnswering,mh as BertForSequenceClassification,hh as BertForTokenClassification,fh as BertModel,Vr as BertPreTrainedModel,xf as BertTokenizer,O_ as BitImageProcessor,xh as BlenderbotForConditionalGeneration,wh as BlenderbotModel,Ho as BlenderbotPreTrainedModel,bh as BlenderbotSmallForConditionalGeneration,yh as BlenderbotSmallModel,Xo as BlenderbotSmallPreTrainedModel,yf as BlenderbotSmallTokenizer,bf as BlenderbotTokenizer,kh as BloomForCausalLM,vh as BloomModel,Ko as BloomPreTrainedModel,vf as BloomTokenizer,C_ as CLIPFeatureExtractor,Ac as CLIPImageProcessor,Ch as CLIPModel,pr as CLIPPreTrainedModel,$h as CLIPSegForImageSegmentation,Nh as CLIPSegModel,ea as CLIPSegPreTrainedModel,Lh as CLIPTextModel,Zo as CLIPTextModelWithProjection,Ef as CLIPTokenizer,Ph as CLIPVisionModel,zh as CLIPVisionModelWithProjection,Ah as CamembertForMaskedLM,Th as CamembertForQuestionAnswering,Mh as CamembertForSequenceClassification,Sh as CamembertForTokenClassification,Eh as CamembertModel,Hr as CamembertPreTrainedModel,kf as CamembertTokenizer,p_ as ChatterboxFeatureExtractor,Qo as ChatterboxModel,lu as ChatterboxPreTrainedModel,E_ as ChatterboxProcessor,I_ as ChineseCLIPFeatureExtractor,Oh as ChineseCLIPModel,cu as ChineseCLIPPreTrainedModel,Jo as ClapAudioModelWithProjection,d_ as ClapFeatureExtractor,Ih as ClapModel,On as ClapPreTrainedModel,Yo as ClapTextModelWithProjection,tu as ClassifierFreeGuidanceLogitsProcessor,Dh as CodeGenForCausalLM,Rh as CodeGenModel,ta as CodeGenPreTrainedModel,Mf as CodeGenTokenizer,Af as CodeLlamaTokenizer,jh as Cohere2ForCausalLM,Uh as Cohere2Model,sa as Cohere2PreTrainedModel,Bh as CohereForCausalLM,Fh as CohereModel,ra as CoherePreTrainedModel,Sf as CohereTokenizer,qh as ConvBertForMaskedLM,Hh as ConvBertForQuestionAnswering,Wh as ConvBertForSequenceClassification,Vh as ConvBertForTokenClassification,Gh as ConvBertModel,Xr as ConvBertPreTrainedModel,Tf as ConvBertTokenizer,L_ as ConvNextFeatureExtractor,Kh as ConvNextForImageClassification,Mc as ConvNextImageProcessor,Xh as ConvNextModel,na as ConvNextPreTrainedModel,Yh as ConvNextV2ForImageClassification,Qh as ConvNextV2Model,oa as ConvNextV2PreTrainedModel,tg as DFineForObjectDetection,eg as DFineModel,ia as DFinePreTrainedModel,Ag as DINOv3ConvNextModel,hu as DINOv3ConvNextPreTrainedModel,N_ as DINOv3ViTImageProcessor,Mg as DINOv3ViTModel,gu as DINOv3ViTPreTrainedModel,R_ as DPTFeatureExtractor,zg as DPTForDepthEstimation,Oc as DPTImageProcessor,Pg as DPTModel,fa as DPTPreTrainedModel,ca as DacDecoderModel,pu as DacDecoderOutput,la as DacEncoderModel,uu as DacEncoderOutput,Co as DacFeatureExtractor,rg as DacModel,In as DacPreTrainedModel,ng as DebertaForMaskedLM,ig as DebertaForQuestionAnswering,og as DebertaForSequenceClassification,ag as DebertaForTokenClassification,sg as DebertaModel,Kr as DebertaPreTrainedModel,If as DebertaTokenizer,cg as DebertaV2ForMaskedLM,dg as DebertaV2ForQuestionAnswering,ug as DebertaV2ForSequenceClassification,pg as DebertaV2ForTokenClassification,lg as DebertaV2Model,Qr as DebertaV2PreTrainedModel,Of as DebertaV2Tokenizer,fg as DecisionTransformerModel,du as DecisionTransformerPreTrainedModel,P_ as DeiTFeatureExtractor,mg as DeiTForImageClassification,Sc as DeiTImageProcessor,_g as DeiTModel,ua as DeiTPreTrainedModel,hg as DepthAnythingForDepthEstimation,fu as DepthAnythingPreTrainedModel,kl as DepthEstimationPipeline,gg as DepthProForDepthEstimation,_u as DepthProPreTrainedModel,z_ as DetrFeatureExtractor,xg as DetrForObjectDetection,yg as DetrForSegmentation,Tc as DetrImageProcessor,wg as DetrModel,Ln as DetrObjectDetectionOutput,Cn as DetrPreTrainedModel,mu as DetrSegmentationOutput,vg as Dinov2ForImageClassification,bg as Dinov2Model,pa as Dinov2PreTrainedModel,Eg as Dinov2WithRegistersForImageClassification,kg as Dinov2WithRegistersModel,da as Dinov2WithRegistersPreTrainedModel,Cg as DistilBertForMaskedLM,Ig as DistilBertForQuestionAnswering,Tg as DistilBertForSequenceClassification,Og as DistilBertForTokenClassification,Sg as DistilBertModel,Yr as DistilBertPreTrainedModel,Cf as DistilBertTokenizer,bl as DocumentQuestionAnsweringPipeline,$_ as DonutFeatureExtractor,_n as DonutImageProcessor,Lg as DonutSwinModel,wu as DonutSwinPreTrainedModel,Fo as DynamicCache,T0 as EdgeTamModel,$g as EfficientNetForImageClassification,D_ as EfficientNetImageProcessor,Ng as EfficientNetModel,_a as EfficientNetPreTrainedModel,Dg as ElectraForMaskedLM,Ug as ElectraForQuestionAnswering,Fg as ElectraForSequenceClassification,Bg as ElectraForTokenClassification,Rg as ElectraModel,Jr as ElectraPreTrainedModel,Lf as ElectraTokenizer,Io as EncodecFeatureExtractor,nu as EosTokenCriteria,Gg as Ernie4_5ForCausalLM,jg as Ernie4_5Model,ma as Ernie4_5PretrainedModel,Wg as EsmForMaskedLM,Vg as EsmForSequenceClassification,Hg as EsmForTokenClassification,qg as EsmModel,Ps as EsmPreTrainedModel,Pf as EsmTokenizer,Kg as ExaoneForCausalLM,Xg as ExaoneModel,ha as ExaonePreTrainedModel,Yg as FalconForCausalLM,Zg as FalconH1ForCausalLM,Jg as FalconH1Model,wa as FalconH1PreTrainedModel,Qg as FalconModel,ga as FalconPreTrainedModel,zf as FalconTokenizer,tw as FastViTForImageClassification,ew as FastViTModel,xa as FastViTPreTrainedModel,El as FeatureExtractionPipeline,Ae as FeatureExtractor,al as FillMaskPipeline,rw as Florence2ForConditionalGeneration,xu as Florence2PreTrainedModel,hm as Florence2Processor,Hc as ForcedBOSTokenLogitsProcessor,Xc as ForcedEOSTokenLogitsProcessor,F_ as GLPNFeatureExtractor,dw as GLPNForDepthEstimation,pw as GLPNModel,Aa as GLPNPreTrainedModel,vw as GPT2LMHeadModel,bw as GPT2Model,Ia as GPT2PreTrainedModel,Rf as GPT2Tokenizer,_w as GPTBigCodeForCausalLM,fw as GPTBigCodeModel,Ma as GPTBigCodePreTrainedModel,Ew as GPTJForCausalLM,kw as GPTJModel,Ca as GPTJPreTrainedModel,hw as GPTNeoForCausalLM,mw as GPTNeoModel,Sa as GPTNeoPreTrainedModel,ww as GPTNeoXForCausalLM,gw as GPTNeoXModel,Ta as GPTNeoXPreTrainedModel,$f as GPTNeoXTokenizer,aw as Gemma2ForCausalLM,ow as Gemma2Model,ba as Gemma2PreTrainedModel,lw as Gemma3ForCausalLM,iw as Gemma3Model,va as Gemma3PreTrainedModel,f_ as Gemma3nAudioFeatureExtractor,ka as Gemma3nForCausalLM,Pn as Gemma3nForConditionalGeneration,yu as Gemma3nPreTrainedModel,gm as Gemma3nProcessor,nw as GemmaForCausalLM,sw as GemmaModel,ya as GemmaPreTrainedModel,Nf as GemmaTokenizer,uw as GlmForCausalLM,cw as GlmModel,Ea as GlmPreTrainedModel,yw as GptOssForCausalLM,xw as GptOssModel,Oa as GptOssPreTrainedModel,Mw as GraniteForCausalLM,Aw as GraniteModel,Tw as GraniteMoeHybridForCausalLM,Sw as GraniteMoeHybridModel,Pa as GraniteMoeHybridPreTrainedModel,La as GranitePreTrainedModel,__ as GraniteSpeechFeatureExtractor,Ow as GraniteSpeechForConditionalGeneration,wm as GraniteSpeechProcessor,Iw as GroundingDinoForObjectDetection,B_ as GroundingDinoImageProcessor,vu as GroundingDinoPreTrainedModel,xm as GroundingDinoProcessor,Cw as GroupViTModel,ku as GroupViTPreTrainedModel,Pw as HeliumForCausalLM,Lw as HeliumModel,za as HeliumPreTrainedModel,Df as HerbertTokenizer,Nw as HieraForImageClassification,zw as HieraModel,Na as HieraPreTrainedModel,jw as HubertForCTC,Gw as HubertForSequenceClassification,Uw as HubertModel,Bw as HubertPreTrainedModel,Ww as HunYuanDenseV1ForCausalLM,qw as HunYuanDenseV1Model,$a as HunYuanDenseV1PreTrainedModel,Qw as IJepaForImageClassification,Kw as IJepaModel,Ra as IJepaPreTrainedModel,Xw as Idefics3ForConditionalGeneration,Ic as Idefics3ImageProcessor,Bc as Idefics3Processor,hl as ImageClassificationPipeline,Al as ImageFeatureExtractionPipeline,X as ImageFeatureExtractor,X as ImageProcessor,Ws as ImageSegmentationPipeline,vl as ImageToImagePipeline,ml as ImageToTextPipeline,x2 as InterruptableStoppingCriteria,Jw as JAISLMHeadModel,Yw as JAISModel,Da as JAISPreTrainedModel,j_ as JinaCLIPImageProcessor,Zw as JinaCLIPModel,zn as JinaCLIPPreTrainedModel,bm as JinaCLIPProcessor,Fa as JinaCLIPTextModel,ex as JinaCLIPVisionModel,rx as Lfm2ForCausalLM,tx as Lfm2Model,nx as Lfm2MoeForCausalLM,sx as Lfm2MoeModel,Ua as Lfm2MoePreTrainedModel,Ba as Lfm2PreTrainedModel,ox as Lfm2VlForConditionalGeneration,G_ as Lfm2VlImageProcessor,vm as Lfm2VlProcessor,Ub as LiteWhisperForConditionalGeneration,lx as Llama4ForCausalLM,Au as Llama4PreTrainedModel,ix as LlamaForCausalLM,ax as LlamaModel,ja as LlamaPreTrainedModel,Ff as LlamaTokenizer,Wt as LlavaForConditionalGeneration,Wt as LlavaOnevisionForConditionalGeneration,q_ as LlavaOnevisionImageProcessor,Eu as LlavaPreTrainedModel,km as LlavaProcessor,Hw as LlavaQwen2ForCausalLM,Ot as LogLevel,Gt as LogitsProcessor,Ts as LogitsProcessorList,Do as LogitsWarper,ux as LongT5ForConditionalGeneration,cx as LongT5Model,Ga as LongT5PreTrainedModel,dx as M2M100ForConditionalGeneration,px as M2M100Model,qa as M2M100PreTrainedModel,Bf as M2M100Tokenizer,jf as MBart50Tokenizer,yx as MBartForCausalLM,wx as MBartForConditionalGeneration,xx as MBartForSequenceClassification,gx as MBartModel,Ns as MBartPreTrainedModel,Mo as MBartTokenizer,ny as MPNetForMaskedLM,iy as MPNetForQuestionAnswering,oy as MPNetForSequenceClassification,ay as MPNetForTokenClassification,sy as MPNetModel,Zr as MPNetPreTrainedModel,Wf as MPNetTokenizer,py as MT5ForConditionalGeneration,uy as MT5Model,ri as MT5PreTrainedModel,_x as MarianMTModel,fx as MarianModel,Wa as MarianPreTrainedModel,Uf as MarianTokenizer,V_ as Mask2FormerImageProcessor,W_ as MaskFormerFeatureExtractor,hx as MaskFormerForInstanceSegmentation,mn as MaskFormerImageProcessor,mx as MaskFormerModel,Va as MaskFormerPreTrainedModel,su as MaxLengthCriteria,bx as Metric3DForDepthEstimation,Mu as Metric3DPreTrainedModel,vx as Metric3Dv2ForDepthEstimation,Su as Metric3Dv2PreTrainedModel,kx as MgpstrForSceneTextRecognition,Tu as MgpstrModelOutput,Ou as MgpstrPreTrainedModel,Em as MgpstrProcessor,Gf as MgpstrTokenizer,Xa as MimiDecoderModel,Cu as MimiDecoderOutput,Ha as MimiEncoderModel,Iu as MimiEncoderOutput,Ex as MimiModel,Nn as MimiPreTrainedModel,Jc as MinLengthLogitsProcessor,Zc as MinNewTokensLengthLogitsProcessor,Mx as MistralForCausalLM,Ax as MistralModel,Ka as MistralPreTrainedModel,Tx as MobileBertForMaskedLM,Ix as MobileBertForQuestionAnswering,Ox as MobileBertForSequenceClassification,Sx as MobileBertModel,$s as MobileBertPreTrainedModel,qf as MobileBertTokenizer,Lx as MobileLLMForCausalLM,Cx as MobileLLMModel,Qa as MobileLLMPreTrainedModel,H_ as MobileNetV1FeatureExtractor,zx as MobileNetV1ForImageClassification,Nx as MobileNetV1ForSemanticSegmentation,Cc as MobileNetV1ImageProcessor,Px as MobileNetV1Model,$n as MobileNetV1PreTrainedModel,X_ as MobileNetV2FeatureExtractor,Rx as MobileNetV2ForImageClassification,Dx as MobileNetV2ForSemanticSegmentation,Lc as MobileNetV2ImageProcessor,$x as MobileNetV2Model,Rn as MobileNetV2PreTrainedModel,K_ as MobileNetV3FeatureExtractor,Bx as MobileNetV3ForImageClassification,Ux as MobileNetV3ForSemanticSegmentation,Pc as MobileNetV3ImageProcessor,Fx as MobileNetV3Model,Dn as MobileNetV3PreTrainedModel,Q_ as MobileNetV4FeatureExtractor,Gx as MobileNetV4ForImageClassification,qx as MobileNetV4ForSemanticSegmentation,zc as MobileNetV4ImageProcessor,jx as MobileNetV4Model,Fn as MobileNetV4PreTrainedModel,Y_ as MobileViTFeatureExtractor,Vx as MobileViTForImageClassification,Nc as MobileViTImageProcessor,Wx as MobileViTModel,Ya as MobileViTPreTrainedModel,Xx as MobileViTV2ForImageClassification,Hx as MobileViTV2Model,Ja as MobileViTV2PreTrainedModel,o1 as ModelRegistry,ey as ModernBertDecoderForCausalLM,Zx as ModernBertDecoderModel,Za as ModernBertDecoderPreTrainedModel,Qx as ModernBertForMaskedLM,Yx as ModernBertForSequenceClassification,Jx as ModernBertForTokenClassification,Kx as ModernBertModel,Rs as ModernBertPreTrainedModel,Vw as Moondream1ForConditionalGeneration,m_ as MoonshineFeatureExtractor,ry as MoonshineForConditionalGeneration,ty as MoonshineModel,ei as MoonshinePreTrainedModel,Am as MoonshineProcessor,cy as MptForCausalLM,ly as MptModel,ti as MptPreTrainedModel,dy as MultiModalityCausalLM,Lu as MultiModalityPreTrainedModel,_y as MusicgenForCausalLM,ni as MusicgenForConditionalGeneration,fy as MusicgenModel,si as MusicgenPreTrainedModel,hy as NanoChatForCausalLM,my as NanoChatModel,oi as NanoChatPreTrainedModel,wy as NeoBertForMaskedLM,by as NeoBertForQuestionAnswering,xy as NeoBertForSequenceClassification,yy as NeoBertForTokenClassification,gy as NeoBertModel,es as NeoBertPreTrainedModel,Vf as NllbTokenizer,eu as NoBadWordsLogitsProcessor,Qc as NoRepeatNGramLogitsProcessor,vy as NomicBertModel,Pu as NomicBertPreTrainedModel,J_ as NougatImageProcessor,Hf as NougatTokenizer,zy as OPTForCausalLM,Py as OPTModel,pi as OPTPreTrainedModel,xl as ObjectDetectionPipeline,My as Olmo2ForCausalLM,Ay as Olmo2Model,ii as Olmo2PreTrainedModel,Ty as Olmo3ForCausalLM,Sy as Olmo3Model,li as Olmo3PreTrainedModel,Ey as OlmoForCausalLM,Iy as OlmoHybridForCausalLM,Oy as OlmoHybridModel,ci as OlmoHybridPreTrainedModel,ky as OlmoModel,ai as OlmoPreTrainedModel,Ly as OpenELMForCausalLM,Cy as OpenELMModel,ui as OpenELMPreTrainedModel,Z_ as OwlViTFeatureExtractor,Dy as OwlViTForObjectDetection,hn as OwlViTImageProcessor,Ry as OwlViTModel,fi as OwlViTPreTrainedModel,Mm as OwlViTProcessor,$y as Owlv2ForObjectDetection,em as Owlv2ImageProcessor,Ny as Owlv2Model,di as Owlv2PreTrainedModel,Fy as PaliGemmaForConditionalGeneration,Sm as PaliGemmaProcessor,h_ as ParakeetFeatureExtractor,By as ParakeetForCTC,zu as ParakeetPreTrainedModel,jy as PatchTSMixerForPrediction,Uy as PatchTSMixerModel,_i as PatchTSMixerPreTrainedModel,qy as PatchTSTForPrediction,Gy as PatchTSTModel,mi as PatchTSTPreTrainedModel,Xy as Phi3ForCausalLM,Hy as Phi3Model,gi as Phi3PreTrainedModel,wi as Phi3VForCausalLM,sm as Phi3VImageProcessor,Nu as Phi3VPreTrainedModel,Tm as Phi3VProcessor,Vy as PhiForCausalLM,Wy as PhiModel,hi as PhiPreTrainedModel,nm as PixtralImageProcessor,Om as PixtralProcessor,y as PreTrainedModel,W as PreTrainedTokenizer,bn as PretrainedConfig,re as Processor,Qy as PvtForImageClassification,om as PvtImageProcessor,Ky as PvtModel,xi as PvtPreTrainedModel,Lo as PyAnnoteFeatureExtractor,Jy as PyAnnoteForAudioFrameClassification,Yy as PyAnnoteModel,yi as PyAnnotePreTrainedModel,Im as PyAnnoteProcessor,ol as QuestionAnsweringPipeline,e0 as Qwen2ForCausalLM,Zy as Qwen2Model,r0 as Qwen2MoeForCausalLM,t0 as Qwen2MoeModel,vi as Qwen2MoePreTrainedModel,bi as Qwen2PreTrainedModel,Xf as Qwen2Tokenizer,Ds as Qwen2VLForCausalLM,Bn as Qwen2VLForConditionalGeneration,am as Qwen2VLImageProcessor,$u as Qwen2VLPreTrainedModel,No as Qwen2VLProcessor,Fs as Qwen2_5_VLForCausalLM,ki as Qwen2_5_VLForConditionalGeneration,$o as Qwen2_5_VLProcessor,n0 as Qwen3ForCausalLM,s0 as Qwen3Model,a0 as Qwen3MoeForCausalLM,o0 as Qwen3MoeModel,Ai as Qwen3MoePreTrainedModel,l0 as Qwen3NextForCausalLM,i0 as Qwen3NextModel,Mi as Qwen3NextPreTrainedModel,Ei as Qwen3PreTrainedModel,Us as Qwen3VLForCausalLM,Bs as Qwen3VLForConditionalGeneration,Si as Qwen3VLMoeForCausalLM,c0 as Qwen3VLMoeForConditionalGeneration,Cm as Qwen3VLProcessor,js as Qwen3_5ForCausalLM,Un as Qwen3_5ForConditionalGeneration,Ti as Qwen3_5MoeForCausalLM,u0 as Qwen3_5MoeForConditionalGeneration,_0 as RFDetrForObjectDetection,f0 as RFDetrModel,Ru as RFDetrObjectDetectionOutput,Ii as RFDetrPreTrainedModel,Zh as RTDetrForObjectDetection,im as RTDetrImageProcessor,Jh as RTDetrModel,dr as RTDetrObjectDetectionOutput,aa as RTDetrPreTrainedModel,M0 as RTDetrV2ForObjectDetection,A0 as RTDetrV2Model,Du as RTDetrV2ObjectDetectionOutput,Ci as RTDetrV2PreTrainedModel,Oo as RawAudio,Ye as RawImage,Ep as RawVideo,Ml as RawVideoFrame,Yc as RepetitionPenaltyLogitsProcessor,d0 as ResNetForImageClassification,p0 as ResNetModel,Oi as ResNetPreTrainedModel,b0 as RoFormerForMaskedLM,E0 as RoFormerForQuestionAnswering,v0 as RoFormerForSequenceClassification,k0 as RoFormerForTokenClassification,y0 as RoFormerModel,rs as RoFormerPreTrainedModel,Qf as RoFormerTokenizer,h0 as RobertaForMaskedLM,x0 as RobertaForQuestionAnswering,g0 as RobertaForSequenceClassification,w0 as RobertaForTokenClassification,m0 as RobertaModel,ts as RobertaPreTrainedModel,Kf as RobertaTokenizer,zo as Sam2ImageProcessor,Uu as Sam2ImageSegmentationOutput,Li as Sam2Model,ju as Sam2PreTrainedModel,Uc as Sam2Processor,Lm as Sam2VideoProcessor,zo as Sam3ImageProcessor,O0 as Sam3TrackerModel,zo as SamImageProcessor,Fu as SamImageSegmentationOutput,S0 as SamModel,Bu as SamPreTrainedModel,Ro as SamProcessor,lm as SapiensFeatureExtractor,C0 as SapiensForDepthEstimation,L0 as SapiensForNormalEstimation,I0 as SapiensForSemanticSegmentation,$c as SapiensImageProcessor,jn as SapiensPreTrainedModel,g_ as SeamlessM4TFeatureExtractor,cm as SegformerFeatureExtractor,z0 as SegformerForImageClassification,N0 as SegformerForSemanticSegmentation,Rc as SegformerImageProcessor,P0 as SegformerModel,Gn as SegformerPreTrainedModel,um as SiglipImageProcessor,$0 as SiglipModel,Pi as SiglipPreTrainedModel,zi as SiglipTextModel,Yf as SiglipTokenizer,R0 as SiglipVisionModel,F0 as SmolLM3ForCausalLM,D0 as SmolLM3Model,Ni as SmolLM3PreTrainedModel,Ic as SmolVLMImageProcessor,Bc as SmolVLMProcessor,Ri as SnacDecoderModel,$i as SnacEncoderModel,w_ as SnacFeatureExtractor,B0 as SnacModel,qn as SnacPreTrainedModel,x_ as SpeechT5FeatureExtractor,j0 as SpeechT5ForSpeechToText,G0 as SpeechT5ForTextToSpeech,q0 as SpeechT5HifiGan,U0 as SpeechT5Model,Wn as SpeechT5PreTrainedModel,Pm as SpeechT5Processor,Jf as SpeechT5Tokenizer,V0 as SqueezeBertForMaskedLM,X0 as SqueezeBertForQuestionAnswering,H0 as SqueezeBertForSequenceClassification,W0 as SqueezeBertModel,Gs as SqueezeBertPreTrainedModel,Zf as SqueezeBertTokenizer,Q0 as StableLmForCausalLM,K0 as StableLmModel,Di as StableLmPreTrainedModel,J0 as Starcoder2ForCausalLM,Y0 as Starcoder2Model,Fi as Starcoder2PreTrainedModel,Wr as StoppingCriteria,En as StoppingCriteriaList,Z0 as StyleTextToSpeech2Model,Gu as StyleTextToSpeech2PreTrainedModel,il as SummarizationPipeline,Bi as SupertonicForConditionalGeneration,qu as SupertonicPreTrainedModel,vn as SuppressTokensAtBeginLogitsProcessor,nb as Swin2SRForImageSuperResolution,pm as Swin2SRImageProcessor,sb as Swin2SRModel,Ui as Swin2SRPreTrainedModel,tb as SwinForImageClassification,rb as SwinForSemanticSegmentation,eb as SwinModel,Vn as SwinPreTrainedModel,ab as T5ForConditionalGeneration,ob as T5Model,ji as T5PreTrainedModel,e_ as T5Tokenizer,lb as TableTransformerForObjectDetection,ib as TableTransformerModel,Wu as TableTransformerObjectDetectionOutput,Gi as TableTransformerPreTrainedModel,ru as TemperatureLogitsWarper,$ as Tensor,Er as Text2TextGenerationPipeline,sl as TextClassificationPipeline,cl as TextGenerationPipeline,n1 as TextStreamer,_l as TextToAudioPipeline,nl as TokenClassificationPipeline,W as TokenizersBackend,w2 as TopKLogitsWarper,g2 as TopPLogitsWarper,cb as TrOCRForCausalLM,Vu as TrOCRPreTrainedModel,ll as TranslationPipeline,zs as UltravoxModel,bu as UltravoxPreTrainedModel,zm as UltravoxProcessor,pb as UniSpeechForCTC,db as UniSpeechForSequenceClassification,ub as UniSpeechModel,Hn as UniSpeechPreTrainedModel,hb as UniSpeechSatForAudioFrameClassification,_b as UniSpeechSatForCTC,mb as UniSpeechSatForSequenceClassification,fb as UniSpeechSatModel,qs as UniSpeechSatPreTrainedModel,ym as VLChatProcessor,U_ as VLMImageProcessor,wb as VaultGemmaForCausalLM,gb as VaultGemmaModel,qi as VaultGemmaPreTrainedModel,dm as ViTFeatureExtractor,bb as ViTForImageClassification,Dc as ViTImageProcessor,vb as ViTMAEModel,Hu as ViTMAEPreTrainedModel,Eb as ViTMSNForImageClassification,kb as ViTMSNModel,Vi as ViTMSNPreTrainedModel,yb as ViTModel,Wi as ViTPreTrainedModel,xb as VisionEncoderDecoderModel,Ab as VitMatteForImageMatting,fm as VitMatteImageProcessor,Xu as VitMattePreTrainedModel,Mb as VitPoseForPoseEstimation,_m as VitPoseImageProcessor,Ku as VitPosePreTrainedModel,Sb as VitsModel,Qu as VitsModelOutput,Yu as VitsPreTrainedModel,r_ as VitsTokenizer,Tb as VoxtralForConditionalGeneration,Nm as VoxtralProcessor,v_ as VoxtralRealtimeFeatureExtractor,Hi as VoxtralRealtimeForConditionalGeneration,Ju as VoxtralRealtimePreTrainedModel,Rm as VoxtralRealtimeProcessor,Lb as Wav2Vec2BertForCTC,Pb as Wav2Vec2BertForSequenceClassification,Cb as Wav2Vec2BertModel,Xn as Wav2Vec2BertPreTrainedModel,s_ as Wav2Vec2CTCTokenizer,y_ as Wav2Vec2FeatureExtractor,Fw as Wav2Vec2ForAudioFrameClassification,Rw as Wav2Vec2ForCTC,Dw as Wav2Vec2ForSequenceClassification,$w as Wav2Vec2Model,rr as Wav2Vec2PreTrainedModel,Dm as Wav2Vec2Processor,Fm as Wav2Vec2ProcessorWithLM,Db as WavLMForAudioFrameClassification,Nb as WavLMForCTC,$b as WavLMForSequenceClassification,Rb as WavLMForXVector,zb as WavLMModel,ss as WavLMPreTrainedModel,b_ as WeSpeakerFeatureExtractor,Fb as WeSpeakerResNetModel,ep as WeSpeakerResNetPreTrainedModel,k_ as WhisperFeatureExtractor,rp as WhisperForConditionalGeneration,Bb as WhisperModel,Xi as WhisperPreTrainedModel,Bm as WhisperProcessor,_M as WhisperTextStreamer,Kc as WhisperTimeStampLogitsProcessor,n_ as WhisperTokenizer,Vb as XLMForQuestionAnswering,qb as XLMForSequenceClassification,Wb as XLMForTokenClassification,jb as XLMModel,ns as XLMPreTrainedModel,Xb as XLMRobertaForMaskedLM,Yb as XLMRobertaForQuestionAnswering,Kb as XLMRobertaForSequenceClassification,Qb as XLMRobertaForTokenClassification,Hb as XLMRobertaModel,os as XLMRobertaPreTrainedModel,o_ as XLMRobertaTokenizer,a_ as XLMTokenizer,Gb as XLMWithLMHeadModel,Zu as XVectorOutput,mm as YolosFeatureExtractor,Zb as YolosForObjectDetection,Fc as YolosImageProcessor,Jb as YolosModel,sp as YolosObjectDetectionOutput,Ki as YolosPreTrainedModel,t1 as YoutuForCausalLM,e1 as YoutuModel,Qi as YoutuPreTrainedModel,dl as ZeroShotAudioClassificationPipeline,ul as ZeroShotClassificationPipeline,wl as ZeroShotImageClassificationPipeline,yl as ZeroShotObjectDetectionPipeline,Ee as cat,YL as cos_sim,iE as dot,_e as env,Xe as full,Ao as full_like,uf as interpolate,vt as interpolate_4d,vR as layer_norm,tz as load_image,Wz as load_video,md as log_softmax,XA as matmul,gc as mean,KA as mean_pooling,st as ones,wc as ones_like,PP as permute,Moe as pipeline,YA as quantize_embeddings,kR as rand,QA as randn,_s as random,c_ as read_audio,bR as rfft,hc as slice,$e as softmax,It as stack,pf as std_mean,er as topk,ff as zeros,_f as zeros_like};
23
+ ${s}${o}`+n.repeat(t)+`${s}`,a}function Fz(t,e,r,s){return`${e}${s}`+r.repeat(t)+`${e}`}function Bz(t,e,r,s,n,o){return t===0&&e===0?Fz(r,s,n,o):Dz(r,t,e,s,n,o)}var Hc=class extends re{static image_processor_class=Ce;static tokenizer_class=oe;static uses_processor_config=!0;fake_image_token="<fake_token_around_image>";image_token="<image>";global_img_token="<global-img>";async _call(e,r=null,s={}){s.return_row_col_info??=!0;let n;r&&(n=await this.image_processor(r,s)),Array.isArray(e)||(e=[e]);let o=n.rows??[new Array(e.length).fill(0)],a=n.cols??[new Array(e.length).fill(0)],i=this.config.image_seq_len,l=[],c=[];for(let d=0;d<e.length;++d){let _=e[d],m=o[d],w=a[d];l.push(Wk(_,this.image_token));let x=m.map((A,T)=>Bz(A,w[T],i,this.fake_image_token,this.image_token,this.global_img_token)),E=_.split(this.image_token);if(E.length===0)throw new Error("The image token should be present in the text.");let k=E[0];for(let A=0;A<x.length;++A)k+=x[A]+E[A+1];c.push(k)}return{...this.tokenizer(c),...n}}};var Om=class extends re{static image_processor_class=Ce;static tokenizer_class=oe;static uses_processor_config=!0;constructor(e,r,s){super(e,r,s),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:r=null,chat_template:s="default"}={}){r?Array.isArray(r)||(r=[r]):r=await Promise.all(e.filter(E=>E.images).flatMap(E=>E.images).map(E=>Qe.read(E)));let n=this.tokenizer,o=n.apply_chat_template(e,{tokenize:!1,add_generation_prompt:!0,chat_template:s}),a=E=>n.encode(E,{add_special_tokens:!1}),i=o.split(this.image_tag),l=i.length-1;if(r.length!==l)throw new Error(`Number of images provided (${r.length}) does not match number of "${this.image_tag}" image tags (${l})`);let[c,p,d]=n.convert_tokens_to_ids([this.image_tag,this.image_start_tag,this.image_end_tag]),_=a(i[0]),m=new Array(_.length).fill(!1);for(let E=1;E<i.length;++E){let k=new Array(this.num_image_tokens).fill(c),A=a(i[E]);_=ht(_,[p],k,[d],A);let T=new Array(this.num_image_tokens).fill(!0);m=ht(m,[!1],T,[!1],new Array(A.length).fill(!1))}let w=[1,_.length],x={input_ids:new $("int64",_,w),attention_mask:new $("int64",new Array(_.length).fill(1),w),images_seq_mask:new $("bool",m,w),images_emb_mask:new $("bool",new Array(l*this.num_image_tokens).fill(!0),[1,l,this.num_image_tokens])};if(r&&r.length>0){let E=await this.image_processor(r);return E.pixel_values.unsqueeze_(0),{...x,...E}}return x}};var Im=class extends re{static tokenizer_class=oe;static image_processor_class=Ce;async _call(e=null,r=null,s={}){if(!e&&!r)throw new Error("Either text or images must be provided");let n=e?this.tokenizer(e,s):{},o=r?await this.image_processor(r,s):{};return{...n,...o}}};var Cm=class extends re{static tokenizer_class=oe;static image_processor_class=Ce;async _call(e,r=null,s={}){let{image_rows:n,image_cols:o,image_sizes:a,...i}=await this.image_processor(e,{...s,return_row_col_info:!0});if(r){let l=this.config.image_token??"<image>",{tile_size:c=512,downsample_factor:p=2,encoder_patch_size:d=16,use_thumbnail:_=!0}=this.image_processor.config,m=T=>Math.ceil(Math.floor(T/d)/p),w=m(c)**2,x=this.config.image_start_token??"<|image_start|>",E=this.config.image_end_token??"<|image_end|>",k=this.config.image_thumbnail??"<|img_thumbnail|>";Array.isArray(r)||(r=[r]);let A=0;r=r.map(T=>{let S=T.split(l);return S[0]+S.slice(1).map(L=>{let O=A++,[v,W]=a[O],X=n[O],B=o[O],H=m(v)*m(W),G=x;if(X>1||B>1){let Q=l.repeat(w);for(let R=0;R<X;++R)for(let C=0;C<B;++C)G+=`<|img_row_${R+1}_col_${C+1}|>`+Q;_&&(G+=k+l.repeat(H))}else G+=l.repeat(H);return G+E+L}).join("")})}return{...i,...r?this.tokenizer(r,s):{}}}};var Lm=class extends re{static tokenizer_class=oe;static image_processor_class=Ce;static uses_processor_config=!0;async _call(e,r=null,s={}){let n=await this.image_processor(e,s);if(r){let[a,i]=n.pixel_values.dims.slice(-2),{image_token:l,patch_size:c,num_additional_image_tokens:p}=this.config,d=Math.floor(a/c)*Math.floor(i/c)+p;r=structuredClone(r),Array.isArray(r)||(r=[r]);for(let _=0;_<r.length;++_)r[_]=r[_].replace(l,l.repeat(d))}let o=r?this.tokenizer(r,s):{};return{...n,...o}}};var R2={char:["char_decode",1],bpe:["bpe_decode",2],wp:["wp_decode",102]},Pm=class extends re{static tokenizer_class=oe;static image_processor_class=Ce;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,r){if(!R2.hasOwnProperty(r))throw new Error(`Format ${r} is not supported.`);let[s,n]=R2[r],o=this[s].bind(this),[a,i]=e.dims,l=[],c=[],p=e.tolist();for(let _=0;_<a;++_){let m=p[_],w=[],x=[];for(let k=1;k<i;++k){let[A,T]=Oe(Ne(m[k]));if(x.push(A),T==n)break;w.push(T)}let E=x.length>0?x.reduce((k,A)=>k*A,1):0;c.push(w),l.push(E)}return[o(c),l]}char_decode(e){return this.char_tokenizer.batch_decode(e).map(r=>r.replaceAll(" ",""))}bpe_decode(e){return this.bpe_tokenizer.batch_decode(e)}wp_decode(e){return this.wp_tokenizer.batch_decode(e).map(r=>r.replaceAll(" ",""))}batch_decode([e,r,s]){let[n,o]=this._decode_helper(e,"char"),[a,i]=this._decode_helper(r,"bpe"),[l,c]=this._decode_helper(s,"wp"),p=[],d=[];for(let _=0;_<n.length;++_){let[m,w]=Oe([o[_],i[_],c[_]]);p.push([n[_],a[_],l[_]][w]),d.push(m)}return{generated_text:p,scores:d,char_preds:n,bpe_preds:a,wp_preds:l}}static async from_pretrained(...e){let r=await super.from_pretrained(...e),s=await oe.from_pretrained("Xenova/gpt2"),n=await oe.from_pretrained("Xenova/bert-base-uncased");return r.components={image_processor:r.image_processor,char_tokenizer:r.tokenizer,bpe_tokenizer:s,wp_tokenizer:n},r}async _call(e,r=null){let s=await this.image_processor(e);return r&&(s.labels=this.tokenizer(r).input_ids),s}};var zm=class extends re{static tokenizer_class=oe;static feature_extractor_class=Xe;async _call(e){return await this.feature_extractor(e)}};var Nm=class extends re{static tokenizer_class=oe;static image_processor_class=Ce};var vn="<image>";function Uz(t,e,r,s,n){return`${s.repeat(r*n)}${e}${t}
24
+ `}var $m=class extends re{static tokenizer_class=oe;static image_processor_class=Ce;static uses_processor_config=!1;async _call(e,r=null,s={}){r||(Z.warn("You are using PaliGemma without a text prefix. It will perform as a picture-captioning model."),r=""),Array.isArray(e)||(e=[e]),Array.isArray(r)||(r=[r]);let n=this.tokenizer.bos_token,o=this.image_processor.config.image_seq_length,a;r.some(c=>c.includes(vn))?a=r.map(c=>{let p=c.replaceAll(vn,vn.repeat(o)),d=p.lastIndexOf(vn),_=d===-1?0:d+vn.length;return p.slice(0,_)+n+p.slice(_)+`
25
+ `}):(Z.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=r.map(c=>Uz(c,n,o,vn,e.length)));let i=this.tokenizer(a,s);return{...await this.image_processor(e,s),...i}}};var D2="<|image|>",jz=/<\|image_\d+\|>/g,Rm=class extends re{static image_processor_class=Ce;static tokenizer_class=oe;async _call(e,r=null,{padding:s=!0,truncation:n=!0,num_crops:o=null}={}){Array.isArray(e)||(e=[e]);let a,i;if(r){i=await this.image_processor(r,{num_crops:o});let{num_img_tokens:l}=i,c=e.map((d,_)=>d.split(jz).join(D2.repeat(l[_])));a=this.tokenizer(c,{padding:s,truncation:n});let p=this.tokenizer._tokenizer.token_to_id(D2);a.input_ids.map_(d=>d==p?-d:d)}else a=this.tokenizer(e);return{...a,...i}}};var Dm=class extends re{static tokenizer_class=oe;static image_processor_class=Ce;static uses_processor_config=!0;async _call(e,r=null,s={}){let n=await this.image_processor(e,s);if(r){let[a,i]=n.pixel_values.dims.slice(-2),{image_token:l,image_break_token:c,image_end_token:p,patch_size:d,spatial_merge_size:_}=this.config,m=d*_,w=Math.floor(a/m),x=Math.floor(i/m);r=structuredClone(r),Array.isArray(r)||(r=[r]);for(let E=0;E<r.length;++E){let k=l.repeat(x),A=k+c,T=k+p,S=A.repeat(w-1)+T;r[E]=r[E].replace(l,S)}}let o=r?this.tokenizer(r,s):{};return{...n,...o}}};var Fm=class extends re{static feature_extractor_class=$o;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}};var Bo=class extends Es{};var Bm=class extends Bo{};var Uo=class extends re{static image_processor_class=Ce;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)}};var Xc=class extends Uo{},Um=class extends Xc{};var jm=class extends re{static tokenizer_class=oe;static feature_extractor_class=Xe;async _call(e){return await this.feature_extractor(e)}};var Gm=class extends re{static tokenizer_class=oe;static feature_extractor_class=Xe;static uses_processor_config=!0;async _call(e,r=null,s={}){if(Array.isArray(e))throw new Error("Batched inputs are not supported yet.");let n={};if(r){let a=r.length,{input_features:i}=await this.feature_extractor(r,{...s,max_length:a}),l=Math.round(a/this.config.encoder_ds_factor+1e-4),c=1+Math.ceil(l/this.config.stack_factor);n.audio_token_len=[c],n.audio_values=i;let p=this.config.audio_placeholder;if(!e.includes(p))throw new Error(`The input text does not contain the image token ${p}.`);e=e.replaceAll(p,p.repeat(c))}return{...this.tokenizer(e,{add_special_tokens:!1,...s}),...n}}};var Kc="[AUDIO]",Gz="[BEGIN_AUDIO]",qz=375;function Wz(t,e){let r=[];for(let s=0;s<t.length;s+=e)r.push(t.subarray(s,Math.min(s+e,t.length)));return r}var qm=class extends re{static tokenizer_class=oe;static feature_extractor_class=Xe;static uses_processor_config=!1;async _call(e,r=null,s={}){if(Array.isArray(e))throw new Error("Batched inputs are not supported yet.");let n={};if(r){if(!e.includes(Kc))throw new Error(`The input text does not contain the audio token ${Kc}.`);Array.isArray(r)||(r=[r]);let a=e.split(Kc),i=a.length-1;if(i!==r.length)throw new Error(`The number of audio inputs (${r.length}) does not match the number of audio tokens in the text (${i}).`);let l=this.feature_extractor.config.n_samples,c=r.map(w=>Wz(w,l)),p=c.map(w=>w.length),d=c.flat(),_=(await Promise.all(d.map(w=>this.feature_extractor(w,s)))).map(w=>w.input_features);n.audio_values=_.length>1?ke(_,0):_[0];let m=a[0];for(let w=0;w<p.length;++w){m+=Gz;for(let x=0;x<p[w];++x)m+=Kc.repeat(qz);m+=a[w+1]}e=m}return{...this.tokenizer(e,{add_special_tokens:!1,...s}),...n}}};var F2=32,Wm=6,Qc=8,Vz=10,Hz=32,Vm=class extends re{static tokenizer_class=oe;static feature_extractor_class=Xe;static uses_processor_config=!1;get num_mel_frames_first_audio_chunk(){return(Wm+1)*Qc}get num_samples_first_audio_chunk(){let{hop_length:e,n_fft:r}=this.feature_extractor.config;return(this.num_mel_frames_first_audio_chunk-1)*e+Math.floor(r/2)}get num_samples_per_audio_chunk(){let{hop_length:e,n_fft:r}=this.feature_extractor.config;return Qc*e+r}get num_right_pad_tokens(){return Wm+1+Vz}get audio_length_per_tok(){return Qc}get raw_audio_length_per_tok(){return Qc*this.feature_extractor.config.hop_length}async _call(e,{is_streaming:r=!1,is_first_audio_chunk:s=!0}={}){if(Re(e,"VoxtralRealtimeProcessor"),!r&&!s)throw new Error("In non-streaming mode (`is_streaming=false`), `is_first_audio_chunk` must be `true`.");if(s)if(r){let n=F2*this.raw_audio_length_per_tok,o=new Float32Array(n+e.length);o.set(e,n);let a=await this.feature_extractor(o,{center:!0}),l=1+(F2+Wm),c=new BigInt64Array(l).fill(BigInt(Hz));return c[0]=1n,{input_ids:new $("int64",c,[1,l]),...a}}else{let n=this.num_right_pad_tokens*this.raw_audio_length_per_tok,o=new Float32Array(e.length+n);return o.set(e),await this.feature_extractor(o,{center:!0})}else return await this.feature_extractor(e,{center:!1})}};var Hm=class extends re{static tokenizer_class=oe;static feature_extractor_class=Xe;async _call(e){return await this.feature_extractor(e)}};var Xm=class extends re{static tokenizer_class=oe;static feature_extractor_class=Xe;async _call(e){return await this.feature_extractor(e)}};var Km=class extends re{static tokenizer_class=oe;static feature_extractor_class=Xe;async _call(e){return await this.feature_extractor(e)}};var Jc=class{static async from_pretrained(e,r={}){let s=await ut(e,yr,!0,r),{image_processor_type:n,feature_extractor_type:o,processor_class:a}=s;if(a&&Yc[a])return Yc[a].from_pretrained(e,r);if(!n&&!o)throw new Error("No `image_processor_type` or `feature_extractor_type` found in the config.");let i={};if(n){let c=bn[n.replace(/Fast$/,"")];if(!c)throw new Error(`Unknown image_processor_type: '${n}'.`);i.image_processor=new c(s)}if(o){let c=bn[o];if(c)i.image_processor=new c(s);else{let p=Ro[o];if(!p)throw new Error(`Unknown feature_extractor_type: '${o}'.`);i.feature_extractor=new p(s)}}let l={};return new re(l,i,null)}};async function Xz(t,e){return await ut(t,"config.json",!0,e)}function kn(t){let e={},r={};switch(t.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"lfm2_vl":case"chatterbox":case"lighton_ocr":case"glm_ocr":case"mistral3":case"qwen2_5_vl":case"qwen3_vl":case"qwen3_vl_moe":r=kn(t.text_config);break;case"moondream1":r=kn(t.phi_config);break;case"musicgen":r=kn(t.decoder);break;case"multi_modality":r=kn(t.language_config);break;case"gpt2":case"gptj":case"jais":case"codegen":case"gpt_bigcode":e.num_heads="n_head",e.num_layers="n_layer",e.hidden_size="n_embd";break;case"gpt_neox":case"stablelm":case"opt":case"falcon":case"modernbert-decoder":e.num_heads="num_attention_heads",e.num_layers="num_hidden_layers",e.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":e.num_heads="num_key_value_heads",e.num_layers="num_hidden_layers",e.hidden_size="hidden_size",e.num_attention_heads="num_attention_heads",e.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"glm":case"helium":case"ernie4_5":case"hunyuan_v1_dense":case"falcon_h1":case"nemotron_h":case"ministral":case"ministral3":e.num_heads="num_key_value_heads",e.num_layers="num_hidden_layers",e.dim_kv="head_dim";break;case"openelm":e.num_heads="num_kv_heads",e.num_layers="num_transformer_layers",e.dim_kv="head_dim";break;case"gpt_neo":case"donut-swin":e.num_heads="num_heads",e.num_layers="num_layers",e.hidden_size="hidden_size";break;case"bloom":e.num_heads="n_head",e.num_layers="n_layer",e.hidden_size="hidden_size";break;case"mpt":e.num_heads="n_heads",e.num_layers="n_layers",e.hidden_size="d_model";break;case"exaone":e.num_heads="num_key_value_heads",e.num_layers="num_layers",e.dim_kv="head_dim",e.num_attention_heads="num_attention_heads";break;case"youtu":case"deepseek_v3":case"glm_moe_dsa":case"mistral4":e.num_heads="num_key_value_heads",e.num_layers="num_hidden_layers",e.dim_kv="qk_head_dim",e.num_attention_heads="num_attention_heads";break;case"t5":case"mt5":case"longt5":e.num_decoder_layers="num_decoder_layers",e.num_decoder_heads="num_heads",e.decoder_dim_kv="d_kv",e.num_encoder_layers="num_layers",e.num_encoder_heads="num_heads",e.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":e.num_decoder_layers="decoder_layers",e.num_decoder_heads="decoder_attention_heads",e.decoder_hidden_size="d_model",e.num_encoder_layers="encoder_layers",e.num_encoder_heads="encoder_attention_heads",e.encoder_hidden_size="d_model";break;case"speecht5":e.num_decoder_layers="decoder_layers",e.num_decoder_heads="decoder_attention_heads",e.decoder_hidden_size="hidden_size",e.num_encoder_layers="encoder_layers",e.num_encoder_heads="encoder_attention_heads",e.encoder_hidden_size="hidden_size";break;case"trocr":e.num_encoder_layers=e.num_decoder_layers="decoder_layers",e.num_encoder_heads=e.num_decoder_heads="decoder_attention_heads",e.encoder_hidden_size=e.decoder_hidden_size="d_model";break;case"musicgen_decoder":e.num_encoder_layers=e.num_decoder_layers="num_hidden_layers",e.num_encoder_heads=e.num_decoder_heads="num_attention_heads",e.encoder_hidden_size=e.decoder_hidden_size="hidden_size";break;case"moonshine":e.num_decoder_layers="decoder_num_hidden_layers",e.num_decoder_heads="decoder_num_key_value_heads",e.num_encoder_layers="encoder_num_hidden_layers",e.num_encoder_heads="encoder_num_key_value_heads",e.encoder_hidden_size=e.decoder_hidden_size="hidden_size";break;case"vision-encoder-decoder":let n=kn(t.decoder),o="num_decoder_layers"in n,a=Ke(t,["model_type","is_encoder_decoder"]);return o?(a.num_decoder_layers=n.num_decoder_layers,a.num_decoder_heads=n.num_decoder_heads,a.decoder_hidden_size=n.decoder_hidden_size,a.num_encoder_layers=n.num_encoder_layers,a.num_encoder_heads=n.num_encoder_heads,a.encoder_hidden_size=n.encoder_hidden_size):(a.num_layers=n.num_layers,a.num_heads=n.num_heads,a.hidden_size=n.hidden_size),a}let s={...r,...Ke(t,["model_type","multi_query","is_encoder_decoder"])};for(let n in e)s[n]=t[e[n]];return s}function As(t,e){t instanceof En||(t=new En(t));let r=e?.batch_size??1;if(["lfm2","lfm2_moe"].includes(t.model_type)){let s=e?.prefix??"past_key_values",n=s==="present"?"present":"past",o={},{layer_types:a,num_attention_heads:i,num_key_value_heads:l,hidden_size:c,conv_L_cache:p}=t,d=c/i;for(let _=0;_<a.length;++_)if(a[_]==="full_attention")for(let m of["key","value"])o[`${s}.${_}.${m}`]=[r,l,0,d];else if(a[_]==="conv")o[`${n}_conv.${_}`]=[r,c,p];else throw new Error(`Unsupported layer type: ${a[_]}`);return o}else if(["granitemoehybrid","falcon_h1","nemotron_h"].includes(t.model_type)){let s=e?.prefix??"past_key_values",n=s==="present"?"present":"past",o=t,a=o.layer_types??o.layers_block_type,i=o.num_hidden_layers??a?.length,l=o.num_key_value_heads,c=o.head_dim??o.hidden_size/o.num_attention_heads,p=o.mamba_n_heads??o.mamba_num_heads,d=o.mamba_d_head??o.mamba_head_dim,_=o.mamba_d_state??o.ssm_state_size,m=o.mamba_n_groups??o.n_groups,w=o.mamba_d_conv??o.conv_kernel,E=(o.mamba_d_ssm??(o.mamba_expand?o.mamba_expand*o.hidden_size:p*d))+2*m*_,k={};for(let A=0;A<i;++A)if((!a||a[A]==="mamba")&&(k[`${n}_conv.${A}`]=[r,E,w],k[`${n}_ssm.${A}`]=[r,p,d,_]),!a||a[A]==="attention")for(let T of["key","value"])k[`${s}.${A}.${T}`]=[r,l,0,c];return k}else if(["qwen3_next","qwen3_5_text","qwen3_5_moe_text","olmo_hybrid"].includes(t.model_type)){let s=e?.prefix??"past_key_values",n=s==="present"?"present":"past",o={},{head_dim:a,layer_types:i,num_attention_heads:l,num_key_value_heads:c,hidden_size:p,linear_num_value_heads:d,linear_num_key_heads:_,linear_key_head_dim:m,linear_value_head_dim:w,linear_conv_kernel_dim:x}=t,E=m*_,k=w*d,A=a??p/l;for(let T=0;T<i.length;++T)if(i[T]==="full_attention")for(let S of["key","value"])o[`${s}.${T}.${S}`]=[r,c,0,A];else if(i[T]==="linear_attention"){if(t.model_type==="olmo_hybrid")o[`${n}_conv.${T}.key`]=[r,E,x],o[`${n}_conv.${T}.value`]=[r,k,x],o[`${n}_conv.${T}.query`]=[r,E,x];else{let S=E*2+k;o[`${n}_conv.${T}`]=[r,S,x]}o[`${n}_recurrent.${T}`]=[r,d,m,w]}else throw new Error(`Unsupported layer type: ${i[T]}`);return o}else if(["lfm2_vl","qwen3_5","qwen3_5_moe","voxtral_realtime"].includes(t.model_type)){let s;return t.model_type==="voxtral_realtime"&&e?.session_name==="audio_encoder"?s=t.audio_config:s=t.text_config,As(s,e)}return Kz(t,e)}function Kz(t,{prefix:e="past_key_values",batch_size:r=1}={}){let s={},n=t.normalized_config;if(n.is_encoder_decoder&&"num_encoder_heads"in n&&"num_decoder_heads"in n){let o=n.encoder_dim_kv??n.encoder_hidden_size/n.num_encoder_heads,a=n.decoder_dim_kv??n.decoder_hidden_size/n.num_decoder_heads,i=[r,n.num_encoder_heads,0,o],l=[r,n.num_decoder_heads,0,a];for(let c=0;c<n.num_decoder_layers;++c)s[`${e}.${c}.encoder.key`]=i,s[`${e}.${c}.encoder.value`]=i,s[`${e}.${c}.decoder.key`]=l,s[`${e}.${c}.decoder.value`]=l}else{let o=n.num_heads,a=n.num_layers,i=n.dim_kv??n.hidden_size/(n.num_attention_heads??o);if(n.model_type==="falcon"){let l=[r*o,0,i];for(let c=0;c<a;++c)s[`${e}.${c}.key`]=l,s[`${e}.${c}.value`]=l}else if(n.multi_query){let l=[r*o,0,2*i];for(let c=0;c<a;++c)s[`${e}.${c}.key_value`]=l}else if(n.model_type==="bloom"){let l=[r*o,i,0],c=[r*o,0,i];for(let p=0;p<a;++p)s[`${e}.${p}.key`]=l,s[`${e}.${p}.value`]=c}else if(n.model_type==="openelm")for(let l=0;l<a;++l){let c=[r,o[l],0,i];s[`${e}.${l}.key`]=c,s[`${e}.${l}.value`]=c}else{let l=[r,o,0,i];for(let c=0;c<a;++c)s[`${e}.${c}.key`]=l,s[`${e}.${c}.value`]=l}}return s}var En=class t{model_type=null;is_encoder_decoder=!1;max_position_embeddings;"transformers.js_config";constructor(e){Object.assign(this,e),this.normalized_config=kn(this)}static async from_pretrained(e,{progress_callback:r=null,config:s=null,cache_dir:n=null,local_files_only:o=!1,revision:a="main"}={}){s&&!(s instanceof t)&&(s=new t(s));let i=s??await Xz(e,{progress_callback:r,config:s,cache_dir:n,local_files_only:o,revision:a});return new this(i)}},Bt=class{static async from_pretrained(...e){return En.from_pretrained(...e)}};function Qm(t,e,r){return t?typeof t=="object"&&t!==null?t.hasOwnProperty(e)?+t[e]:t.hasOwnProperty(r)?+t[r]:0:+t:0}function Ym(t,e){let r=[];for(let s=0;s<e;++s)r.push(`${t}_data${s===0?"":"_"+s}`);return r}async function B2(t,e,r,s){let n=`${e}${s}.onnx`,o=`${r.subfolder??""}/${n}`;return await ho(t,o,!0,r,ie.IS_NODE_ENV)}async function U2(t,e,r,s,n,o={}){let a=`${e}${r}.onnx`,i=ie.IS_NODE_ENV,l=[],c=Qm(n,a,e);if(c>0){if(c>tc)throw new Error(`The number of external data chunks (${c}) exceeds the maximum allowed value (${tc}).`);let p=Ym(a,c);for(let d of p){let _=`${s.subfolder??""}/${d}`;l.push(new Promise(async(m,w)=>{let x=await ho(t,_,!0,s,i);m(x instanceof Uint8Array?{path:d,data:x}:d)}))}}else o.externalData!==void 0&&(l=o.externalData.map(async p=>{if(typeof p.data=="string"){let d=await ho(t,p.data,!0,s);return{...p,data:d}}return p}));return Promise.all(l)}async function Qz(t,e,r,s=!1,n=void 0){let o=r.config?.["transformers.js_config"]??{},a=bc(r.device??o.device,e,{warn:S=>Z.info(S)}),i=d2(a),l=o.device_config??{};l.hasOwnProperty(a)&&(o={...o,...l[a]});let c=vc(r.dtype??o.dtype,e,a,{configDtype:o.dtype,warn:S=>Z.info(S)});if(So.hasOwnProperty(c)){if(a==="webgpu"&&!ie.IS_NODE_ENV&&c===wt.fp16&&!await g2())throw new Error(`The device (${a}) does not support fp16.`)}else throw new Error(`Invalid dtype: ${c}. Should be one of: ${Object.keys(wt).join(", ")}`);let p=o.kv_cache_dtype,d=p?typeof p=="string"?p:p[c]??"float32":void 0;if(d&&!["float32","float16"].includes(d))throw new Error(`Invalid kv_cache_dtype: ${d}. Should be one of: float32, float16`);let _=So[c],m={...r.session_options};m.executionProviders??=i;let w=o.free_dimension_overrides;w?m.freeDimensionOverrides??=w:a.startsWith("webnn")&&!m.freeDimensionOverrides&&Z.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"]["${a}"]. When 'free_dimension_overrides' is not set, you may experience significant performance degradation.`);let x=B2(t,e,r,_),E=r.use_external_data_format??o.use_external_data_format,k=await U2(t,e,_,r,E,m);if(k.length>0&&!ie.IS_NODE_ENV&&(m.externalData=k),s&&a==="webgpu"&&p!==!1){let S=As(r.config,{prefix:"present",session_name:n});if(Object.keys(S).length>0&&!Mo()){let L={};for(let O in S)L[O]="gpu-buffer";m.preferredOutputLocation=L}}return{buffer_or_path:await x,session_options:m,session_config:{dtype:c,kv_cache_dtype:d,device:a}}}async function j2(t,e,r,s=void 0){return Object.fromEntries(await Promise.all(Object.keys(e).map(async n=>{let o=s?.[n]??!1,{buffer_or_path:a,session_options:i,session_config:l}=await Qz(t,e[n],r,o,n),c=await wc(a,i,l);return[n,c]})))}function G2(t){for(let e in t)yc(t[e])?t[e]=new $(t[e]):typeof t[e]=="object"&&G2(t[e]);return t}async function de(t,e){let r=Yz(t,e);try{let s=Object.fromEntries(Object.entries(r).map(([o,a])=>{let i=a.ort_tensor;return ie.IS_NODE_ENV&&typeof Float16Array<"u"&&i.cpuData instanceof Float16Array&&(i.cpuData=new Uint16Array(i.cpuData.buffer)),[o,i]})),n=await xc(t,s);return G2(n)}catch(s){let n=Object.fromEntries(Object.entries(r).map(([o,a])=>{let i={type:a.type,dims:a.dims,location:a.location};return i.location!=="gpu-buffer"&&(i.data=a.data),[o,i]}));throw Z.error(`An error occurred during model execution: "${s}".`),Z.error("Inputs given to model:",n),s}}function Yz(t,e){let r=Object.create(null),s=[];for(let a of t.inputNames){let i=e[a];if(!(i instanceof $)){s.push(a);continue}r[a]=Mo()?i.clone():i}if(s.length>0)throw new Error(`An error occurred during model execution: "Missing the following inputs: ${s.join(", ")}.`);let n=Object.keys(e).length,o=t.inputNames.length;if(n>o){let a=Object.keys(e).filter(i=>!t.inputNames.includes(i));Z.warn(`WARNING: Too many inputs were provided (${n} > ${o}). The following inputs will be ignored: "${a.join(", ")}".`)}return r}var $e=class{};var j=class extends $e{constructor({logits:e,...r}){super(),this.logits=e;let s=Object.values(r);s.length>0&&(this.attentions=s)}},he=class extends $e{constructor({logits:e}){super(),this.logits=e}},ge=class extends $e{constructor({logits:e}){super(),this.logits=e}},Ae=class extends $e{constructor({start_logits:e,end_logits:r}){super(),this.start_logits=e,this.end_logits=r}},bt=class extends $e{constructor({logits:e}){super(),this.logits=e}};var Zc=class extends $e{constructor({alphas:e}){super(),this.alphas=e}};var Ut=class extends et{_call(e,r){throw Error("`_call` should be implemented in a subclass")}},jo=class extends et{_call(e,r){throw Error("`_call` should be implemented in a subclass")}},Ms=class extends et{constructor(){super(),this.processors=[]}push(e){this.processors.push(e)}extend(e){this.processors.push(...e)}_call(e,r){let s=r;for(let n of this.processors)s=n(e,s);return s}[Symbol.iterator](){return this.processors.values()}},eu=class extends Ut{constructor(e){super(),this.bos_token_id=e}_call(e,r){for(let s=0;s<e.length;++s)if(e[s].length===1){let n=r[s].data;n.fill(-1/0),n[this.bos_token_id]=0}return r}},tu=class extends Ut{constructor(e,r){super(),this.max_length=e,this.eos_token_id=Array.isArray(r)?r:[r]}_call(e,r){for(let s=0;s<e.length;++s)if(e[s].length===this.max_length-1){let n=r[s].data;n.fill(-1/0);for(let o of this.eos_token_id)n[o]=0}return r}},An=class extends Ut{constructor(e,r){super(),this.begin_suppress_tokens=e,this.begin_index=r}_call(e,r){for(let s=0;s<e.length;++s)if(e[s].length===this.begin_index){let n=r[s].data;for(let o of this.begin_suppress_tokens)n[o]=-1/0}return r}},ru=class extends Ut{constructor(e,r){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=r.length,r.at(-1)===this.no_timestamps_token_id&&(this.begin_index-=1),this.max_initial_timestamp_index=e.max_initial_timestamp_index}_call(e,r){for(let s=0;s<e.length;++s){let n=r[s].data;if(n[this.no_timestamps_token_id]=-1/0,e[s].length===this.begin_index-1){n.fill(-1/0),n[this.timestamp_begin]=0;continue}let o=e[s].slice(this.begin_index),a=o.length>=1&&o[o.length-1]>=this.timestamp_begin,i=o.length<2||o[o.length-2]>=this.timestamp_begin;if(a&&(i?n.subarray(this.timestamp_begin).fill(-1/0):n.subarray(0,this.eos_token_id).fill(-1/0)),e[s].length===this.begin_index&&this.max_initial_timestamp_index!==null){let d=this.timestamp_begin+this.max_initial_timestamp_index;n.subarray(d+1).fill(-1/0)}let l=kd(n),c=Math.log(l.subarray(this.timestamp_begin).map(Math.exp).reduce((d,_)=>d+_)),p=Oe(l.subarray(0,this.timestamp_begin))[0];c>p&&n.subarray(0,this.timestamp_begin).fill(-1/0)}return r}},su=class extends Ut{constructor(e){super(),this.no_repeat_ngram_size=e}getNgrams(e){let r=e.length,s=[];for(let o=0;o<r+1-this.no_repeat_ngram_size;++o){let a=[];for(let i=0;i<this.no_repeat_ngram_size;++i)a.push(e[o+i]);s.push(a.map(Number))}let n=new Map;for(let o of s){let a=o.slice(0,o.length-1),i=JSON.stringify(a),l=n.get(i)??[];l.push(o[o.length-1]),n.set(i,l)}return n}getGeneratedNgrams(e,r){let s=r.slice(r.length+1-this.no_repeat_ngram_size,r.length);return e.get(JSON.stringify(s.map(Number)))??[]}calcBannedNgramTokens(e){let r=[];if(e.length+1<this.no_repeat_ngram_size)return r;{let s=this.getNgrams(e);return this.getGeneratedNgrams(s,e)}}_call(e,r){for(let s=0;s<e.length;++s){let n=r[s].data,o=this.calcBannedNgramTokens(e[s]);for(let a of o)n[a]=-1/0}return r}},nu=class extends Ut{constructor(e){super(),this.penalty=e}_call(e,r){for(let s=0;s<e.length;++s){let n=r[s].data;for(let o of new Set(e[s])){let a=Number(o);n[a]<0?n[a]*=this.penalty:n[a]/=this.penalty}}return r}},ou=class extends Ut{constructor(e,r){super(),this.min_length=e,this.eos_token_id=Array.isArray(r)?r:[r]}_call(e,r){for(let s=0;s<e.length;++s)if(e[s].length<this.min_length){let n=r[s].data;for(let o of this.eos_token_id)n[o]=-1/0}return r}},au=class extends Ut{constructor(e,r,s){super(),this.prompt_length_to_skip=e,this.min_new_tokens=r,this.eos_token_id=Array.isArray(s)?s:[s]}_call(e,r){for(let s=0;s<e.length;++s)if(e[s].length-this.prompt_length_to_skip<this.min_new_tokens){let o=r[s].data;for(let a of this.eos_token_id)o[a]=-1/0}return r}},iu=class extends Ut{constructor(e,r){super(),this.bad_words_ids=e,this.eos_token_id=Array.isArray(r)?r:[r]}_call(e,r){for(let s=0;s<e.length;++s){let n=r[s].data,o=e[s];for(let a of this.bad_words_ids){if(o.length<a.length-1)continue;let i=!0;for(let l=1;l<=a.length-1;++l)if(a.at(-l-1)!=o.at(-l)){i=!1;break}i&&(n[a.at(-1)]=-1/0)}}return r}},lu=class extends Ut{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,r){if(r.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 ${r.dims[0]} for the logits and ${e.length} for the input ids.`);let s=e.length,n=r.slice([0,s],null),o=r.slice([s,r.dims[0]],null);for(let a=0;a<o.data.length;++a)o.data[a]+=(n.data[a]-o.data[a])*this.guidance_scale;return o}},cu=class extends jo{constructor(e){if(super(),typeof e!="number"||e<=0){let r=`\`temperature\` (=${e}) must be a strictly positive float, otherwise your next token scores will be invalid.`;e===0&&(r+=" If you're looking for greedy decoding strategies, set `do_sample=false`.")}this.temperature=e}_call(e,r){let s=r.data;for(let n=0;n<s.length;++n)s[n]/=this.temperature;return r}},q2=class extends jo{constructor(e,{filter_value:r=-1/0,min_tokens_to_keep:s=1}={}){if(super(),e<0||e>1)throw new Error(`\`top_p\` must be a float > 0 and < 1, but is ${e}`);if(!Number.isInteger(s)||s<1)throw new Error(`\`min_tokens_to_keep\` must be a positive integer, but is ${s}`);this.top_p=e,this.filter_value=r,this.min_tokens_to_keep=s}},W2=class extends jo{constructor(e,{filter_value:r=-1/0,min_tokens_to_keep:s=1}={}){if(super(),!Number.isInteger(e)||e<0)throw new Error(`\`top_k\` must be a positive integer, but is ${e}`);this.top_k=Math.max(e,s),this.filter_value=r}};var Mn=class{max_length=20;max_new_tokens=null;min_length=0;min_new_tokens=null;early_stopping=!1;max_time=null;do_sample=!1;num_beams=1;num_beam_groups=1;penalty_alpha=null;use_cache=!0;temperature=1;top_k=50;top_p=1;typical_p=1;epsilon_cutoff=0;eta_cutoff=0;diversity_penalty=0;repetition_penalty=1;encoder_repetition_penalty=1;length_penalty=1;no_repeat_ngram_size=0;bad_words_ids=null;force_words_ids=null;renormalize_logits=!1;constraints=null;forced_bos_token_id=null;forced_eos_token_id=null;remove_invalid_values=!1;exponential_decay_length_penalty=null;suppress_tokens=null;streamer=null;begin_suppress_tokens=null;forced_decoder_ids=null;guidance_scale=null;num_return_sequences=1;output_attentions=!1;output_hidden_states=!1;output_scores=!1;return_dict_in_generate=!1;pad_token_id=null;bos_token_id=null;eos_token_id=null;encoder_no_repeat_ngram_size=0;decoder_start_token_id=null;generation_kwargs={};constructor(e){Object.assign(this,Ke(e,Object.getOwnPropertyNames(this)))}};var Gr=class extends et{_call(e,r){throw Error("StoppingCriteria needs to be subclassed")}},Sn=class t extends et{constructor(){super(),this.criteria=[]}push(e){this.criteria.push(e)}extend(e){e instanceof t?e=e.criteria:e instanceof Gr&&(e=[e]),this.criteria.push(...e)}_call(e,r){let s=new Array(e.length).fill(!1);for(let n of this.criteria){let o=n(e,r);for(let a=0;a<s.length;++a)s[a]||=o[a]}return s}[Symbol.iterator](){return this.criteria.values()}},uu=class extends Gr{constructor(e,r=null){super(),this.max_length=e,this.max_position_embeddings=r}_call(e){return e.map(r=>r.length>=this.max_length)}},pu=class extends Gr{constructor(e){super(),Array.isArray(e)||(e=[e]),this.eos_token_id=e}_call(e,r){return e.map(s=>{let n=s.at(-1);return this.eos_token_id.some(o=>n==o)})}},V2=class extends Gr{constructor(){super(),this.interrupted=!1}interrupt(){this.interrupted=!0}reset(){this.interrupted=!1}_call(e,r){return new Array(e.length).fill(this.interrupted)}};var Ss=class extends et{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,r){let s=e.dims.at(-1),n=e.data;if(r===-1)n=n.slice(-s);else{let o=r*s;n=n.slice(o,o+s)}return n}randomSelect(e){return bE(e)}static getSampler(e){if(e.do_sample)return new Zm(e);if(e.num_beams>1)return new eh(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 Jm(e)}},Jm=class extends Ss{async sample(e){let r=Oe(e.data)[1];return[[BigInt(r),0]]}},Zm=class extends Ss{async sample(e){let r=e.dims.at(-1);this.generation_config.top_k>0&&(r=Math.min(this.generation_config.top_k,r));let[s,n]=await Yt(e,r),o=Ne(s.data);return Array.from({length:this.generation_config.num_beams},()=>{let a=this.randomSelect(o);return[n.data[a],Math.log(o[a])]})}},eh=class extends Ss{async sample(e){let r=e.dims.at(-1);this.generation_config.top_k>0&&(r=Math.min(this.generation_config.top_k,r));let[s,n]=await Yt(e,r),o=Ne(s.data);return Array.from({length:this.generation_config.num_beams},(a,i)=>[n.data[i],Math.log(o[i])])}};var th=class{constructor(e){if(e)for(let r in e){if(r in this)throw new TypeError(`Key "${r}" conflicts with an existing property on DynamicCache`);let s=e[r];if(!(s instanceof $))throw new TypeError(`Expected a Tensor for key "${r}", got ${typeof s}`);this[r]=s}}get_seq_length(){let e=this;for(let r in e)if(r.startsWith("past_key_values."))return e[r].dims.at(-2);throw new Error("Unable to determine sequence length from the cache.")}async dispose(){let e=[];for(let r of Object.values(this))r.location==="gpu-buffer"&&e.push(r.dispose());await Promise.all(e)}},Go=th;var Ts=null;function X2(t){Ts=t}function rh(t){if(t instanceof $)return t;if(t.length===0)throw Error("items must be non-empty");if(Array.isArray(t[0])){if(t.some(e=>e.length!==t[0].length))throw Error("Unable to create tensor, you should probably activate truncation and/or padding with 'padding=True' and/or 'truncation=True' to have batched tensors with the same length.");return new $("int64",BigInt64Array.from(t.flat().map(e=>BigInt(e))),[t.length,t[0].length])}else return new $("int64",BigInt64Array.from(t.map(e=>BigInt(e))),[1,t.length])}function sh(t){return new $("bool",[t],[1])}var K={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,MultimodalLanguageModelOnly:16,VoxtralRealtime:17},Tn={[K.DecoderOnly]:{can_generate:!0,forward:Tt,prepare_inputs:On,sessions:(t,e)=>({model:e.model_file_name??"model"}),cache_sessions:{model:!0},optional_configs:{generation_config:"generation_config.json"}},[K.DecoderOnlyWithoutHead]:{can_generate:!1,forward:Tt,prepare_inputs:On,sessions:(t,e)=>({model:e.model_file_name??"model"})},[K.Seq2Seq]:{can_generate:!0,forward:du,prepare_inputs:Wo,sessions:()=>({model:"encoder_model",decoder_model_merged:"decoder_model_merged"}),cache_sessions:{decoder_model_merged:!0},optional_configs:{generation_config:"generation_config.json"}},[K.Vision2Seq]:{can_generate:!0,forward:du,prepare_inputs:Wo,sessions:()=>({model:"encoder_model",decoder_model_merged:"decoder_model_merged"}),cache_sessions:{decoder_model_merged:!0},optional_configs:{generation_config:"generation_config.json"}},[K.Musicgen]:{can_generate:!0,forward:du,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"}},[K.EncoderDecoder]:{can_generate:!1,forward:du,sessions:()=>({model:"encoder_model",decoder_model_merged:"decoder_model_merged"}),cache_sessions:{decoder_model_merged:!0}},[K.MaskGeneration]:{sessions:()=>({model:"vision_encoder",prompt_encoder_mask_decoder:"prompt_encoder_mask_decoder"})},[K.ImageTextToText]:{can_generate:!0,forward:H2,prepare_inputs:qo,sessions:t=>{let e={embed_tokens:"embed_tokens",vision_encoder:"vision_encoder",decoder_model_merged:"decoder_model_merged"};return t.is_encoder_decoder&&(e.model="encoder_model"),e},cache_sessions:{decoder_model_merged:!0},optional_configs:{generation_config:"generation_config.json"}},[K.AudioTextToText]:{can_generate:!0,forward:Zz,prepare_inputs:qo,sessions:()=>({embed_tokens:"embed_tokens",audio_encoder:"audio_encoder",decoder_model_merged:"decoder_model_merged"}),cache_sessions:{decoder_model_merged:!0},optional_configs:{generation_config:"generation_config.json"}},[K.ImageAudioTextToText]:{can_generate:!0,prepare_inputs:qo,sessions:()=>({embed_tokens:"embed_tokens",audio_encoder:"audio_encoder",vision_encoder:"vision_encoder",decoder_model_merged:"decoder_model_merged"}),optional_configs:{generation_config:"generation_config.json"}},[K.Phi3V]:{can_generate:!0,prepare_inputs:qo,sessions:()=>({prepare_inputs_embeds:"prepare_inputs_embeds",model:"model",vision_encoder:"vision_encoder"}),cache_sessions:{model:!0},optional_configs:{generation_config:"generation_config.json"}},[K.MultiModality]:{can_generate:!0,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"}},[K.AutoEncoder]:{can_generate:!1,forward:Jz,sessions:()=>({encoder_model:"encoder_model",decoder_model:"decoder_model"})},[K.Supertonic]:{sessions:()=>({text_encoder:"text_encoder",latent_denoiser:"latent_denoiser",voice_decoder:"voice_decoder"})},[K.Chatterbox]:{can_generate:!0,forward:jt,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"}},[K.MultimodalLanguageModelOnly]:{can_generate:!0,forward:H2,prepare_inputs:qo,sessions:()=>({embed_tokens:"embed_tokens",decoder_model_merged:"decoder_model_merged"}),cache_sessions:{decoder_model_merged:!0},optional_configs:{generation_config:"generation_config.json"}},[K.VoxtralRealtime]:{can_generate:!0,prepare_inputs:On,sessions:()=>({embed_tokens:"embed_tokens",audio_encoder:"audio_encoder",decoder_model_merged:"decoder_model_merged"}),cache_sessions:{decoder_model_merged:!0,audio_encoder:!0},optional_configs:{generation_config:"generation_config.json"}},default:{can_generate:!1,forward:jt,sessions:(t,e)=>({model:e.model_file_name??"model"})}};function K2(t,e,r={}){let s=Tn[t]??Tn.default;return{sessions:s.sessions(e,r),cache_sessions:s.cache_sessions,optional_configs:s.optional_configs}}var Jt=new Map,fu=new Map,Os=new Map,y=class extends et{main_input_name="input_ids";forward_params=["input_ids","attention_mask"];_return_dict_in_generate_keys=null;constructor(e,r,s){super(),this.config=e,this.sessions=r,this.configs=s;let n=Os.get(this.constructor),o=Jt.get(n),a=Tn[o]??Tn.default;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(){let e=[];for(let r of Object.values(this.sessions))e.push(r.release?.());return await Promise.all(e)}static async from_pretrained(e,{progress_callback:r=null,config:s=null,cache_dir:n=null,local_files_only:o=!1,revision:a="main",model_file_name:i=null,subfolder:l="onnx",device:c=null,dtype:p=null,use_external_data_format:d=null,session_options:_={}}={}){let m={progress_callback:r,config:s,cache_dir:n,local_files_only:o,revision:a,model_file_name:i,subfolder:l,device:c,dtype:p,use_external_data_format:d,session_options:_},w=Os.get(this),x=Jt.get(w);s=m.config=await Bt.from_pretrained(e,m);let E=Tn[x]??Tn.default;if(x===void 0){let S=w??s?.model_type;S!=="custom"&&Z.warn(`Model type for '${S}' not found, assuming encoder-only architecture. Please report this at ${Br}.`)}let k=E.sessions(s,m),A=[j2(e,k,m,E.cache_sessions)];E.optional_configs&&A.push(tN(e,E.optional_configs,m));let T=await Promise.all(A);return new this(s,...T)}async _call(e){return await this.forward(e)}async forward(e){return await this._forward(this,e)}get generation_config(){return this.configs?.generation_config??null}_get_logits_processor(e,r,s=null){let n=new Ms;if(e.repetition_penalty!==null&&e.repetition_penalty!==1&&n.push(new nu(e.repetition_penalty)),e.no_repeat_ngram_size!==null&&e.no_repeat_ngram_size>0&&n.push(new su(e.no_repeat_ngram_size)),e.bad_words_ids!==null&&n.push(new iu(e.bad_words_ids,e.eos_token_id)),e.min_length!==null&&e.eos_token_id!==null&&e.min_length>0&&n.push(new ou(e.min_length,e.eos_token_id)),e.min_new_tokens!==null&&e.eos_token_id!==null&&e.min_new_tokens>0&&n.push(new au(r,e.min_new_tokens,e.eos_token_id)),e.forced_bos_token_id!==null&&n.push(new eu(e.forced_bos_token_id)),e.forced_eos_token_id!==null&&n.push(new tu(e.max_length,e.forced_eos_token_id)),e.begin_suppress_tokens!==null){let o=r>1||e.forced_bos_token_id===null?r:r+1;n.push(new An(e.begin_suppress_tokens,o))}return e.guidance_scale!==null&&e.guidance_scale>1&&n.push(new lu(e.guidance_scale)),e.temperature===0&&e.do_sample&&(Z.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`."),e.do_sample=!1),e.do_sample&&e.temperature!==null&&e.temperature!==1&&n.push(new cu(e.temperature)),s!==null&&n.extend(s),n}_prepare_generation_config(e,r,s=Mn){let n={...this.config};for(let a of["decoder","generator","text_config"])a in n&&Object.assign(n,n[a]);let o=new s(n);return Object.assign(o,this.generation_config??{}),e&&Object.assign(o,e),r&&Object.assign(o,Ke(r,Object.getOwnPropertyNames(o))),o}_get_stopping_criteria(e,r=null){let s=new Sn;return e.max_length!==null&&s.push(new uu(e.max_length,this.config.max_position_embeddings??null)),e.eos_token_id!==null&&s.push(new pu(e.eos_token_id)),r&&s.extend(r),s}_validate_model_class(){if(!this.can_generate){let e=[Ts.MODEL_FOR_CAUSAL_LM_MAPPING_NAMES,Ts.MODEL_FOR_VISION_2_SEQ_MAPPING_NAMES,Ts.MODEL_FOR_SEQ_TO_SEQ_CAUSAL_LM_MAPPING_NAMES,Ts.MODEL_FOR_SPEECH_SEQ_2_SEQ_MAPPING_NAMES].filter(Boolean),r=Os.get(this.constructor),s=new Set,n=this.config.model_type;for(let a of e){let i=a?.get(n);i&&s.add(i)}let o=`The current model class (${r}) is not compatible with \`.generate()\`, as it doesn't have a language model head.`;throw s.size>0&&(o+=` Please use the following class instead: ${[...s].join(", ")}`),Error(o)}}prepare_inputs_for_generation(...e){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,...e)}_update_model_kwargs_for_generation({generated_input_ids:e,outputs:r,model_inputs:s,is_encoder_decoder:n}){return s.past_key_values=this.getPastKeyValues(r,s.past_key_values),s.input_ids=new $("int64",e.flat(),[e.length,1]),n?"decoder_attention_mask"in s:s.attention_mask=ke([s.attention_mask,tt([s.attention_mask.dims[0],1])],1),s.position_ids=null,s}_prepare_model_inputs({inputs:e,bos_token_id:r,model_kwargs:s}){let n=Ke(s,this.forward_params),o=this.main_input_name;if(o in n){if(e)throw new Error("`inputs`: {inputs}` were passed alongside {input_name} which is not allowed. Make sure to either pass {inputs} or {input_name}=...")}else n[o]=e;return{inputs_tensor:n[o],model_inputs:n,model_input_name:o}}async _prepare_encoder_decoder_kwargs_for_generation({inputs_tensor:e,model_inputs:r,model_input_name:s,generation_config:n}){if(this.sessions.model.inputNames.includes("inputs_embeds")&&!r.inputs_embeds&&"_prepare_inputs_embeds"in this){let{input_ids:a,pixel_values:i,attention_mask:l,...c}=r,p=await this._prepare_inputs_embeds(r);r={...c,...Ke(p,["inputs_embeds","attention_mask"])}}let{last_hidden_state:o}=await jt(this,r);if(n.guidance_scale!==null&&n.guidance_scale>1)o=ke([o,Oo(o,0)],0),"attention_mask"in r&&(r.attention_mask=ke([r.attention_mask,vf(r.attention_mask)],0));else if(r.decoder_input_ids){let a=rh(r.decoder_input_ids).dims[0];if(a!==o.dims[0]){if(o.dims[0]!==1)throw new Error(`The encoder outputs have a different batch size (${o.dims[0]}) than the decoder inputs (${a}).`);o=ke(Array.from({length:a},()=>o),0)}}return r.encoder_outputs=o,r}_prepare_decoder_input_ids_for_generation({batch_size:e,model_input_name:r,model_kwargs:s,decoder_start_token_id:n,bos_token_id:o,generation_config:a}){let{decoder_input_ids:i,...l}=s;if(!(i instanceof $)){if(i)Array.isArray(i[0])||(i=Array.from({length:e},()=>i));else if(n??=o,this.config.model_type==="musicgen")i=Array.from({length:e*this.config.decoder.num_codebooks},()=>[n]);else if(Array.isArray(n)){if(n.length!==e)throw new Error(`\`decoder_start_token_id\` expcted to have length ${e} but got ${n.length}`);i=n}else i=Array.from({length:e},()=>[n]);i=rh(i)}return s.decoder_attention_mask=Mc(i),{input_ids:i,model_inputs:l}}async generate({inputs:e=null,generation_config:r=null,logits_processor:s=null,stopping_criteria:n=null,streamer:o=null,...a}){this._validate_model_class(),r=this._prepare_generation_config(r,a);let{inputs_tensor:i,model_inputs:l,model_input_name:c}=this._prepare_model_inputs({inputs:e,model_kwargs:a}),p=this.config.is_encoder_decoder;p&&("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 d;p?{input_ids:d,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}):d=l[c];let _=d.dims.at(-1);r.max_new_tokens!==null&&(r.max_length=_+r.max_new_tokens);let m=this._get_logits_processor(r,_,s),w=this._get_stopping_criteria(r,n),x=l[c].dims.at(0),E=Ss.getSampler(r),k=new Array(x).fill(0),A=d.tolist();o&&o.put(A);let T,S={},L={};for(;;){if(l=this.prepare_inputs_for_generation(A,l,r),T=await this.forward(l),r.return_dict_in_generate)if(r.output_attentions){let G=this.getAttentions(T);for(let Q in G)Q in S||(S[Q]=[]),S[Q].push(G[Q])}else this._return_dict_in_generate_keys&&Object.assign(L,Ke(T,this._return_dict_in_generate_keys));let W=T.logits.slice(null,-1,null).to("float32"),X=m(A,W),B=[];for(let G=0;G<X.dims.at(0);++G){let Q=X[G],R=await E(Q);for(let[C,te]of R){let ae=BigInt(C);k[G]+=te,A[G].push(ae),B.push([ae]);break}}if(o&&o.put(B),w(A).every(G=>G))break;l=this._update_model_kwargs_for_generation({generated_input_ids:B,outputs:T,model_inputs:l,is_encoder_decoder:p})}o&&o.end();let O=this.getPastKeyValues(T,l.past_key_values,!0),v=new $("int64",A.flat(),[A.length,A[0].length]);if(r.return_dict_in_generate)return{sequences:v,past_key_values:O,...S,...L};for(let W of Object.values(T))W.location==="gpu-buffer"&&W.dispose();return v}getPastKeyValues(e,r,s=!1){let n=Object.create(null);for(let o in e)if(o.startsWith("present")){let a=o.replace("present_ssm","past_ssm").replace("present_conv","past_conv").replace("present_recurrent","past_recurrent").replace("present","past_key_values"),i=o.includes("encoder");if(i&&r?n[a]=r[a]:n[a]=e[o],r&&(!i||s)){let l=r[a];l.location==="gpu-buffer"&&l.dispose()}}return new Go(n)}getAttentions(e){let r={};for(let s of["cross_attentions","encoder_attentions","decoder_attentions"])for(let n in e)n.startsWith(s)&&(s in r||(r[s]=[]),r[s].push(e[n]));return r}addPastKeyValues(e,r){if(r)Object.assign(e,r);else{let s=this.sessions.decoder_model_merged??this.sessions.model,n=(e[this.main_input_name]??e.attention_mask)?.dims?.[0]??1,o=s?.config?.kv_cache_dtype??"float32",a=o==="float16"?xr.float16:xr.float32,i=As(this.config,{batch_size:n});for(let l in i){let c=i[l].reduce((p,d)=>p*d,1);e[l]=new $(o,new a(c),i[l])}}}async _encode_input(e,r,s){if(!Object.hasOwn(this.sessions,e))throw new Error(`Model does not have a ${e} session.`);let n=this.sessions[e];return(await de(n,Ke(r,n.inputNames)))[s]}async encode_image(e){return this._encode_input("vision_encoder",e,"image_features")}async encode_text(e){return this._encode_input("embed_tokens",e,"inputs_embeds")}async encode_audio(e){return this._encode_input("audio_encoder",e,"audio_features")}};async function du(t,e){let{encoder_outputs:r,input_ids:s,decoder_input_ids:n,...o}=e;if(!r){let a=Ke(e,t.sessions.model.inputNames);r=(await jt(t,a)).last_hidden_state}return o.input_ids=n,o.encoder_hidden_states=r,t.sessions.decoder_model_merged.inputNames.includes("encoder_attention_mask")&&(o.encoder_attention_mask=e.attention_mask),await Tt(t,o,!0)}async function jt(t,e){let r=t.sessions.model,s=Ke(e,r.inputNames);if(r.inputNames.includes("inputs_embeds")&&!s.inputs_embeds){if(!e.input_ids)throw new Error("Both `input_ids` and `inputs_embeds` are missing in the model inputs.");s.inputs_embeds=await t.encode_text({input_ids:e.input_ids})}if(r.inputNames.includes("token_type_ids")&&!s.token_type_ids){if(!s.input_ids)throw new Error("Both `input_ids` and `token_type_ids` are missing in the model inputs.");s.token_type_ids=vf(s.input_ids)}if(r.inputNames.includes("pixel_mask")&&!s.pixel_mask){if(!s.pixel_values)throw new Error("Both `pixel_values` and `pixel_mask` are missing in the model inputs.");let n=s.pixel_values.dims;s.pixel_mask=tt([n[0],n[2],n[3]])}return await de(r,s)}async function Jz(t,e){let r=await t.encode(e);return await t.decode(r)}async function Tt(t,e,r=!1){let s=t.sessions[r?"decoder_model_merged":"model"],{past_key_values:n,...o}=e;if(s.inputNames.includes("use_cache_branch")&&(o.use_cache_branch=sh(!!n)),s.inputNames.includes("position_ids")&&o.attention_mask&&!o.position_ids){let i=["paligemma","gemma3_text","gemma3"].includes(t.config.model_type)?1:0;o.position_ids=eN(o,n,i)}s.inputNames.includes("num_logits_to_keep")&&!o.num_logits_to_keep&&(o.num_logits_to_keep=new $("int64",[0n],[])),t.addPastKeyValues(o,n);let a=Ke(o,s.inputNames);return await de(s,a)}async function Q2(t,{encode_function:e,merge_function:r,modality_input_names:s,modality_output_name:n,input_ids:o=null,attention_mask:a=null,position_ids:i=null,inputs_embeds:l=null,past_key_values:c=null,generation_config:p=null,logits_processor:d=null,..._}){if(!l){l=await t.encode_text({input_ids:o,..._});let w=Ke(_,s);if(Object.keys(w).length>0){if(o.dims[1]!==1){let x=await e({...w,..._});({inputs_embeds:l,attention_mask:a}=r({[n]:x,inputs_embeds:l,input_ids:o,attention_mask:a}))}else if(c&&o.dims[1]===1){let x=o.dims[1],E=c.get_seq_length();a=ke([tt([o.dims[0],E]),a.slice(null,[a.dims[1]-x,a.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(t.config.model_type)){let{image_grid_thw:w,video_grid_thw:x}=_;[i]=t.get_rope_index(o,w,x,a)}return await Tt(t,{inputs_embeds:l,past_key_values:c,attention_mask:a,position_ids:i,generation_config:p,logits_processor:d},!0)}async function Zz(t,e){return await Q2(t,{...e,modality_input_names:["audio_values","input_features"],modality_output_name:"audio_features",encode_function:t.encode_audio.bind(t),merge_function:t._merge_input_ids_with_audio_features.bind(t)})}async function H2(t,e){return await Q2(t,{...e,modality_input_names:["pixel_values"],modality_output_name:"image_features",encode_function:t.encode_image.bind(t),merge_function:t._merge_input_ids_with_image_features.bind(t)})}function nh(t,e=0){let[r,s]=t.dims,n=t.data,o=new BigInt64Array(n.length);for(let a=0;a<r;++a){let i=a*s,l=BigInt(e);for(let c=0;c<s;++c){let p=i+c;n[p]===0n?o[p]=BigInt(1):(o[p]=l,l+=n[p])}}return{data:o,dims:t.dims}}function eN(t,e=null,r=0){let{input_ids:s,inputs_embeds:n,attention_mask:o}=t,{data:a,dims:i}=nh(o,r),l=new $("int64",a,i);if(e){let c=-(s??n).dims.at(1);l=l.slice(null,[c,null])}return l}function On(t,e,r,s){let n=r.past_key_values?r.past_key_values.get_seq_length():0;if((t.sessions.decoder_model_merged??t.sessions.model)?.inputNames.includes("num_logits_to_keep")&&!r.num_logits_to_keep&&(r.num_logits_to_keep=new $("int64",[1n],[])),!r.attention_mask){let a;for(let i of["input_ids","inputs_embeds","position_ids"])if(r[i]){a=r[i].dims;break}if(!a)throw new Error("attention_mask is not provided, and unable to infer its shape from model inputs.");r.attention_mask=tt([a[0],n+a[1]])}if(r.past_key_values){let{input_ids:a,attention_mask:i}=r;i&&i.dims[1]>a.dims[1]||n<a.dims[1]&&(r.input_ids=a.slice(null,[n,null]))}return r}function Wo(t,e,r,s){return r.past_key_values&&(e=e.map(n=>[n.at(-1)])),{...r,decoder_input_ids:rh(e)}}function qo(t,...e){return t.config.is_encoder_decoder?Wo(t,...e):On(t,...e)}function Y2({modality_token_id:t,inputs_embeds:e,modality_features:r,input_ids:s,attention_mask:n}){let o=s.tolist().map(c=>c.reduce((p,d,_)=>(d==t&&p.push(_),p),[])),a=o.reduce((c,p)=>c+p.length,0),i=r.dims[0];if(a!==i)throw new Error(`Number of tokens and features do not match: tokens: ${a}, features ${i}`);let l=0;for(let c=0;c<o.length;++c){let p=o[c],d=e[c];for(let _=0;_<p.length;++_)d[p[_]].data.set(r[l++].data)}return{inputs_embeds:e,attention_mask:n}}function In({image_token_id:t,inputs_embeds:e,image_features:r,input_ids:s,attention_mask:n}){return Y2({modality_token_id:t,inputs_embeds:e,modality_features:r,input_ids:s,attention_mask:n})}function _u({audio_token_id:t,inputs_embeds:e,audio_features:r,input_ids:s,attention_mask:n}){return Y2({modality_token_id:t,inputs_embeds:e,modality_features:r,input_ids:s,attention_mask:n})}async function tN(t,e,r){return Object.fromEntries(await Promise.all(Object.keys(e).map(async s=>{let n=await ut(t,e[s],!1,r);return[s,n]})))}var ol={};Zs(ol,{ASTForAudioClassification:()=>hh,ASTModel:()=>mh,ASTPreTrainedModel:()=>Ko,AfmoeForCausalLM:()=>dh,AfmoeModel:()=>ph,AfmoePreTrainedModel:()=>Ho,AlbertForMaskedLM:()=>lh,AlbertForQuestionAnswering:()=>ih,AlbertForSequenceClassification:()=>ah,AlbertModel:()=>oh,AlbertPreTrainedModel:()=>Is,ApertusForCausalLM:()=>uh,ApertusModel:()=>ch,ApertusPreTrainedModel:()=>Vo,ArceeForCausalLM:()=>_h,ArceeModel:()=>fh,ArceePreTrainedModel:()=>Xo,BartForConditionalGeneration:()=>wh,BartForSequenceClassification:()=>xh,BartModel:()=>gh,BartPretrainedModel:()=>Cn,BeitForImageClassification:()=>bh,BeitModel:()=>yh,BeitPreTrainedModel:()=>Qo,BertForMaskedLM:()=>kh,BertForQuestionAnswering:()=>Mh,BertForSequenceClassification:()=>Eh,BertForTokenClassification:()=>Ah,BertModel:()=>vh,BertPreTrainedModel:()=>qr,BlenderbotForConditionalGeneration:()=>Th,BlenderbotModel:()=>Sh,BlenderbotPreTrainedModel:()=>Yo,BlenderbotSmallForConditionalGeneration:()=>Ih,BlenderbotSmallModel:()=>Oh,BlenderbotSmallPreTrainedModel:()=>Jo,BloomForCausalLM:()=>Lh,BloomModel:()=>Ch,BloomPreTrainedModel:()=>Zo,CHMv2ForDepthEstimation:()=>Fh,CHMv2PreTrainedModel:()=>gu,CLIPModel:()=>Uh,CLIPPreTrainedModel:()=>cr,CLIPSegForImageSegmentation:()=>Vh,CLIPSegModel:()=>Wh,CLIPSegPreTrainedModel:()=>na,CLIPTextModel:()=>jh,CLIPTextModelWithProjection:()=>sa,CLIPVisionModel:()=>Gh,CLIPVisionModelWithProjection:()=>qh,CamembertForMaskedLM:()=>zh,CamembertForQuestionAnswering:()=>Rh,CamembertForSequenceClassification:()=>Nh,CamembertForTokenClassification:()=>$h,CamembertModel:()=>Ph,CamembertPreTrainedModel:()=>Wr,ChatterboxModel:()=>ea,ChatterboxPreTrainedModel:()=>mu,ChineseCLIPModel:()=>Dh,ChineseCLIPPreTrainedModel:()=>hu,ClapAudioModelWithProjection:()=>ra,ClapModel:()=>Bh,ClapPreTrainedModel:()=>Ln,ClapTextModelWithProjection:()=>ta,CodeGenForCausalLM:()=>Xh,CodeGenModel:()=>Hh,CodeGenPreTrainedModel:()=>oa,Cohere2ForCausalLM:()=>Jh,Cohere2Model:()=>Yh,Cohere2PreTrainedModel:()=>ia,CohereForCausalLM:()=>Qh,CohereModel:()=>Kh,CoherePreTrainedModel:()=>aa,ConvBertForMaskedLM:()=>eg,ConvBertForQuestionAnswering:()=>sg,ConvBertForSequenceClassification:()=>tg,ConvBertForTokenClassification:()=>rg,ConvBertModel:()=>Zh,ConvBertPreTrainedModel:()=>Vr,ConvNextForImageClassification:()=>og,ConvNextModel:()=>ng,ConvNextPreTrainedModel:()=>la,ConvNextV2ForImageClassification:()=>ig,ConvNextV2Model:()=>ag,ConvNextV2PreTrainedModel:()=>ca,DFineForObjectDetection:()=>pg,DFineModel:()=>ug,DFinePreTrainedModel:()=>pa,DINOv3ConvNextModel:()=>Rg,DINOv3ConvNextPreTrainedModel:()=>Eu,DINOv3ViTModel:()=>Dg,DINOv3ViTPreTrainedModel:()=>Au,DPTForDepthEstimation:()=>Vg,DPTModel:()=>Wg,DPTPreTrainedModel:()=>wa,DacDecoderModel:()=>fa,DacDecoderOutput:()=>xu,DacEncoderModel:()=>da,DacEncoderOutput:()=>wu,DacModel:()=>dg,DacPreTrainedModel:()=>Pn,DebertaForMaskedLM:()=>_g,DebertaForQuestionAnswering:()=>gg,DebertaForSequenceClassification:()=>mg,DebertaForTokenClassification:()=>hg,DebertaModel:()=>fg,DebertaPreTrainedModel:()=>Hr,DebertaV2ForMaskedLM:()=>bg,DebertaV2ForQuestionAnswering:()=>Eg,DebertaV2ForSequenceClassification:()=>vg,DebertaV2ForTokenClassification:()=>kg,DebertaV2Model:()=>yg,DebertaV2PreTrainedModel:()=>Xr,DecisionTransformerModel:()=>Ag,DecisionTransformerPreTrainedModel:()=>yu,DeepseekV3ForCausalLM:()=>xg,DeepseekV3Model:()=>wg,DeepseekV3PreTrainedModel:()=>_a,DeiTForImageClassification:()=>Sg,DeiTModel:()=>Mg,DeiTPreTrainedModel:()=>ma,DepthAnythingForDepthEstimation:()=>Tg,DepthAnythingPreTrainedModel:()=>bu,DepthProForDepthEstimation:()=>Og,DepthProPreTrainedModel:()=>vu,DetrForObjectDetection:()=>Cg,DetrForSegmentation:()=>Lg,DetrModel:()=>Ig,DetrObjectDetectionOutput:()=>Nn,DetrPreTrainedModel:()=>zn,DetrSegmentationOutput:()=>ku,Dinov2ForImageClassification:()=>zg,Dinov2Model:()=>Pg,Dinov2PreTrainedModel:()=>ha,Dinov2WithRegistersForImageClassification:()=>$g,Dinov2WithRegistersModel:()=>Ng,Dinov2WithRegistersPreTrainedModel:()=>ga,DistilBertForMaskedLM:()=>Gg,DistilBertForQuestionAnswering:()=>jg,DistilBertForSequenceClassification:()=>Bg,DistilBertForTokenClassification:()=>Ug,DistilBertModel:()=>Fg,DistilBertPreTrainedModel:()=>Kr,DonutSwinModel:()=>qg,DonutSwinPreTrainedModel:()=>Mu,EdgeTamModel:()=>J0,EfficientNetForImageClassification:()=>Xg,EfficientNetModel:()=>Hg,EfficientNetPreTrainedModel:()=>xa,ElectraForMaskedLM:()=>Qg,ElectraForQuestionAnswering:()=>Zg,ElectraForSequenceClassification:()=>Yg,ElectraForTokenClassification:()=>Jg,ElectraModel:()=>Kg,ElectraPreTrainedModel:()=>Qr,Ernie4_5ForCausalLM:()=>tw,Ernie4_5Model:()=>ew,Ernie4_5PretrainedModel:()=>ya,EsmForMaskedLM:()=>sw,EsmForSequenceClassification:()=>nw,EsmForTokenClassification:()=>ow,EsmModel:()=>rw,EsmPreTrainedModel:()=>Cs,EuroBertForMaskedLM:()=>iw,EuroBertForSequenceClassification:()=>lw,EuroBertForTokenClassification:()=>cw,EuroBertModel:()=>aw,EuroBertPreTrainedModel:()=>Ls,ExaoneForCausalLM:()=>pw,ExaoneModel:()=>uw,ExaonePreTrainedModel:()=>ba,FalconForCausalLM:()=>fw,FalconH1ForCausalLM:()=>mw,FalconH1Model:()=>_w,FalconH1PreTrainedModel:()=>ka,FalconModel:()=>dw,FalconPreTrainedModel:()=>va,FastViTForImageClassification:()=>gw,FastViTModel:()=>hw,FastViTPreTrainedModel:()=>Ea,Florence2ForConditionalGeneration:()=>ww,Florence2PreTrainedModel:()=>Su,GLPNForDepthEstimation:()=>Cw,GLPNModel:()=>Iw,GLPNPreTrainedModel:()=>Ca,GPT2LMHeadModel:()=>Uw,GPT2Model:()=>Bw,GPT2PreTrainedModel:()=>$a,GPTBigCodeForCausalLM:()=>Pw,GPTBigCodeModel:()=>Lw,GPTBigCodePreTrainedModel:()=>La,GPTJForCausalLM:()=>Gw,GPTJModel:()=>jw,GPTJPreTrainedModel:()=>Ra,GPTNeoForCausalLM:()=>Nw,GPTNeoModel:()=>zw,GPTNeoPreTrainedModel:()=>Pa,GPTNeoXForCausalLM:()=>Rw,GPTNeoXModel:()=>$w,GPTNeoXPreTrainedModel:()=>za,Gemma2ForCausalLM:()=>vw,Gemma2Model:()=>bw,Gemma2PreTrainedModel:()=>Ma,Gemma3ForCausalLM:()=>Ew,Gemma3Model:()=>kw,Gemma3PreTrainedModel:()=>Sa,Gemma3nForCausalLM:()=>Ta,Gemma3nForConditionalGeneration:()=>$n,Gemma3nPreTrainedModel:()=>Tu,GemmaForCausalLM:()=>yw,GemmaModel:()=>xw,GemmaPreTrainedModel:()=>Aa,GlmForCausalLM:()=>Mw,GlmModel:()=>Aw,GlmMoeDsaForCausalLM:()=>Tw,GlmMoeDsaModel:()=>Sw,GlmMoeDsaPreTrainedModel:()=>Ia,GlmOcrForConditionalGeneration:()=>Ow,GlmPreTrainedModel:()=>Oa,GptOssForCausalLM:()=>Fw,GptOssModel:()=>Dw,GptOssPreTrainedModel:()=>Na,GraniteForCausalLM:()=>Ww,GraniteModel:()=>qw,GraniteMoeHybridForCausalLM:()=>Hw,GraniteMoeHybridModel:()=>Vw,GraniteMoeHybridPreTrainedModel:()=>Fa,GranitePreTrainedModel:()=>Da,GraniteSpeechForConditionalGeneration:()=>Xw,GroundingDinoForObjectDetection:()=>Kw,GroundingDinoPreTrainedModel:()=>Cu,GroupViTModel:()=>Qw,GroupViTPreTrainedModel:()=>Lu,HeliumForCausalLM:()=>Jw,HeliumModel:()=>Yw,HeliumPreTrainedModel:()=>Ba,HieraForImageClassification:()=>ex,HieraModel:()=>Zw,HieraPreTrainedModel:()=>Ua,HubertForCTC:()=>ix,HubertForSequenceClassification:()=>lx,HubertModel:()=>ax,HubertPreTrainedModel:()=>ox,HunYuanDenseV1ForCausalLM:()=>ux,HunYuanDenseV1Model:()=>cx,HunYuanDenseV1PreTrainedModel:()=>ja,IJepaForImageClassification:()=>mx,IJepaModel:()=>_x,IJepaPreTrainedModel:()=>Ga,Idefics3ForConditionalGeneration:()=>fx,JAISLMHeadModel:()=>gx,JAISModel:()=>hx,JAISPreTrainedModel:()=>qa,JinaCLIPModel:()=>wx,JinaCLIPPreTrainedModel:()=>Dn,JinaCLIPTextModel:()=>Wa,JinaCLIPVisionModel:()=>xx,Lfm2ForCausalLM:()=>bx,Lfm2Model:()=>yx,Lfm2MoeForCausalLM:()=>Ex,Lfm2MoeModel:()=>kx,Lfm2MoePreTrainedModel:()=>Ha,Lfm2PreTrainedModel:()=>Va,Lfm2VlForConditionalGeneration:()=>Ax,LightOnOcrForConditionalGeneration:()=>vx,LiteWhisperForConditionalGeneration:()=>f1,Llama4ForCausalLM:()=>Tx,Llama4PreTrainedModel:()=>zu,LlamaForCausalLM:()=>Sx,LlamaModel:()=>Mx,LlamaPreTrainedModel:()=>Xa,LlavaForConditionalGeneration:()=>Ot,LlavaOnevisionForConditionalGeneration:()=>Ot,LlavaPreTrainedModel:()=>Pu,LlavaQwen2ForCausalLM:()=>dx,LongT5ForConditionalGeneration:()=>Ix,LongT5Model:()=>Ox,LongT5PreTrainedModel:()=>Ka,M2M100ForConditionalGeneration:()=>Lx,M2M100Model:()=>Cx,M2M100PreTrainedModel:()=>Qa,MBartForCausalLM:()=>Bx,MBartForConditionalGeneration:()=>Dx,MBartForSequenceClassification:()=>Fx,MBartModel:()=>Rx,MBartPreTrainedModel:()=>Rs,MPNetForMaskedLM:()=>My,MPNetForQuestionAnswering:()=>Oy,MPNetForSequenceClassification:()=>Sy,MPNetForTokenClassification:()=>Ty,MPNetModel:()=>Ay,MPNetPreTrainedModel:()=>Yr,MT5ForConditionalGeneration:()=>Py,MT5Model:()=>Ly,MT5PreTrainedModel:()=>ci,MarianMTModel:()=>zx,MarianModel:()=>Px,MarianPreTrainedModel:()=>Ya,MaskFormerForInstanceSegmentation:()=>$x,MaskFormerModel:()=>Nx,MaskFormerPreTrainedModel:()=>Ja,Metric3DForDepthEstimation:()=>Ux,Metric3DPreTrainedModel:()=>Nu,Metric3Dv2ForDepthEstimation:()=>jx,Metric3Dv2PreTrainedModel:()=>$u,MgpstrForSceneTextRecognition:()=>Gx,MgpstrModelOutput:()=>Ru,MgpstrPreTrainedModel:()=>Du,MimiDecoderModel:()=>ei,MimiDecoderOutput:()=>Bu,MimiEncoderModel:()=>Za,MimiEncoderOutput:()=>Fu,MimiModel:()=>qx,MimiPreTrainedModel:()=>Fn,Mistral4ForCausalLM:()=>Xx,Mistral4Model:()=>Hx,Mistral4PreTrainedModel:()=>ri,MistralForCausalLM:()=>Vx,MistralModel:()=>Wx,MistralPreTrainedModel:()=>ti,MobileBertForMaskedLM:()=>Qx,MobileBertForQuestionAnswering:()=>Jx,MobileBertForSequenceClassification:()=>Yx,MobileBertModel:()=>Kx,MobileBertPreTrainedModel:()=>Ds,MobileLLMForCausalLM:()=>ey,MobileLLMModel:()=>Zx,MobileLLMPreTrainedModel:()=>si,MobileNetV1ForImageClassification:()=>ry,MobileNetV1ForSemanticSegmentation:()=>sy,MobileNetV1Model:()=>ty,MobileNetV1PreTrainedModel:()=>Bn,MobileNetV2ForImageClassification:()=>oy,MobileNetV2ForSemanticSegmentation:()=>ay,MobileNetV2Model:()=>ny,MobileNetV2PreTrainedModel:()=>Un,MobileNetV3ForImageClassification:()=>ly,MobileNetV3ForSemanticSegmentation:()=>cy,MobileNetV3Model:()=>iy,MobileNetV3PreTrainedModel:()=>jn,MobileNetV4ForImageClassification:()=>py,MobileNetV4ForSemanticSegmentation:()=>dy,MobileNetV4Model:()=>uy,MobileNetV4PreTrainedModel:()=>Gn,MobileViTForImageClassification:()=>_y,MobileViTModel:()=>fy,MobileViTPreTrainedModel:()=>ni,MobileViTV2ForImageClassification:()=>hy,MobileViTV2Model:()=>my,MobileViTV2PreTrainedModel:()=>oi,ModernBertDecoderForCausalLM:()=>vy,ModernBertDecoderModel:()=>by,ModernBertDecoderPreTrainedModel:()=>ai,ModernBertForMaskedLM:()=>wy,ModernBertForSequenceClassification:()=>xy,ModernBertForTokenClassification:()=>yy,ModernBertModel:()=>gy,ModernBertPreTrainedModel:()=>Fs,Moondream1ForConditionalGeneration:()=>px,MoonshineForConditionalGeneration:()=>Ey,MoonshineModel:()=>ky,MoonshinePreTrainedModel:()=>ii,MptForCausalLM:()=>Cy,MptModel:()=>Iy,MptPreTrainedModel:()=>li,MultiModalityCausalLM:()=>zy,MultiModalityPreTrainedModel:()=>Uu,MusicgenForCausalLM:()=>$y,MusicgenForConditionalGeneration:()=>pi,MusicgenModel:()=>Ny,MusicgenPreTrainedModel:()=>ui,NanoChatForCausalLM:()=>Dy,NanoChatModel:()=>Ry,NanoChatPreTrainedModel:()=>di,NemotronHForCausalLM:()=>By,NemotronHModel:()=>Fy,NemotronHPreTrainedModel:()=>fi,NeoBertForMaskedLM:()=>jy,NeoBertForQuestionAnswering:()=>Wy,NeoBertForSequenceClassification:()=>Gy,NeoBertForTokenClassification:()=>qy,NeoBertModel:()=>Uy,NeoBertPreTrainedModel:()=>Jr,NomicBertModel:()=>Vy,NomicBertPreTrainedModel:()=>ju,OPTForCausalLM:()=>n0,OPTModel:()=>s0,OPTPreTrainedModel:()=>xi,Olmo2ForCausalLM:()=>Qy,Olmo2Model:()=>Ky,Olmo2PreTrainedModel:()=>mi,Olmo3ForCausalLM:()=>Jy,Olmo3Model:()=>Yy,Olmo3PreTrainedModel:()=>hi,OlmoForCausalLM:()=>Xy,OlmoHybridForCausalLM:()=>e0,OlmoHybridModel:()=>Zy,OlmoHybridPreTrainedModel:()=>gi,OlmoModel:()=>Hy,OlmoPreTrainedModel:()=>_i,OpenELMForCausalLM:()=>r0,OpenELMModel:()=>t0,OpenELMPreTrainedModel:()=>wi,OwlViTForObjectDetection:()=>l0,OwlViTModel:()=>i0,OwlViTPreTrainedModel:()=>bi,Owlv2ForObjectDetection:()=>a0,Owlv2Model:()=>o0,Owlv2PreTrainedModel:()=>yi,PaliGemmaForConditionalGeneration:()=>c0,ParakeetForCTC:()=>u0,ParakeetPreTrainedModel:()=>Gu,PatchTSMixerForPrediction:()=>d0,PatchTSMixerModel:()=>p0,PatchTSMixerPreTrainedModel:()=>vi,PatchTSTForPrediction:()=>_0,PatchTSTModel:()=>f0,PatchTSTPreTrainedModel:()=>ki,Phi3ForCausalLM:()=>w0,Phi3Model:()=>g0,Phi3PreTrainedModel:()=>Ai,Phi3VForCausalLM:()=>Mi,Phi3VPreTrainedModel:()=>qu,PhiForCausalLM:()=>h0,PhiModel:()=>m0,PhiPreTrainedModel:()=>Ei,PreTrainedModel:()=>y,PvtForImageClassification:()=>y0,PvtModel:()=>x0,PvtPreTrainedModel:()=>Si,PyAnnoteForAudioFrameClassification:()=>v0,PyAnnoteModel:()=>b0,PyAnnotePreTrainedModel:()=>Ti,Qwen2ForCausalLM:()=>E0,Qwen2Model:()=>k0,Qwen2MoeForCausalLM:()=>M0,Qwen2MoeModel:()=>A0,Qwen2MoePreTrainedModel:()=>Ii,Qwen2PreTrainedModel:()=>Oi,Qwen2VLForCausalLM:()=>Ps,Qwen2VLForConditionalGeneration:()=>Rn,Qwen2VLPreTrainedModel:()=>Ou,Qwen2_5_VLForCausalLM:()=>Ns,Qwen2_5_VLForConditionalGeneration:()=>zs,Qwen3ForCausalLM:()=>T0,Qwen3Model:()=>S0,Qwen3MoeForCausalLM:()=>I0,Qwen3MoeModel:()=>O0,Qwen3MoePreTrainedModel:()=>Li,Qwen3NextForCausalLM:()=>L0,Qwen3NextModel:()=>C0,Qwen3NextPreTrainedModel:()=>Pi,Qwen3PreTrainedModel:()=>Ci,Qwen3VLForCausalLM:()=>Us,Qwen3VLForConditionalGeneration:()=>Bs,Qwen3VLMoeForCausalLM:()=>zi,Qwen3VLMoeForConditionalGeneration:()=>P0,Qwen3_5ForCausalLM:()=>js,Qwen3_5ForConditionalGeneration:()=>qn,Qwen3_5MoeForCausalLM:()=>Ni,Qwen3_5MoeForConditionalGeneration:()=>z0,RFDetrForObjectDetection:()=>D0,RFDetrModel:()=>R0,RFDetrObjectDetectionOutput:()=>Wu,RFDetrPreTrainedModel:()=>Ri,RTDetrForObjectDetection:()=>cg,RTDetrModel:()=>lg,RTDetrObjectDetectionOutput:()=>ur,RTDetrPreTrainedModel:()=>ua,RTDetrV2ForObjectDetection:()=>Q0,RTDetrV2Model:()=>K0,RTDetrV2ObjectDetectionOutput:()=>Vu,RTDetrV2PreTrainedModel:()=>Di,ResNetForImageClassification:()=>$0,ResNetModel:()=>N0,ResNetPreTrainedModel:()=>$i,RoFormerForMaskedLM:()=>W0,RoFormerForQuestionAnswering:()=>X0,RoFormerForSequenceClassification:()=>V0,RoFormerForTokenClassification:()=>H0,RoFormerModel:()=>q0,RoFormerPreTrainedModel:()=>es,RobertaForMaskedLM:()=>B0,RobertaForQuestionAnswering:()=>G0,RobertaForSequenceClassification:()=>U0,RobertaForTokenClassification:()=>j0,RobertaModel:()=>F0,RobertaPreTrainedModel:()=>Zr,Sam2ImageSegmentationOutput:()=>Ku,Sam2Model:()=>Fi,Sam2PreTrainedModel:()=>Qu,Sam3TrackerModel:()=>Z0,SamImageSegmentationOutput:()=>Hu,SamModel:()=>Y0,SamPreTrainedModel:()=>Xu,SapiensForDepthEstimation:()=>tb,SapiensForNormalEstimation:()=>rb,SapiensForSemanticSegmentation:()=>eb,SapiensPreTrainedModel:()=>Wn,SegformerForImageClassification:()=>nb,SegformerForSemanticSegmentation:()=>ob,SegformerModel:()=>sb,SegformerPreTrainedModel:()=>Vn,SiglipModel:()=>ab,SiglipPreTrainedModel:()=>Bi,SiglipTextModel:()=>Ui,SiglipVisionModel:()=>ib,SmolLM3ForCausalLM:()=>cb,SmolLM3Model:()=>lb,SmolLM3PreTrainedModel:()=>ji,SnacDecoderModel:()=>qi,SnacEncoderModel:()=>Gi,SnacModel:()=>ub,SnacPreTrainedModel:()=>Hn,SolarOpenForCausalLM:()=>db,SolarOpenModel:()=>pb,SolarOpenPreTrainedModel:()=>Wi,SpeechT5ForSpeechToText:()=>_b,SpeechT5ForTextToSpeech:()=>mb,SpeechT5HifiGan:()=>hb,SpeechT5Model:()=>fb,SpeechT5PreTrainedModel:()=>Xn,SqueezeBertForMaskedLM:()=>wb,SqueezeBertForQuestionAnswering:()=>yb,SqueezeBertForSequenceClassification:()=>xb,SqueezeBertModel:()=>gb,SqueezeBertPreTrainedModel:()=>Gs,StableLmForCausalLM:()=>vb,StableLmModel:()=>bb,StableLmPreTrainedModel:()=>Vi,Starcoder2ForCausalLM:()=>Eb,Starcoder2Model:()=>kb,Starcoder2PreTrainedModel:()=>Hi,StyleTextToSpeech2Model:()=>Ab,StyleTextToSpeech2PreTrainedModel:()=>Yu,SupertonicForConditionalGeneration:()=>Xi,SupertonicPreTrainedModel:()=>Ju,Swin2SRForImageSuperResolution:()=>Ib,Swin2SRModel:()=>Ob,Swin2SRPreTrainedModel:()=>Ki,SwinForImageClassification:()=>Sb,SwinForSemanticSegmentation:()=>Tb,SwinModel:()=>Mb,SwinPreTrainedModel:()=>Kn,T5ForConditionalGeneration:()=>Lb,T5Model:()=>Cb,T5PreTrainedModel:()=>Qi,TableTransformerForObjectDetection:()=>zb,TableTransformerModel:()=>Pb,TableTransformerObjectDetectionOutput:()=>Zu,TableTransformerPreTrainedModel:()=>Yi,TrOCRForCausalLM:()=>Nb,TrOCRPreTrainedModel:()=>ep,UltravoxModel:()=>$s,UltravoxPreTrainedModel:()=>Iu,UniSpeechForCTC:()=>Rb,UniSpeechForSequenceClassification:()=>Db,UniSpeechModel:()=>$b,UniSpeechPreTrainedModel:()=>Qn,UniSpeechSatForAudioFrameClassification:()=>jb,UniSpeechSatForCTC:()=>Bb,UniSpeechSatForSequenceClassification:()=>Ub,UniSpeechSatModel:()=>Fb,UniSpeechSatPreTrainedModel:()=>qs,VaultGemmaForCausalLM:()=>qb,VaultGemmaModel:()=>Gb,VaultGemmaPreTrainedModel:()=>Ji,ViTForImageClassification:()=>Hb,ViTMAEModel:()=>Xb,ViTMAEPreTrainedModel:()=>tp,ViTMSNForImageClassification:()=>Qb,ViTMSNModel:()=>Kb,ViTMSNPreTrainedModel:()=>el,ViTModel:()=>Vb,ViTPreTrainedModel:()=>Zi,VisionEncoderDecoderModel:()=>Wb,VitMatteForImageMatting:()=>Yb,VitMattePreTrainedModel:()=>rp,VitPoseForPoseEstimation:()=>Jb,VitPosePreTrainedModel:()=>sp,VitsModel:()=>Zb,VitsModelOutput:()=>np,VitsPreTrainedModel:()=>op,VoxtralForConditionalGeneration:()=>e1,VoxtralRealtimeForConditionalGeneration:()=>tl,VoxtralRealtimePreTrainedModel:()=>ap,Wav2Vec2BertForCTC:()=>n1,Wav2Vec2BertForSequenceClassification:()=>o1,Wav2Vec2BertModel:()=>s1,Wav2Vec2BertPreTrainedModel:()=>Yn,Wav2Vec2ForAudioFrameClassification:()=>nx,Wav2Vec2ForCTC:()=>rx,Wav2Vec2ForSequenceClassification:()=>sx,Wav2Vec2Model:()=>tx,Wav2Vec2PreTrainedModel:()=>Zt,WavLMForAudioFrameClassification:()=>u1,WavLMForCTC:()=>i1,WavLMForSequenceClassification:()=>l1,WavLMForXVector:()=>c1,WavLMModel:()=>a1,WavLMPreTrainedModel:()=>ts,WeSpeakerResNetModel:()=>p1,WeSpeakerResNetPreTrainedModel:()=>lp,WhisperForConditionalGeneration:()=>up,WhisperModel:()=>d1,WhisperPreTrainedModel:()=>rl,XLMForQuestionAnswering:()=>w1,XLMForSequenceClassification:()=>h1,XLMForTokenClassification:()=>g1,XLMModel:()=>_1,XLMPreTrainedModel:()=>rs,XLMRobertaForMaskedLM:()=>y1,XLMRobertaForQuestionAnswering:()=>k1,XLMRobertaForSequenceClassification:()=>b1,XLMRobertaForTokenClassification:()=>v1,XLMRobertaModel:()=>x1,XLMRobertaPreTrainedModel:()=>ss,XLMWithLMHeadModel:()=>m1,XVectorOutput:()=>ip,YolosForObjectDetection:()=>A1,YolosModel:()=>E1,YolosObjectDetectionOutput:()=>pp,YolosPreTrainedModel:()=>sl,YoutuForCausalLM:()=>S1,YoutuModel:()=>M1,YoutuPreTrainedModel:()=>nl});var Is=class extends y{},oh=class extends Is{},ah=class extends Is{async _call(e){return new j(await super._call(e))}},ih=class extends Is{async _call(e){return new Ae(await super._call(e))}},lh=class extends Is{async _call(e){return new ge(await super._call(e))}};var Vo=class extends y{},ch=class extends Vo{},uh=class extends Vo{};var Ho=class extends y{},ph=class extends Ho{},dh=class extends Ho{};var Xo=class extends y{},fh=class extends Xo{},_h=class extends Xo{};var Ko=class extends y{},mh=class extends Ko{},hh=class extends Ko{};var Cn=class extends y{},gh=class extends Cn{},wh=class extends Cn{},xh=class extends Cn{async _call(e){return new j(await super._call(e))}};var Qo=class extends y{},yh=class extends Qo{},bh=class extends Qo{async _call(e){return new j(await super._call(e))}};var qr=class extends y{},vh=class extends qr{},kh=class extends qr{async _call(e){return new ge(await super._call(e))}},Eh=class extends qr{async _call(e){return new j(await super._call(e))}},Ah=class extends qr{async _call(e){return new he(await super._call(e))}},Mh=class extends qr{async _call(e){return new Ae(await super._call(e))}};var Yo=class extends y{},Sh=class extends Yo{},Th=class extends Yo{};var Jo=class extends y{},Oh=class extends Jo{},Ih=class extends Jo{};var Zo=class extends y{},Ch=class extends Zo{},Lh=class extends Zo{};var Wr=class extends y{},Ph=class extends Wr{},zh=class extends Wr{async _call(e){return new ge(await super._call(e))}},Nh=class extends Wr{async _call(e){return new j(await super._call(e))}},$h=class extends Wr{async _call(e){return new he(await super._call(e))}},Rh=class extends Wr{async _call(e){return new Ae(await super._call(e))}};var rN=4299n,J2=6561n,mu=class extends y{forward_params=["input_ids","inputs_embeds","attention_mask","position_ids","audio_values","exaggeration","audio_features","audio_tokens","speaker_embeddings","speaker_features","past_key_values"];main_input_name="input_ids";_return_dict_in_generate_keys=["audio_tokens","speaker_embeddings","speaker_features"]},ea=class extends mu{async encode_speech(e){return de(this.sessions.speech_encoder,{audio_values:e})}async forward({input_ids:e=null,attention_mask:r=null,audio_values:s=null,exaggeration:n=null,position_ids:o=null,inputs_embeds:a=null,past_key_values:i=null,generation_config:l=null,logits_processor:c=null,audio_features:p=null,audio_tokens:d=null,speaker_embeddings:_=null,speaker_features:m=null,...w}){let x;if(!a){let k=this.sessions.embed_tokens.inputNames,A={input_ids:e};if(k.includes("exaggeration")){if(!(n instanceof $)){let T=e.dims[0];if(n==null)n=He([T],.5);else if(typeof n=="number")n=He([T],n);else if(Array.isArray(n))n=new $("float32",n,[T]);else throw new Error("Unsupported type for `exaggeration` input")}A.exaggeration=n}if(k.includes("position_ids")&&(A.position_ids=o),{inputs_embeds:a}=await de(this.sessions.embed_tokens,A),p&&d&&_&&m&&(x={audio_features:p,audio_tokens:d,speaker_embeddings:_,speaker_features:m}),x||s)x??=await this.encode_speech(s),a=ke([x.audio_features,a],1),r=tt([a.dims[0],a.dims[1]]);else{let T=a.dims[1];if(!i||T!==1)throw new Error("Incorrect state encountered during generation.");let S=i.get_seq_length();r=tt([a.dims[0],S+T])}}return{...await Tt(this,{inputs_embeds:a,past_key_values:i,attention_mask:r,generation_config:l,logits_processor:c},!1),...x}}prepare_inputs_for_generation(e,r,s){if(!r.position_ids&&this.sessions.embed_tokens.inputNames.includes("position_ids"))if(r.input_ids.dims[1]===1){let n=Array.from({length:e.length},(o,a)=>e[a].length-e[a].findLastIndex(i=>i==J2)-1);r.position_ids=new $("int64",n,[e.length,1])}else{let o=r.input_ids.tolist().map(a=>{let i=0;return a.map(l=>l>=J2?0:i++)});r.position_ids=new $("int64",o.flat(),r.input_ids.dims)}return r.input_ids.dims[1]===1&&(delete r.audio_values,delete r.audio_features,delete r.audio_tokens,delete r.speaker_embeddings,delete r.speaker_features),On(this,e,r,s)}async generate(e){let{sequences:r,audio_tokens:s,speaker_embeddings:n,speaker_features:o}=await super.generate({...e,return_dict_in_generate:!0}),a=r.slice(null,[e.input_ids.dims[1],-1]),i=He([a.dims[0],3],rN),l=ke([s,a,i],1),{waveform:c}=await de(this.sessions.conditional_decoder,{speech_tokens:l,speaker_features:o,speaker_embeddings:n});return c}};var hu=class extends y{},Dh=class extends hu{};var gu=class extends y{},Fh=class extends gu{};var Ln=class extends y{},Bh=class extends Ln{},ta=class extends Ln{static async from_pretrained(e,r={}){return super.from_pretrained(e,{...r,model_file_name:r.model_file_name??"text_model"})}},ra=class extends Ln{static async from_pretrained(e,r={}){return super.from_pretrained(e,{...r,model_file_name:r.model_file_name??"audio_model"})}};var cr=class extends y{},Uh=class extends cr{},jh=class extends cr{static async from_pretrained(e,r={}){return super.from_pretrained(e,{...r,model_file_name:r.model_file_name??"text_model"})}},sa=class extends cr{static async from_pretrained(e,r={}){return super.from_pretrained(e,{...r,model_file_name:r.model_file_name??"text_model"})}},Gh=class extends cr{static async from_pretrained(e,r={}){return super.from_pretrained(e,{...r,model_file_name:r.model_file_name??"vision_model"})}},qh=class extends cr{static async from_pretrained(e,r={}){return super.from_pretrained(e,{...r,model_file_name:r.model_file_name??"vision_model"})}};var na=class extends y{},Wh=class extends na{},Vh=class extends na{};var oa=class extends y{},Hh=class extends oa{},Xh=class extends oa{};var aa=class extends y{},Kh=class extends aa{},Qh=class extends aa{};var ia=class extends y{},Yh=class extends ia{},Jh=class extends ia{};var Vr=class extends y{},Zh=class extends Vr{},eg=class extends Vr{async _call(e){return new ge(await super._call(e))}},tg=class extends Vr{async _call(e){return new j(await super._call(e))}},rg=class extends Vr{async _call(e){return new he(await super._call(e))}},sg=class extends Vr{async _call(e){return new Ae(await super._call(e))}};var la=class extends y{},ng=class extends la{},og=class extends la{async _call(e){return new j(await super._call(e))}};var ca=class extends y{},ag=class extends ca{},ig=class extends ca{async _call(e){return new j(await super._call(e))}};var ua=class extends y{},lg=class extends ua{},cg=class extends ua{async _call(e){return new ur(await super._call(e))}},ur=class extends $e{constructor({logits:e,pred_boxes:r}){super(),this.logits=e,this.pred_boxes=r}};var pa=class extends y{},ug=class extends pa{},pg=class extends pa{async _call(e){return new ur(await super._call(e))}};var wu=class extends $e{constructor({audio_codes:e}){super(),this.audio_codes=e}},xu=class extends $e{constructor({audio_values:e}){super(),this.audio_values=e}},Pn=class extends y{main_input_name="input_values";forward_params=["input_values"]},dg=class extends Pn{async encode(e){return new wu(await de(this.sessions.encoder_model,e))}async decode(e){return new xu(await de(this.sessions.decoder_model,e))}},da=class extends Pn{static async from_pretrained(e,r={}){return super.from_pretrained(e,{...r,model_file_name:r.model_file_name??"encoder_model"})}},fa=class extends Pn{static async from_pretrained(e,r={}){return super.from_pretrained(e,{...r,model_file_name:r.model_file_name??"decoder_model"})}};var Hr=class extends y{},fg=class extends Hr{},_g=class extends Hr{async _call(e){return new ge(await super._call(e))}},mg=class extends Hr{async _call(e){return new j(await super._call(e))}},hg=class extends Hr{async _call(e){return new he(await super._call(e))}},gg=class extends Hr{async _call(e){return new Ae(await super._call(e))}};var _a=class extends y{},wg=class extends _a{},xg=class extends _a{};var Xr=class extends y{},yg=class extends Xr{},bg=class extends Xr{async _call(e){return new ge(await super._call(e))}},vg=class extends Xr{async _call(e){return new j(await super._call(e))}},kg=class extends Xr{async _call(e){return new he(await super._call(e))}},Eg=class extends Xr{async _call(e){return new Ae(await super._call(e))}};var yu=class extends y{},Ag=class extends yu{};var ma=class extends y{},Mg=class extends ma{},Sg=class extends ma{async _call(e){return new j(await super._call(e))}};var bu=class extends y{},Tg=class extends bu{};var vu=class extends y{},Og=class extends vu{};var zn=class extends y{},Ig=class extends zn{},Cg=class extends zn{async _call(e){return new Nn(await super._call(e))}},Lg=class extends zn{async _call(e){return new ku(await super._call(e))}},Nn=class extends $e{constructor({logits:e,pred_boxes:r}){super(),this.logits=e,this.pred_boxes=r}},ku=class extends $e{constructor({logits:e,pred_boxes:r,pred_masks:s}){super(),this.logits=e,this.pred_boxes=r,this.pred_masks=s}};var ha=class extends y{},Pg=class extends ha{},zg=class extends ha{async _call(e){return new j(await super._call(e))}};var ga=class extends y{},Ng=class extends ga{},$g=class extends ga{async _call(e){return new j(await super._call(e))}};var Eu=class extends y{},Rg=class extends Eu{};var Au=class extends y{},Dg=class extends Au{};var Kr=class extends y{},Fg=class extends Kr{},Bg=class extends Kr{async _call(e){return new j(await super._call(e))}},Ug=class extends Kr{async _call(e){return new he(await super._call(e))}},jg=class extends Kr{async _call(e){return new Ae(await super._call(e))}},Gg=class extends Kr{async _call(e){return new ge(await super._call(e))}};var Mu=class extends y{},qg=class extends Mu{};var wa=class extends y{},Wg=class extends wa{},Vg=class extends wa{};var xa=class extends y{},Hg=class extends xa{},Xg=class extends xa{async _call(e){return new j(await super._call(e))}};var Qr=class extends y{},Kg=class extends Qr{},Qg=class extends Qr{async _call(e){return new ge(await super._call(e))}},Yg=class extends Qr{async _call(e){return new j(await super._call(e))}},Jg=class extends Qr{async _call(e){return new he(await super._call(e))}},Zg=class extends Qr{async _call(e){return new Ae(await super._call(e))}};var ya=class extends y{},ew=class extends ya{},tw=class extends ya{};var Cs=class extends y{},rw=class extends Cs{},sw=class extends Cs{async _call(e){return new ge(await super._call(e))}},nw=class extends Cs{async _call(e){return new j(await super._call(e))}},ow=class extends Cs{async _call(e){return new he(await super._call(e))}};var Ls=class extends y{},aw=class extends Ls{},iw=class extends Ls{async _call(e){return new ge(await super._call(e))}},lw=class extends Ls{async _call(e){return new j(await super._call(e))}},cw=class extends Ls{async _call(e){return new he(await super._call(e))}};var ba=class extends y{},uw=class extends ba{},pw=class extends ba{};var va=class extends y{},dw=class extends va{},fw=class extends va{};var ka=class extends y{},_w=class extends ka{},mw=class extends ka{};var Ea=class extends y{},hw=class extends Ea{},gw=class extends Ea{async _call(e){return new j(await super._call(e))}};var Su=class extends y{forward_params=["input_ids","inputs_embeds","attention_mask","pixel_values","encoder_outputs","decoder_input_ids","decoder_inputs_embeds","decoder_attention_mask","past_key_values"];main_input_name="inputs_embeds"},ww=class extends Su{_merge_input_ids_with_image_features({inputs_embeds:e,image_features:r,input_ids:s,attention_mask:n}){return{inputs_embeds:ke([r,e],1),attention_mask:ke([tt(r.dims.slice(0,2)),n],1)}}async _prepare_inputs_embeds({input_ids:e,pixel_values:r,inputs_embeds:s,attention_mask:n}){if(!e&&!r)throw new Error("Either `input_ids` or `pixel_values` should be provided.");let o,a;return e&&(o=await this.encode_text({input_ids:e})),r&&(a=await this.encode_image({pixel_values:r})),o&&a?{inputs_embeds:s,attention_mask:n}=this._merge_input_ids_with_image_features({inputs_embeds:o,image_features:a,input_ids:e,attention_mask:n}):s=o||a,{inputs_embeds:s,attention_mask:n}}async forward({input_ids:e,pixel_values:r,attention_mask:s,decoder_input_ids:n,decoder_attention_mask:o,encoder_outputs:a,past_key_values:i,inputs_embeds:l,decoder_inputs_embeds:c}){if(l||({inputs_embeds:l,attention_mask:s}=await this._prepare_inputs_embeds({input_ids:e,pixel_values:r,inputs_embeds:l,attention_mask:s})),!a){let{last_hidden_state:d}=await jt(this,{inputs_embeds:l,attention_mask:s});a=d}if(!c){if(!n)throw new Error("Either `decoder_input_ids` or `decoder_inputs_embeds` should be provided.");c=await this.encode_text({input_ids:n})}return await Tt(this,{inputs_embeds:c,attention_mask:o,encoder_attention_mask:s,encoder_hidden_states:a,past_key_values:i},!0)}};var Aa=class extends y{},xw=class extends Aa{},yw=class extends Aa{};var Ma=class extends y{},bw=class extends Ma{},vw=class extends Ma{};var Sa=class extends y{},kw=class extends Sa{},Ew=class extends Sa{};var Tu=class extends y{forward_params=["input_ids","attention_mask","inputs_embeds","per_layer_inputs","position_ids","pixel_values","input_features","input_features_mask","past_key_values"]},$n=class extends Tu{async forward({input_ids:e=null,attention_mask:r=null,pixel_values:s=null,input_features:n=null,input_features_mask:o=null,position_ids:a=null,inputs_embeds:i=null,per_layer_inputs:l=null,past_key_values:c=null,generation_config:p=null,logits_processor:d=null,..._}){if((!i||!l)&&({inputs_embeds:i,per_layer_inputs:l}=await de(this.sessions.embed_tokens,{input_ids:e}),e.dims[1]!==1)){if(s){let{image_features:w}=await de(this.sessions.vision_encoder,{pixel_values:s});({inputs_embeds:i,attention_mask:r}=this._merge_input_ids_with_image_features({image_features:w,inputs_embeds:i,input_ids:e,attention_mask:r}))}if(n){let{audio_features:w}=await de(this.sessions.audio_encoder,{input_features:n,input_features_mask:o});({inputs_embeds:i,attention_mask:r}=this._merge_input_ids_with_audio_features({audio_features:w,inputs_embeds:i,input_ids:e,attention_mask:r}))}}return await Tt(this,{inputs_embeds:i,per_layer_inputs:l,past_key_values:c,attention_mask:r,position_ids:a,generation_config:p,logits_processor:d},!0)}_merge_input_ids_with_image_features(e){let r=e.image_features.dims.at(-1),s=e.image_features.view(-1,r);return In({image_token_id:this.config.image_token_id,...e,image_features:s})}_merge_input_ids_with_audio_features(e){let r=e.audio_features.dims.at(-1),s=e.audio_features.view(-1,r);return _u({audio_token_id:this.config.audio_token_id,...e,audio_features:s})}},Ta=class extends $n{};var Oa=class extends y{},Aw=class extends Oa{},Mw=class extends Oa{};var Ia=class extends y{},Sw=class extends Ia{},Tw=class extends Ia{};var Ou=class extends y{forward_params=["input_ids","attention_mask","position_ids","past_key_values","pixel_values","image_grid_thw"]},Rn=class extends Ou{image_grid_thw_name="grid_thw";_get_text_only_rope_index(e,r){if(r){let{data:s,dims:n}=nh(r),o=BigInt64Array.from({length:3*s.length},(i,l)=>s[l%s.length]),a=Array.from({length:n[0]},(i,l)=>Oe(s.subarray(n[1]*l,n[1]*(l+1)))[0]+1n+BigInt(n[1]));return[new $("int64",o,[3,...n]),new $("int64",a,[a.length,1])]}else{let[s,n]=e.dims,o=BigInt64Array.from({length:3*s*n},(a,i)=>BigInt(Math.floor(i%n/s)));return[new $("int64",o,[3,...e.dims]),bf([s,1])]}}_reorder_and_write_positions(e,r,s,n){let o=e.reduce((c,p)=>c+p.length,0),a=new Array(o),i=0;for(let c=0;c<3;++c)for(let p of e){let d=p.length/3;for(let _=c*d;_<(c+1)*d;++_)a[i++]=p[_]}let l=0;for(let c=0;c<r.length;++c)if(r[c]==1){for(let p=0;p<3;++p)s[p][n][c]=a[p*o/3+l];++l}return a}_get_multimodal_rope_positions({filtered_ids:e,image_grid_thw_list:r,video_grid_thw_list:s,spatial_merge_size:n,state:o}){let{image_token_id:a,video_token_id:i,vision_start_token_id:l}=this.config,c=e,d=c.reduce((A,T,S)=>(T==l&&A.push(S),A),[]).map(A=>c[A+1]),_=d.filter(A=>A==a).length,m=d.filter(A=>A==i).length,w=[],x=0,E=_,k=m;for(let A=0;A<d.length;++A){let T=c.findIndex((J,xe)=>xe>x&&J==a),S=c.findIndex((J,xe)=>xe>x&&J==i),L=E>0&&T!==-1?T:c.length+1,O=k>0&&S!==-1?S:c.length+1,v,W,X,B;L<O?([W,X,B]=r[o.image_index],++o.image_index,--E,v=L):([W,X,B]=s[o.video_index],++o.video_index,--k,v=O);let[H,G,Q]=[Number(W),Math.floor(Number(X)/n),Math.floor(Number(B)/n)],R=v-x,C=w.length>0?Oe(w.at(-1))[0]+1:0;w.push(Array.from({length:3*R},(J,xe)=>C+xe%R));let te=R+C,ae=H*G*Q,P=Array.from({length:ae},(J,xe)=>te+Math.floor(xe/(G*Q))),N=Array.from({length:ae},(J,xe)=>te+Math.floor(xe/Q)%G),F=Array.from({length:ae},(J,xe)=>te+xe%Q);w.push([P,N,F].flat()),x=v+ae}if(x<c.length){let A=w.length>0?Oe(w.at(-1))[0]+1:0,T=c.length-x;w.push(Array.from({length:3*T},(S,L)=>A+L%T))}return w}get_rope_index(e,r,s,n){let{vision_config:o}=this.config,a=o.spatial_merge_size??2;if(r||s){let i=e.tolist();n||(n=Mc(e));let l=n.tolist(),c=Array.from({length:3},()=>Array.from({length:e.dims[0]},()=>Array.from({length:e.dims[1]},()=>0))),p=r?r.tolist():[],d=s?s.tolist():[],_={image_index:0,video_index:0},m=[];for(let w=0;w<i.length;++w){let x=i[w].filter((A,T)=>l[w][T]==1),E=this._get_multimodal_rope_positions({filtered_ids:x,image_grid_thw_list:p,video_grid_thw_list:d,spatial_merge_size:a,state:_}),k=this._reorder_and_write_positions(E,l[w],c,w);m.push(Oe(k)[0]+1-i[w].length)}return[new $("int64",c.flat(1/0),[3,e.dims[0],e.dims[1]]),new $("int64",m,[m.length,1])]}else return this._get_text_only_rope_index(e,n)}async encode_image({pixel_values:e,image_grid_thw:r}){return(await de(this.sessions.vision_encoder,{pixel_values:e,[this.image_grid_thw_name]:r})).image_features}_merge_input_ids_with_image_features(e){return In({image_token_id:this.config.image_token_id,...e})}prepare_inputs_for_generation(e,r,s){if(r.attention_mask&&!r.position_ids)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;let n=r.past_key_values.get_seq_length();if(n<r.input_ids.dims[1]){let[o,a]=this.get_rope_index(r.input_ids,r.image_grid_thw,r.video_grid_thw,r.attention_mask);r.rope_deltas=a,r.position_ids=o.slice(null,null,[n,null]),r.input_ids=r.input_ids.slice(null,[n,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));let o=BigInt(n),a=r.rope_deltas.map(i=>o+i);r.position_ids=St([a,a,a],0)}}return r}},Ps=class extends Rn{};var zs=class extends Rn{image_grid_thw_name="image_grid_thw"},Ns=class extends Ps{image_grid_thw_name="image_grid_thw"};var Ow=class extends zs{get_vision_position_ids(e,r,s,n){let o=Math.floor(r[0]/s),a=Math.floor(r[1]/n),i=Math.floor(r[2]/n),l=a*i*o,c=Array.from({length:l},()=>e),p=Array.from({length:l},(_,m)=>e+Math.floor(m/(i*o))),d=Array.from({length:l},(_,m)=>e+m%i);return[...c,...p,...d]}_get_multimodal_rope_positions({filtered_ids:e,image_grid_thw_list:r,video_grid_thw_list:s,spatial_merge_size:n,state:o}){let{image_token_id:a}=this.config,i=[],l=0,c=e[0]==a?1:0;for(let _=1;_<=e.length;++_){let m=_<e.length?e[_]==a?1:0:-1;m!==c&&(i.push([c,l,_]),l=_,c=m)}let p=0,d=[];for(let[_,m,w]of i)if(_===0){let x=w-m;d.push(Array.from({length:3*x},(E,k)=>p+k%x)),p+=x}else{let x=r[o.image_index++].map(Number),E=x[0];d.push(this.get_vision_position_ids(p,x,E,n)),p+=Math.max(x[1],x[2])/n}return d}};var Ca=class extends y{},Iw=class extends Ca{},Cw=class extends Ca{};var La=class extends y{},Lw=class extends La{},Pw=class extends La{};var Pa=class extends y{},zw=class extends Pa{},Nw=class extends Pa{};var za=class extends y{},$w=class extends za{},Rw=class extends za{};var Na=class extends y{},Dw=class extends Na{},Fw=class extends Na{};var $a=class extends y{},Bw=class extends $a{},Uw=class extends $a{};var Ra=class extends y{},jw=class extends Ra{},Gw=class extends Ra{};var Da=class extends y{},qw=class extends Da{},Ww=class extends Da{};var Fa=class extends y{},Vw=class extends Fa{},Hw=class extends Fa{};var Iu=class extends y{forward_params=["input_ids","attention_mask","position_ids","audio_values","past_key_values"]},$s=class extends Iu{_merge_input_ids_with_audio_features(e){let r=e.audio_features.dims.at(-1),s=e.audio_features.view(-1,r);return _u({audio_token_id:this.config.ignore_index??this.config.audio_token_id??this.config.audio_token_index,...e,audio_features:s})}};var Xw=class extends $s{forward_params=["input_ids","attention_mask","input_features","past_key_values"]};var Cu=class extends y{},Kw=class extends Cu{};var Lu=class extends y{},Qw=class extends Lu{};var Ba=class extends y{},Yw=class extends Ba{},Jw=class extends Ba{};var Ua=class extends y{},Zw=class extends Ua{},ex=class extends Ua{async _call(e){return new j(await super._call(e))}};var Zt=class extends y{},tx=class extends Zt{},rx=class extends Zt{async _call(e){return new bt(await super._call(e))}},sx=class extends Zt{async _call(e){return new j(await super._call(e))}},nx=class extends Zt{async _call(e){return new he(await super._call(e))}};var ox=class extends y{},ax=class extends Zt{},ix=class extends Zt{async _call(e){return new bt(await super._call(e))}},lx=class extends Zt{async _call(e){return new j(await super._call(e))}};var ja=class extends y{},cx=class extends ja{},ux=class extends ja{};var Pu=class extends y{forward_params=["input_ids","attention_mask","pixel_values","position_ids","past_key_values"]},Ot=class extends Pu{_merge_input_ids_with_image_features(e){let r=e.image_features.dims.at(-1),s=e.image_features.view(-1,r);return In({image_token_id:this.config.image_token_index??this.config.image_token_id,...e,image_features:s})}},px=class extends Ot{},dx=class extends Ot{};var fx=class extends Ot{forward_params=["input_ids","attention_mask","pixel_values","pixel_attention_mask","position_ids","past_key_values"]};var Ga=class extends y{},_x=class extends Ga{},mx=class extends Ga{async _call(e){return new j(await super._call(e))}};var qa=class extends y{},hx=class extends qa{},gx=class extends qa{};var Dn=class extends y{},wx=class extends Dn{async forward(e){let r=!e.input_ids,s=!e.pixel_values;if(r&&s)throw new Error("Either `input_ids` or `pixel_values` should be provided.");if(r&&(e.input_ids=tt([e.pixel_values.dims[0],1])),s){let{image_size:c}=this.config.vision_config;e.pixel_values=He([0,3,c,c],0)}let{text_embeddings:n,image_embeddings:o,l2norm_text_embeddings:a,l2norm_image_embeddings:i}=await super.forward(e),l={};return r||(l.text_embeddings=n,l.l2norm_text_embeddings=a),s||(l.image_embeddings=o,l.l2norm_image_embeddings=i),l}},Wa=class extends Dn{static async from_pretrained(e,r={}){return super.from_pretrained(e,{...r,model_file_name:r.model_file_name??"text_model"})}},xx=class extends Dn{static async from_pretrained(e,r={}){return super.from_pretrained(e,{...r,model_file_name:r.model_file_name??"vision_model"})}};var Va=class extends y{},yx=class extends Va{},bx=class extends Va{};var vx=class extends Ot{};var Ha=class extends y{},kx=class extends Ha{},Ex=class extends Ha{};var Ax=class extends Ot{forward_params=["input_ids","attention_mask","pixel_values","pixel_attention_mask","spatial_shapes","position_ids","past_key_values"]};var Xa=class extends y{},Mx=class extends Xa{},Sx=class extends Xa{};var zu=class extends y{},Tx=class extends zu{};var Ka=class extends y{},Ox=class extends Ka{},Ix=class extends Ka{};var Qa=class extends y{},Cx=class extends Qa{},Lx=class extends Qa{};var Ya=class extends y{},Px=class extends Ya{},zx=class extends Ya{};var Ja=class extends y{},Nx=class extends Ja{},$x=class extends Ja{};var Rs=class extends y{},Rx=class extends Rs{},Dx=class extends Rs{},Fx=class extends Rs{async _call(e){return new j(await super._call(e))}},Bx=class extends Rs{};var Nu=class extends y{},Ux=class extends Nu{};var $u=class extends y{},jx=class extends $u{};var Ru=class extends $e{constructor({char_logits:e,bpe_logits:r,wp_logits:s}){super(),this.char_logits=e,this.bpe_logits=r,this.wp_logits=s}get logits(){return[this.char_logits,this.bpe_logits,this.wp_logits]}},Du=class extends y{},Gx=class extends Du{async _call(e){return new Ru(await super._call(e))}};var Fu=class extends $e{constructor({audio_codes:e}){super(),this.audio_codes=e}},Bu=class extends $e{constructor({audio_values:e}){super(),this.audio_values=e}},Fn=class extends y{main_input_name="input_values";forward_params=["input_values"]},qx=class extends Fn{async encode(e){return new Fu(await de(this.sessions.encoder_model,e))}async decode(e){return new Bu(await de(this.sessions.decoder_model,e))}},Za=class extends Fn{static async from_pretrained(e,r={}){return super.from_pretrained(e,{...r,model_file_name:r.model_file_name??"encoder_model"})}},ei=class extends Fn{static async from_pretrained(e,r={}){return super.from_pretrained(e,{...r,model_file_name:r.model_file_name??"decoder_model"})}};var ti=class extends y{},Wx=class extends ti{},Vx=class extends ti{};var ri=class extends y{},Hx=class extends ri{},Xx=class extends ri{};var Ds=class extends y{},Kx=class extends Ds{},Qx=class extends Ds{async _call(e){return new ge(await super._call(e))}},Yx=class extends Ds{async _call(e){return new j(await super._call(e))}},Jx=class extends Ds{async _call(e){return new Ae(await super._call(e))}};var si=class extends y{},Zx=class extends si{},ey=class extends si{};var Bn=class extends y{},ty=class extends Bn{},ry=class extends Bn{async _call(e){return new j(await super._call(e))}},sy=class extends Bn{};var Un=class extends y{},ny=class extends Un{},oy=class extends Un{async _call(e){return new j(await super._call(e))}},ay=class extends Un{};var jn=class extends y{},iy=class extends jn{},ly=class extends jn{async _call(e){return new j(await super._call(e))}},cy=class extends jn{};var Gn=class extends y{},uy=class extends Gn{},py=class extends Gn{async _call(e){return new j(await super._call(e))}},dy=class extends Gn{};var ni=class extends y{},fy=class extends ni{},_y=class extends ni{async _call(e){return new j(await super._call(e))}};var oi=class extends y{},my=class extends oi{},hy=class extends oi{async _call(e){return new j(await super._call(e))}};var Fs=class extends y{},gy=class extends Fs{},wy=class extends Fs{async _call(e){return new ge(await super._call(e))}},xy=class extends Fs{async _call(e){return new j(await super._call(e))}},yy=class extends Fs{async _call(e){return new he(await super._call(e))}};var ai=class extends y{},by=class extends ai{},vy=class extends ai{};var ii=class extends y{requires_attention_mask=!1;main_input_name="input_values";forward_params=["input_values","decoder_input_ids","past_key_values"]},ky=class extends ii{},Ey=class extends ii{};var Yr=class extends y{},Ay=class extends Yr{},My=class extends Yr{async _call(e){return new ge(await super._call(e))}},Sy=class extends Yr{async _call(e){return new j(await super._call(e))}},Ty=class extends Yr{async _call(e){return new he(await super._call(e))}},Oy=class extends Yr{async _call(e){return new Ae(await super._call(e))}};var li=class extends y{},Iy=class extends li{},Cy=class extends li{};var ci=class extends y{},Ly=class extends ci{},Py=class extends ci{};var Uu=class extends y{},zy=class extends Uu{forward_params=["input_ids","pixel_values","images_seq_mask","images_emb_mask","attention_mask","position_ids","past_key_values"];constructor(...e){super(...e),this._generation_mode="text"}async forward(e){let r=this._generation_mode??"text",s;if(r==="text"||!e.past_key_values){let l=this.sessions.prepare_inputs_embeds,c=Ke(e,l.inputNames);s=await de(l,c)}else{let l=this.sessions.gen_img_embeds,c=Ke({image_ids:e.input_ids},l.inputNames);s=await de(l,c)}let n={...e,...s},o=await Tt(this,n),a=this.sessions[r==="text"?"lm_head":"gen_head"];if(!a)throw new Error(`Unable to find "${a}" generation head`);let i=await de(a,Ke(o,a.inputNames));return{...s,...o,...i}}prepare_inputs_for_generation(e,r,s){let n=!!r.past_key_values;return s.guidance_scale!==null&&s.guidance_scale>1&&(n?r.input_ids=ke([r.input_ids,r.input_ids],0):(r.input_ids=ke([r.input_ids,Oo(r.input_ids,BigInt(s.pad_token_id))],0),r.attention_mask=ke([r.attention_mask,Oo(r.attention_mask,0n)],0))),(n||!r.pixel_values)&&(r.pixel_values=He([0,0,3,384,384],1)),n&&(r.images_seq_mask=new $("bool",new Array(1).fill(!0).fill(!1,0,1),[1,1]),r.images_emb_mask=new $("bool",new Array(0).fill(!1),[1,1,0])),r}async generate(e){return this._generation_mode="text",super.generate(e)}async generate_images(e){this._generation_mode="image";let r=(e.inputs??e[this.main_input_name]).dims[1],n=(await super.generate(e)).slice(null,[r,null]),o=this.sessions.image_decode,{decoded_image:a}=await de(o,{generated_tokens:n}),i=a.add_(1).mul_(255/2).clamp_(0,255).to("uint8"),l=[];for(let c of i){let p=Qe.fromTensor(c);l.push(p)}return l}};var ui=class extends y{},Ny=class extends ui{},$y=class extends ui{},pi=class extends y{forward_params=["input_ids","attention_mask","encoder_outputs","decoder_input_ids","decoder_attention_mask","past_key_values"];_apply_and_filter_by_delay_pattern_mask(e){let[r,s]=e.dims,n=this.config.decoder.num_codebooks,o=s-n,a=0;for(let c=0;c<e.size;++c){if(e.data[c]==this.config.decoder.pad_token_id)continue;let p=c%s,d=Math.floor(c/s)%n,_=p-d;_>0&&_<=o&&(e.data[a++]=e.data[c])}let i=Math.floor(r/n),l=a/(i*n);return new $(e.type,e.data.slice(0,a),[i,n,l])}prepare_inputs_for_generation(e,r,s){let n=BigInt(this.config.decoder.pad_token_id),o=structuredClone(e);for(let a=0;a<o.length;++a)for(let i=0;i<o[a].length;++i)a%this.config.decoder.num_codebooks>=i&&(o[a][i]=n);return s.guidance_scale!==null&&s.guidance_scale>1&&(o=o.concat(o)),Wo(this,o,r,s)}async generate(e){let r=await super.generate(e),s=this._apply_and_filter_by_delay_pattern_mask(r).unsqueeze_(0),{audio_values:n}=await de(this.sessions.encodec_decode,{audio_codes:s});return n}};var di=class extends y{},Ry=class extends di{},Dy=class extends di{};var fi=class extends y{},Fy=class extends fi{},By=class extends fi{};var Jr=class extends y{},Uy=class extends Jr{},jy=class extends Jr{async _call(e){return new ge(await super._call(e))}},Gy=class extends Jr{async _call(e){return new j(await super._call(e))}},qy=class extends Jr{async _call(e){return new he(await super._call(e))}},Wy=class extends Jr{async _call(e){return new Ae(await super._call(e))}};var ju=class extends y{},Vy=class extends ju{};var _i=class extends y{},Hy=class extends _i{},Xy=class extends _i{};var mi=class extends y{},Ky=class extends mi{},Qy=class extends mi{};var hi=class extends y{},Yy=class extends hi{},Jy=class extends hi{};var gi=class extends y{},Zy=class extends gi{},e0=class extends gi{};var wi=class extends y{},t0=class extends wi{},r0=class extends wi{};var xi=class extends y{},s0=class extends xi{},n0=class extends xi{};var yi=class extends y{},o0=class extends yi{},a0=class extends yi{};var bi=class extends y{},i0=class extends bi{},l0=class extends bi{};var c0=class extends Ot{};var Gu=class extends y{},u0=class extends Gu{async _call(e){return new bt(await super._call(e))}};var vi=class extends y{},p0=class extends vi{},d0=class extends vi{};var ki=class extends y{},f0=class extends ki{},_0=class extends ki{};var Ei=class extends y{},m0=class extends Ei{},h0=class extends Ei{};var Ai=class extends y{},g0=class extends Ai{},w0=class extends Ai{};var qu=class extends y{forward_params=["input_ids","inputs_embeds","attention_mask","position_ids","pixel_values","image_sizes","past_key_values"]},Mi=class extends qu{async forward({input_ids:e=null,attention_mask:r=null,pixel_values:s=null,image_sizes:n=null,position_ids:o=null,inputs_embeds:a=null,past_key_values:i=null,generation_config:l=null,logits_processor:c=null,...p}){if(!a){let _;if(s&&e.dims[1]!==1){if(!n)throw new Error("`image_sizes` must be provided when `pixel_values` is provided.");({image_features:_}=await de(this.sessions.vision_encoder,{pixel_values:s,image_sizes:n}))}else{let m=this.config.normalized_config.hidden_size;_=new $("float32",[],[0,m])}({inputs_embeds:a}=await de(this.sessions.prepare_inputs_embeds,{input_ids:e,image_features:_}))}return await Tt(this,{inputs_embeds:a,past_key_values:i,attention_mask:r,position_ids:o,generation_config:l,logits_processor:c},!1)}};var Si=class extends y{},x0=class extends Si{},y0=class extends Si{async _call(e){return new j(await super._call(e))}};var Ti=class extends y{},b0=class extends Ti{},v0=class extends Ti{async _call(e){return new he(await super._call(e))}};var Oi=class extends y{},k0=class extends Oi{},E0=class extends Oi{};var Ii=class extends y{},A0=class extends Ii{},M0=class extends Ii{};var Ci=class extends y{},S0=class extends Ci{},T0=class extends Ci{};var Li=class extends y{},O0=class extends Li{},I0=class extends Li{};var Pi=class extends y{},C0=class extends Pi{},L0=class extends Pi{};var Bs=class extends zs{},Us=class extends Ns{};var P0=class extends Bs{},zi=class extends Us{};var qn=class extends Bs{},js=class extends qn{};var z0=class extends qn{},Ni=class extends js{};var $i=class extends y{},N0=class extends $i{},$0=class extends $i{async _call(e){return new j(await super._call(e))}};var Ri=class extends y{},R0=class extends Ri{},D0=class extends Ri{async _call(e){return new Wu(await super._call(e))}},Wu=class extends ur{};var Zr=class extends y{},F0=class extends Zr{},B0=class extends Zr{async _call(e){return new ge(await super._call(e))}},U0=class extends Zr{async _call(e){return new j(await super._call(e))}},j0=class extends Zr{async _call(e){return new he(await super._call(e))}},G0=class extends Zr{async _call(e){return new Ae(await super._call(e))}};var es=class extends y{},q0=class extends es{},W0=class extends es{async _call(e){return new ge(await super._call(e))}},V0=class extends es{async _call(e){return new j(await super._call(e))}},H0=class extends es{async _call(e){return new he(await super._call(e))}},X0=class extends es{async _call(e){return new Ae(await super._call(e))}};var Di=class extends y{},K0=class extends Di{},Q0=class extends Di{async _call(e){return new Vu(await super._call(e))}},Vu=class extends ur{};var Hu=class extends $e{constructor({iou_scores:e,pred_masks:r}){super(),this.iou_scores=e,this.pred_masks=r}},Xu=class extends y{},Y0=class extends Xu{async get_image_embeddings({pixel_values:e}){return await jt(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??=tt(e.input_points.dims.slice(0,-1));let r={image_embeddings:e.image_embeddings,image_positional_embeddings:e.image_positional_embeddings};return e.input_points&&(r.input_points=e.input_points),e.input_labels&&(r.input_labels=e.input_labels),e.input_boxes&&(r.input_boxes=e.input_boxes),await de(this.sessions.prompt_encoder_mask_decoder,r)}async _call(e){return new Hu(await super._call(e))}};var Ku=class extends $e{constructor({iou_scores:e,pred_masks:r,object_score_logits:s}){super(),this.iou_scores=e,this.pred_masks=r,this.object_score_logits=s}},Qu=class extends y{},Fi=class extends Qu{async get_image_embeddings({pixel_values:e}){return await jt(this,{pixel_values:e})}async forward(e){let{num_feature_levels:r}=this.config.vision_config;if(Array.from({length:r},(a,i)=>`image_embeddings.${i}`).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.");let a=e.input_points.dims;e.input_labels??=tt(a.slice(0,-1)),e.input_boxes??=He([a[0],0,4],0)}else if(e.input_boxes){let a=e.input_boxes.dims;e.input_labels=He([a[0],a[1],0],-1n),e.input_points=He([a[0],1,0,2],0)}else throw new Error("At least one of `input_points` or `input_boxes` must be provided.");let n=this.sessions.prompt_encoder_mask_decoder,o=Ke(e,n.inputNames);return await de(n,o)}async _call(e){return new Ku(await super._call(e))}},J0=class extends Fi{},Z0=class extends Fi{};var Wn=class extends y{},eb=class extends Wn{},tb=class extends Wn{},rb=class extends Wn{};var Vn=class extends y{},sb=class extends Vn{},nb=class extends Vn{},ob=class extends Vn{};var Bi=class extends y{},ab=class extends Bi{},Ui=class extends Bi{static async from_pretrained(e,r={}){return super.from_pretrained(e,{...r,model_file_name:r.model_file_name??"text_model"})}},ib=class extends cr{static async from_pretrained(e,r={}){return super.from_pretrained(e,{...r,model_file_name:r.model_file_name??"vision_model"})}};var ji=class extends y{},lb=class extends ji{},cb=class extends ji{};var Hn=class extends y{main_input_name="input_values";forward_params=["input_values"]},ub=class extends Hn{async encode(e){return await de(this.sessions.encoder_model,e)}async decode(e){return await de(this.sessions.decoder_model,e)}},Gi=class extends Hn{static async from_pretrained(e,r={}){return super.from_pretrained(e,{...r,model_file_name:r.model_file_name??"encoder_model"})}},qi=class extends Hn{static async from_pretrained(e,r={}){return super.from_pretrained(e,{...r,model_file_name:r.model_file_name??"decoder_model"})}};var Wi=class extends y{},pb=class extends Wi{},db=class extends Wi{};var Xn=class extends y{},fb=class extends Xn{},_b=class extends Xn{},mb=class extends Xn{async generate_speech(e,r,{threshold:s=.5,minlenratio:n=0,maxlenratio:o=20,vocoder:a=null}={}){let i={input_ids:e},{encoder_outputs:l,encoder_attention_mask:c}=await jt(this,i),p=l.dims[1]/this.config.reduction_factor,d=Math.floor(p*o),_=Math.floor(p*n),m=this.config.num_mel_bins,w=[],x=null,E=null,k=0;for(;;){++k;let S=sh(!!E),L;E?L=E.output_sequence_out:L=new $("float32",new Float32Array(m),[1,1,m]);let O={use_cache_branch:S,output_sequence:L,encoder_attention_mask:c,speaker_embeddings:r,encoder_hidden_states:l};this.addPastKeyValues(O,x),E=await de(this.sessions.decoder_model_merged,O),x=this.getPastKeyValues(E,x);let{prob:v,spectrum:W}=E;if(w.push(W),k>=_&&(Array.from(v.data).filter(X=>X>=s).length>0||k>=d))break}let A=ke(w),{waveform:T}=await de(a.sessions.model,{spectrogram:A});return{spectrogram:A,waveform:T}}},hb=class extends y{main_input_name="spectrogram"};var Gs=class extends y{},gb=class extends Gs{},wb=class extends Gs{async _call(e){return new ge(await super._call(e))}},xb=class extends Gs{async _call(e){return new j(await super._call(e))}},yb=class extends Gs{async _call(e){return new Ae(await super._call(e))}};var Vi=class extends y{},bb=class extends Vi{},vb=class extends Vi{};var Hi=class extends y{},kb=class extends Hi{},Eb=class extends Hi{};var Yu=class extends y{},Ab=class extends Yu{};var Ju=class extends y{},Xi=class extends Ju{async generate_speech({input_ids:e,attention_mask:r,style:s,num_inference_steps:n=5,speed:o=1.05}){let{sampling_rate:a,chunk_compress_factor:i,base_chunk_size:l,latent_dim:c}=this.config,{last_hidden_state:p,durations:d}=await de(this.sessions.text_encoder,{input_ids:e,attention_mask:r,style:s}),_=d.div(o).mul_(a),m=l*i,w=_.data,x=Int32Array.from(w,B=>Math.ceil(B/m)),E=Math.max(...x),k=e.dims[0],A=new BigInt64Array(k*E);for(let B=0;B<k;++B)A.fill(1n,B*E,B*E+x[B]);let T=new $("int64",A,[k,E]),S=c*i,L=S*E,O=v2([k,S,E]),v=O.data;for(let B=0;B<k;++B)if(x[B]!==E)for(let H=0;H<S;++H)v.fill(0,B*L+H*E+x[B],B*L+(H+1)*E);let W=He([k],n);for(let B=0;B<n;++B){let H=He([k],B);({denoised_latents:O}=await de(this.sessions.latent_denoiser,{style:s,noisy_latents:O,latent_mask:T,encoder_outputs:p,attention_mask:r,timestep:H,num_inference_steps:W}))}let{waveform:X}=await de(this.sessions.voice_decoder,{latents:O});return{waveform:X,durations:_}}};var Kn=class extends y{},Mb=class extends Kn{},Sb=class extends Kn{async _call(e){return new j(await super._call(e))}},Tb=class extends Kn{};var Ki=class extends y{},Ob=class extends Ki{},Ib=class extends Ki{};var Qi=class extends y{forward_params=["input_ids","attention_mask","encoder_outputs","decoder_input_ids","decoder_attention_mask","past_key_values"]},Cb=class extends Qi{},Lb=class extends Qi{};var Yi=class extends y{},Pb=class extends Yi{},zb=class extends Yi{async _call(e){return new Zu(await super._call(e))}},Zu=class extends Nn{};var ep=class extends y{},Nb=class extends ep{};var Qn=class extends y{},$b=class extends Qn{},Rb=class extends Qn{async _call(e){return new bt(await super._call(e))}},Db=class extends Qn{async _call(e){return new j(await super._call(e))}};var qs=class extends y{},Fb=class extends qs{},Bb=class extends qs{async _call(e){return new bt(await super._call(e))}},Ub=class extends qs{async _call(e){return new j(await super._call(e))}},jb=class extends qs{async _call(e){return new he(await super._call(e))}};var Ji=class extends y{},Gb=class extends Ji{},qb=class extends Ji{};var Wb=class extends y{main_input_name="pixel_values";forward_params=["pixel_values","decoder_input_ids","encoder_hidden_states","past_key_values"]};var Zi=class extends y{},Vb=class extends Zi{},Hb=class extends Zi{async _call(e){return new j(await super._call(e))}};var tp=class extends y{},Xb=class extends tp{};var el=class extends y{},Kb=class extends el{},Qb=class extends el{async _call(e){return new j(await super._call(e))}};var rp=class extends y{},Yb=class extends rp{async _call(e){return new Zc(await super._call(e))}};var sp=class extends y{},Jb=class extends sp{};var np=class extends $e{constructor({waveform:e,spectrogram:r}){super(),this.waveform=e,this.spectrogram=r}},op=class extends y{},Zb=class extends op{async _call(e){return new np(await super._call(e))}};var e1=class extends $s{};var Z2=2,sN=1,t1=new WeakMap;function nN(t,e){let{text_config:r,audio_config:s}=t.config,n=t.sessions.audio_encoder,{num_mel_bins:o,hidden_size:a}=s,i=o+a,l=new Go,c=n?.config?.kv_cache_dtype??"float32",p=c==="float16"?xr.float16:xr.float32,d=As(s,{batch_size:1});for(let w in d){let x=d[w].reduce((E,k)=>E*k,1);l[w]=new $(c,new p(x),d[w])}let _=new $(c,new p(i*Z2),[1,i,Z2]),m=e[Symbol.asyncIterator]?.()??e[Symbol.iterator]?.();if(!m)throw new Error("input_features must be iterable or async iterable");return{encoder_session:n,enc_kv_cache:l,enc_padding_cache:_,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:m,text_hidden_size:r.hidden_size}}async function oN(t,e){let r=e.dims[2],s=Math.floor((sN+r-3)/2)+1,n=new $("int64",BigInt64Array.from({length:s},(p,d)=>BigInt(t.enc_past_seq_len+d)),[1,s]),o=t.enc_past_seq_len+s,a=tt([1,o]),{audio_embeds:i,present_padding_cache:l,...c}=await de(t.encoder_session,{input_features:e,attention_mask:a,position_ids:n,past_padding_cache:t.enc_padding_cache,...t.enc_kv_cache});t.enc_padding_cache.location==="gpu-buffer"&&t.enc_padding_cache.dispose(),t.enc_padding_cache=l;for(let p in c)if(p.startsWith("present.")){let d=p.replace("present","past_key_values"),_=t.enc_kv_cache[d];_?.location==="gpu-buffer"&&_.dispose(),t.enc_kv_cache[d]=c[p]}return t.enc_past_seq_len=o,i}async function aN(t,e){for(;t.audio_embed_total_tokens<e&&!t.stream_exhausted;){let r=await t.chunks_iter.next();if(r.done){t.stream_exhausted=!0;break}let s=await oN(t,r.value);t.audio_embed_queue.push({data:s.data,tokens:s.dims[1]}),t.audio_embed_total_tokens+=s.dims[1]}}function iN(t,e,r){if(t.audio_embed_queue.length===0)return;let s=e.data,n=0,o=r;for(;o>0&&t.audio_embed_queue.length>0;){let a=t.audio_embed_queue[0],i=a.tokens-t.audio_queue_offset,l=Math.min(o,i),c=t.audio_queue_offset*t.text_hidden_size;for(let p=0;p<l*t.text_hidden_size;++p)s[n*t.text_hidden_size+p]+=a.data[c+p];n+=l,o-=l,t.audio_queue_offset+=l,t.audio_queue_offset>=a.tokens&&(t.audio_embed_queue.shift(),t.audio_queue_offset=0)}t.audio_consumed+=r-o}var r1=class extends Gr{constructor(e){super(),this._s=e}_call(e){let r=this._s.stream_exhausted&&this._s.audio_embed_queue.length===0;return e.map(()=>r)}},ap=class extends y{forward_params=["input_ids","attention_mask","position_ids","past_key_values"]},tl=class extends ap{async forward({input_ids:e,past_key_values:r,...s}){let n=e.dims[1],o=t1.get(this);o&&await aN(o,o.audio_consumed+n);let{inputs_embeds:a}=await de(this.sessions.embed_tokens,{input_ids:e});o&&iN(o,a,n);let i={inputs_embeds:a,...s};this.addPastKeyValues(i,r);let l=this.sessions.decoder_model_merged,c=Ke(i,l.inputNames);return await de(l,c)}async generate({input_features:e,stopping_criteria:r,...s}){if(!e)throw new Error("input_features (generator/iterable) must be provided");let n=nN(this,e);t1.set(this,n);let o=new Sn;o.push(new r1(n)),r&&o.extend(r);try{return await super.generate({...s,stopping_criteria:o})}finally{n.enc_kv_cache.dispose(),t1.delete(this)}}};var Yn=class extends y{},s1=class extends Yn{},n1=class extends Yn{async _call(e){return new bt(await super._call(e))}},o1=class extends Yn{async _call(e){return new j(await super._call(e))}};var ip=class extends $e{constructor({logits:e,embeddings:r}){super(),this.logits=e,this.embeddings=r}},ts=class extends y{},a1=class extends ts{},i1=class extends ts{async _call(e){return new bt(await super._call(e))}},l1=class extends ts{async _call(e){return new j(await super._call(e))}},c1=class extends ts{async _call(e){return new ip(await super._call(e))}},u1=class extends ts{async _call(e){return new he(await super._call(e))}};var lp=class extends y{},p1=class extends lp{};var cp=class extends Mn{return_timestamps=null;return_token_timestamps=null;num_frames=null;alignment_heads=null;task=null;language=null;no_timestamps_token_id=null;prompt_ids=null;is_multilingual=null;lang_to_id=null;task_to_id=null;max_initial_timestamp_index=1};var rl=class extends y{requires_attention_mask=!1;main_input_name="input_features";forward_params=["input_features","attention_mask","decoder_input_ids","decoder_attention_mask","past_key_values"]},d1=class extends rl{},up=class extends rl{_prepare_generation_config(e,r){return super._prepare_generation_config(e,r,cp)}_retrieve_init_tokens(e){let r=[e.decoder_start_token_id],s=e.language,n=e.task;if(e.is_multilingual){s||(Z.warn("No language specified - defaulting to English (en)."),s="en");let a=`<|${A2(s)}|>`;r.push(e.lang_to_id[a]),r.push(e.task_to_id[n??"transcribe"])}else if(s||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&&r.at(-1)!==e.no_timestamps_token_id?r.push(e.no_timestamps_token_id):e.return_timestamps&&r.at(-1)===e.no_timestamps_token_id&&(Z.warn("<|notimestamps|> prompt token is removed from generation_config since `return_timestamps` is set to `true`."),r.pop()),r.filter(o=>o!=null)}async generate({inputs:e=null,generation_config:r=null,logits_processor:s=null,stopping_criteria:n=null,...o}){r=this._prepare_generation_config(r,o);let a=o.decoder_input_ids??this._retrieve_init_tokens(r);if(r.return_timestamps&&(s??=new Ms,s.push(new ru(r,a))),r.begin_suppress_tokens&&(s??=new Ms,s.push(new An(r.begin_suppress_tokens,a.length))),r.return_token_timestamps){if(!r.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.");r.task==="translate"&&Z.warn("Token-level timestamps may not be reliable for task 'translate'."),r.output_attentions=!0,r.return_dict_in_generate=!0}let i=await super.generate({inputs:e,generation_config:r,logits_processor:s,decoder_input_ids:a,...o});return r.return_token_timestamps&&(i.token_timestamps=this._extract_token_timestamps(i,r.alignment_heads,r.num_frames)),i}_extract_token_timestamps(e,r,s=null,n=.02){if(!e.cross_attentions)throw new Error("Model outputs must contain cross attentions to extract timestamps. This is most likely because the model was not exported with `output_attentions=True`.");s==null&&Z.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 o=this.config.median_filter_width;o===void 0&&(Z.warn("Model config has no `median_filter_width`, using default value of 7."),o=7);let a=e.cross_attentions,i=Array.from({length:this.config.decoder_layers},(x,E)=>ke(a.map(k=>k[E]),2)),l=St(r.map(([x,E])=>{if(x>=i.length)throw new Error(`Layer index ${x} is out of bounds for cross attentions (length ${i.length}).`);return s?i[x].slice(null,E,null,[0,s]):i[x].slice(null,E)})).transpose(1,0,2,3),[c,p]=xf(l,-2,0,!0),d=l.clone();for(let x=0;x<d.dims[0];++x){let E=d[x];for(let k=0;k<E.dims[0];++k){let A=E[k],T=c[x][k][0].data,S=p[x][k][0].data;for(let L=0;L<A.dims[0];++L){let O=A[L].data;for(let v=0;v<O.length;++v)O[v]=(O[v]-S[v])/T[v];O.set(NE(O,o))}}}let _=[Ac(d,1)],m=e.sequences.dims,w=new $("float32",new Float32Array(m[0]*m[1]),m);for(let x=0;x<m[0];++x){let E=_[x].neg().squeeze_(0),[k,A]=RE(E.tolist()),T=Array.from({length:k.length-1},(O,v)=>k[v+1]-k[v]),S=ht([1],T).map(O=>!!O),L=[];for(let O=0;O<S.length;++O)S[O]&&L.push(A[O]*n);w[x].data.set(L,1)}return w}},f1=class extends up{};var rs=class extends y{},_1=class extends rs{},m1=class extends rs{async _call(e){return new ge(await super._call(e))}},h1=class extends rs{async _call(e){return new j(await super._call(e))}},g1=class extends rs{async _call(e){return new he(await super._call(e))}},w1=class extends rs{async _call(e){return new Ae(await super._call(e))}};var ss=class extends y{},x1=class extends ss{},y1=class extends ss{async _call(e){return new ge(await super._call(e))}},b1=class extends ss{async _call(e){return new j(await super._call(e))}},v1=class extends ss{async _call(e){return new he(await super._call(e))}},k1=class extends ss{async _call(e){return new Ae(await super._call(e))}};var sl=class extends y{},E1=class extends sl{},A1=class extends sl{async _call(e){return new pp(await super._call(e))}},pp=class extends $e{constructor({logits:e,pred_boxes:r}){super(),this.logits=e,this.pred_boxes=r}};var nl=class extends y{},M1=class extends nl{},S1=class extends nl{};var lN=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"]]),cN=new Map([["t5","T5Model"],["longt5","LongT5Model"],["mt5","MT5Model"],["bart","BartModel"],["mbart","MBartModel"],["marian","MarianModel"],["whisper","WhisperModel"],["m2m_100","M2M100Model"],["blenderbot","BlenderbotModel"],["blenderbot-small","BlenderbotSmallModel"]]),uN=new Map([["mimi","MimiModel"],["dac","DacModel"],["snac","SnacModel"]]),pN=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"]]),eM=new Map([["speecht5","SpeechT5ForSpeechToText"],["whisper","WhisperForConditionalGeneration"],["lite-whisper","LiteWhisperForConditionalGeneration"],["moonshine","MoonshineForConditionalGeneration"]]),tM=new Map([["speecht5","SpeechT5ForTextToSpeech"]]),rM=new Map([["vits","VitsModel"],["musicgen","MusicgenForConditionalGeneration"],["supertonic","SupertonicForConditionalGeneration"]]),sM=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"]]),nM=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"]]),oM=new Map([["t5","T5ForConditionalGeneration"],["longt5","LongT5ForConditionalGeneration"],["mt5","MT5ForConditionalGeneration"],["bart","BartForConditionalGeneration"],["mbart","MBartForConditionalGeneration"],["marian","MarianMTModel"],["m2m_100","M2M100ForConditionalGeneration"],["blenderbot","BlenderbotForConditionalGeneration"],["blenderbot-small","BlenderbotSmallForConditionalGeneration"]]),aM=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_moe","Qwen3_5MoeForCausalLM"],["gemma3n","Gemma3nForCausalLM"],["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"]]),dN=new Map([["multi_modality","MultiModalityCausalLM"]]),iM=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"]]),lM=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"]]),cM=new Map([["vision-encoder-decoder","VisionEncoderDecoderModel"],["idefics3","Idefics3ForConditionalGeneration"],["smolvlm","SmolVLMForConditionalGeneration"]]),uM=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"],["gemma3n","Gemma3nForConditionalGeneration"],["mistral3","Mistral3ForConditionalGeneration"],["lighton_ocr","LightOnOcrForConditionalGeneration"],["glm_ocr","GlmOcrForConditionalGeneration"]]),pM=new Map([["granite_speech","GraniteSpeechForConditionalGeneration"],["ultravox","UltravoxModel"],["voxtral","VoxtralForConditionalGeneration"],["voxtral_realtime","VoxtralRealtimeForConditionalGeneration"]]),fN=new Map([["vision-encoder-decoder","VisionEncoderDecoderModel"]]),dM=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"]]),fM=new Map([["detr","DetrForObjectDetection"],["rt_detr","RTDetrForObjectDetection"],["rt_detr_v2","RTDetrV2ForObjectDetection"],["rf_detr","RFDetrForObjectDetection"],["d_fine","DFineForObjectDetection"],["table-transformer","TableTransformerForObjectDetection"],["yolos","YolosForObjectDetection"]]),_M=new Map([["owlvit","OwlViTForObjectDetection"],["owlv2","Owlv2ForObjectDetection"],["grounding-dino","GroundingDinoForObjectDetection"]]),Jn=new Map([["detr","DetrForSegmentation"],["clipseg","CLIPSegForImageSegmentation"]]),mM=new Map([["segformer","SegformerForSemanticSegmentation"],["sapiens","SapiensForSemanticSegmentation"],["swin","SwinForSemanticSegmentation"],["mobilenet_v1","MobileNetV1ForSemanticSegmentation"],["mobilenet_v2","MobileNetV2ForSemanticSegmentation"],["mobilenet_v3","MobileNetV3ForSemanticSegmentation"],["mobilenet_v4","MobileNetV4ForSemanticSegmentation"]]),hM=new Map([["detr","DetrForSegmentation"],["maskformer","MaskFormerForInstanceSegmentation"]]),gM=new Map([["sam","SamModel"],["sam2","Sam2Model"],["edgetam","EdgeTamModel"],["sam3_tracker","Sam3TrackerModel"]]),wM=new Map([["wav2vec2","Wav2Vec2ForCTC"],["wav2vec2-bert","Wav2Vec2BertForCTC"],["unispeech","UniSpeechForCTC"],["unispeech-sat","UniSpeechSatForCTC"],["wavlm","WavLMForCTC"],["hubert","HubertForCTC"],["parakeet_ctc","ParakeetForCTC"]]),xM=new Map([["wav2vec2","Wav2Vec2ForSequenceClassification"],["wav2vec2-bert","Wav2Vec2BertForSequenceClassification"],["unispeech","UniSpeechForSequenceClassification"],["unispeech-sat","UniSpeechSatForSequenceClassification"],["wavlm","WavLMForSequenceClassification"],["hubert","HubertForSequenceClassification"],["audio-spectrogram-transformer","ASTForAudioClassification"]]),yM=new Map([["wavlm","WavLMForXVector"]]),bM=new Map([["unispeech-sat","UniSpeechSatForAudioFrameClassification"],["wavlm","WavLMForAudioFrameClassification"],["wav2vec2","Wav2Vec2ForAudioFrameClassification"],["pyannote","PyAnnoteForAudioFrameClassification"]]),vM=new Map([["vitmatte","VitMatteForImageMatting"]]),_N=new Map([["patchtst","PatchTSTForPrediction"],["patchtsmixer","PatchTSMixerForPrediction"]]),kM=new Map([["swin2sr","Swin2SRForImageSuperResolution"]]),EM=new Map([["chmv2","CHMv2ForDepthEstimation"],["dpt","DPTForDepthEstimation"],["depth_anything","DepthAnythingForDepthEstimation"],["glpn","GLPNForDepthEstimation"],["sapiens","SapiensForDepthEstimation"],["depth_pro","DepthProForDepthEstimation"],["metric3d","Metric3DForDepthEstimation"],["metric3dv2","Metric3Dv2ForDepthEstimation"]]),AM=new Map([["sapiens","SapiensForNormalEstimation"]]),MM=new Map([["vitpose","VitPoseForPoseEstimation"]]),SM=new Map([["clip","CLIPVisionModelWithProjection"],["siglip","SiglipVisionModel"],["jina_clip","JinaCLIPVisionModel"]]),T1=[[lN,K.EncoderOnly],[cN,K.EncoderDecoder],[pN,K.DecoderOnlyWithoutHead],[uN,K.AutoEncoder],[sM,K.EncoderOnly],[nM,K.EncoderOnly],[oM,K.Seq2Seq],[eM,K.Seq2Seq],[aM,K.DecoderOnly],[dN,K.MultiModality],[iM,K.EncoderOnly],[lM,K.EncoderOnly],[cM,K.Vision2Seq],[uM,K.ImageTextToText],[pM,K.AudioTextToText],[dM,K.EncoderOnly],[Jn,K.EncoderOnly],[hM,K.EncoderOnly],[mM,K.EncoderOnly],[vM,K.EncoderOnly],[_N,K.EncoderOnly],[kM,K.EncoderOnly],[EM,K.EncoderOnly],[AM,K.EncoderOnly],[MM,K.EncoderOnly],[fM,K.EncoderOnly],[_M,K.EncoderOnly],[gM,K.MaskGeneration],[wM,K.EncoderOnly],[xM,K.EncoderOnly],[tM,K.Seq2Seq],[rM,K.EncoderOnly],[yM,K.EncoderOnly],[bM,K.EncoderOnly],[SM,K.EncoderOnly]];for(let[t,e]of T1)for(let r of t.values()){Jt.set(r,e);let s=ol[r];Os.set(s,r),fu.set(r,s)}var mN=[["MusicgenForConditionalGeneration",pi,K.Musicgen],["Phi3VForCausalLM",Mi,K.Phi3V],["CLIPTextModelWithProjection",sa,K.EncoderOnly],["SiglipTextModel",Ui,K.EncoderOnly],["JinaCLIPTextModel",Wa,K.EncoderOnly],["ClapTextModelWithProjection",ta,K.EncoderOnly],["ClapAudioModelWithProjection",ra,K.EncoderOnly],["DacEncoderModel",da,K.EncoderOnly],["DacDecoderModel",fa,K.EncoderOnly],["MimiEncoderModel",Za,K.EncoderOnly],["MimiDecoderModel",ei,K.EncoderOnly],["SnacEncoderModel",Gi,K.EncoderOnly],["SnacDecoderModel",qi,K.EncoderOnly],["Gemma3nForConditionalGeneration",$n,K.ImageAudioTextToText],["SupertonicForConditionalGeneration",Xi,K.Supertonic],["ChatterboxModel",ea,K.Chatterbox],["Qwen2VLForCausalLM",Ps,K.MultimodalLanguageModelOnly],["Qwen2_5_VLForCausalLM",Ns,K.MultimodalLanguageModelOnly],["Qwen3VLForCausalLM",Us,K.MultimodalLanguageModelOnly],["Qwen3VLMoeForCausalLM",zi,K.MultimodalLanguageModelOnly],["Qwen3_5ForCausalLM",js,K.MultimodalLanguageModelOnly],["Qwen3_5MoeForCausalLM",Ni,K.MultimodalLanguageModelOnly],["Gemma3nForCausalLM",Ta,K.MultimodalLanguageModelOnly],["VoxtralRealtimeForConditionalGeneration",tl,K.VoxtralRealtime]];for(let[t,e,r]of mN)Jt.set(t,r),Os.set(e,t),fu.set(t,e);var TM=new Map([["modnet",Jn],["birefnet",Jn],["isnet",Jn],["ben",Jn]]);for(let[t,e]of TM.entries())e.set(t,"PreTrainedModel"),Jt.set(t,K.EncoderOnly),fu.set(t,y);var OM=new Set(TM.keys());Jt.set("PreTrainedModel",K.EncoderOnly);Os.set(y,"PreTrainedModel");var Le={MODEL_FOR_SEQUENCE_CLASSIFICATION_MAPPING_NAMES:sM,MODEL_FOR_TOKEN_CLASSIFICATION_MAPPING_NAMES:nM,MODEL_FOR_TEXT_TO_SPECTROGRAM_MAPPING_NAMES:tM,MODEL_FOR_TEXT_TO_WAVEFORM_MAPPING_NAMES:rM,MODEL_FOR_MASKED_LM_MAPPING_NAMES:iM,MODEL_FOR_QUESTION_ANSWERING_MAPPING_NAMES:lM,MODEL_FOR_IMAGE_CLASSIFICATION_MAPPING_NAMES:dM,MODEL_FOR_IMAGE_SEGMENTATION_MAPPING_NAMES:Jn,MODEL_FOR_SEMANTIC_SEGMENTATION_MAPPING_NAMES:mM,MODEL_FOR_UNIVERSAL_SEGMENTATION_MAPPING_NAMES:hM,MODEL_FOR_OBJECT_DETECTION_MAPPING_NAMES:fM,MODEL_FOR_ZERO_SHOT_OBJECT_DETECTION_MAPPING_NAMES:_M,MODEL_FOR_MASK_GENERATION_MAPPING_NAMES:gM,MODEL_FOR_CTC_MAPPING_NAMES:wM,MODEL_FOR_AUDIO_CLASSIFICATION_MAPPING_NAMES:xM,MODEL_FOR_AUDIO_XVECTOR_MAPPING_NAMES:yM,MODEL_FOR_AUDIO_FRAME_CLASSIFICATION_MAPPING_NAMES:bM,MODEL_FOR_DOCUMENT_QUESTION_ANSWERING_MAPPING_NAMES:fN,MODEL_FOR_IMAGE_MATTING_MAPPING_NAMES:vM,MODEL_FOR_IMAGE_TO_IMAGE_MAPPING_NAMES:kM,MODEL_FOR_DEPTH_ESTIMATION_MAPPING_NAMES:EM,MODEL_FOR_NORMAL_ESTIMATION_MAPPING_NAMES:AM,MODEL_FOR_POSE_ESTIMATION_MAPPING_NAMES:MM,MODEL_FOR_IMAGE_FEATURE_EXTRACTION_MAPPING_NAMES:SM,MODEL_FOR_IMAGE_TEXT_TO_TEXT_MAPPING_NAMES:uM,MODEL_FOR_AUDIO_TEXT_TO_TEXT_MAPPING_NAMES:pM,MODEL_FOR_SEQ_TO_SEQ_CAUSAL_LM_MAPPING_NAMES:oM,MODEL_FOR_SPEECH_SEQ_2_SEQ_MAPPING_NAMES:eM,MODEL_FOR_CAUSAL_LM_MAPPING_NAMES:aM,MODEL_FOR_VISION_2_SEQ_MAPPING_NAMES:cM};X2(Le);var Te=class{static MODEL_CLASS_MAPPINGS=null;static BASE_IF_FAIL=!1;static supports(e){if(!this.MODEL_CLASS_MAPPINGS)return!1;for(let r of this.MODEL_CLASS_MAPPINGS)if(r.has(e))return!0;return this.BASE_IF_FAIL}static async from_pretrained(e,{progress_callback:r=null,config:s=null,cache_dir:n=null,local_files_only:o=!1,revision:a="main",model_file_name:i=null,subfolder:l="onnx",device:c=null,dtype:p=null,use_external_data_format:d=null,session_options:_={}}={}){let m={progress_callback:r,config:s,cache_dir:n,local_files_only:o,revision:a,model_file_name:i,subfolder:l,device:c,dtype:p,use_external_data_format:d,session_options:_};if(m.config=await Bt.from_pretrained(e,m),!this.MODEL_CLASS_MAPPINGS)throw new Error("`MODEL_CLASS_MAPPINGS` not implemented for this type of `AutoClass`: "+this.name);let{model_type:w}=m.config;for(let x of this.MODEL_CLASS_MAPPINGS){let E=x.get(w);if(!E){for(let k of x.values())if(k[0]===w){E=k;break}if(!E)continue}return await ol[E].from_pretrained(e,m)}if(this.BASE_IF_FAIL)return OM.has(w)||Z.warn(`Unknown model class "${w}", attempting to construct from base class.`),await y.from_pretrained(e,m);throw Error(`Unsupported model type: ${w}`)}},br=class extends Te{static MODEL_CLASS_MAPPINGS=T1.map(e=>e[0]);static BASE_IF_FAIL=!0},al=class extends Te{static MODEL_CLASS_MAPPINGS=[Le.MODEL_FOR_SEQUENCE_CLASSIFICATION_MAPPING_NAMES]},dp=class extends Te{static MODEL_CLASS_MAPPINGS=[Le.MODEL_FOR_TOKEN_CLASSIFICATION_MAPPING_NAMES]},Zn=class extends Te{static MODEL_CLASS_MAPPINGS=[Le.MODEL_FOR_SEQ_TO_SEQ_CAUSAL_LM_MAPPING_NAMES]},fp=class extends Te{static MODEL_CLASS_MAPPINGS=[Le.MODEL_FOR_SPEECH_SEQ_2_SEQ_MAPPING_NAMES]},_p=class extends Te{static MODEL_CLASS_MAPPINGS=[Le.MODEL_FOR_TEXT_TO_SPECTROGRAM_MAPPING_NAMES]},mp=class extends Te{static MODEL_CLASS_MAPPINGS=[Le.MODEL_FOR_TEXT_TO_WAVEFORM_MAPPING_NAMES]},hp=class extends Te{static MODEL_CLASS_MAPPINGS=[Le.MODEL_FOR_CAUSAL_LM_MAPPING_NAMES]},gp=class extends Te{static MODEL_CLASS_MAPPINGS=[Le.MODEL_FOR_MASKED_LM_MAPPING_NAMES]},wp=class extends Te{static MODEL_CLASS_MAPPINGS=[Le.MODEL_FOR_QUESTION_ANSWERING_MAPPING_NAMES]},xp=class extends Te{static MODEL_CLASS_MAPPINGS=[Le.MODEL_FOR_VISION_2_SEQ_MAPPING_NAMES]},yp=class extends Te{static MODEL_CLASS_MAPPINGS=[Le.MODEL_FOR_IMAGE_CLASSIFICATION_MAPPING_NAMES]},il=class extends Te{static MODEL_CLASS_MAPPINGS=[Le.MODEL_FOR_IMAGE_SEGMENTATION_MAPPING_NAMES]},ll=class extends Te{static MODEL_CLASS_MAPPINGS=[Le.MODEL_FOR_SEMANTIC_SEGMENTATION_MAPPING_NAMES]},cl=class extends Te{static MODEL_CLASS_MAPPINGS=[Le.MODEL_FOR_UNIVERSAL_SEGMENTATION_MAPPING_NAMES]},bp=class extends Te{static MODEL_CLASS_MAPPINGS=[Le.MODEL_FOR_OBJECT_DETECTION_MAPPING_NAMES]},vp=class extends Te{static MODEL_CLASS_MAPPINGS=[Le.MODEL_FOR_ZERO_SHOT_OBJECT_DETECTION_MAPPING_NAMES]},IM=class extends Te{static MODEL_CLASS_MAPPINGS=[Le.MODEL_FOR_MASK_GENERATION_MAPPING_NAMES]},kp=class extends Te{static MODEL_CLASS_MAPPINGS=[Le.MODEL_FOR_CTC_MAPPING_NAMES]},Ep=class extends Te{static MODEL_CLASS_MAPPINGS=[Le.MODEL_FOR_AUDIO_CLASSIFICATION_MAPPING_NAMES]},CM=class extends Te{static MODEL_CLASS_MAPPINGS=[Le.MODEL_FOR_AUDIO_XVECTOR_MAPPING_NAMES]},LM=class extends Te{static MODEL_CLASS_MAPPINGS=[Le.MODEL_FOR_AUDIO_FRAME_CLASSIFICATION_MAPPING_NAMES]},Ap=class extends Te{static MODEL_CLASS_MAPPINGS=[Le.MODEL_FOR_DOCUMENT_QUESTION_ANSWERING_MAPPING_NAMES]},PM=class extends Te{static MODEL_CLASS_MAPPINGS=[Le.MODEL_FOR_IMAGE_MATTING_MAPPING_NAMES]},Mp=class extends Te{static MODEL_CLASS_MAPPINGS=[Le.MODEL_FOR_IMAGE_TO_IMAGE_MAPPING_NAMES]},Sp=class extends Te{static MODEL_CLASS_MAPPINGS=[Le.MODEL_FOR_DEPTH_ESTIMATION_MAPPING_NAMES]},zM=class extends Te{static MODEL_CLASS_MAPPINGS=[Le.MODEL_FOR_NORMAL_ESTIMATION_MAPPING_NAMES]},NM=class extends Te{static MODEL_CLASS_MAPPINGS=[Le.MODEL_FOR_POSE_ESTIMATION_MAPPING_NAMES]},Tp=class extends Te{static MODEL_CLASS_MAPPINGS=[Le.MODEL_FOR_IMAGE_FEATURE_EXTRACTION_MAPPING_NAMES]},$M=class extends Te{static MODEL_CLASS_MAPPINGS=[Le.MODEL_FOR_IMAGE_TEXT_TO_TEXT_MAPPING_NAMES]},RM=class extends Te{static MODEL_CLASS_MAPPINGS=[Le.MODEL_FOR_AUDIO_TEXT_TO_TEXT_MAPPING_NAMES]};async function Je(t){return Array.isArray(t)||(t=[t]),await Promise.all(t.map(e=>Qe.read(e)))}async function ns(t,e){return Array.isArray(t)||(t=[t]),await Promise.all(t.map(r=>typeof r=="string"||r instanceof URL?g_(r,e):r instanceof Float64Array?new Float32Array(r):r))}function ul(t,e){e&&(t=t.map(a=>a|0));let[r,s,n,o]=t;return{xmin:r,ymin:s,xmax:n,ymax:o}}var fe=class extends et{constructor({task:e,model:r,tokenizer:s=null,processor:n=null}){super(),this.task=e,this.model=r,this.tokenizer=s,this.processor=n}async dispose(){await this.model.dispose()}};var pl=class extends fe{async _call(e,{top_k:r=1}={}){let s=this.tokenizer(e,{padding:!0,truncation:!0}),n=await this.model(s),{problem_type:o,id2label:a}=this.model.config,i=o==="multi_label_classification"?c=>c.sigmoid():c=>new $("float32",Ne(c.data),c.dims),l=[];for(let c of n.logits){let p=i(c),d=await Yt(p,r),_=d[0].tolist(),w=d[1].tolist().map((x,E)=>({label:a?a[x]:`LABEL_${x}`,score:_[E]}));r===1?l.push(...w):l.push(w)}return Array.isArray(e)||r===1?l:l[0]}};var dl=class extends fe{async _call(e,{ignore_labels:r=["O"]}={}){let s=Array.isArray(e),n=this.tokenizer(s?e:[e],{padding:!0,truncation:!0}),a=(await this.model(n)).logits,i=this.model.config.id2label,l=[];for(let c=0;c<a.dims[0];++c){let p=n.input_ids[c],d=a[c],_=[];for(let m=0;m<d.dims[0];++m){let w=d[m],x=Oe(w.data)[1],E=i?i[x]:`LABEL_${x}`;if(r.includes(E))continue;let k=this.tokenizer.decode([p[m].item()],{skip_special_tokens:!0});if(k==="")continue;let A=Ne(w.data);_.push({entity:E,score:A[x],index:m,word:k})}l.push(_)}return s?l:l[0]}};var fl=class extends fe{async _call(e,r,{top_k:s=1}={}){let n=this.tokenizer(e,{text_pair:r,padding:!0,truncation:!0}),o=Array.isArray(e),{start_logits:a,end_logits:i}=await this.model(n),l=n.input_ids.tolist(),c=n.attention_mask.tolist(),{all_special_ids:p,sep_token_id:d}=this.tokenizer,_=[];for(let m=0;m<a.dims[0];++m){let w=l[m],x=w.findIndex(O=>O==d),E=a[m].tolist(),k=i[m].tolist();for(let O=1;O<E.length;++O)(c[m]==0||O<=x||p.findIndex(v=>v==w[O])!==-1)&&(E[O]=-1/0,k[O]=-1/0);let A=Ne(E).map((O,v)=>[O,v]),T=Ne(k).map((O,v)=>[O,v]);A[0][0]=0,T[0][0]=0;let S=qk(A,T).filter(O=>O[0][1]<=O[1][1]).map(O=>[O[0][1],O[1][1],O[0][0]*O[1][0]]).sort((O,v)=>v[2]-O[2]),L=[];for(let O=0;O<Math.min(S.length,s);++O){let[v,W,X]=S[O],B=w.slice(v,W+1),H=this.tokenizer.decode(B,{skip_special_tokens:!0});L.push({answer:H,score:X})}s===1?_.push(...L):_.push(L)}return o?_:_[0]}};var _l=class extends fe{async _call(e,{top_k:r=5}={}){let{mask_token_id:s,mask_token:n}=this.tokenizer,o=this.tokenizer(e,{padding:!0,truncation:!0}),{logits:a}=await this.model(o),i=[],l=o.input_ids.tolist();for(let c=0;c<l.length;++c){let p=l[c],d=p.findIndex(E=>E==s);if(d===-1)throw Error(`Mask token (${n}) not found in text.`);let _=a[c][d],m=await Yt(new $("float32",Ne(_.data),_.dims),r),w=m[0].tolist(),x=m[1].tolist();i.push(x.map((E,k)=>{let A=p.slice();return A[d]=E,{score:w[k],token:Number(E),token_str:this.tokenizer.decode([E]),sequence:this.tokenizer.decode(A,{skip_special_tokens:!0})}}))}return Array.isArray(e)?i:i[0]}};var vr=class extends fe{_key="generated_text";async _call(e,r={}){Array.isArray(e)||(e=[e]),this.model.config.prefix&&(e=e.map(l=>this.model.config.prefix+l));let s=this.model.config.task_specific_params;s&&s[this.task]&&s[this.task].prefix&&(e=e.map(l=>s[this.task].prefix+l));let n=this.tokenizer,o={padding:!0,truncation:!0},a;this.task==="translation"&&"_build_translation_inputs"in n?a=n._build_translation_inputs(e,o,r):a=n(e,o);let i=await this.model.generate({...a,...r});return n.batch_decode(i,{skip_special_tokens:!0}).map(l=>({[this._key]:l}))}};var ml=class extends vr{_key="summary_text"};var hl=class extends vr{_key="translation_text"};function DM(t){return Array.isArray(t)&&t.every(e=>"role"in e&&"content"in e)}var gl=class extends fe{async _call(e,r={}){let s=!1,n=!1,o=r.add_special_tokens??(this.tokenizer.add_bos_token||this.tokenizer.add_eos_token)??!1,a=r.tokenizer_encode_kwargs,i;if(typeof e=="string")i=e=[e];else if(Array.isArray(e)&&e.every(w=>typeof w=="string"))s=!0,i=e;else{if(DM(e))e=[e];else if(Array.isArray(e)&&e.every(DM))s=!0;else throw new Error("Input must be a string, an array of strings, a Chat, or an array of Chats");n=!0,i=e.map(w=>this.tokenizer.apply_chat_template(w,{tokenize:!1,add_generation_prompt:!0,...a})),o=!1,a=void 0}let l=n?!1:r.return_full_text??!0;this.tokenizer.padding_side="left";let c=this.tokenizer(i,{add_special_tokens:o,padding:!0,truncation:!0,...a}),p=await this.model.generate({...c,...r}),d=this.tokenizer.batch_decode(p,{skip_special_tokens:!0}),_;!l&&c.input_ids.dims.at(-1)>0&&(_=this.tokenizer.batch_decode(c.input_ids,{skip_special_tokens:!0}).map(w=>w.length));let m=Array.from({length:e.length},w=>[]);for(let w=0;w<d.length;++w){let x=Math.floor(w/p.dims[0]*e.length);_&&(d[w]=d[w].slice(_[x])),m[x].push({generated_text:n?[...e[x],{role:"assistant",content:d[w]}]:d[w]})}return!s&&m.length===1?m[0]:m}};var wl=class extends fe{constructor(e){super(e),this.label2id=Object.fromEntries(Object.entries(this.model.config.label2id).map(([r,s])=>[r.toLowerCase(),s])),this.entailment_id=this.label2id.entailment,this.entailment_id===void 0&&(Z.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&&(Z.warn("Could not find 'contradiction' in label2id mapping. Using 0 as contradiction_id."),this.contradiction_id=0)}async _call(e,r,{hypothesis_template:s="This example is {}.",multi_label:n=!1}={}){let o=Array.isArray(e);o||(e=[e]),Array.isArray(r)||(r=[r]);let a=r.map(c=>s.replace("{}",c)),i=n||r.length===1,l=[];for(let c of e){let p=[];for(let m of a){let w=this.tokenizer(c,{text_pair:m,padding:!0,truncation:!0}),x=await this.model(w);i?p.push([x.logits.data[this.contradiction_id],x.logits.data[this.entailment_id]]):p.push(x.logits.data[this.entailment_id])}let _=(i?p.map(m=>Ne(m)[1]):Ne(p)).map((m,w)=>[m,w]).sort((m,w)=>w[0]-m[0]);l.push({sequence:c,labels:_.map(m=>r[m[1]]),scores:_.map(m=>m[0])})}return o?l:l[0]}};var xl=class extends fe{async _call(e,{top_k:r=5}={}){let s=this.processor.feature_extractor.config.sampling_rate,n=await ns(e,s),o=this.model.config.id2label,a=[];for(let i of n){let l=await this.processor(i),p=(await this.model(l)).logits[0],d=await Yt(new $("float32",Ne(p.data),p.dims),r),_=d[0].tolist(),w=d[1].tolist().map((x,E)=>({label:o?o[x]:`LABEL_${x}`,score:_[E]}));a.push(w)}return Array.isArray(e)?a:a[0]}};var yl=class extends fe{async _call(e,r,{hypothesis_template:s="This is a sound of {}."}={}){let n=!Array.isArray(e);n&&(e=[e]);let o=r.map(p=>s.replace("{}",p)),a=this.tokenizer(o,{padding:!0,truncation:!0}),i=this.processor.feature_extractor.config.sampling_rate,l=await ns(e,i),c=[];for(let p of l){let d=await this.processor(p),_=await this.model({...a,...d}),m=Ne(_.logits_per_audio.data);c.push([...m].map((w,x)=>({score:w,label:r[x]})))}return n?c[0]:c}};var bl=class extends fe{async _call(e,r={}){switch(this.model.config.model_type){case"whisper":case"lite-whisper":return this._call_whisper(e,r);case"wav2vec2":case"wav2vec2-bert":case"unispeech":case"unispeech-sat":case"hubert":case"parakeet_ctc":return this._call_wav2vec2(e,r);case"moonshine":return this._call_moonshine(e,r);default:throw new Error(`AutomaticSpeechRecognitionPipeline does not support model type '${this.model.config.model_type}'.`)}}async _call_wav2vec2(e,r){r.language&&Z.warn('`language` parameter is not yet supported for `wav2vec2` models, defaulting to "English".'),r.task&&Z.warn('`task` parameter is not yet supported for `wav2vec2` models, defaulting to "transcribe".');let s=!Array.isArray(e),n=s?[e]:e,o=this.processor.feature_extractor.config.sampling_rate,a=await ns(n,o),i=[];for(let l of a){let c=await this.processor(l),d=(await this.model(c)).logits[0],_=[];for(let w of d)_.push(Oe(w.data)[1]);let m=this.tokenizer.decode(_,{skip_special_tokens:!0}).trim();i.push({text:m})}return s?i[0]:i}async _call_whisper(e,r){let s=r.return_timestamps??!1,n=r.chunk_length_s??0,o=r.force_full_sequences??!1,a=r.stride_length_s??null,i={...r};s==="word"&&(i.return_token_timestamps=!0,i.return_timestamps=!1);let l=!Array.isArray(e),c=l?[e]:e,p=this.processor.feature_extractor.config,d=p.chunk_length/this.model.config.max_source_positions,_=p.hop_length,m=p.sampling_rate,w=await ns(c,m),x=[];for(let E of w){let k=[];if(n>0){if(a===null)a=n/6;else if(n<=a)throw Error("`chunk_length_s` must be larger than `stride_length_s`.");let S=m*n,L=m*a,O=S-2*L,v=0;for(;;){let W=v+S,X=E.subarray(v,W),B=await this.processor(X),H=v===0,G=W>=E.length;if(k.push({stride:[X.length,H?0:L,G?0:L],input_features:B.input_features,is_last:G}),G)break;v+=O}}else k=[{stride:[E.length,0,0],input_features:(await this.processor(E)).input_features,is_last:!0}];for(let S of k){i.num_frames=Math.floor(S.stride[0]/_);let L=await this.model.generate({inputs:S.input_features,...i});s==="word"?(S.tokens=L.sequences.tolist()[0],S.token_timestamps=L.token_timestamps.tolist()[0].map(O=>ds(O,2))):S.tokens=L[0].tolist(),S.stride=S.stride.map(O=>O/m)}let[A,T]=this.tokenizer._decode_asr(k,{time_precision:d,return_timestamps:s,force_full_sequences:o});x.push({text:A,...T})}return l?x[0]:x}async _call_moonshine(e,r){let s=!Array.isArray(e),n=s?[e]:e,o=this.processor.feature_extractor.config.sampling_rate,a=await ns(n,o),i=[];for(let l of a){let c=await this.processor(l),p=Math.floor(l.length/o)*6,d=await this.model.generate({max_new_tokens:p,...r,...c}),_=this.processor.batch_decode(d,{skip_special_tokens:!0})[0];i.push({text:_})}return s?i[0]:i}};var vl=class extends fe{DEFAULT_VOCODER_ID="Xenova/speecht5_hifigan";constructor(e){super(e),this.vocoder=e.vocoder??null}async _prepare_speaker_embeddings(e,r){if((typeof e=="string"||e instanceof URL)&&(e=new Float32Array(await(await _e.fetch(e)).arrayBuffer())),e instanceof Float32Array)e=new $("float32",e,[e.length]);else if(!(e instanceof $))throw new Error("Speaker embeddings must be a `Tensor`, `Float32Array`, `string`, or `URL`.");if(r>1){if(e.dims[0]===1)e=e.repeat(r,1);else if(e.dims[0]!==r)throw new Error(`Expected speaker embeddings batch size to be 1 or ${r}, but got ${e.dims[0]}.`)}return e}_postprocess_waveform(e,r,s,n=null){let o=r.data,[a,i]=r.dims,l=n?n.data:null,c=[];for(let p=0;p<a;++p){let d=l?Math.min(Math.ceil(l[p]),i):i,_=p*i;c.push(new Po(o.slice(_,_+d),s))}return Array.isArray(e)?c:c[0]}async _call(e,r){return this.processor?this._call_text_to_spectrogram(e,r):this.model.config.model_type==="supertonic"?this._call_supertonic(e,r):this._call_text_to_waveform(e)}async _call_supertonic(e,{speaker_embeddings:r,num_inference_steps:s,speed:n}){if(!r)throw new Error("Speaker embeddings must be provided for Supertonic models.");let{sampling_rate:o,style_dim:a}=this.model.config,i=this.tokenizer(e,{padding:!0,truncation:!0}),l=i.input_ids.dims[0];r=await this._prepare_speaker_embeddings(r,l),r=r.view(l,-1,a);let{waveform:c,durations:p}=await this.model.generate_speech({...i,style:r,num_inference_steps:s,speed:n});return this._postprocess_waveform(e,c,o,p)}async _call_text_to_waveform(e){let r=this.tokenizer(e,{padding:!0,truncation:!0}),{waveform:s}=await this.model(r),n=this.model.config.sampling_rate;return this._postprocess_waveform(e,s,n)}async _call_text_to_spectrogram(e,{speaker_embeddings:r}){this.vocoder||(Z.info("No vocoder specified, using default HifiGan vocoder."),this.vocoder=await br.from_pretrained(this.DEFAULT_VOCODER_ID,{dtype:"fp32"}));let{input_ids:s}=this.tokenizer(e,{padding:!0,truncation:!0}),n=s.dims[0];r=await this._prepare_speaker_embeddings(r,n),r=r.view(n,-1);let{waveform:o}=await this.model.generate_speech(s,r,{vocoder:this.vocoder}),a=this.processor.feature_extractor.config.sampling_rate;return this._postprocess_waveform(e,o,a)}};var kl=class extends fe{async _call(e,r={}){let s=Array.isArray(e),n=await Je(e),{pixel_values:o}=await this.processor(n),a=[];for(let i of o){i.dims=[1,...i.dims];let l=await this.model.generate({inputs:i,...r}),c=this.tokenizer.batch_decode(l,{skip_special_tokens:!0}).map(p=>({generated_text:p.trim()}));a.push(c)}return s?a:a[0]}};var El=class extends fe{async _call(e,{top_k:r=5}={}){let s=await Je(e),{pixel_values:n}=await this.processor(s),o=await this.model({pixel_values:n}),{id2label:a}=this.model.config,i=[];for(let l of o.logits){let c=await Yt(new $("float32",Ne(l.data),l.dims),r),p=c[0].tolist(),_=c[1].tolist().map((m,w)=>({label:a?a[m]:`LABEL_${m}`,score:p[w]}));i.push(_)}return Array.isArray(e)?i:i[0]}};var FM={panoptic:"post_process_panoptic_segmentation",instance:"post_process_instance_segmentation",semantic:"post_process_semantic_segmentation"},Ws=class extends fe{async _call(e,{threshold:r=.5,mask_threshold:s=.5,overlap_mask_area_threshold:n=.8,label_ids_to_fuse:o=null,target_sizes:a=null,subtask:i=null}={}){if(Array.isArray(e)&&e.length!==1)throw Error("Image segmentation pipeline currently only supports a batch size of 1.");let c=await Je(e),p=c.map(A=>[A.height,A.width]),d=await this.processor(c),{inputNames:_,outputNames:m}=this.model.sessions.model;if(!_.includes("pixel_values")){if(_.length!==1)throw Error(`Expected a single input name, but got ${_.length} inputs: ${_}.`);let A=_[0];if(A in d)throw Error(`Input name ${A} already exists in the inputs.`);d[A]=d.pixel_values}let w=await this.model(d),x=null;if(i!==null)x=FM[i];else if(this.processor.image_processor){for(let[A,T]of Object.entries(FM))if(T in this.processor.image_processor){x=this.processor.image_processor[T].bind(this.processor.image_processor),i=A;break}}let E=this.model.config.id2label,k=[];if(i)if(i==="panoptic"||i==="instance"){let A=x(w,r,s,n,o,a??p)[0],T=A.segmentation;for(let S of A.segments_info){let L=new Uint8ClampedArray(T.data.length);for(let v=0;v<T.data.length;++v)T.data[v]===S.id&&(L[v]=255);let O=new Qe(L,T.dims[1],T.dims[0],1);k.push({score:S.score,label:E[S.label_id],mask:O})}}else if(i==="semantic"){let{segmentation:A,labels:T}=x(w,a??p)[0];for(let S of T){let L=new Uint8ClampedArray(A.data.length);for(let v=0;v<A.data.length;++v)A.data[v]===S&&(L[v]=255);let O=new Qe(L,A.dims[1],A.dims[0],1);k.push({score:null,label:E[S],mask:O})}}else throw Error(`Subtask ${i} not supported.`);else{let T=w[m[0]];for(let S=0;S<p.length;++S){let L=p[S],O=T[S];O.data.some(W=>W<-1e-5||W>1+1e-5)&&O.sigmoid_();let v=await Qe.fromTensor(O.mul_(255).to("uint8")).resize(L[1],L[0]);k.push({label:null,score:null,mask:v})}}return k}};var Al=class extends Ws{async _call(e,r={}){let s=await Je(e),n=await super._call(e,r),o=s.map((a,i)=>{let l=a.clone();return l.putAlpha(n[i].mask),l});return Array.isArray(e)?o:o[0]}};var Ml=class extends fe{async _call(e,r,{hypothesis_template:s="This is a photo of {}"}={}){let n=Array.isArray(e),o=await Je(e),a=r.map(_=>s.replace("{}",_)),i=this.tokenizer(a,{padding:this.model.config.model_type==="siglip"?"max_length":!0,truncation:!0}),{pixel_values:l}=await this.processor(o),c=await this.model({...i,pixel_values:l}),p=this.model.config.model_type==="siglip"?_=>_.sigmoid().data:_=>Ne(_.data),d=[];for(let _ of c.logits_per_image){let w=[...p(_)].map((x,E)=>({score:x,label:r[E]}));w.sort((x,E)=>E.score-x.score),d.push(w)}return n?d:d[0]}};var Sl=class extends fe{async _call(e,{threshold:r=.9,percentage:s=!1}={}){let n=Array.isArray(e);if(n&&e.length!==1)throw Error("Object detection pipeline currently only supports a batch size of 1.");let o=await Je(e),a=s?null:o.map(m=>[m.height,m.width]),{pixel_values:i,pixel_mask:l}=await this.processor(o),c=await this.model({pixel_values:i,pixel_mask:l}),p=this.processor.image_processor.post_process_object_detection(c,r,a),{id2label:d}=this.model.config,_=p.map(m=>m.boxes.map((w,x)=>({score:m.scores[x],label:d[m.classes[x]],box:ul(w,!s)})));return n?_:_[0]}};var Tl=class extends fe{async _call(e,r,{threshold:s=.1,top_k:n=null,percentage:o=!1}={}){let a=Array.isArray(e),i=await Je(e),l=this.tokenizer(r,{padding:!0,truncation:!0}),c=await this.processor(i),p=[];for(let d=0;d<i.length;++d){let _=i[d],m=o?null:[[_.height,_.width]],w=c.pixel_values[d].unsqueeze_(0),x=await this.model({...l,pixel_values:w}),E;if("post_process_grounded_object_detection"in this.processor){let k=this.processor.post_process_grounded_object_detection(x,l.input_ids,{box_threshold:s,text_threshold:s,target_sizes:m})[0];E=k.boxes.map((A,T)=>({score:k.scores[T],label:k.labels[T],box:ul(A,!o)}))}else{let k=this.processor.image_processor.post_process_object_detection(x,s,m,!0)[0];E=k.boxes.map((A,T)=>({score:k.scores[T],label:r[k.classes[T]],box:ul(A,!o)}))}E.sort((k,A)=>A.score-k.score),n!==null&&(E=E.slice(0,n)),p.push(E)}return a?p:p[0]}};var Ol=class extends fe{async _call(e,r,s={}){if(Array.isArray(e)){if(e.length!==1)throw Error("Document Question Answering pipeline currently only supports a batch size of 1.");e=e[0]}let n=(await Je(e))[0],{pixel_values:o}=await this.processor(n),a=`<s_docvqa><s_question>${r}</s_question><s_answer>`,i=this.tokenizer(a,{add_special_tokens:!1,padding:!0,truncation:!0}).input_ids,l=await this.model.generate({inputs:o,max_length:this.model.config.decoder.max_position_embeddings,decoder_input_ids:i,...s}),p=this.tokenizer.batch_decode(l)[0].match(/<s_answer>(.*?)<\/s_answer>/),d=null;return p&&p.length>=2&&(d=p[1].trim()),[{answer:d}]}};var Il=class extends fe{async _call(e){let r=await Je(e),s=await this.processor(r),n=await this.model(s),o=[];for(let a of n.reconstruction){let i=a.squeeze().clamp_(0,1).mul_(255).round_().to("uint8");o.push(Qe.fromTensor(i))}return Array.isArray(e)?o:o[0]}};var Cl=class extends fe{async _call(e){let r=await Je(e),s=await this.processor(r),{predicted_depth:n}=await this.model(s),o=[];for(let a=0;a<r.length;++a){let i=n[a],[l,c]=i.dims.slice(-2),[p,d]=r[a].size,_=(await yt(i.view(1,1,l,c),{size:[d,p],mode:"bilinear"})).view(d,p),m=_.min().item(),w=_.max().item(),x=_.sub(m).div_(w-m).mul_(255).to("uint8").unsqueeze(0),E=Qe.fromTensor(x);o.push({predicted_depth:_,depth:E})}return Array.isArray(e)?o:o[0]}};var Ll=class extends fe{async _call(e,{pooling:r="none",normalize:s=!1,quantize:n=!1,precision:o="binary"}={}){let a=this.tokenizer(e,{padding:!0,truncation:!0}),i=await this.model(a),l=i.last_hidden_state??i.logits??i.token_embeddings;switch(r){case"none":break;case"mean":l=b2(l,a.attention_mask);break;case"first_token":case"cls":l=l.slice(null,0);break;case"last_token":case"eos":l=l.slice(null,-1);break;default:throw Error(`Pooling method '${r}' not supported.`)}return s&&(l=l.normalize(2,-1)),n&&(l=k2(l,o)),l}};var Pl=class extends fe{async _call(e,{pool:r=null}={}){let s=await Je(e),{pixel_values:n}=await this.processor(s),o=await this.model({pixel_values:n}),a;if(r){if(!("pooler_output"in o))throw Error("No pooled output was returned. Make sure the model has a 'pooler' layer when using the 'pool' option.");a=o.pooler_output}else a=o.last_hidden_state??o.logits??o.image_embeds;return a}};var eo=Object.freeze({"text-classification":{pipeline:pl,model:al,default:{model:"Xenova/distilbert-base-uncased-finetuned-sst-2-english"},type:"text"},"token-classification":{pipeline:dl,model:dp,default:{model:"Xenova/bert-base-multilingual-cased-ner-hrl"},type:"text"},"question-answering":{pipeline:fl,model:wp,default:{model:"Xenova/distilbert-base-cased-distilled-squad"},type:"text"},"fill-mask":{pipeline:_l,model:gp,default:{model:"onnx-community/ettin-encoder-32m-ONNX",dtype:"fp32"},type:"text"},summarization:{pipeline:ml,model:Zn,default:{model:"Xenova/distilbart-cnn-6-6"},type:"text"},translation:{pipeline:hl,model:Zn,default:{model:"Xenova/t5-small"},type:"text"},"text2text-generation":{pipeline:vr,model:Zn,default:{model:"Xenova/flan-t5-small"},type:"text"},"text-generation":{pipeline:gl,model:hp,default:{model:"onnx-community/Qwen3-0.6B-ONNX",dtype:"q4"},type:"text"},"zero-shot-classification":{pipeline:wl,model:al,default:{model:"Xenova/distilbert-base-uncased-mnli"},type:"text"},"audio-classification":{pipeline:xl,model:Ep,default:{model:"Xenova/wav2vec2-base-superb-ks"},type:"audio"},"zero-shot-audio-classification":{pipeline:yl,model:br,default:{model:"Xenova/clap-htsat-unfused"},type:"multimodal"},"automatic-speech-recognition":{pipeline:bl,model:[fp,kp],default:{model:"Xenova/whisper-tiny.en"},type:"multimodal"},"text-to-audio":{pipeline:vl,model:[mp,_p],default:{model:"onnx-community/Supertonic-TTS-ONNX",dtype:"fp32"},type:"text"},"image-to-text":{pipeline:kl,model:xp,default:{model:"Xenova/vit-gpt2-image-captioning"},type:"multimodal"},"image-classification":{pipeline:El,model:yp,default:{model:"Xenova/vit-base-patch16-224"},type:"multimodal"},"image-segmentation":{pipeline:Ws,model:[il,ll,cl],default:{model:"Xenova/detr-resnet-50-panoptic"},type:"multimodal"},"background-removal":{pipeline:Al,model:[il,ll,cl],default:{model:"Xenova/modnet"},type:"image"},"zero-shot-image-classification":{pipeline:Ml,model:br,default:{model:"Xenova/clip-vit-base-patch32"},type:"multimodal"},"object-detection":{pipeline:Sl,model:bp,default:{model:"Xenova/detr-resnet-50"},type:"multimodal"},"zero-shot-object-detection":{pipeline:Tl,model:vp,default:{model:"Xenova/owlvit-base-patch32"},type:"multimodal"},"document-question-answering":{pipeline:Ol,model:Ap,default:{model:"Xenova/donut-base-finetuned-docvqa"},type:"multimodal"},"image-to-image":{pipeline:Il,model:Mp,default:{model:"Xenova/swin2SR-classical-sr-x2-64"},type:"image"},"depth-estimation":{pipeline:Cl,model:Sp,default:{model:"onnx-community/depth-anything-v2-small"},type:"image"},"feature-extraction":{pipeline:Ll,model:br,default:{model:"onnx-community/all-MiniLM-L6-v2-ONNX",dtype:"fp32"},type:"text"},"image-feature-extraction":{pipeline:Pl,model:[Tp,br],default:{model:"onnx-community/dinov3-vits16-pretrain-lvd1689m-ONNX",dtype:"fp32"},type:"image"}}),Op=Object.freeze({"sentiment-analysis":"text-classification",ner:"token-classification",asr:"automatic-speech-recognition","text-to-speech":"text-to-audio",embeddings:"feature-extraction"});function hN(t,{config:e=null,cache_dir:r=null,local_files_only:s=!1,revision:n="main"}={}){if(e!==null)return Bt.from_pretrained(t,{config:e,cache_dir:r,local_files_only:s,revision:n});let o=JSON.stringify([t,r,s,n]);return sc(o,()=>Bt.from_pretrained(t,{config:e,cache_dir:r,local_files_only:s,revision:n}))}async function Ip(t,{config:e=null,dtype:r=null,device:s=null,model_file_name:n=null}={}){e=await hN(t,{config:e});let o=["config.json"],a=e["transformers.js_config"]??{},i=a.use_external_data_format,l="onnx",c=s??a.device,p=r??a.dtype,d,_=e.architectures||[],m=!1;for(let k of _){let A=Jt.get(k);if(A!==void 0){d=A,m=!0;break}}if(!m&&e.model_type){let k=Jt.get(e.model_type);if(k!==void 0&&(d=k,m=!0),!m){for(let A of Object.values(Ts))if(A.has(e.model_type)){d=Jt.get(A.get(e.model_type)),m=!0;break}}}if(!m){let k=_.length>0?_.join(", "):"(none)";Z.warn(`[get_model_files] Architecture(s) not found in MODEL_TYPE_MAPPING: [${k}] for model type '${e.model_type}'. Falling back to EncoderOnly (single model.onnx file). If you encounter issues, please report at: ${Br}`),d=K.EncoderOnly}let w=(k,A=null)=>{A=A??k;let T=bc(c,k),S=vc(p,k,T),L=So[S]??"",O=`${A}${L}.onnx`,v=l?`${l}/${O}`:O;o.push(v);let W=Qm(i,O,k);for(let X of Ym(O,W)){let B=l?`${l}/${X}`:X;o.push(B)}},{sessions:x,optional_configs:E}=K2(d,e,{model_file_name:n});for(let[k,A]of Object.entries(x))w(k,A);if(E)for(let k of Object.values(E))o.push(k);return o}async function Cp(t){if(!t)throw new Error("modelId is required");return(await ar(t,yr,{})).exists?[yr]:[]}async function kr(t,{config:e=null,dtype:r=null,device:s=null,model_file_name:n=null,include_tokenizer:o=!0,include_processor:a=!0}={}){let i=await Ip(t,{config:e,dtype:r,device:s,model_file_name:n});if(o){let l=await _n(t);i.push(...l)}if(a){let l=await Cp(t);i.push(...l)}return i}async function Er(t,e,r={}){t=Op[t]??t;let s=eo[t];if(!s)throw new Error(`Unsupported pipeline task: ${t}. Must be one of [${Object.keys(eo).join(", ")}]`);let{type:n}=s;return kr(e,{...r,include_tokenizer:n!=="audio"&&n!=="image",include_processor:n!=="text"})}async function Rae(t,e=null,{progress_callback:r=null,config:s=null,cache_dir:n=null,local_files_only:o=!1,revision:a="main",device:i=null,dtype:l=null,subfolder:c="onnx",use_external_data_format:p=null,model_file_name:d=null,session_options:_={}}={}){t=Op[t]??t;let m=eo[t.split("_",1)[0]];if(!m)throw Error(`Unsupported pipeline: ${t}. Must be one of [${Object.keys(eo)}]`);e||(e=m.default.model,Z.info(`No model specified. Using default model: "${e}".`),!l&&m.default.dtype&&(l=m.default.dtype));let w=await Er(t,e,{device:i,dtype:l}),x={};r&&(await Promise.all(w.map(async H=>ar(e,H)))).forEach((H,G)=>{H.exists&&(x[w[G]]={loaded:0,total:H.size??0})});let E={progress_callback:r?B=>{if(B.status==="progress"){x[B.file]={loaded:B.loaded,total:B.total};let H=Object.values(x).reduce((R,C)=>R+C.loaded,0),G=Object.values(x).reduce((R,C)=>R+C.total,0),Q=G>0?H/G*100:0;r({status:"progress_total",name:B.name,progress:Q,loaded:H,total:G,files:structuredClone(x)})}r(B)}:void 0,config:s,cache_dir:n,local_files_only:o,revision:a,device:i,dtype:l,subfolder:c,use_external_data_format:p,model_file_name:d,session_options:_},k=w.includes("tokenizer.json"),A=w.includes("preprocessor_config.json"),T=m.model,S;if(Array.isArray(T)){let B=s??await Bt.from_pretrained(e,E),{model_type:H}=B,G=T.find(Q=>Q.supports(H));if(!G)throw Error(`Unsupported model type "${H}" for task "${t}". None of the candidate model classes support this type.`);S=G.from_pretrained(e,{...E,config:B})}else S=T.from_pretrained(e,E);let[L,O,v]=await Promise.all([k?oe.from_pretrained(e,E):null,A?Jc.from_pretrained(e,E):null,S]),W={task:t,model:v};L&&(W.tokenizer=L),O&&(W.processor=O),gr(r,{status:"ready",task:t,model:e});let X=m.pipeline;return new X(W)}var gN=t=>t>=19968&&t<=40959||t>=13312&&t<=19903||t>=131072&&t<=173791||t>=173824&&t<=177983||t>=177984&&t<=178207||t>=178208&&t<=183983||t>=63744&&t<=64255||t>=194560&&t<=195103,O1=class{put(e){throw Error("Not implemented")}end(){throw Error("Not implemented")}},BM=ie.IS_PROCESS_AVAILABLE?t=>process.stdout.write(t):t=>console.log(t),I1=class extends O1{constructor(e,{skip_prompt:r=!1,callback_function:s=null,token_callback_function:n=null,skip_special_tokens:o=!0,decode_kwargs:a={},...i}={}){super(),this.tokenizer=e,this.skip_prompt=r,this.callback_function=s??BM,this.token_callback_function=n,this.decode_kwargs={skip_special_tokens:o,...a,...i},this.token_cache=[],this.print_len=0,this.next_tokens_are_prompt=!0,this.special_ids=new Set(this.tokenizer.all_special_ids.map(BigInt))}put(e){if(e.length>1)throw Error("TextStreamer only supports batch size of 1");let r=this.next_tokens_are_prompt;if(r&&(this.next_tokens_are_prompt=!1,this.skip_prompt))return;let s=e[0];if(this.token_callback_function?.(s),s.length===1&&this.special_ids.has(s[0])){if(this.decode_kwargs.skip_special_tokens)return;if(this.token_cache.length>0){let l=this.tokenizer.decode(this.token_cache,this.decode_kwargs).slice(this.print_len);this.on_finalized_text(l,!1),this.token_cache=[],this.print_len=0}let a=this.tokenizer.decode(s,this.decode_kwargs);this.on_finalized_text(a,!1);return}this.token_cache=ht(this.token_cache,s);let n=this.tokenizer.decode(this.token_cache,this.decode_kwargs),o;r||n.endsWith(`
26
+ `)?(o=n.slice(this.print_len),this.token_cache=[],this.print_len=0):n.length>0&&gN(n.charCodeAt(n.length-1))?(o=n.slice(this.print_len),this.print_len+=o.length):(o=n.slice(this.print_len,n.lastIndexOf(" ")+1),this.print_len+=o.length),this.on_finalized_text(o,!1)}end(){let e;this.token_cache.length>0?(e=this.tokenizer.decode(this.token_cache,this.decode_kwargs).slice(this.print_len),this.token_cache=[],this.print_len=0):e="",this.next_tokens_are_prompt=!0,this.on_finalized_text(e,!0)}on_finalized_text(e,r){e.length>0&&this.callback_function?.(e),r&&this.callback_function===BM&&ie.IS_PROCESS_AVAILABLE&&this.callback_function?.(`
27
+ `)}},UM=class extends I1{constructor(e,{skip_prompt:r=!1,callback_function:s=null,token_callback_function:n=null,on_chunk_start:o=null,on_chunk_end:a=null,on_finalize:i=null,time_precision:l=.02,skip_special_tokens:c=!0,decode_kwargs:p={}}={}){super(e,{skip_prompt:r,skip_special_tokens:c,callback_function:s,token_callback_function:n,decode_kwargs:p}),this.timestamp_begin=e.timestamp_begin,this.on_chunk_start=o,this.on_chunk_end=a,this.on_finalize=i,this.time_precision=l,this.waiting_for_timestamp=!1}put(e){if(e.length>1)throw Error("WhisperTextStreamer only supports batch size of 1");let r=e[0];if(r.length===1){let s=Number(r[0])-this.timestamp_begin;if(s>=0){let n=s*this.time_precision;this.waiting_for_timestamp?this.on_chunk_end?.(n):this.on_chunk_start?.(n),this.waiting_for_timestamp=!this.waiting_for_timestamp,this.token_callback_function?.(r);return}}return super.put(e)}end(){super.end(),this.on_finalize?.()}};var zl=class{constructor(e,r){this.image=e,this.timestamp=r}},Lp=class{constructor(e,r){e.length>0&&e[0]instanceof Qe&&(e=e.map((s,n)=>new zl(s,(n+1)/(e.length+1)*r))),this.frames=e,this.duration=r}get width(){return this.frames[0].image.width}get height(){return this.frames[0].image.height}get fps(){return this.frames.length/this.duration}};async function wN(t,{num_frames:e=null,fps:r=null}={}){if(!ie.IS_BROWSER_ENV)throw new Error("`load_video` is currently only supported in browser environments.");if(e==null&&r==null)throw new Error("Either num_frames or fps must be provided.");let s=[],n=document.createElement("video");if(n.crossOrigin="anonymous",n.muted=!0,typeof t=="string")n.src=t;else if(t instanceof Blob)n.src=URL.createObjectURL(t);else if(t instanceof HTMLVideoElement)n.src=t.src;else throw new Error("Invalid URL or video element provided.");if(await new Promise(d=>n.onloadedmetadata=d),n.seekable.start(0)===n.seekable.end(0)){let _=await(await _e.fetch(n.src)).blob();n.src=URL.createObjectURL(_),await new Promise(m=>n.onloadedmetadata=m)}let o=n.duration,a,i;e!=null?(a=e,i=e===1?0:o/(e-1)):(i=1/r,a=Math.floor(o/i));let l=[];for(let d=0;d<a;++d)l.push(e===1?o/2:d*i);let c=document.createElement("canvas");c.width=n.videoWidth,c.height=n.videoHeight;let p=c.getContext("2d",{willReadFrequently:!0});for(let d of l){n.currentTime=d,await new Promise(x=>{n.onseeked=x}),p.drawImage(n,0,0,c.width,c.height);let _=p.getImageData(0,0,c.width,c.height),m=new Qe(_.data,c.width,c.height,4),w=new zl(m,d);s.push(w)}return n.remove(),new Lp(s,o)}async function Pp(t,e,r={}){let s=await Kt(r?.cache_dir);if(!s)return{allCached:!1,files:e.map(a=>({file:a,cached:!1}))};let n=await Promise.all(e.map(async o=>{let{localPath:a,proposedCacheKey:i}=Cr(t,o,r,s),l=await Lr(s,a,i);return{file:o,cached:!!l}}));return{allCached:n.every(o=>o.cached),files:n}}async function jM(t,e,r={}){let s=await Kt(r?.cache_dir);if(!s)return!1;let{localPath:n,proposedCacheKey:o}=Cr(t,e,r,s);return!!await Lr(s,n,o)}async function GM(t,e={}){if(!t)throw new Error("modelId is required");if(!await jM(t,"config.json",e))return!1;let r=await kr(t,e);return(await Pp(t,r,e)).allCached}async function qM(t,e={}){if(!t)throw new Error("modelId is required");let r=await kr(t,e);return await Pp(t,r,e)}async function WM(t,e,r={}){if(!t)throw new Error("task is required");if(!e)throw new Error("modelId is required");if(!await jM(e,"config.json",r))return!1;let s=await Er(t,e,r);return(await Pp(e,s,r)).allCached}async function VM(t,e,r={}){if(!t)throw new Error("task is required");if(!e)throw new Error("modelId is required");let s=await Er(t,e,r);return await Pp(e,s,r)}async function HM(t,e,r={}){let s=await Kt(r?.cache_dir);if(!s)return{filesDeleted:0,filesCached:0,files:e.map(o=>({file:o,deleted:!1,wasCached:!1}))};if(!s.delete)throw new Error("Cache does not support delete operation");let n=await Promise.all(e.map(async o=>{let{localPath:a,proposedCacheKey:i}=Cr(t,o,r,s),c=!!await Lr(s,a,i),p=!1;if(c){let d=await s.delete(i),_=!d&&i!==a?await s.delete(a):!1;p=d||_}return{file:o,deleted:p,wasCached:c}}));return{filesDeleted:n.filter(o=>o.deleted).length,filesCached:n.filter(o=>o.wasCached).length,files:n}}async function XM(t,e={}){if(!t)throw new Error("modelId is required");let r=await kr(t,e);return await HM(t,r,e)}async function KM(t,e,r={}){if(!t)throw new Error("task is required");if(!e)throw new Error("modelId is required");let s=await Er(t,e,r);return await HM(e,s,r)}var C1=class{static async get_files(e,r={}){return kr(e,r)}static async get_pipeline_files(e,r,s={}){return Er(e,r,s)}static async get_model_files(e,r={}){return Ip(e,r)}static async get_tokenizer_files(e){return _n(e)}static async get_processor_files(e){return Cp(e)}static async is_cached(e,r={}){return GM(e,r)}static async is_cached_files(e,r={}){return qM(e,r)}static async is_pipeline_cached(e,r,s={}){return WM(e,r,s)}static async is_pipeline_cached_files(e,r,s={}){return VM(e,r,s)}static async get_file_metadata(e,r,s={}){return ar(e,r,s)}static async clear_cache(e,r={}){return XM(e,r)}static async clear_pipeline_cache(e,r,s={}){return KM(e,r,s)}};export{w_ as ASTFeatureExtractor,hh as ASTForAudioClassification,mh as ASTModel,Ko as ASTPreTrainedModel,dh as AfmoeForCausalLM,ph as AfmoeModel,Ho as AfmoePreTrainedModel,lh as AlbertForMaskedLM,ih as AlbertForQuestionAnswering,ah as AlbertForSequenceClassification,oh as AlbertModel,Is as AlbertPreTrainedModel,Af as AlbertTokenizer,uh as ApertusForCausalLM,ch as ApertusModel,Vo as ApertusPreTrainedModel,_h as ArceeForCausalLM,fh as ArceeModel,Xo as ArceePreTrainedModel,xl as AudioClassificationPipeline,Bt as AutoConfig,Xe as AutoFeatureExtractor,Ce as AutoImageProcessor,br as AutoModel,Ep as AutoModelForAudioClassification,LM as AutoModelForAudioFrameClassification,RM as AutoModelForAudioTextToText,kp as AutoModelForCTC,hp as AutoModelForCausalLM,Sp as AutoModelForDepthEstimation,Ap as AutoModelForDocumentQuestionAnswering,yp as AutoModelForImageClassification,Tp as AutoModelForImageFeatureExtraction,PM as AutoModelForImageMatting,il as AutoModelForImageSegmentation,$M as AutoModelForImageTextToText,Mp as AutoModelForImageToImage,IM as AutoModelForMaskGeneration,gp as AutoModelForMaskedLM,zM as AutoModelForNormalEstimation,bp as AutoModelForObjectDetection,NM as AutoModelForPoseEstimation,wp as AutoModelForQuestionAnswering,ll as AutoModelForSemanticSegmentation,Zn as AutoModelForSeq2SeqLM,al as AutoModelForSequenceClassification,fp as AutoModelForSpeechSeq2Seq,_p as AutoModelForTextToSpectrogram,mp as AutoModelForTextToWaveform,dp as AutoModelForTokenClassification,cl as AutoModelForUniversalSegmentation,xp as AutoModelForVision2Seq,CM as AutoModelForXVector,vp as AutoModelForZeroShotObjectDetection,Jc as AutoProcessor,oe as AutoTokenizer,bl as AutomaticSpeechRecognitionPipeline,Al as BackgroundRemovalPipeline,wh as BartForConditionalGeneration,xh as BartForSequenceClassification,gh as BartModel,Cn as BartPretrainedModel,Mf as BartTokenizer,O1 as BaseStreamer,N_ as BeitFeatureExtractor,bh as BeitForImageClassification,yh as BeitModel,Qo as BeitPreTrainedModel,kh as BertForMaskedLM,Mh as BertForQuestionAnswering,Eh as BertForSequenceClassification,Ah as BertForTokenClassification,vh as BertModel,qr as BertPreTrainedModel,Sf as BertTokenizer,$_ as BitImageProcessor,Th as BlenderbotForConditionalGeneration,Sh as BlenderbotModel,Yo as BlenderbotPreTrainedModel,Ih as BlenderbotSmallForConditionalGeneration,Oh as BlenderbotSmallModel,Jo as BlenderbotSmallPreTrainedModel,Tf as BlenderbotSmallTokenizer,Of as BlenderbotTokenizer,Lh as BloomForCausalLM,Ch as BloomModel,Zo as BloomPreTrainedModel,If as BloomTokenizer,Fh as CHMv2ForDepthEstimation,D_ as CHMv2ImageProcessor,gu as CHMv2PreTrainedModel,F_ as CLIPFeatureExtractor,Lc as CLIPImageProcessor,Uh as CLIPModel,cr as CLIPPreTrainedModel,Vh as CLIPSegForImageSegmentation,Wh as CLIPSegModel,na as CLIPSegPreTrainedModel,jh as CLIPTextModel,sa as CLIPTextModelWithProjection,Lf as CLIPTokenizer,Gh as CLIPVisionModel,qh as CLIPVisionModelWithProjection,zh as CamembertForMaskedLM,Rh as CamembertForQuestionAnswering,Nh as CamembertForSequenceClassification,$h as CamembertForTokenClassification,Ph as CamembertModel,Wr as CamembertPreTrainedModel,Cf as CamembertTokenizer,x_ as ChatterboxFeatureExtractor,ea as ChatterboxModel,mu as ChatterboxPreTrainedModel,L_ as ChatterboxProcessor,R_ as ChineseCLIPFeatureExtractor,Dh as ChineseCLIPModel,hu as ChineseCLIPPreTrainedModel,ra as ClapAudioModelWithProjection,y_ as ClapFeatureExtractor,Bh as ClapModel,Ln as ClapPreTrainedModel,ta as ClapTextModelWithProjection,lu as ClassifierFreeGuidanceLogitsProcessor,Xh as CodeGenForCausalLM,Hh as CodeGenModel,oa as CodeGenPreTrainedModel,zf as CodeGenTokenizer,Pf as CodeLlamaTokenizer,Jh as Cohere2ForCausalLM,Yh as Cohere2Model,ia as Cohere2PreTrainedModel,Qh as CohereForCausalLM,Kh as CohereModel,aa as CoherePreTrainedModel,Nf as CohereTokenizer,eg as ConvBertForMaskedLM,sg as ConvBertForQuestionAnswering,tg as ConvBertForSequenceClassification,rg as ConvBertForTokenClassification,Zh as ConvBertModel,Vr as ConvBertPreTrainedModel,$f as ConvBertTokenizer,B_ as ConvNextFeatureExtractor,og as ConvNextForImageClassification,Pc as ConvNextImageProcessor,ng as ConvNextModel,la as ConvNextPreTrainedModel,ig as ConvNextV2ForImageClassification,ag as ConvNextV2Model,ca as ConvNextV2PreTrainedModel,pg as DFineForObjectDetection,ug as DFineModel,pa as DFinePreTrainedModel,Rg as DINOv3ConvNextModel,Eu as DINOv3ConvNextPreTrainedModel,G_ as DINOv3ViTImageProcessor,Dg as DINOv3ViTModel,Au as DINOv3ViTPreTrainedModel,W_ as DPTFeatureExtractor,Vg as DPTForDepthEstimation,$c as DPTImageProcessor,Wg as DPTModel,wa as DPTPreTrainedModel,fa as DacDecoderModel,xu as DacDecoderOutput,da as DacEncoderModel,wu as DacEncoderOutput,No as DacFeatureExtractor,dg as DacModel,Pn as DacPreTrainedModel,_g as DebertaForMaskedLM,gg as DebertaForQuestionAnswering,mg as DebertaForSequenceClassification,hg as DebertaForTokenClassification,fg as DebertaModel,Hr as DebertaPreTrainedModel,Df as DebertaTokenizer,bg as DebertaV2ForMaskedLM,Eg as DebertaV2ForQuestionAnswering,vg as DebertaV2ForSequenceClassification,kg as DebertaV2ForTokenClassification,yg as DebertaV2Model,Xr as DebertaV2PreTrainedModel,Rf as DebertaV2Tokenizer,Ag as DecisionTransformerModel,yu as DecisionTransformerPreTrainedModel,xg as DeepseekV3ForCausalLM,wg as DeepseekV3Model,_a as DeepseekV3PreTrainedModel,U_ as DeiTFeatureExtractor,Sg as DeiTForImageClassification,zc as DeiTImageProcessor,Mg as DeiTModel,ma as DeiTPreTrainedModel,Tg as DepthAnythingForDepthEstimation,bu as DepthAnythingPreTrainedModel,Cl as DepthEstimationPipeline,Og as DepthProForDepthEstimation,vu as DepthProPreTrainedModel,j_ as DetrFeatureExtractor,Cg as DetrForObjectDetection,Lg as DetrForSegmentation,Nc as DetrImageProcessor,Ig as DetrModel,Nn as DetrObjectDetectionOutput,zn as DetrPreTrainedModel,ku as DetrSegmentationOutput,zg as Dinov2ForImageClassification,Pg as Dinov2Model,ha as Dinov2PreTrainedModel,$g as Dinov2WithRegistersForImageClassification,Ng as Dinov2WithRegistersModel,ga as Dinov2WithRegistersPreTrainedModel,Gg as DistilBertForMaskedLM,jg as DistilBertForQuestionAnswering,Bg as DistilBertForSequenceClassification,Ug as DistilBertForTokenClassification,Fg as DistilBertModel,Kr as DistilBertPreTrainedModel,Ff as DistilBertTokenizer,Ol as DocumentQuestionAnsweringPipeline,q_ as DonutFeatureExtractor,gn as DonutImageProcessor,qg as DonutSwinModel,Mu as DonutSwinPreTrainedModel,Go as DynamicCache,J0 as EdgeTamModel,Xg as EfficientNetForImageClassification,V_ as EfficientNetImageProcessor,Hg as EfficientNetModel,xa as EfficientNetPreTrainedModel,Qg as ElectraForMaskedLM,Zg as ElectraForQuestionAnswering,Yg as ElectraForSequenceClassification,Jg as ElectraForTokenClassification,Kg as ElectraModel,Qr as ElectraPreTrainedModel,Bf as ElectraTokenizer,zo as EncodecFeatureExtractor,pu as EosTokenCriteria,tw as Ernie4_5ForCausalLM,ew as Ernie4_5Model,ya as Ernie4_5PretrainedModel,sw as EsmForMaskedLM,nw as EsmForSequenceClassification,ow as EsmForTokenClassification,rw as EsmModel,Cs as EsmPreTrainedModel,Uf as EsmTokenizer,iw as EuroBertForMaskedLM,lw as EuroBertForSequenceClassification,cw as EuroBertForTokenClassification,aw as EuroBertModel,Ls as EuroBertPreTrainedModel,pw as ExaoneForCausalLM,uw as ExaoneModel,ba as ExaonePreTrainedModel,fw as FalconForCausalLM,mw as FalconH1ForCausalLM,_w as FalconH1Model,ka as FalconH1PreTrainedModel,dw as FalconModel,va as FalconPreTrainedModel,jf as FalconTokenizer,gw as FastViTForImageClassification,hw as FastViTModel,Ea as FastViTPreTrainedModel,Ll as FeatureExtractionPipeline,Ee as FeatureExtractor,_l as FillMaskPipeline,ww as Florence2ForConditionalGeneration,Su as Florence2PreTrainedModel,Em as Florence2Processor,eu as ForcedBOSTokenLogitsProcessor,tu as ForcedEOSTokenLogitsProcessor,X_ as GLPNFeatureExtractor,Cw as GLPNForDepthEstimation,Iw as GLPNModel,Ca as GLPNPreTrainedModel,Uw as GPT2LMHeadModel,Bw as GPT2Model,$a as GPT2PreTrainedModel,Wf as GPT2Tokenizer,Pw as GPTBigCodeForCausalLM,Lw as GPTBigCodeModel,La as GPTBigCodePreTrainedModel,Gw as GPTJForCausalLM,jw as GPTJModel,Ra as GPTJPreTrainedModel,Nw as GPTNeoForCausalLM,zw as GPTNeoModel,Pa as GPTNeoPreTrainedModel,Rw as GPTNeoXForCausalLM,$w as GPTNeoXModel,za as GPTNeoXPreTrainedModel,qf as GPTNeoXTokenizer,vw as Gemma2ForCausalLM,bw as Gemma2Model,Ma as Gemma2PreTrainedModel,Ew as Gemma3ForCausalLM,kw as Gemma3Model,Sa as Gemma3PreTrainedModel,b_ as Gemma3nAudioFeatureExtractor,Ta as Gemma3nForCausalLM,$n as Gemma3nForConditionalGeneration,Tu as Gemma3nPreTrainedModel,Am as Gemma3nProcessor,yw as GemmaForCausalLM,xw as GemmaModel,Aa as GemmaPreTrainedModel,Gf as GemmaTokenizer,H_ as Glm46VImageProcessor,Mm as Glm46VProcessor,Mw as GlmForCausalLM,Aw as GlmModel,Tw as GlmMoeDsaForCausalLM,Sw as GlmMoeDsaModel,Ia as GlmMoeDsaPreTrainedModel,Ow as GlmOcrForConditionalGeneration,Oa as GlmPreTrainedModel,Fw as GptOssForCausalLM,Dw as GptOssModel,Na as GptOssPreTrainedModel,Ww as GraniteForCausalLM,qw as GraniteModel,Hw as GraniteMoeHybridForCausalLM,Vw as GraniteMoeHybridModel,Fa as GraniteMoeHybridPreTrainedModel,Da as GranitePreTrainedModel,v_ as GraniteSpeechFeatureExtractor,Xw as GraniteSpeechForConditionalGeneration,Sm as GraniteSpeechProcessor,Kw as GroundingDinoForObjectDetection,K_ as GroundingDinoImageProcessor,Cu as GroundingDinoPreTrainedModel,Tm as GroundingDinoProcessor,Qw as GroupViTModel,Lu as GroupViTPreTrainedModel,Jw as HeliumForCausalLM,Yw as HeliumModel,Ba as HeliumPreTrainedModel,Vf as HerbertTokenizer,ex as HieraForImageClassification,Zw as HieraModel,Ua as HieraPreTrainedModel,ix as HubertForCTC,lx as HubertForSequenceClassification,ax as HubertModel,ox as HubertPreTrainedModel,ux as HunYuanDenseV1ForCausalLM,cx as HunYuanDenseV1Model,ja as HunYuanDenseV1PreTrainedModel,mx as IJepaForImageClassification,_x as IJepaModel,Ga as IJepaPreTrainedModel,fx as Idefics3ForConditionalGeneration,Rc as Idefics3ImageProcessor,Hc as Idefics3Processor,El as ImageClassificationPipeline,Pl as ImageFeatureExtractionPipeline,V as ImageFeatureExtractor,V as ImageProcessor,Ws as ImageSegmentationPipeline,Il as ImageToImagePipeline,kl as ImageToTextPipeline,V2 as InterruptableStoppingCriteria,gx as JAISLMHeadModel,hx as JAISModel,qa as JAISPreTrainedModel,Y_ as JinaCLIPImageProcessor,wx as JinaCLIPModel,Dn as JinaCLIPPreTrainedModel,Im as JinaCLIPProcessor,Wa as JinaCLIPTextModel,xx as JinaCLIPVisionModel,bx as Lfm2ForCausalLM,yx as Lfm2Model,Ex as Lfm2MoeForCausalLM,kx as Lfm2MoeModel,Ha as Lfm2MoePreTrainedModel,Va as Lfm2PreTrainedModel,Ax as Lfm2VlForConditionalGeneration,J_ as Lfm2VlImageProcessor,Cm as Lfm2VlProcessor,vx as LightOnOcrForConditionalGeneration,f1 as LiteWhisperForConditionalGeneration,Tx as Llama4ForCausalLM,zu as Llama4PreTrainedModel,Sx as LlamaForCausalLM,Mx as LlamaModel,Xa as LlamaPreTrainedModel,Hf as LlamaTokenizer,Ot as LlavaForConditionalGeneration,Ot as LlavaOnevisionForConditionalGeneration,Z_ as LlavaOnevisionImageProcessor,Pu as LlavaPreTrainedModel,Lm as LlavaProcessor,dx as LlavaQwen2ForCausalLM,Mt as LogLevel,Ut as LogitsProcessor,Ms as LogitsProcessorList,jo as LogitsWarper,Ix as LongT5ForConditionalGeneration,Ox as LongT5Model,Ka as LongT5PreTrainedModel,Lx as M2M100ForConditionalGeneration,Cx as M2M100Model,Qa as M2M100PreTrainedModel,Xf as M2M100Tokenizer,Qf as MBart50Tokenizer,Bx as MBartForCausalLM,Dx as MBartForConditionalGeneration,Fx as MBartForSequenceClassification,Rx as MBartModel,Rs as MBartPreTrainedModel,Io as MBartTokenizer,My as MPNetForMaskedLM,Oy as MPNetForQuestionAnswering,Sy as MPNetForSequenceClassification,Ty as MPNetForTokenClassification,Ay as MPNetModel,Yr as MPNetPreTrainedModel,Zf as MPNetTokenizer,Py as MT5ForConditionalGeneration,Ly as MT5Model,ci as MT5PreTrainedModel,zx as MarianMTModel,Px as MarianModel,Ya as MarianPreTrainedModel,Kf as MarianTokenizer,tm as Mask2FormerImageProcessor,em as MaskFormerFeatureExtractor,$x as MaskFormerForInstanceSegmentation,wn as MaskFormerImageProcessor,Nx as MaskFormerModel,Ja as MaskFormerPreTrainedModel,uu as MaxLengthCriteria,Ux as Metric3DForDepthEstimation,Nu as Metric3DPreTrainedModel,jx as Metric3Dv2ForDepthEstimation,$u as Metric3Dv2PreTrainedModel,Gx as MgpstrForSceneTextRecognition,Ru as MgpstrModelOutput,Du as MgpstrPreTrainedModel,Pm as MgpstrProcessor,Yf as MgpstrTokenizer,ei as MimiDecoderModel,Bu as MimiDecoderOutput,Za as MimiEncoderModel,Fu as MimiEncoderOutput,qx as MimiModel,Fn as MimiPreTrainedModel,ou as MinLengthLogitsProcessor,au as MinNewTokensLengthLogitsProcessor,Xx as Mistral4ForCausalLM,Hx as Mistral4Model,ri as Mistral4PreTrainedModel,Vx as MistralForCausalLM,Wx as MistralModel,ti as MistralPreTrainedModel,Qx as MobileBertForMaskedLM,Jx as MobileBertForQuestionAnswering,Yx as MobileBertForSequenceClassification,Kx as MobileBertModel,Ds as MobileBertPreTrainedModel,Jf as MobileBertTokenizer,ey as MobileLLMForCausalLM,Zx as MobileLLMModel,si as MobileLLMPreTrainedModel,rm as MobileNetV1FeatureExtractor,ry as MobileNetV1ForImageClassification,sy as MobileNetV1ForSemanticSegmentation,Dc as MobileNetV1ImageProcessor,ty as MobileNetV1Model,Bn as MobileNetV1PreTrainedModel,sm as MobileNetV2FeatureExtractor,oy as MobileNetV2ForImageClassification,ay as MobileNetV2ForSemanticSegmentation,Fc as MobileNetV2ImageProcessor,ny as MobileNetV2Model,Un as MobileNetV2PreTrainedModel,nm as MobileNetV3FeatureExtractor,ly as MobileNetV3ForImageClassification,cy as MobileNetV3ForSemanticSegmentation,Bc as MobileNetV3ImageProcessor,iy as MobileNetV3Model,jn as MobileNetV3PreTrainedModel,om as MobileNetV4FeatureExtractor,py as MobileNetV4ForImageClassification,dy as MobileNetV4ForSemanticSegmentation,Uc as MobileNetV4ImageProcessor,uy as MobileNetV4Model,Gn as MobileNetV4PreTrainedModel,am as MobileViTFeatureExtractor,_y as MobileViTForImageClassification,jc as MobileViTImageProcessor,fy as MobileViTModel,ni as MobileViTPreTrainedModel,hy as MobileViTV2ForImageClassification,my as MobileViTV2Model,oi as MobileViTV2PreTrainedModel,C1 as ModelRegistry,vy as ModernBertDecoderForCausalLM,by as ModernBertDecoderModel,ai as ModernBertDecoderPreTrainedModel,wy as ModernBertForMaskedLM,xy as ModernBertForSequenceClassification,yy as ModernBertForTokenClassification,gy as ModernBertModel,Fs as ModernBertPreTrainedModel,px as Moondream1ForConditionalGeneration,k_ as MoonshineFeatureExtractor,Ey as MoonshineForConditionalGeneration,ky as MoonshineModel,ii as MoonshinePreTrainedModel,zm as MoonshineProcessor,Cy as MptForCausalLM,Iy as MptModel,li as MptPreTrainedModel,zy as MultiModalityCausalLM,Uu as MultiModalityPreTrainedModel,$y as MusicgenForCausalLM,pi as MusicgenForConditionalGeneration,Ny as MusicgenModel,ui as MusicgenPreTrainedModel,Dy as NanoChatForCausalLM,Ry as NanoChatModel,di as NanoChatPreTrainedModel,By as NemotronHForCausalLM,Fy as NemotronHModel,fi as NemotronHPreTrainedModel,jy as NeoBertForMaskedLM,Wy as NeoBertForQuestionAnswering,Gy as NeoBertForSequenceClassification,qy as NeoBertForTokenClassification,Uy as NeoBertModel,Jr as NeoBertPreTrainedModel,e_ as NllbTokenizer,iu as NoBadWordsLogitsProcessor,su as NoRepeatNGramLogitsProcessor,Vy as NomicBertModel,ju as NomicBertPreTrainedModel,im as NougatImageProcessor,t_ as NougatTokenizer,n0 as OPTForCausalLM,s0 as OPTModel,xi as OPTPreTrainedModel,Sl as ObjectDetectionPipeline,Qy as Olmo2ForCausalLM,Ky as Olmo2Model,mi as Olmo2PreTrainedModel,Jy as Olmo3ForCausalLM,Yy as Olmo3Model,hi as Olmo3PreTrainedModel,Xy as OlmoForCausalLM,e0 as OlmoHybridForCausalLM,Zy as OlmoHybridModel,gi as OlmoHybridPreTrainedModel,Hy as OlmoModel,_i as OlmoPreTrainedModel,r0 as OpenELMForCausalLM,t0 as OpenELMModel,wi as OpenELMPreTrainedModel,lm as OwlViTFeatureExtractor,l0 as OwlViTForObjectDetection,xn as OwlViTImageProcessor,i0 as OwlViTModel,bi as OwlViTPreTrainedModel,Nm as OwlViTProcessor,a0 as Owlv2ForObjectDetection,cm as Owlv2ImageProcessor,o0 as Owlv2Model,yi as Owlv2PreTrainedModel,c0 as PaliGemmaForConditionalGeneration,$m as PaliGemmaProcessor,E_ as ParakeetFeatureExtractor,u0 as ParakeetForCTC,Gu as ParakeetPreTrainedModel,d0 as PatchTSMixerForPrediction,p0 as PatchTSMixerModel,vi as PatchTSMixerPreTrainedModel,_0 as PatchTSTForPrediction,f0 as PatchTSTModel,ki as PatchTSTPreTrainedModel,w0 as Phi3ForCausalLM,g0 as Phi3Model,Ai as Phi3PreTrainedModel,Mi as Phi3VForCausalLM,dm as Phi3VImageProcessor,qu as Phi3VPreTrainedModel,Rm as Phi3VProcessor,h0 as PhiForCausalLM,m0 as PhiModel,Ei as PhiPreTrainedModel,fm as PixtralImageProcessor,Dm as PixtralProcessor,y as PreTrainedModel,q as PreTrainedTokenizer,En as PretrainedConfig,re as Processor,y0 as PvtForImageClassification,_m as PvtImageProcessor,x0 as PvtModel,Si as PvtPreTrainedModel,$o as PyAnnoteFeatureExtractor,v0 as PyAnnoteForAudioFrameClassification,b0 as PyAnnoteModel,Ti as PyAnnotePreTrainedModel,Fm as PyAnnoteProcessor,fl as QuestionAnsweringPipeline,E0 as Qwen2ForCausalLM,k0 as Qwen2Model,M0 as Qwen2MoeForCausalLM,A0 as Qwen2MoeModel,Ii as Qwen2MoePreTrainedModel,Oi as Qwen2PreTrainedModel,r_ as Qwen2Tokenizer,Ps as Qwen2VLForCausalLM,Rn as Qwen2VLForConditionalGeneration,Do as Qwen2VLImageProcessor,Ou as Qwen2VLPreTrainedModel,Es as Qwen2VLProcessor,Ns as Qwen2_5_VLForCausalLM,zs as Qwen2_5_VLForConditionalGeneration,Bo as Qwen2_5_VLProcessor,T0 as Qwen3ForCausalLM,S0 as Qwen3Model,I0 as Qwen3MoeForCausalLM,O0 as Qwen3MoeModel,Li as Qwen3MoePreTrainedModel,L0 as Qwen3NextForCausalLM,C0 as Qwen3NextModel,Pi as Qwen3NextPreTrainedModel,Ci as Qwen3PreTrainedModel,Us as Qwen3VLForCausalLM,Bs as Qwen3VLForConditionalGeneration,zi as Qwen3VLMoeForCausalLM,P0 as Qwen3VLMoeForConditionalGeneration,Bm as Qwen3VLProcessor,js as Qwen3_5ForCausalLM,qn as Qwen3_5ForConditionalGeneration,Ni as Qwen3_5MoeForCausalLM,z0 as Qwen3_5MoeForConditionalGeneration,D0 as RFDetrForObjectDetection,R0 as RFDetrModel,Wu as RFDetrObjectDetectionOutput,Ri as RFDetrPreTrainedModel,cg as RTDetrForObjectDetection,mm as RTDetrImageProcessor,lg as RTDetrModel,ur as RTDetrObjectDetectionOutput,ua as RTDetrPreTrainedModel,Q0 as RTDetrV2ForObjectDetection,K0 as RTDetrV2Model,Vu as RTDetrV2ObjectDetectionOutput,Di as RTDetrV2PreTrainedModel,Po as RawAudio,Qe as RawImage,Lp as RawVideo,zl as RawVideoFrame,nu as RepetitionPenaltyLogitsProcessor,$0 as ResNetForImageClassification,N0 as ResNetModel,$i as ResNetPreTrainedModel,W0 as RoFormerForMaskedLM,X0 as RoFormerForQuestionAnswering,V0 as RoFormerForSequenceClassification,H0 as RoFormerForTokenClassification,q0 as RoFormerModel,es as RoFormerPreTrainedModel,n_ as RoFormerTokenizer,B0 as RobertaForMaskedLM,G0 as RobertaForQuestionAnswering,U0 as RobertaForSequenceClassification,j0 as RobertaForTokenClassification,F0 as RobertaModel,Zr as RobertaPreTrainedModel,s_ as RobertaTokenizer,Fo as Sam2ImageProcessor,Ku as Sam2ImageSegmentationOutput,Fi as Sam2Model,Qu as Sam2PreTrainedModel,Xc as Sam2Processor,Um as Sam2VideoProcessor,Fo as Sam3ImageProcessor,Z0 as Sam3TrackerModel,Fo as SamImageProcessor,Hu as SamImageSegmentationOutput,Y0 as SamModel,Xu as SamPreTrainedModel,Uo as SamProcessor,hm as SapiensFeatureExtractor,tb as SapiensForDepthEstimation,rb as SapiensForNormalEstimation,eb as SapiensForSemanticSegmentation,Gc as SapiensImageProcessor,Wn as SapiensPreTrainedModel,A_ as SeamlessM4TFeatureExtractor,gm as SegformerFeatureExtractor,nb as SegformerForImageClassification,ob as SegformerForSemanticSegmentation,qc as SegformerImageProcessor,sb as SegformerModel,Vn as SegformerPreTrainedModel,wm as SiglipImageProcessor,ab as SiglipModel,Bi as SiglipPreTrainedModel,Ui as SiglipTextModel,o_ as SiglipTokenizer,ib as SiglipVisionModel,cb as SmolLM3ForCausalLM,lb as SmolLM3Model,ji as SmolLM3PreTrainedModel,Rc as SmolVLMImageProcessor,Hc as SmolVLMProcessor,qi as SnacDecoderModel,Gi as SnacEncoderModel,M_ as SnacFeatureExtractor,ub as SnacModel,Hn as SnacPreTrainedModel,db as SolarOpenForCausalLM,pb as SolarOpenModel,Wi as SolarOpenPreTrainedModel,S_ as SpeechT5FeatureExtractor,_b as SpeechT5ForSpeechToText,mb as SpeechT5ForTextToSpeech,hb as SpeechT5HifiGan,fb as SpeechT5Model,Xn as SpeechT5PreTrainedModel,jm as SpeechT5Processor,a_ as SpeechT5Tokenizer,wb as SqueezeBertForMaskedLM,yb as SqueezeBertForQuestionAnswering,xb as SqueezeBertForSequenceClassification,gb as SqueezeBertModel,Gs as SqueezeBertPreTrainedModel,i_ as SqueezeBertTokenizer,vb as StableLmForCausalLM,bb as StableLmModel,Vi as StableLmPreTrainedModel,Eb as Starcoder2ForCausalLM,kb as Starcoder2Model,Hi as Starcoder2PreTrainedModel,Gr as StoppingCriteria,Sn as StoppingCriteriaList,Ab as StyleTextToSpeech2Model,Yu as StyleTextToSpeech2PreTrainedModel,ml as SummarizationPipeline,Xi as SupertonicForConditionalGeneration,Ju as SupertonicPreTrainedModel,An as SuppressTokensAtBeginLogitsProcessor,Ib as Swin2SRForImageSuperResolution,xm as Swin2SRImageProcessor,Ob as Swin2SRModel,Ki as Swin2SRPreTrainedModel,Sb as SwinForImageClassification,Tb as SwinForSemanticSegmentation,Mb as SwinModel,Kn as SwinPreTrainedModel,Lb as T5ForConditionalGeneration,Cb as T5Model,Qi as T5PreTrainedModel,l_ as T5Tokenizer,zb as TableTransformerForObjectDetection,Pb as TableTransformerModel,Zu as TableTransformerObjectDetectionOutput,Yi as TableTransformerPreTrainedModel,cu as TemperatureLogitsWarper,$ as Tensor,vr as Text2TextGenerationPipeline,pl as TextClassificationPipeline,gl as TextGenerationPipeline,I1 as TextStreamer,vl as TextToAudioPipeline,dl as TokenClassificationPipeline,q as TokenizersBackend,W2 as TopKLogitsWarper,q2 as TopPLogitsWarper,Nb as TrOCRForCausalLM,ep as TrOCRPreTrainedModel,hl as TranslationPipeline,$s as UltravoxModel,Iu as UltravoxPreTrainedModel,Gm as UltravoxProcessor,Rb as UniSpeechForCTC,Db as UniSpeechForSequenceClassification,$b as UniSpeechModel,Qn as UniSpeechPreTrainedModel,jb as UniSpeechSatForAudioFrameClassification,Bb as UniSpeechSatForCTC,Ub as UniSpeechSatForSequenceClassification,Fb as UniSpeechSatModel,qs as UniSpeechSatPreTrainedModel,Om as VLChatProcessor,Q_ as VLMImageProcessor,qb as VaultGemmaForCausalLM,Gb as VaultGemmaModel,Ji as VaultGemmaPreTrainedModel,ym as ViTFeatureExtractor,Hb as ViTForImageClassification,Wc as ViTImageProcessor,Xb as ViTMAEModel,tp as ViTMAEPreTrainedModel,Qb as ViTMSNForImageClassification,Kb as ViTMSNModel,el as ViTMSNPreTrainedModel,Vb as ViTModel,Zi as ViTPreTrainedModel,Wb as VisionEncoderDecoderModel,Yb as VitMatteForImageMatting,bm as VitMatteImageProcessor,rp as VitMattePreTrainedModel,Jb as VitPoseForPoseEstimation,vm as VitPoseImageProcessor,sp as VitPosePreTrainedModel,Zb as VitsModel,np as VitsModelOutput,op as VitsPreTrainedModel,u_ as VitsTokenizer,e1 as VoxtralForConditionalGeneration,qm as VoxtralProcessor,I_ as VoxtralRealtimeFeatureExtractor,tl as VoxtralRealtimeForConditionalGeneration,ap as VoxtralRealtimePreTrainedModel,Vm as VoxtralRealtimeProcessor,n1 as Wav2Vec2BertForCTC,o1 as Wav2Vec2BertForSequenceClassification,s1 as Wav2Vec2BertModel,Yn as Wav2Vec2BertPreTrainedModel,p_ as Wav2Vec2CTCTokenizer,T_ as Wav2Vec2FeatureExtractor,nx as Wav2Vec2ForAudioFrameClassification,rx as Wav2Vec2ForCTC,sx as Wav2Vec2ForSequenceClassification,tx as Wav2Vec2Model,Zt as Wav2Vec2PreTrainedModel,Hm as Wav2Vec2Processor,Xm as Wav2Vec2ProcessorWithLM,u1 as WavLMForAudioFrameClassification,i1 as WavLMForCTC,l1 as WavLMForSequenceClassification,c1 as WavLMForXVector,a1 as WavLMModel,ts as WavLMPreTrainedModel,O_ as WeSpeakerFeatureExtractor,p1 as WeSpeakerResNetModel,lp as WeSpeakerResNetPreTrainedModel,C_ as WhisperFeatureExtractor,up as WhisperForConditionalGeneration,d1 as WhisperModel,rl as WhisperPreTrainedModel,Km as WhisperProcessor,UM as WhisperTextStreamer,ru as WhisperTimeStampLogitsProcessor,d_ as WhisperTokenizer,w1 as XLMForQuestionAnswering,h1 as XLMForSequenceClassification,g1 as XLMForTokenClassification,_1 as XLMModel,rs as XLMPreTrainedModel,y1 as XLMRobertaForMaskedLM,k1 as XLMRobertaForQuestionAnswering,b1 as XLMRobertaForSequenceClassification,v1 as XLMRobertaForTokenClassification,x1 as XLMRobertaModel,ss as XLMRobertaPreTrainedModel,f_ as XLMRobertaTokenizer,__ as XLMTokenizer,m1 as XLMWithLMHeadModel,ip as XVectorOutput,km as YolosFeatureExtractor,A1 as YolosForObjectDetection,Vc as YolosImageProcessor,E1 as YolosModel,pp as YolosObjectDetectionOutput,sl as YolosPreTrainedModel,S1 as YoutuForCausalLM,M1 as YoutuModel,nl as YoutuPreTrainedModel,yl as ZeroShotAudioClassificationPipeline,wl as ZeroShotClassificationPipeline,Ml as ZeroShotImageClassificationPipeline,Tl as ZeroShotObjectDetectionPipeline,ke as cat,EP as cos_sim,PE as dot,_e as env,He as full,Oo as full_like,wf as interpolate,yt as interpolate_4d,KR as layer_norm,Tz as load_image,wN as load_video,kd as log_softmax,y2 as matmul,Ac as mean,b2 as mean_pooling,tt as ones,Mc as ones_like,az as permute,Rae as pipeline,k2 as quantize_embeddings,QR as rand,v2 as randn,ps as random,g_ as read_audio,XR as rfft,Ec as slice,Ne as softmax,St as stack,xf as std_mean,Yt as topk,bf as zeros,vf as zeros_like};