@onirix/ar-engine-sdk 1.10.0 → 1.11.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +10 -0
- package/dist/onirix_native_sdk.js +1 -1
- package/dist/ox-sdk.esm.js +3 -3
- package/package.json +3 -3
package/dist/ox-sdk.esm.js
CHANGED
@@ -38,7 +38,7 @@ class Euler{constructor(t=0,a=0,h=0,s="XYZ"){this.x=t,this.y=a,this.z=h,this.ord
|
|
38
38
|
|
39
39
|
const mat4RotationZ90CCW=(new Matrix4).set(0,1,0,0,-1,0,0,0,0,0,1,0,0,0,0,1),mat4RotationZ90CW=(new Matrix4).set(0,-1,0,0,1,0,0,0,0,0,1,0,0,0,0,1),mat4RotationX90CW=(new Matrix4).set(1,0,0,0,0,0,1,0,0,-1,0,0,0,0,0,1),mat3RotationX90CCW=(new Matrix3).set(1,0,0,0,0,1,0,-1,0),mat3RotationZ90CW=(new Matrix3).set(0,-1,0,1,0,0,0,0,1);
|
40
40
|
|
41
|
-
class NativeManager{constructor(t,i,e,a){this.uiManager=t,this.deviceManager=i,this.workerManager=e,this.indexedDBManager=a,this.webXRRelocationListener=null,this.osfStrBuffer=null;}async init(t,i){try{let e=new URL("./onirix_native_sdk.js",import.meta.url),a=await this.indexedDBManager.getFromCacheOrFetch("SDK_1.10.0",e),r=URL.createObjectURL(new Blob([a],{type:"text/javascript"}));const{default:s}=await import(/* webpackIgnore: true, webpackMode: "lazy" */r);let n,o,h;if(this.useVocabulary=i.useVocabulary,this.host=i.host??"https://studio.onirix.com",this.useVocabulary&&(n=await this.indexedDBManager.getFromCacheOrFetch("orb.fbow","https://cdn.onirix.com/onirix-engine-sdk/orb.fbow")),i.mode===TrackingMode.Spatial){if(o=await fetch(`${this.host}/api/projects/self/targets/${i.sceneOid}/osf?token=${t}`),!o.ok)throw new ReconstructionPendingError(`Could not get Onirix Spatial File. Server responded with ${o.status}`);const e=await o.arrayBuffer();h=new Uint8Array(e),await this.workerManager.createWorkers();}this.nativeSDK=await s({preRun:e=>{i.mode==TrackingMode.Spatial?e.FS_createDataFile("/","scene.osf",h,!0,!0,!0):i.mode===TrackingMode.Curved||i.mode===TrackingMode.Image?(this.useVocabulary&&e.FS_createDataFile("/","orb.fbow",n,!0,!0,!0),e.FS_createPreloadedFile("/","classifier.otf",`${this.host}/api/projects/self/targets/otf?token=${t}`,!0,!1)):i.mode===TrackingMode.Surface&&this.useVocabulary&&e.FS_createDataFile("/","orb.fbow",n,!0,!0,!0);}}),this.spatialBufferSize=this.getBufferSize(),this.buffer=this.nativeSDK._malloc(1228800),this.imageBuffer=this.nativeSDK._malloc(1228800),this.imuAccData=this.nativeSDK._malloc(32),this.imuRotData=this.nativeSDK._malloc(72),this.cameraParamsStruct=this.nativeSDK._malloc(40),this.frameLayoutStruct=this.nativeSDK._malloc(28),this.nativeSDK.HEAPU32[this.cameraParamsStruct/4+0]=640,this.nativeSDK.HEAPU32[this.cameraParamsStruct/4+1]=480,this.nativeSDK.HEAPF64[this.cameraParamsStruct/8+1]=468,this.nativeSDK.HEAPF64[this.cameraParamsStruct/8+2]=468,this.nativeSDK.HEAPF64[this.cameraParamsStruct/8+3]=320,this.nativeSDK.HEAPF64[this.cameraParamsStruct/8+4]=240,i.debug&&this.nativeSDK._OX_SetLogCallback(this.nativeSDK.addFunction((t=>{console.log(`[OnirixEngineSDK] ${this.nativeSDK.UTF8ToString(t)}`);}),"vi"));}catch(t){throw console.log(t),t instanceof ReconstructionPendingError?t:new InternalError(t)}await this.checkLicense(t,i);}getBufferSize(){return this.nativeSDK._OX_GetBufferSize()}getIntrinsics(){return [this.nativeSDK.HEAPF64[this.cameraParamsStruct/8+2],this.nativeSDK.HEAPF64[this.cameraParamsStruct/8+3],this.nativeSDK.HEAPF64[this.cameraParamsStruct/8+4]]}setIntrinsics(t,i,e){this.nativeSDK.HEAPF64[this.cameraParamsStruct/8+1]=t,this.nativeSDK.HEAPF64[this.cameraParamsStruct/8+2]=t,this.nativeSDK.HEAPF64[this.cameraParamsStruct/8+3]=i,this.nativeSDK.HEAPF64[this.cameraParamsStruct/8+4]=e,this.nativeSDK._OX_UpdateIntrinsics(t,i,e);}async checkLicense(t,i){try{const e=this.getStringBuffer(this.host),a=this.getStringBuffer(t),r=this.getStringBuffer(window.location.hostname),s=this.getStringBuffer(this.deviceManager.platform),n=this.getStringBuffer(this.deviceManager.device),o=this.getStringBuffer(JSON.stringify(i)),h=await new Promise(((t,i)=>{this.nativeSDK._OX_SetLicense([e],[a],[r],[s],[n],[o],this.nativeSDK.addFunction(((i,e)=>t({ivl:i,oxError:this.nativeSDK.UTF8ToString(e)})),"vii"));}));if(this.releaseStringBuffer(e),this.releaseStringBuffer(a),this.releaseStringBuffer(r),this.releaseStringBuffer(s),this.releaseStringBuffer(n),this.releaseStringBuffer(o),!h.ivl)throw new LicenseError("Invalid license",h.oxError)}catch(t){throw new LicenseError(t,t.oxError)}}startImageTracking(t,i,e,a,r=!1){if(this.onDetected=t,this.onPose=i,this.onLost=e,this.useVocabulary){const t=this.getStringBuffer("orb.fbow");this.nativeSDK._OX_Initialize(this.cameraParamsStruct,[t]),this.releaseStringBuffer(t);}else this.nativeSDK._OX_Initialize(this.cameraParamsStruct,"");let s=this.getStringBuffer("classifier.otf");this.nativeSDK._OX_LoadImageClassifier([s]),this.releaseStringBuffer(s),this.nativeSDK._OX_StartImageDetection(2,r?1:a,this.nativeSDK.addFunction((t=>this.onDetected(this.nativeSDK.UTF8ToString(t))),"vi"),this.nativeSDK.addFunction((t=>{const i=this.nativeSDK.HEAPF64.subarray(t/8,t/8+16);let e=(new Matrix4).fromArray(i);e.multiply(mat4RotationX90CW),e.invert(),this.uiManager.isPortrait()?(e.multiply(r?mat4RotationZ90CW:mat4RotationZ90CCW),this.onPose(e.toArray())):this.onPose(e.toArray());}),"vi"),this.nativeSDK.addFunction((t=>this.onLost(this.nativeSDK.UTF8ToString(t))),"vi"));}startCurvedImageTracking(t,i,e){if(this.onDetected=t,this.onPose=i,this.onLost=e,this.useVocabulary){const t=this.getStringBuffer("orb.fbow");this.nativeSDK._OX_Initialize(this.cameraParamsStruct,[t]),this.releaseStringBuffer(t);}else this.nativeSDK._OX_Initialize(this.cameraParamsStruct,"");let a=this.getStringBuffer("classifier.otf");this.nativeSDK._OX_LoadImageClassifier([a]),this.releaseStringBuffer(a),this.nativeSDK._OX_StartCurvedImageDetection(2,1,this.nativeSDK.addFunction((t=>this.onDetected(this.nativeSDK.UTF8ToString(t))),"vi"),this.nativeSDK.addFunction((t=>{const i=this.nativeSDK.HEAPF64.subarray(t/8,t/8+16);let e=(new Matrix4).fromArray(i);e.multiply(mat4RotationX90CW),e.invert(),this.uiManager.isPortrait()?(e.multiply(mat4RotationZ90CCW),this.onPose(e.toArray())):this.onPose(e.toArray());}),"vi"),this.nativeSDK.addFunction((t=>this.onLost(this.nativeSDK.UTF8ToString(t))),"vi"));}startQRCodeTracking(t,i,e){this.onDetected=t,this.onPose=i,this.onLost=e,this.nativeSDK._OX_Initialize(this.cameraParamsStruct,""),this.nativeSDK._OX_StartQRCodeDetection(2,this.nativeSDK.addFunction((t=>this.onDetected(this.nativeSDK.UTF8ToString(t))),"vi"),this.nativeSDK.addFunction((t=>{const i=this.nativeSDK.HEAPF64.subarray(t/8,t/8+16);let e=(new Matrix4).fromArray(i);e.multiply(mat4RotationX90CW),e.invert(),this.uiManager.isPortrait()?(e.multiply(mat4RotationZ90CCW),this.onPose(e.toArray())):this.onPose(e.toArray());}),"vi"),this.nativeSDK.addFunction((t=>this.onLost(this.nativeSDK.UTF8ToString(t))),"vi"));}startSLAM(t,i,e){if(this.onPose=t,this.onKeyFrame=i,this.onStatusChange=e,this.useVocabulary){const t=this.getStringBuffer("orb.fbow");this.nativeSDK._OX_Initialize(this.cameraParamsStruct,[t]),this.releaseStringBuffer(t);}else this.nativeSDK._OX_Initialize(this.cameraParamsStruct,"");this.nativeSDK._OX_StartSLAM(this.nativeSDK.addFunction((t=>{const i=this.nativeSDK.HEAPF64.subarray(t/8,t/8+16);let e=(new Matrix4).fromArray(i);e.invert(),this.uiManager.isPortrait()?(e.multiply(mat4RotationZ90CCW),this.onPose(e.toArray())):this.onPose(e.toArray());}),"vi"),null!=this.onKeyFrame?this.nativeSDK.addFunction((()=>this.onKeyFrame()),"v"):null,this.nativeSDK.addFunction(((t,i)=>{this.onStatusChange([this.nativeSDK.UTF8ToString(t),this.nativeSDK.UTF8ToString(i)]);}),"vii"));}startSpatialTracking(t,i,e){if(this.onDetected=t,e||(this.onPose=i),this.nativeSDK._OX_Initialize(this.cameraParamsStruct,""),this.nativeSDK._OX_StartSpatialTracking(this.nativeSDK.addFunction((t=>{e||(this.spatialLocated=!0),this.onDetected("");}),"vi"),this.nativeSDK.addFunction((t=>{const i=this.nativeSDK.HEAPF64.subarray(t/8,t/8+16);let a=(new Matrix4).fromArray(i);a.invert(),this.uiManager.isPortrait()&&a.multiply(e?mat4RotationZ90CW:mat4RotationZ90CCW),e?(this.webXRRelocationListener(a),this.onDetected("")):this.onPose(a.toArray());}),"vi"),!e),this.osfStrBuffer=this.getStringBuffer("scene.osf"),this.nativeSDK._OX_LoadOSF(this.osfStrBuffer),!e&&2==this.extractionType())throw new InternalError("Onirix compatibility mode for WorldTracking is not supported for Spatial scenes.")}processFrame(t,i=null,e=480,a=640,r=0,s=0){let n=i||this.buffer;this.nativeSDK.HEAPU8.set(t,n),this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+0]=a,this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+1]=e,this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+2]=4*a,this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+3]=!1,this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+4]=5,this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+5]=s,this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+6]=r,this.nativeSDK._OX_ProcessFrame(n,this.frameLayoutStruct);}getXRFrameBuffer(t,i){return this.xrBuffer||(this.xrBuffer=this.nativeSDK._malloc(t*i*4)),this.xrBuffer}initExtractionBuffers(){this.extractionBuffer=this.nativeSDK._malloc(4*this.spatialBufferSize),this.matchBuffer=this.nativeSDK._malloc(14e3),this.coarseLocationBuffer=this.nativeSDK._malloc(32768);}loadExtractionData(t,i=-1){return this.extractionBuffer&&this.coarseLocationBuffer?(this.nativeSDK.HEAPF32.set(t.extraction,this.extractionBuffer/4),this.nativeSDK.HEAPF32.set(t.descriptor,this.coarseLocationBuffer/4),this.nativeSDK._OX_LoadExtractionData(this.extractionBuffer,this.coarseLocationBuffer,i)):0}coarseLocationCheck(t){return this.coarseLocationBuffer?(this.nativeSDK.HEAPF32.set(t.descriptor,this.coarseLocationBuffer/4),this.nativeSDK._OX_CoarseLocationCheck(this.coarseLocationBuffer)):0}getCandidateData(t){let i=this.nativeSDK._OX_GetCandidateData(t);return new Float32Array(this.nativeSDK.HEAPF32.buffer,i,this.spatialBufferSize)}loadMatch(t){this.matchBuffer&&(this.nativeSDK.HEAPF32.set(t,this.matchBuffer/4),this.nativeSDK._OX_LoadMatch(this.matchBuffer));}spatialLocalize(){return this.nativeSDK._OX_SpatialLocalize()}setSpatialQualityLevel(t){return this.nativeSDK._OX_SetSpatialQualityLevel(t)}loadKeyframePose(t){this.nativeSDK._OX_LoadKfPose(t);}numSLAMKeyframes(){return this.nativeSDK._OX_GetSLAMNumKfs()}getSLAMKeyframe(t){let i=this.nativeSDK._OX_GetSLAMKf(t),e=[];for(let t=0;t<1228800;t++)e.push(this.nativeSDK.HEAPU8[i+t]);return new Uint8Array(e)}stopImageTracking(){this.nativeSDK._OX_StopImageDetection();}stopQRCodeTracking(){this.nativeSDK._OX_StopQRCodeDetection();}stopSLAM(){this.nativeSDK._OX_StopSLAM();}stopSpatialTracking(){this.nativeSDK._OX_StopSpatialTracking();}addImage(t,i){this.nativeSDK.HEAPU8.set(i,this.imageBuffer),this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+0]=640,this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+1]=480,this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+2]=2560,this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+3]=!1,this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+4]=5,this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+5]=0,this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+6]=0;const e=this.getStringBuffer(t);this.nativeSDK._OX_AddImage([e],this.imageBuffer,this.frameLayoutStruct),this.releaseStringBuffer(e);}destroy(){this.nativeSDK._OX_Destroy(),this.osfStrBuffer&&this.releaseStringBuffer(this.osfStrBuffer);}extractionType(){return this.nativeSDK._OX_ExtractionType()}getStringBuffer(t){const i=this.nativeSDK.lengthBytesUTF8(t)+1;let e=this.nativeSDK._malloc(i);return this.nativeSDK.stringToUTF8(t,e,i),e}releaseStringBuffer(t){this.nativeSDK._free(t);}parseNativeJSON(t){let i;try{i=JSON.parse(t);}catch(i){console.error(`Could not parse ${t}`);}return i}getSLAMMap(){return this.parseNativeJSON(this.nativeSDK.UTF8ToString(this.nativeSDK._OX_GetSLAMMap()))}getSLAMTrackingPoints(){return this.parseNativeJSON(this.nativeSDK.UTF8ToString(this.nativeSDK._OX_GetSLAMTrackingPoints()))}raycast(t,i,e,a,r,s){return this.parseNativeJSON(this.nativeSDK.UTF8ToString(this.nativeSDK._OX_Raycast(t,i,e,a,r,s)))}getSpatialMap(){return this.parseNativeJSON(this.nativeSDK.UTF8ToString(this.nativeSDK._OX_GetSpatialMap()))}setWebXRRelocationListener(t){this.webXRRelocationListener=t;}}
|
41
|
+
class NativeManager{constructor(t,i,e,a){this.uiManager=t,this.deviceManager=i,this.workerManager=e,this.indexedDBManager=a,this.webXRRelocationListener=null,this.osfStrBuffer=null;}async init(t,i){try{let e=new URL("./onirix_native_sdk.js",import.meta.url),a=await this.indexedDBManager.getFromCacheOrFetch("SDK_1.11.0",e),r=URL.createObjectURL(new Blob([a],{type:"text/javascript"}));const{default:s}=await import(/* webpackIgnore: true, webpackMode: "lazy" */r);let n,o,h;if(this.useVocabulary=i.useVocabulary,this.host=i.host??"https://studio.onirix.com",this.useVocabulary&&(n=await this.indexedDBManager.getFromCacheOrFetch("orb.fbow","https://cdn.onirix.com/onirix-engine-sdk/orb.fbow")),i.mode===TrackingMode.Spatial){if(o=await fetch(`${this.host}/api/projects/self/targets/${i.sceneOid}/osf?token=${t}`),!o.ok)throw new ReconstructionPendingError(`Could not get Onirix Spatial File. Server responded with ${o.status}`);const e=await o.arrayBuffer();h=new Uint8Array(e),await this.workerManager.createWorkers();}this.nativeSDK=await s({preRun:e=>{i.mode==TrackingMode.Spatial?e.FS_createDataFile("/","scene.osf",h,!0,!0,!0):i.mode===TrackingMode.Curved||i.mode===TrackingMode.Image?(this.useVocabulary&&e.FS_createDataFile("/","orb.fbow",n,!0,!0,!0),e.FS_createPreloadedFile("/","classifier.otf",`${this.host}/api/projects/self/targets/otf?token=${t}`,!0,!1)):i.mode===TrackingMode.Surface&&this.useVocabulary&&e.FS_createDataFile("/","orb.fbow",n,!0,!0,!0);}}),this.spatialBufferSize=this.getBufferSize(),this.lastPoseBuffer=this.nativeSDK._malloc(64),this.buffer=this.nativeSDK._malloc(1228800),this.imageBuffer=this.nativeSDK._malloc(1228800),this.imuAccData=this.nativeSDK._malloc(32),this.imuRotData=this.nativeSDK._malloc(72),this.cameraParamsStruct=this.nativeSDK._malloc(40),this.frameLayoutStruct=this.nativeSDK._malloc(28),this.nativeSDK.HEAPU32[this.cameraParamsStruct/4+0]=640,this.nativeSDK.HEAPU32[this.cameraParamsStruct/4+1]=480,this.nativeSDK.HEAPF64[this.cameraParamsStruct/8+1]=468,this.nativeSDK.HEAPF64[this.cameraParamsStruct/8+2]=468,this.nativeSDK.HEAPF64[this.cameraParamsStruct/8+3]=320,this.nativeSDK.HEAPF64[this.cameraParamsStruct/8+4]=240,i.debug&&this.nativeSDK._OX_SetLogCallback(this.nativeSDK.addFunction((t=>{console.log(`[OnirixEngineSDK] ${this.nativeSDK.UTF8ToString(t)}`);}),"vi"));}catch(t){throw console.log(t),t instanceof ReconstructionPendingError?t:new InternalError(t)}await this.checkLicense(t,i);}getBufferSize(){return this.nativeSDK._OX_GetBufferSize()}getIntrinsics(){return [this.nativeSDK.HEAPF64[this.cameraParamsStruct/8+2],this.nativeSDK.HEAPF64[this.cameraParamsStruct/8+3],this.nativeSDK.HEAPF64[this.cameraParamsStruct/8+4]]}setIntrinsics(t,i,e){this.nativeSDK.HEAPF64[this.cameraParamsStruct/8+1]=t,this.nativeSDK.HEAPF64[this.cameraParamsStruct/8+2]=t,this.nativeSDK.HEAPF64[this.cameraParamsStruct/8+3]=i,this.nativeSDK.HEAPF64[this.cameraParamsStruct/8+4]=e,this.nativeSDK._OX_UpdateIntrinsics(t,i,e);}async checkLicense(t,i){try{const e=this.getStringBuffer(this.host),a=this.getStringBuffer(t),r=this.getStringBuffer(window.location.hostname),s=this.getStringBuffer(this.deviceManager.platform),n=this.getStringBuffer(this.deviceManager.device),o=this.getStringBuffer(JSON.stringify(i)),h=await new Promise(((t,i)=>{this.nativeSDK._OX_SetLicense([e],[a],[r],[s],[n],[o],this.nativeSDK.addFunction(((i,e)=>t({ivl:i,oxError:this.nativeSDK.UTF8ToString(e)})),"vii"));}));if(this.releaseStringBuffer(e),this.releaseStringBuffer(a),this.releaseStringBuffer(r),this.releaseStringBuffer(s),this.releaseStringBuffer(n),this.releaseStringBuffer(o),!h.ivl)throw new LicenseError("Invalid license",h.oxError)}catch(t){throw new LicenseError(t,t.oxError)}}startImageTracking(t,i,e,a,r=!1){if(this.onDetected=t,this.onPose=i,this.onLost=e,this.useVocabulary){const t=this.getStringBuffer("orb.fbow");this.nativeSDK._OX_Initialize(this.cameraParamsStruct,[t]),this.releaseStringBuffer(t);}else this.nativeSDK._OX_Initialize(this.cameraParamsStruct,"");let s=this.getStringBuffer("classifier.otf");this.nativeSDK._OX_LoadImageClassifier([s]),this.releaseStringBuffer(s),this.nativeSDK._OX_StartImageDetection(2,r?1:a,this.nativeSDK.addFunction((t=>this.onDetected(this.nativeSDK.UTF8ToString(t))),"vi"),this.nativeSDK.addFunction((t=>{const i=this.nativeSDK.HEAPF64.subarray(t/8,t/8+16);let e=(new Matrix4).fromArray(i);e.multiply(mat4RotationX90CW),e.invert(),this.uiManager.isPortrait()?(e.multiply(r?mat4RotationZ90CW:mat4RotationZ90CCW),this.onPose(e.toArray())):this.onPose(e.toArray());}),"vi"),this.nativeSDK.addFunction((t=>this.onLost(this.nativeSDK.UTF8ToString(t))),"vi"));}startCurvedImageTracking(t,i,e){if(this.onDetected=t,this.onPose=i,this.onLost=e,this.useVocabulary){const t=this.getStringBuffer("orb.fbow");this.nativeSDK._OX_Initialize(this.cameraParamsStruct,[t]),this.releaseStringBuffer(t);}else this.nativeSDK._OX_Initialize(this.cameraParamsStruct,"");let a=this.getStringBuffer("classifier.otf");this.nativeSDK._OX_LoadImageClassifier([a]),this.releaseStringBuffer(a),this.nativeSDK._OX_StartCurvedImageDetection(2,1,this.nativeSDK.addFunction((t=>this.onDetected(this.nativeSDK.UTF8ToString(t))),"vi"),this.nativeSDK.addFunction((t=>{const i=this.nativeSDK.HEAPF64.subarray(t/8,t/8+16);let e=(new Matrix4).fromArray(i);e.multiply(mat4RotationX90CW),e.invert(),this.uiManager.isPortrait()?(e.multiply(mat4RotationZ90CCW),this.onPose(e.toArray())):this.onPose(e.toArray());}),"vi"),this.nativeSDK.addFunction((t=>this.onLost(this.nativeSDK.UTF8ToString(t))),"vi"));}startQRCodeTracking(t,i,e){this.onDetected=t,this.onPose=i,this.onLost=e,this.nativeSDK._OX_Initialize(this.cameraParamsStruct,""),this.nativeSDK._OX_StartQRCodeDetection(2,this.nativeSDK.addFunction((t=>this.onDetected(this.nativeSDK.UTF8ToString(t))),"vi"),this.nativeSDK.addFunction((t=>{const i=this.nativeSDK.HEAPF64.subarray(t/8,t/8+16);let e=(new Matrix4).fromArray(i);e.multiply(mat4RotationX90CW),e.invert(),this.uiManager.isPortrait()?(e.multiply(mat4RotationZ90CCW),this.onPose(e.toArray())):this.onPose(e.toArray());}),"vi"),this.nativeSDK.addFunction((t=>this.onLost(this.nativeSDK.UTF8ToString(t))),"vi"));}startSLAM(t,i,e){if(this.onPose=t,this.onKeyFrame=i,this.onStatusChange=e,this.useVocabulary){const t=this.getStringBuffer("orb.fbow");this.nativeSDK._OX_Initialize(this.cameraParamsStruct,[t]),this.releaseStringBuffer(t);}else this.nativeSDK._OX_Initialize(this.cameraParamsStruct,"");this.nativeSDK._OX_StartSLAM(this.nativeSDK.addFunction((t=>{const i=this.nativeSDK.HEAPF64.subarray(t/8,t/8+16);let e=(new Matrix4).fromArray(i);e.invert(),this.uiManager.isPortrait()?(e.multiply(mat4RotationZ90CCW),this.onPose(e.toArray())):this.onPose(e.toArray());}),"vi"),null!=this.onKeyFrame?this.nativeSDK.addFunction((()=>this.onKeyFrame()),"v"):null,this.nativeSDK.addFunction(((t,i)=>{this.onStatusChange([this.nativeSDK.UTF8ToString(t),this.nativeSDK.UTF8ToString(i)]);}),"vii"));}startSpatialTracking(t,i,e){if(this.onDetected=t,e||(this.onPose=i),this.nativeSDK._OX_Initialize(this.cameraParamsStruct,""),this.nativeSDK._OX_StartSpatialTracking(this.nativeSDK.addFunction((t=>{e||(this.spatialLocated=!0),this.onDetected("");}),"vi"),this.nativeSDK.addFunction((t=>{const i=this.nativeSDK.HEAPF64.subarray(t/8,t/8+16);let a=(new Matrix4).fromArray(i);e?(this.webXRRelocationListener(a),this.onDetected("")):this.onPose(a.toArray());}),"vi"),!e),this.osfStrBuffer=this.getStringBuffer("scene.osf"),this.nativeSDK._OX_LoadOSF(this.osfStrBuffer),!e&&2==this.extractionType())throw new InternalError("Onirix compatibility mode for WorldTracking is not supported for Spatial scenes.")}processFrame(t,i=null,e=480,a=640,r=0,s=0){let n=i||this.buffer;this.nativeSDK.HEAPU8.set(t,n),this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+0]=a,this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+1]=e,this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+2]=4*a,this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+3]=!1,this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+4]=5,this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+5]=s,this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+6]=r,this.nativeSDK._OX_ProcessFrame(n,this.frameLayoutStruct);}getXRFrameBuffer(t,i){return this.xrBuffer||(this.xrBuffer=this.nativeSDK._malloc(t*i*4)),this.xrBuffer}initExtractionBuffers(){this.extractionBuffer=this.nativeSDK._malloc(4*this.spatialBufferSize),this.matchBuffer=this.nativeSDK._malloc(14e3),this.coarseLocationBuffer=this.nativeSDK._malloc(32768);}loadExtractionData(t,i=-1){return this.extractionBuffer&&this.coarseLocationBuffer?(this.nativeSDK.HEAPF32.set(t.extraction,this.extractionBuffer/4),this.nativeSDK.HEAPF32.set(t.descriptor,this.coarseLocationBuffer/4),this.nativeSDK._OX_LoadExtractionData(this.extractionBuffer,this.coarseLocationBuffer,i)):0}coarseLocationCheck(t){return this.coarseLocationBuffer?(this.nativeSDK.HEAPF32.set(t.descriptor,this.coarseLocationBuffer/4),this.nativeSDK._OX_CoarseLocationCheck(this.coarseLocationBuffer)):0}getCandidateData(t){let i=this.nativeSDK._OX_GetCandidateData(t);return new Float32Array(this.nativeSDK.HEAPF32.buffer,i,this.spatialBufferSize)}loadMatch(t){this.matchBuffer&&(this.nativeSDK.HEAPF32.set(t,this.matchBuffer/4),this.nativeSDK._OX_LoadMatch(this.matchBuffer));}spatialLocalize(t){return this.nativeSDK.HEAPF32.set(t.elements,this.lastPoseBuffer/4),this.nativeSDK._OX_SpatialLocalize(this.lastPoseBuffer)}setSpatialQualityLevel(t){return this.nativeSDK._OX_SetSpatialQualityLevel(t)}loadKeyframePose(t){this.nativeSDK._OX_LoadKfPose(t);}numSLAMKeyframes(){return this.nativeSDK._OX_GetSLAMNumKfs()}getSLAMKeyframe(t){let i=this.nativeSDK._OX_GetSLAMKf(t),e=[];for(let t=0;t<1228800;t++)e.push(this.nativeSDK.HEAPU8[i+t]);return new Uint8Array(e)}stopImageTracking(){this.nativeSDK._OX_StopImageDetection();}stopQRCodeTracking(){this.nativeSDK._OX_StopQRCodeDetection();}stopSLAM(){this.nativeSDK._OX_StopSLAM();}stopSpatialTracking(){this.nativeSDK._OX_StopSpatialTracking();}addImage(t,i){this.nativeSDK.HEAPU8.set(i,this.imageBuffer),this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+0]=640,this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+1]=480,this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+2]=2560,this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+3]=!1,this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+4]=5,this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+5]=0,this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+6]=0;const e=this.getStringBuffer(t);this.nativeSDK._OX_AddImage([e],this.imageBuffer,this.frameLayoutStruct),this.releaseStringBuffer(e);}destroy(){this.nativeSDK._OX_Destroy(),this.osfStrBuffer&&this.releaseStringBuffer(this.osfStrBuffer);}extractionType(){return this.nativeSDK._OX_ExtractionType()}getStringBuffer(t){const i=this.nativeSDK.lengthBytesUTF8(t)+1;let e=this.nativeSDK._malloc(i);return this.nativeSDK.stringToUTF8(t,e,i),e}releaseStringBuffer(t){this.nativeSDK._free(t);}parseNativeJSON(t){let i;try{i=JSON.parse(t);}catch(i){console.error(`Could not parse ${t}`);}return i}getSLAMMap(){return this.parseNativeJSON(this.nativeSDK.UTF8ToString(this.nativeSDK._OX_GetSLAMMap()))}getSLAMTrackingPoints(){return this.parseNativeJSON(this.nativeSDK.UTF8ToString(this.nativeSDK._OX_GetSLAMTrackingPoints()))}raycast(t,i,e,a,r,s){return this.parseNativeJSON(this.nativeSDK.UTF8ToString(this.nativeSDK._OX_Raycast(t,i,e,a,r,s)))}getSpatialMap(){return this.parseNativeJSON(this.nativeSDK.UTF8ToString(this.nativeSDK._OX_GetSpatialMap()))}setWebXRRelocationListener(t){this.webXRRelocationListener=t;}}
|
42
42
|
|
43
43
|
class UIManager{constructor(){this.onFocus=this.onFocus.bind(this);}createRenderCanvas(){this.renderCanvas=document.createElement("canvas"),this.renderCanvas.id="renderer",this.renderCanvas.style.position="absolute",document.body.prepend(this.renderCanvas),this.addTouchListeners();}setRenderCanvas(e){this.renderCanvas=e,this.addTouchListeners();}addTouchListeners(){this.renderCanvas.addEventListener("click",(e=>{this.onCanvasTouch(e);})),this.renderCanvas.addEventListener("touchstart",(e=>{this.onCanvasTouchStart(e);})),this.renderCanvas.addEventListener("touchmove",(e=>{this.onCanvasTouchMove(e);})),this.renderCanvas.addEventListener("touchend",(e=>{this.onCanvasTouchEnd(e);}));}removeRenderCanvas(){this.renderCanvas&&(this.renderCanvas.remove(),this.renderCanvas=null);}createVideoElement(e,t,i){let o=document.createElement("video");o.setAttribute("playsinline","true"),o.setAttribute("autoplay","true"),o.setAttribute("muted",""),this.videoCanvas=document.createElement("canvas"),this.videoCanvas.width=t,this.videoCanvas.height=i,this.videoContext=this.videoCanvas.getContext("2d"),o.srcObject=e,document.body.appendChild(o),this.videoElement=o;const s=this.videoElement.srcObject.getVideoTracks()[0].getSettings();this.videoSizeHorizontal=[Math.max(s.width,s.height),Math.min(s.width,s.height)],this.videoSizeVertical=[Math.min(s.width,s.height),Math.max(s.width,s.height)],window.addEventListener("focus",this.onFocus);}onFocus(){this.videoElement.play();}removeVideoElement(){this.videoElement&&(window.removeEventListener("focus",this.onFocus),this.videoElement.remove(),this.videoElement=null);}fitVideoToScreen(){if(!this.videoSizeHorizontal||!this.videoSizeVertical)return;this.videoSize=window.innerWidth>window.innerHeight?this.videoSizeHorizontal:this.videoSizeVertical;let e=[],t=[];this.videoSize[0]/this.videoSize[1]>window.innerWidth/window.innerHeight?(t=[Math.floor(this.videoSize[0]*(window.innerHeight/this.videoSize[1])),window.innerHeight],e=[-(t[0]-window.innerWidth)/2,0]):(t=[window.innerWidth,Math.floor(this.videoSize[1]*(window.innerWidth/this.videoSize[0]))],e=[0,-(t[1]-window.innerHeight)/2]),document.body.style.setProperty("overflow","hidden"),this.videoElement.width=t[0],this.videoElement.height=t[1],this.videoElement.style.setProperty("position","fixed"),this.videoElement.style.setProperty("z-index","-1"),this.videoElement.style.setProperty("width",`${t[0]}px`),this.videoElement.style.setProperty("height",`${t[1]}px`),this.videoElement.style.setProperty("left",`${e[0]}px`),this.videoElement.style.setProperty("top",`${e[1]}px`),this.videoElement.style.setProperty("touch-action","none"),this.renderCanvas.width=t[0],this.renderCanvas.height=t[1],this.renderCanvas.style.setProperty("position","fixed","important"),this.renderCanvas.style.setProperty("width",`${t[0]}px`,"important"),this.renderCanvas.style.setProperty("height",`${t[1]}px`,"important"),this.renderCanvas.style.setProperty("left",`${e[0]}px`,"important"),this.renderCanvas.style.setProperty("top",`${e[1]}px`,"important"),this.renderCanvas.style.setProperty("touch-action","none","important");}async displayPermissionsDialog(e){return new Promise(((t,i)=>{let o,s,n,r;o=document.createElement("div"),o.id="ox-permissions-dialog",o.style.setProperty("position","fixed"),o.style.setProperty("z-index","999999"),o.style.setProperty("max-width","360px"),o.style.setProperty("width","calc(100% - 140px"),o.style.setProperty("left","50vw"),o.style.setProperty("top","50vh"),o.style.setProperty("transform","translate(-50%, -50%)"),o.style.setProperty("background-color","#FFFFFF"),o.style.setProperty("border-radius","10px"),o.style.setProperty("font-family","'Open Sans', Arial, sans-serif"),o.style.setProperty("text-align","center"),o.style.setProperty("padding","30px"),document.body.appendChild(o),s=document.createElement("h1"),s.id="ox-permissions-dialog-title",s.innerText="Access to motion sensors required",s.style.setProperty("font-size","20px"),o.appendChild(s),n=document.createElement("span"),n.id="ox-permissions-dialog-message",n.innerText="This augmented reality experience requires access to your phone motion sensors. The browser may ask you for permissions.",n.style.setProperty("display","block"),n.style.setProperty("padding","10px 0"),o.appendChild(n),r=document.createElement("button"),r.id="ox-permissions-dialog-ok-button",r.innerText="Okay!",r.style.setProperty("display","block"),r.style.setProperty("margin","auto"),r.style.setProperty("background","#000000"),r.style.setProperty("color","#FFFFFF"),r.style.setProperty("border","none"),r.style.setProperty("border-radius","12px"),r.style.setProperty("padding","20px 0"),r.style.setProperty("width","100%"),r.style.setProperty("font-size","18px"),r.style.setProperty("font-weight","bold"),r.style.setProperty("margin-top","20px"),r.style.setProperty("background-image","linear-gradient(to left, #f6414b, #ee0979)"),o.appendChild(r),r.addEventListener("click",(async s=>{s.stopPropagation(),o.remove();try{await e(),t();}catch(e){i(e);}}));}))}getVideoData(){let e;if(this.videoElement){if(this.isPortrait()){let[e,i]=this.videoSizeVertical;var t=Math.PI/2;this.videoContext.translate(480,0),this.videoContext.rotate(t),this.videoContext.drawImage(this.videoElement,0,0,i,i,0,-160,640,640),this.videoContext.rotate(-t),this.videoContext.translate(-480,0);}else this.videoContext.drawImage(this.videoElement,0,0,640,480);e=this.videoContext.getImageData(0,0,640,480).data;}return e}getVideoElement(){return this.videoElement}getCameraParameters(){let e=640,t=480;return this.isPortrait()||([e,t]=[t,e]),{fov:radToDeg(2*Math.atan(e/936)),aspect:t/e}}isPortrait(){return window.innerWidth<window.innerHeight}setTouchListener(e){this.onTouch=e;}setTouchStartListener(e){this.onTouchStart=e;}setTouchMoveListener(e){this.onTouchMove=e;}setTouchEndListener(e){this.onTouchEnd=e;}getNormalizedTouchCoords(e){const t=new Vector2,i=this.renderCanvas.getBoundingClientRect();return null!=e.clientX?(t.x=(e.clientX-i.left)/i.width*2-1,t.y=-(e.clientY-i.top)/i.height*2+1):e.touches[0]?(t.x=e.touches[0].clientX/window.innerWidth*2-1,t.y=-e.touches[0].clientY/window.innerHeight*2+1):(t.x=e.changedTouches[0].clientX/window.innerWidth*2-1,t.y=-e.changedTouches[0].clientY/window.innerHeight*2+1),t}onCanvasTouch(e){const t=this.getNormalizedTouchCoords(e);this.onTouch&&this.onTouch(t);}onCanvasTouchStart(e){const t=this.getNormalizedTouchCoords(e);this.onTouchStart&&this.onTouchStart(t);}onCanvasTouchMove(e){const t=this.getNormalizedTouchCoords(e);this.onTouchMove&&this.onTouchMove(t);}onCanvasTouchEnd(e){const t=this.getNormalizedTouchCoords(e);this.onTouchEnd&&this.onTouchEnd(t);}}
|
44
44
|
|
@@ -48,9 +48,9 @@ class IMUManager{constructor(e,t){this.uiManager=e,this.deviceManager=t,this.sta
|
|
48
48
|
|
49
49
|
class IndexedDBManager{constructor(e,r){this.dbName=e,this.storeName=r;}async getFromCacheOrFetch(e,r){let t=null;try{t=await this.getFileFromIndexedDB(e);}catch(e){console.log("An error occurred while trying to get element from indexedDB.");}return t||(t=await this.fetchAndCacheFile(r,e)),new Uint8Array(t)}async getFileFromIndexedDB(e){return new Promise(((r,t)=>{const o=indexedDB.open(this.dbName);o.onerror=()=>t(o.error),o.onsuccess=()=>{const s=o.result.transaction(this.storeName,"readonly").objectStore(this.storeName).get(e);s.onsuccess=()=>r(s.result),s.onerror=()=>t(s.error);},o.onupgradeneeded=e=>{e.target.result.createObjectStore(this.storeName);};}))}async saveFileToIndexedDB(e,r){return new Promise(((t,o)=>{const s=indexedDB.open(this.dbName);s.onerror=()=>o(s.error),s.onupgradeneeded=e=>{e.target.result.createObjectStore(this.storeName);},s.onsuccess=()=>{try{const n=s.result.transaction(this.storeName,"readwrite"),a=n.objectStore(this.storeName).put(r,e);a.onsuccess=()=>t(a.result),a.onerror=()=>o(a.error);}catch(e){o(e);}};}))}async fetchAndCacheFile(e,r){const t=await fetch(e),o=await t.arrayBuffer();return await this.saveFileToIndexedDB(r,o),o}}
|
50
50
|
|
51
|
-
class WorkerExtractionData{constructor(Z,l,d,b,c,m,G=5,X=!1){this.data=Z,this.width=l,this.height=d,this.rotate=b,this.flip=c,this.colorSpace=G,this.onlyCoarse=X,this.dtype=m;}}class WorkerMatchingData{constructor(Z,l,d,b){this.idx=Z,this.from=l,this.to=d,this.dtype=b;}}class WorkerManager{constructor(){this.workers={},this.callbacks={};this.indexedDBManager=new IndexedDBManager("onirix-sdk","files");}workerExists(Z){return void 0!==this.workers[Z]&&void 0!==this.callbacks[Z]}createExtractionWorker(Z,l){if(!this.workerExists(Z)){let d=atob("class IndexedDBManager{constructor(e,r){this.dbName=e,this.storeName=r;}async getFromCacheOrFetch(e,r){let t=null;try{t=await this.getFileFromIndexedDB(e);}catch(e){console.log("An error occurred while trying to get element from indexedDB.");}return t||(t=await this.fetchAndCacheFile(r,e)),new Uint8Array(t)}async getFileFromIndexedDB(e){return new Promise(((r,t)=>{const o=indexedDB.open(this.dbName);o.onerror=()=>t(o.error),o.onsuccess=()=>{const s=o.result.transaction(this.storeName,"readonly").objectStore(this.storeName).get(e);s.onsuccess=()=>r(s.result),s.onerror=()=>t(s.error);},o.onupgradeneeded=e=>{e.target.result.createObjectStore(this.storeName);};}))}async saveFileToIndexedDB(e,r){return new Promise(((t,o)=>{const s=indexedDB.open(this.dbName);s.onerror=()=>o(s.error),s.onupgradeneeded=e=>{e.target.result.createObjectStore(this.storeName);},s.onsuccess=()=>{try{const n=s.result.transaction(this.storeName,"readwrite"),a=n.objectStore(this.storeName).put(r,e);a.onsuccess=()=>t(a.result),a.onerror=()=>o(a.error);}catch(e){o(e);}};}))}async fetchAndCacheFile(e,r){const t=await fetch(e),o=await t.arrayBuffer();return await this.saveFileToIndexedDB(r,o),o}}

var he,j,ie,Ar,ut,ct,dt,_,A,mt,ht,He,yt,bt,gt,Et,Tt,H,ae,At,Ot,Lt,It,v,R,vt,Bt,V,Y,ye,Or,We=Object.defineProperty,gr=Object.getOwnPropertyDescriptor,Er=Object.getOwnPropertyNames,Tr=Object.prototype.hasOwnProperty,$e=(e=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(e,{get:(e,t)=>(typeof require<"u"?require:e)[t]}):e)((function(e){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+e+'" is not supported')})),T=(e,t)=>()=>(e&&(t=e(e=0)),t),Ge=(e,t)=>{for(var r in t)We(e,r,{get:t[r],enumerable:!0});},Sr=(e,t,r,n)=>{if(t&&"object"==typeof t||"function"==typeof t)for(let o of Er(t))!Tr.call(e,o)&&o!==r&&We(e,o,{get:()=>t[o],enumerable:!(n=gr(t,o))||n.enumerable});return e},at=e=>Sr(We({},"__esModule",{value:!0}),e),ze=T((()=>{he=new Map,j=[],ie=(e,t,r)=>{if(!t||"function"!=typeof t.init||"function"!=typeof t.createInferenceSessionHandler)throw new TypeError("not a valid backend");{let n=he.get(e);if(void 0===n)he.set(e,{backend:t,priority:r});else {if(n.priority>r)return;if(n.priority===r&&n.backend!==t)throw new Error(`cannot register backend "${e}" using priority ${r}`)}if(r>=0){let t=j.indexOf(e);-1!==t&&j.splice(t,1);for(let t=0;t<j.length;t++)if(he.get(j[t]).priority<=r)return void j.splice(t,0,e);j.push(e);}}},Ar=async e=>{let t=he.get(e);if(!t)return "backend not found.";if(t.initialized)return t.backend;if(t.aborted)return t.error;{let r=!!t.initPromise;try{return r||(t.initPromise=t.backend.init(e)),await t.initPromise,t.initialized=!0,t.backend}catch(e){return r||(t.error=`${e}`,t.aborted=!0),t.error}finally{delete t.initPromise;}}},ut=async e=>{let t,r=e.executionProviders||[],n=r.map((e=>"string"==typeof e?e:e.name)),o=0===n.length?j:n,a=[],i=new Set;for(let e of o){let r=await Ar(e);"string"==typeof r?a.push({name:e,err:r}):(t||(t=r),t===r&&i.add(e));}if(!t)throw new Error(`no available backend found. ERR: ${a.map((e=>`[${e.name}] ${e.err}`)).join(", ")}`);for(let{name:e,err:t}of a)n.includes(e)&&console.warn(`removing requested execution provider "${e}" from session options because it is not available: ${t}`);let s=r.filter((e=>i.has("string"==typeof e?e:e.name)));return [t,new Proxy(e,{get:(e,t)=>"executionProviders"===t?s:Reflect.get(e,t)})]};})),ft=T((()=>{ze();})),lt=T((()=>{ct="1.21.0";})),je=T((()=>{lt(),dt="warning",_={wasm:{},webgl:{},webgpu:{},versions:{common:ct},set logLevel(e){if(void 0!==e){if("string"!=typeof e||-1===["verbose","info","warning","error","fatal"].indexOf(e))throw new Error(`Unsupported logging level: ${e}`);dt=e;}},get logLevel(){return dt}},Object.defineProperty(_,"logLevel",{enumerable:!0});})),pt=T((()=>{je(),A=_;})),wt=T((()=>{mt=(e,t)=>{let r=typeof document<"u"?document.createElement("canvas"):new OffscreenCanvas(1,1);r.width=e.dims[3],r.height=e.dims[2];let n=r.getContext("2d");if(null!=n){let o,a;void 0!==t?.tensorLayout&&"NHWC"===t.tensorLayout?(o=e.dims[2],a=e.dims[3]):(o=e.dims[3],a=e.dims[2]);let i,s,l=void 0!==t?.format?t.format:"RGB",u=t?.norm;void 0===u||void 0===u.mean?i=[255,255,255,255]:"number"==typeof u.mean?i=[u.mean,u.mean,u.mean,u.mean]:(i=[u.mean[0],u.mean[1],u.mean[2],0],void 0!==u.mean[3]&&(i[3]=u.mean[3])),void 0===u||void 0===u.bias?s=[0,0,0,0]:"number"==typeof u.bias?s=[u.bias,u.bias,u.bias,u.bias]:(s=[u.bias[0],u.bias[1],u.bias[2],0],void 0!==u.bias[3]&&(s[3]=u.bias[3]));let f=a*o,d=0,p=f,c=2*f,h=-1;"RGBA"===l?(d=0,p=f,c=2*f,h=3*f):"RGB"===l?(d=0,p=f,c=2*f):"RBG"===l&&(d=0,c=f,p=2*f);for(let t=0;t<a;t++)for(let r=0;r<o;r++){let o=(e.data[d++]-s[0])*i[0],a=(e.data[p++]-s[1])*i[1],l=(e.data[c++]-s[2])*i[2],u=-1===h?255:(e.data[h++]-s[3])*i[3];n.fillStyle="rgba("+o+","+a+","+l+","+u+")",n.fillRect(r,t,1,1);}if("toDataURL"in r)return r.toDataURL();throw new Error("toDataURL is not supported")}throw new Error("Can not access image data")},ht=(e,t)=>{let r,n=typeof document<"u"?document.createElement("canvas").getContext("2d"):new OffscreenCanvas(1,1).getContext("2d");if(null==n)throw new Error("Can not access image data");{let o,a,i;void 0!==t?.tensorLayout&&"NHWC"===t.tensorLayout?(o=e.dims[2],a=e.dims[1],i=e.dims[3]):(o=e.dims[3],a=e.dims[2],i=e.dims[1]);let s,l,u=void 0!==t&&void 0!==t.format?t.format:"RGB",f=t?.norm;void 0===f||void 0===f.mean?s=[255,255,255,255]:"number"==typeof f.mean?s=[f.mean,f.mean,f.mean,f.mean]:(s=[f.mean[0],f.mean[1],f.mean[2],255],void 0!==f.mean[3]&&(s[3]=f.mean[3])),void 0===f||void 0===f.bias?l=[0,0,0,0]:"number"==typeof f.bias?l=[f.bias,f.bias,f.bias,f.bias]:(l=[f.bias[0],f.bias[1],f.bias[2],0],void 0!==f.bias[3]&&(l[3]=f.bias[3]));let d=a*o;if(void 0!==t&&(void 0!==t.format&&4===i&&"RGBA"!==t.format||3===i&&"RGB"!==t.format&&"BGR"!==t.format))throw new Error("Tensor format doesn't match input tensor dims");let p=4,c=0,h=1,w=2,y=3,m=0,g=d,b=2*d,v=-1;"RGBA"===u?(m=0,g=d,b=2*d,v=3*d):"RGB"===u?(m=0,g=d,b=2*d):"RBG"===u&&(m=0,b=d,g=2*d),r=n.createImageData(o,a);for(let t=0;t<a*o;c+=p,h+=p,w+=p,y+=p,t++)r.data[c]=(e.data[m++]-l[0])*s[0],r.data[h]=(e.data[g++]-l[1])*s[1],r.data[w]=(e.data[b++]-l[2])*s[2],r.data[y]=-1===v?255:(e.data[v++]-l[3])*s[3];}return r};})),St=T((()=>{we(),He=(e,t)=>{if(void 0===e)throw new Error("Image buffer must be defined");if(void 0===t.height||void 0===t.width)throw new Error("Image height and width must be defined");if("NHWC"===t.tensorLayout)throw new Error("NHWC Tensor layout is not supported yet");let r,n,{height:o,width:a}=t,i=t.norm??{mean:255,bias:0};r="number"==typeof i.mean?[i.mean,i.mean,i.mean,i.mean]:[i.mean[0],i.mean[1],i.mean[2],i.mean[3]??255],n="number"==typeof i.bias?[i.bias,i.bias,i.bias,i.bias]:[i.bias[0],i.bias[1],i.bias[2],i.bias[3]??0];let s=void 0!==t.format?t.format:"RGBA",l=void 0!==t.tensorFormat&&void 0!==t.tensorFormat?t.tensorFormat:"RGB",u=o*a,f="RGBA"===l?new Float32Array(4*u):new Float32Array(3*u),d=4,p=0,c=1,h=2,w=3,y=0,m=u,g=2*u,b=-1;"RGB"===s&&(d=3,p=0,c=1,h=2,w=-1),"RGBA"===l?b=3*u:"RBG"===l?(y=0,g=u,m=2*u):"BGR"===l&&(g=0,m=u,y=2*u);for(let t=0;t<u;t++,p+=d,h+=d,c+=d,w+=d)f[y++]=(e[p]+n[0])/r[0],f[m++]=(e[c]+n[1])/r[1],f[g++]=(e[h]+n[2])/r[2],-1!==b&&-1!==w&&(f[b++]=(e[w]+n[3])/r[3]);return new v("float32",f,"RGBA"===l?[1,4,o,a]:[1,3,o,a])},yt=async(e,t)=>{let r,n=typeof HTMLImageElement<"u"&&e instanceof HTMLImageElement,o=typeof ImageData<"u"&&e instanceof ImageData,a=typeof ImageBitmap<"u"&&e instanceof ImageBitmap,i="string"==typeof e,s=t??{},l=()=>{if(typeof document<"u")return document.createElement("canvas");if(typeof OffscreenCanvas<"u")return new OffscreenCanvas(1,1);throw new Error("Canvas is not supported")},u=e=>typeof HTMLCanvasElement<"u"&&e instanceof HTMLCanvasElement||e instanceof OffscreenCanvas?e.getContext("2d"):null;if(n){let n=l();n.width=e.width,n.height=e.height;let o=u(n);if(null==o)throw new Error("Can not access image data");{let n=e.height,a=e.width;if(void 0!==t&&void 0!==t.resizedHeight&&void 0!==t.resizedWidth&&(n=t.resizedHeight,a=t.resizedWidth),void 0!==t){if(s=t,void 0!==t.tensorFormat)throw new Error("Image input config format must be RGBA for HTMLImageElement");s.tensorFormat="RGBA",s.height=n,s.width=a;}else s.tensorFormat="RGBA",s.height=n,s.width=a;o.drawImage(e,0,0),r=o.getImageData(0,0,a,n).data;}}else {if(!o){if(a){if(void 0===t)throw new Error("Please provide image config with format for Imagebitmap");let n=l();n.width=e.width,n.height=e.height;let o=u(n);if(null!=o){let t=e.height,n=e.width;return o.drawImage(e,0,0,n,t),r=o.getImageData(0,0,n,t).data,s.height=t,s.width=n,He(r,s)}throw new Error("Can not access image data")}if(i)return new Promise(((t,r)=>{let n=l(),o=u(n);if(!e||!o)return r();let a=new Image;a.crossOrigin="Anonymous",a.src=e,a.onload=()=>{n.width=a.width,n.height=a.height,o.drawImage(a,0,0,n.width,n.height);let e=o.getImageData(0,0,n.width,n.height);s.height=n.height,s.width=n.width,t(He(e.data,s));};}));throw new Error("Input data provided is not supported - aborted tensor creation")}{let n,o;if(void 0!==t&&void 0!==t.resizedWidth&&void 0!==t.resizedHeight?(n=t.resizedHeight,o=t.resizedWidth):(n=e.height,o=e.width),void 0!==t&&(s=t),s.format="RGBA",s.height=n,s.width=o,void 0!==t){let t=l();t.width=o,t.height=n;let a=u(t);if(null==a)throw new Error("Can not access image data");a.putImageData(e,0,0),r=a.getImageData(0,0,o,n).data;}else r=e.data;}}if(void 0!==r)return He(r,s);throw new Error("Input data provided is not supported - aborted tensor creation")},bt=(e,t)=>{let{width:r,height:n,download:o,dispose:a}=t;return new v({location:"texture",type:"float32",texture:e,dims:[1,n,r,4],download:o,dispose:a})},gt=(e,t)=>{let{dataType:r,dims:n,download:o,dispose:a}=t;return new v({location:"gpu-buffer",type:r??"float32",gpuBuffer:e,dims:n,download:o,dispose:a})},Et=(e,t)=>{let{dataType:r,dims:n,download:o,dispose:a}=t;return new v({location:"ml-tensor",type:r??"float32",mlTensor:e,dims:n,download:o,dispose:a})},Tt=(e,t,r)=>new v({location:"cpu-pinned",type:e,data:t,dims:r??[t.length]});})),xt=T((()=>{H=new Map([["float32",Float32Array],["uint8",Uint8Array],["int8",Int8Array],["uint16",Uint16Array],["int16",Int16Array],["int32",Int32Array],["bool",Uint8Array],["float64",Float64Array],["uint32",Uint32Array],["int4",Uint8Array],["uint4",Uint8Array]]),ae=new Map([[Float32Array,"float32"],[Uint8Array,"uint8"],[Int8Array,"int8"],[Uint16Array,"uint16"],[Int16Array,"int16"],[Int32Array,"int32"],[Float64Array,"float64"],[Uint32Array,"uint32"]]),At=!1,Ot=()=>{if(!At){At=!0;let e=typeof BigInt64Array<"u"&&BigInt64Array.from,t=typeof BigUint64Array<"u"&&BigUint64Array.from,r=globalThis.Float16Array,n=typeof r<"u"&&r.from;e&&(H.set("int64",BigInt64Array),ae.set(BigInt64Array,"int64")),t&&(H.set("uint64",BigUint64Array),ae.set(BigUint64Array,"uint64")),n?(H.set("float16",r),ae.set(r,"float16")):H.set("float16",Uint16Array);}};})),Pt=T((()=>{we(),Lt=e=>{let t=1;for(let r=0;r<e.length;r++){let n=e[r];if("number"!=typeof n||!Number.isSafeInteger(n))throw new TypeError(`dims[${r}] must be an integer, got: ${n}`);if(n<0)throw new RangeError(`dims[${r}] must be a non-negative integer, got: ${n}`);t*=n;}return t},It=(e,t)=>{switch(e.location){case"cpu":return new v(e.type,e.data,t);case"cpu-pinned":return new v({location:"cpu-pinned",data:e.data,type:e.type,dims:t});case"texture":return new v({location:"texture",texture:e.texture,type:e.type,dims:t});case"gpu-buffer":return new v({location:"gpu-buffer",gpuBuffer:e.gpuBuffer,type:e.type,dims:t});case"ml-tensor":return new v({location:"ml-tensor",mlTensor:e.mlTensor,type:e.type,dims:t});default:throw new Error(`tensorReshape: tensor location ${e.location} is not supported`)}};})),we=T((()=>{wt(),St(),xt(),Pt(),v=class{constructor(e,t,r){let n,o;if(Ot(),"object"==typeof e&&"location"in e)switch(this.dataLocation=e.location,n=e.type,o=e.dims,e.location){case"cpu-pinned":{let t=H.get(n);if(!t)throw new TypeError(`unsupported type "${n}" to create tensor from pinned buffer`);if(!(e.data instanceof t))throw new TypeError(`buffer should be of type ${t.name}`);this.cpuData=e.data;break}case"texture":if("float32"!==n)throw new TypeError(`unsupported type "${n}" to create tensor from texture`);this.gpuTextureData=e.texture,this.downloader=e.download,this.disposer=e.dispose;break;case"gpu-buffer":if("float32"!==n&&"float16"!==n&&"int32"!==n&&"int64"!==n&&"uint32"!==n&&"uint8"!==n&&"bool"!==n&&"uint4"!==n&&"int4"!==n)throw new TypeError(`unsupported type "${n}" to create tensor from gpu buffer`);this.gpuBufferData=e.gpuBuffer,this.downloader=e.download,this.disposer=e.dispose;break;case"ml-tensor":if("float32"!==n&&"float16"!==n&&"int32"!==n&&"int64"!==n&&"uint32"!==n&&"uint64"!==n&&"int8"!==n&&"uint8"!==n&&"bool"!==n&&"uint4"!==n&&"int4"!==n)throw new TypeError(`unsupported type "${n}" to create tensor from MLTensor`);this.mlTensorData=e.mlTensor,this.downloader=e.download,this.disposer=e.dispose;break;default:throw new Error(`Tensor constructor: unsupported location '${this.dataLocation}'`)}else {let a,i;if("string"==typeof e)if(n=e,i=r,"string"===e){if(!Array.isArray(t))throw new TypeError("A string tensor's data must be a string array.");a=t;}else {let r=H.get(e);if(void 0===r)throw new TypeError(`Unsupported tensor type: ${e}.`);if(Array.isArray(t)){if("float16"===e&&r===Uint16Array||"uint4"===e||"int4"===e)throw new TypeError(`Creating a ${e} tensor from number array is not supported. Please use ${r.name} as data.`);a="uint64"===e||"int64"===e?r.from(t,BigInt):r.from(t);}else if(t instanceof r)a=t;else if(t instanceof Uint8ClampedArray){if("uint8"!==e)throw new TypeError("A Uint8ClampedArray tensor's data must be type of uint8");a=Uint8Array.from(t);}else {if(!("float16"===e&&t instanceof Uint16Array&&r!==Uint16Array))throw new TypeError(`A ${n} tensor's data must be type of ${r}`);a=new globalThis.Float16Array(t.buffer,t.byteOffset,t.length);}}else if(i=t,Array.isArray(e)){if(0===e.length)throw new TypeError("Tensor type cannot be inferred from an empty array.");let t=typeof e[0];if("string"===t)n="string",a=e;else {if("boolean"!==t)throw new TypeError(`Invalid element type of data array: ${t}.`);n="bool",a=Uint8Array.from(e);}}else if(e instanceof Uint8ClampedArray)n="uint8",a=Uint8Array.from(e);else {let t=ae.get(e.constructor);if(void 0===t)throw new TypeError(`Unsupported type for tensor data: ${e.constructor}.`);n=t,a=e;}if(void 0===i)i=[a.length];else if(!Array.isArray(i))throw new TypeError("A tensor's dims must be a number array");o=i,this.cpuData=a,this.dataLocation="cpu";}let a=Lt(o);if(this.cpuData&&a!==this.cpuData.length&&("uint4"!==n&&"int4"!==n||Math.ceil(a/2)!==this.cpuData.length))throw new Error(`Tensor's size(${a}) does not match data length(${this.cpuData.length}).`);this.type=n,this.dims=o,this.size=a;}static async fromImage(e,t){return yt(e,t)}static fromTexture(e,t){return bt(e,t)}static fromGpuBuffer(e,t){return gt(e,t)}static fromMLTensor(e,t){return Et(e,t)}static fromPinnedBuffer(e,t,r){return Tt(e,t,r)}toDataURL(e){return mt(this,e)}toImageData(e){return ht(this,e)}get data(){if(this.ensureValid(),!this.cpuData)throw new Error("The data is not on CPU. Use `getData()` to download GPU data to CPU, or use `texture` or `gpuBuffer` property to access the GPU data directly.");return this.cpuData}get location(){return this.dataLocation}get texture(){if(this.ensureValid(),!this.gpuTextureData)throw new Error("The data is not stored as a WebGL texture.");return this.gpuTextureData}get gpuBuffer(){if(this.ensureValid(),!this.gpuBufferData)throw new Error("The data is not stored as a WebGPU buffer.");return this.gpuBufferData}get mlTensor(){if(this.ensureValid(),!this.mlTensorData)throw new Error("The data is not stored as a WebNN MLTensor.");return this.mlTensorData}async getData(e){switch(this.ensureValid(),this.dataLocation){case"cpu":case"cpu-pinned":return this.data;case"texture":case"gpu-buffer":case"ml-tensor":if(!this.downloader)throw new Error("The current tensor is not created with a specified data downloader.");if(this.isDownloading)throw new Error("The current tensor is being downloaded.");try{this.isDownloading=!0;let t=await this.downloader();return this.downloader=void 0,this.dataLocation="cpu",this.cpuData=t,e&&this.disposer&&(this.disposer(),this.disposer=void 0),t}finally{this.isDownloading=!1;}default:throw new Error(`cannot get data from location: ${this.dataLocation}`)}}dispose(){if(this.isDownloading)throw new Error("The current tensor is being downloaded.");this.disposer&&(this.disposer(),this.disposer=void 0),this.cpuData=void 0,this.gpuTextureData=void 0,this.gpuBufferData=void 0,this.mlTensorData=void 0,this.downloader=void 0,this.isDownloading=void 0,this.dataLocation="none";}ensureValid(){if("none"===this.dataLocation)throw new Error("The tensor is disposed.")}reshape(e){if(this.ensureValid(),this.downloader||this.disposer)throw new Error("Cannot reshape a tensor that owns GPU resource.");return It(this,e)}};})),Ve=T((()=>{we(),R=v;})),Ye=T((()=>{je(),vt=(e,t)=>{(typeof _.trace>"u"?!_.wasm.trace:!_.trace)||console.timeStamp(`${e}::ORT::${t}`);},Bt=(e,t)=>{let r=(new Error).stack?.split(/\r\n|\r|\n/g)||[],n=!1;for(let o=0;o<r.length;o++){if(n&&!r[o].includes("TRACE_FUNC")){let n=`FUNC_${e}::${r[o].trim().split(" ")[1]}`;return t&&(n+=`::${t}`),void vt("CPU",n)}r[o].includes("TRACE_FUNC")&&(n=!0);}},V=e=>{(typeof _.trace>"u"?!_.wasm.trace:!_.trace)||Bt("BEGIN",e);},Y=e=>{(typeof _.trace>"u"?!_.wasm.trace:!_.trace)||Bt("END",e);};})),Ct=T((()=>{ze(),Ve(),Ye(),ye=class e{constructor(e){this.handler=e;}async run(e,t,r){V();let n={},o={};if("object"!=typeof e||null===e||e instanceof R||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("object"==typeof t){if(null===t)throw new TypeError("Unexpected argument[1]: cannot be null.");if(t instanceof R)throw new TypeError("'fetches' cannot be a Tensor");if(Array.isArray(t)){if(0===t.length)throw new TypeError("'fetches' cannot be an empty array.");a=!1;for(let e of t){if("string"!=typeof e)throw new TypeError("'fetches' must be a string array or an object.");if(-1===this.outputNames.indexOf(e))throw new RangeError(`'fetches' contains invalid output name: ${e}.`);n[e]=null;}if("object"==typeof r&&null!==r)o=r;else if(typeof r<"u")throw new TypeError("'options' must be an object.")}else {let e=!1,i=Object.getOwnPropertyNames(t);for(let r of this.outputNames)if(-1!==i.indexOf(r)){let o=t[r];(null===o||o instanceof R)&&(e=!0,a=!1,n[r]=o);}if(e){if("object"==typeof r&&null!==r)o=r;else if(typeof r<"u")throw new TypeError("'options' must be an object.")}else o=t;}}else if(typeof t<"u")throw new TypeError("Unexpected argument[1]: must be 'fetches' or 'options'.");for(let t of this.inputNames)if(typeof e[t]>"u")throw new Error(`input '${t}' is missing in 'feeds'.`);if(a)for(let e of this.outputNames)n[e]=null;let i=await this.handler.run(e,n,o),s={};for(let e in i)if(Object.hasOwnProperty.call(i,e)){let t=i[e];s[e]=t instanceof R?t:new R(t.type,t.data,t.dims);}return Y(),s}async release(){return this.handler.dispose()}static async create(t,r,n,o){V();let a,i={};if("string"==typeof t){if(a=t,"object"==typeof r&&null!==r)i=r;else if(typeof r<"u")throw new TypeError("'options' must be an object.")}else if(t instanceof Uint8Array){if(a=t,"object"==typeof r&&null!==r)i=r;else if(typeof r<"u")throw new TypeError("'options' must be an object.")}else {if(!(t instanceof ArrayBuffer||typeof SharedArrayBuffer<"u"&&t instanceof SharedArrayBuffer))throw new TypeError("Unexpected argument[0]: must be 'path' or 'buffer'.");{let e=t,s=0,l=t.byteLength;if("object"==typeof r&&null!==r)i=r;else if("number"==typeof r){if(s=r,!Number.isSafeInteger(s))throw new RangeError("'byteOffset' must be an integer.");if(s<0||s>=e.byteLength)throw new RangeError(`'byteOffset' is out of range [0, ${e.byteLength}).`);if(l=t.byteLength-s,"number"==typeof n){if(l=n,!Number.isSafeInteger(l))throw new RangeError("'byteLength' must be an integer.");if(l<=0||s+l>e.byteLength)throw new RangeError(`'byteLength' is out of range (0, ${e.byteLength-s}].`);if("object"==typeof o&&null!==o)i=o;else if(typeof o<"u")throw new TypeError("'options' must be an object.")}else if(typeof n<"u")throw new TypeError("'byteLength' must be a number.")}else if(typeof r<"u")throw new TypeError("'options' must be an object.");a=new Uint8Array(e,s,l);}}let[s,l]=await ut(i),u=await s.createInferenceSessionHandler(a,l);return Y(),new e(u)}startProfiling(){this.handler.startProfiling();}endProfiling(){this.handler.endProfiling();}get inputNames(){return this.handler.inputNames}get outputNames(){return this.handler.outputNames}};})),Ut=T((()=>{Ct(),Or=ye;})),_t=T((()=>{})),Mt=T((()=>{})),Dt=T((()=>{})),Rt=T((()=>{})),qe={};Ge(qe,{InferenceSession:()=>Or,TRACE:()=>vt,TRACE_FUNC_BEGIN:()=>V,TRACE_FUNC_END:()=>Y,Tensor:()=>R,env:()=>A,registerBackend:()=>ie});var q=T((()=>{ft(),pt(),Ut(),Ve(),_t(),Mt(),Ye(),Dt(),Rt();})),be=T((()=>{})),Wt={};Ge(Wt,{default:()=>xr});var kt,Nt,xr,jt,M,Pe,Xe,Ir,Pr,Ht,vr,Gt,Vt,zt,Yt,Ze,Ke,ve,qt,Br,Cr,Ee,x,L,fe,S,Jt,Ur,_r,Mr,Dr,Zt,ee,Qt,te,er,tr,Ce,Ue,rr,ce,Rr,Te,Se,re,Fr,ue,Ae,Oe,nr,xe,Le,Ie,Z,D,le,Me,De,_e,tt,rt,ne,oe,Nr,or,sr,ir,ar,ur,fr,cr,lr,Wr,Re,$t=T((()=>{Je(),J(),ge(),kt="ort-wasm-proxy-worker",(Nt=globalThis.self?.name===kt)&&(self.onmessage=e=>{let{type:t,in:r}=e.data;try{switch(t){case"init-wasm":Ee(r.wasm).then((()=>{Te(r).then((()=>{postMessage({type:t});}),(e=>{postMessage({type:t,err:e});}));}),(e=>{postMessage({type:t,err:e});}));break;case"init-ep":{let{epName:e,env:n}=r;Se(n,e).then((()=>{postMessage({type:t});}),(e=>{postMessage({type:t,err:e});}));break}case"copy-from":{let{buffer:e}=r,n=ue(e);postMessage({type:t,out:n});break}case"create":{let{model:e,options:n}=r;Ae(e,n).then((e=>{postMessage({type:t,out:e});}),(e=>{postMessage({type:t,err:e});}));break}case"release":Oe(r),postMessage({type:t});break;case"run":{let{sessionId:e,inputIndices:n,inputs:o,outputIndices:a,options:i}=r;xe(e,n,o,a,new Array(a.length).fill(null),i).then((e=>{e.some((e=>"cpu"!==e[3]))?postMessage({type:t,err:"Proxy does not support non-cpu tensor location."}):postMessage({type:t,out:e},Ie([...o,...e]));}),(e=>{postMessage({type:t,err:e});}));break}case"end-profiling":Le(r),postMessage({type:t});}}catch(e){postMessage({type:t,err:e});}}),xr=Nt?null:e=>new Worker(e??M,{type:"module",name:kt});})),ge=T((()=>{be(),jt=typeof location>"u"?void 0:location.origin,M=(()=>import.meta.url?.startsWith("file:")?new URL(new URL("ort.wasm.bundle.min.mjs",import.meta.url).href,jt).href:import.meta.url)(),Pe=()=>{if(M&&!M.startsWith("blob:"))return M.substring(0,M.lastIndexOf("/")+1)},Xe=(e,t)=>{try{let r=t??M;return (r?new URL(e,r):new URL(e)).origin===jt}catch{return !1}},Ir=(e,t)=>{let r=t??M;try{return (r?new URL(e,r):new URL(e)).href}catch{return}},Pr=(e,t)=>`${t??"./"}${e}`,Ht=async e=>{let t=await(await fetch(e,{credentials:"same-origin"})).blob();return URL.createObjectURL(t)},vr=async e=>(await import(e)).default,Gt=($t(),at(Wt)).default,Vt=async()=>{if(!M)throw new Error("Failed to load proxy worker: cannot determine the script source URL.");if(Xe(M))return [void 0,Gt()];let e=await Ht(M);return [e,Gt(e)]},zt=void 0,Yt=async(e,t,r)=>{if(!e&&!t&&zt&&M&&Xe(M))return [void 0,zt];{let n="ort-wasm-simd-threaded.mjs",o=e??Ir(n,t),a=r&&o&&!Xe(o,t),i=a?await Ht(o):o??Pr(n,t);return [a?i:void 0,await vr(i)]}};})),J=T((()=>{ge(),Ke=!1,ve=!1,qt=!1,Br=()=>{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}},Cr=()=>{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}},Ee=async e=>{if(Ke)return Promise.resolve();if(ve)throw new Error("multiple calls to 'initializeWebAssembly()' detected.");if(qt)throw new Error("previous call to 'initializeWebAssembly()' failed.");ve=!0;let t=e.initTimeout,r=e.numThreads;if(!Cr())throw new Error("WebAssembly SIMD is not supported in the current environment.");let n=Br();r>1&&!n&&(typeof self<"u"&&!self.crossOriginIsolated&&console.warn("env.wasm.numThreads is set to "+r+", but this will not work unless you enable crossOriginIsolated mode. See https://web.dev/cross-origin-isolation-guide/ for more info."),console.warn("WebAssembly multi-threading is not supported in the current environment. Falling back to single-threading."),e.numThreads=r=1);let o=e.wasmPaths,a="string"==typeof o?o:void 0,i=o?.mjs,s=i?.href??i,l=o?.wasm,u=l?.href??l,f=e.wasmBinary,[d,p]=await Yt(s,a,r>1),c=!1,h=[];if(t>0&&h.push(new Promise((e=>{setTimeout((()=>{c=!0,e();}),t);}))),h.push(new Promise(((e,t)=>{let n={numThreads:r};if(f)n.wasmBinary=f;else if(u||a)n.locateFile=e=>u??a+e;else if(s&&0!==s.indexOf("blob:"))n.locateFile=e=>new URL(e,s).href;else if(d){let e=Pe();e&&(n.locateFile=t=>e+t);}p(n).then((t=>{ve=!1,Ke=!0,Ze=t,e(),d&&URL.revokeObjectURL(d);}),(e=>{ve=!1,qt=!0,t(e);}));}))),await Promise.race(h),c)throw new Error(`WebAssembly backend initializing failed due to timeout: ${t}ms`)},x=()=>{if(Ke&&Ze)return Ze;throw new Error("WebAssembly is not initialized yet.")};})),Be=T((()=>{J(),L=(e,t)=>{let r=x(),n=r.lengthBytesUTF8(e)+1,o=r._malloc(n);return r.stringToUTF8(e,o,n),t.push(o),o},fe=(e,t,r,n)=>{if("object"==typeof e&&null!==e){if(r.has(e))throw new Error("Circular reference in options");r.add(e);}Object.entries(e).forEach((([e,o])=>{let a=t?t+e:e;if("object"==typeof o)fe(o,a+".",r,n);else if("string"==typeof o||"number"==typeof o)n(a,o.toString());else {if("boolean"!=typeof o)throw new Error("Can't handle extra config type: "+typeof o);n(a,o?"1":"0");}}));},S=e=>{let t=x(),r=t.stackSave();try{let r=t.PTR_SIZE,n=t.stackAlloc(2*r);t._OrtGetLastError(n,n+r);let o=Number(t.getValue(n,4===r?"i32":"i64")),a=t.getValue(n+r,"*"),i=a?t.UTF8ToString(a):"";throw new Error(`${e} ERROR_CODE: ${o}, ERROR_MESSAGE: ${i}`)}finally{t.stackRestore(r);}};})),Xt=T((()=>{J(),Be(),Jt=e=>{let t=x(),r=0,n=[],o=e||{};try{if(void 0===e?.logSeverityLevel)o.logSeverityLevel=2;else if("number"!=typeof e.logSeverityLevel||!Number.isInteger(e.logSeverityLevel)||e.logSeverityLevel<0||e.logSeverityLevel>4)throw new Error(`log serverity level is not valid: ${e.logSeverityLevel}`);if(void 0===e?.logVerbosityLevel)o.logVerbosityLevel=0;else if("number"!=typeof e.logVerbosityLevel||!Number.isInteger(e.logVerbosityLevel))throw new Error(`log verbosity level is not valid: ${e.logVerbosityLevel}`);void 0===e?.terminate&&(o.terminate=!1);let a=0;return void 0!==e?.tag&&(a=L(e.tag,n)),r=t._OrtCreateRunOptions(o.logSeverityLevel,o.logVerbosityLevel,!!o.terminate,a),0===r&&S("Can't create run options."),void 0!==e?.extra&&fe(e.extra,"",new WeakSet,((e,o)=>{let a=L(e,n),i=L(o,n);0!==t._OrtAddRunConfigEntry(r,a,i)&&S(`Can't set a run config entry: ${e} - ${o}.`);})),[r,n]}catch(e){throw 0!==r&&t._OrtReleaseRunOptions(r),n.forEach((e=>t._free(e))),e}};})),Kt=T((()=>{J(),Be(),Ur=e=>{switch(e){case"disabled":return 0;case"basic":return 1;case"extended":return 2;case"all":return 99;default:throw new Error(`unsupported graph optimization level: ${e}`)}},_r=e=>{switch(e){case"sequential":return 0;case"parallel":return 1;default:throw new Error(`unsupported execution mode: ${e}`)}},Mr=e=>{e.extra||(e.extra={}),e.extra.session||(e.extra.session={});let t=e.extra.session;t.use_ort_model_bytes_directly||(t.use_ort_model_bytes_directly="1"),e.executionProviders&&e.executionProviders.some((e=>"webgpu"===("string"==typeof e?e:e.name)))&&(e.enableMemPattern=!1);},Dr=(e,t,r)=>{for(let n of t){let t="string"==typeof n?n:n.name;switch(t){case"webnn":if(t="WEBNN","string"!=typeof n){let t=n?.deviceType;if(t){let n=L("deviceType",r),o=L(t,r);0!==x()._OrtAddSessionConfigEntry(e,n,o)&&S(`Can't set a session config entry: 'deviceType' - ${t}.`);}}break;case"webgpu":if(t="JS","string"!=typeof n){let t=n;if(t?.preferredLayout){if("NCHW"!==t.preferredLayout&&"NHWC"!==t.preferredLayout)throw new Error(`preferredLayout must be either 'NCHW' or 'NHWC': ${t.preferredLayout}`);let n=L("preferredLayout",r),o=L(t.preferredLayout,r);0!==x()._OrtAddSessionConfigEntry(e,n,o)&&S(`Can't set a session config entry: 'preferredLayout' - ${t.preferredLayout}.`);}}break;case"wasm":case"cpu":continue;default:throw new Error(`not supported execution provider: ${t}`)}let o=L(t,r);0!==x()._OrtAppendExecutionProvider(e,o)&&S(`Can't append execution provider: ${t}.`);}},Zt=e=>{let t=x(),r=0,n=[],o=e||{};Mr(o);try{let e=Ur(o.graphOptimizationLevel??"all"),a=_r(o.executionMode??"sequential"),i="string"==typeof o.logId?L(o.logId,n):0,s=o.logSeverityLevel??2;if(!Number.isInteger(s)||s<0||s>4)throw new Error(`log serverity level is not valid: ${s}`);let l=o.logVerbosityLevel??0;if(!Number.isInteger(l)||l<0||l>4)throw new Error(`log verbosity level is not valid: ${l}`);let u="string"==typeof o.optimizedModelFilePath?L(o.optimizedModelFilePath,n):0;if(r=t._OrtCreateSessionOptions(e,!!o.enableCpuMemArena,!!o.enableMemPattern,a,!!o.enableProfiling,0,i,s,l,u),0===r&&S("Can't create session options."),o.executionProviders&&Dr(r,o.executionProviders,n),void 0!==o.enableGraphCapture){if("boolean"!=typeof o.enableGraphCapture)throw new Error(`enableGraphCapture must be a boolean value: ${o.enableGraphCapture}`);let e=L("enableGraphCapture",n),a=L(o.enableGraphCapture.toString(),n);0!==t._OrtAddSessionConfigEntry(r,e,a)&&S(`Can't set a session config entry: 'enableGraphCapture' - ${o.enableGraphCapture}.`);}if(o.freeDimensionOverrides)for(let[e,a]of Object.entries(o.freeDimensionOverrides)){if("string"!=typeof e)throw new Error(`free dimension override name must be a string: ${e}`);if("number"!=typeof a||!Number.isInteger(a)||a<0)throw new Error(`free dimension override value must be a non-negative integer: ${a}`);let o=L(e,n);0!==t._OrtAddFreeDimensionOverride(r,o,a)&&S(`Can't set a free dimension override: ${e} - ${a}.`);}return void 0!==o.extra&&fe(o.extra,"",new WeakSet,((e,o)=>{let a=L(e,n),i=L(o,n);0!==t._OrtAddSessionConfigEntry(r,a,i)&&S(`Can't set a session config entry: ${e} - ${o}.`);})),[r,n]}catch(e){throw 0!==r&&0!==t._OrtReleaseSessionOptions(r)&&S("Can't release session options."),n.forEach((e=>t._free(e))),e}};})),Qe=T((()=>{ee=e=>{switch(e){case"int8":return 3;case"uint8":return 2;case"bool":return 9;case"int16":return 5;case"uint16":return 4;case"int32":return 6;case"uint32":return 12;case"float16":return 10;case"float32":return 1;case"float64":return 11;case"string":return 8;case"int64":return 7;case"uint64":return 13;case"int4":return 22;case"uint4":return 21;default:throw new Error(`unsupported data type: ${e}`)}},Qt=e=>{switch(e){case 3:return "int8";case 2:return "uint8";case 9:return "bool";case 5:return "int16";case 4:return "uint16";case 6:return "int32";case 12:return "uint32";case 10:return "float16";case 1:return "float32";case 11:return "float64";case 8:return "string";case 7:return "int64";case 13:return "uint64";case 22:return "int4";case 21:return "uint4";default:throw new Error(`unsupported data type: ${e}`)}},te=(e,t)=>{let r=[-1,4,1,1,2,2,4,8,-1,1,2,8,4,8,-1,-1,-1,-1,-1,-1,-1,.5,.5][e],n="number"==typeof t?t:t.reduce(((e,t)=>e*t),1);return r>0?Math.ceil(n*r):void 0},er=e=>{switch(e){case"float16":return typeof Float16Array<"u"&&Float16Array.from?Float16Array:Uint16Array;case"float32":return Float32Array;case"uint8":case"bool":return Uint8Array;case"int8":return Int8Array;case"uint16":return Uint16Array;case"int16":return Int16Array;case"int32":return Int32Array;case"float64":return Float64Array;case"uint32":return Uint32Array;case"int64":return BigInt64Array;case"uint64":return BigUint64Array;default:throw new Error(`unsupported type: ${e}`)}},tr=e=>{switch(e){case"verbose":return 0;case"info":return 1;case"warning":return 2;case"error":return 3;case"fatal":return 4;default:throw new Error(`unsupported logging level: ${e}`)}},Ce=e=>"float32"===e||"float16"===e||"int32"===e||"int64"===e||"uint32"===e||"uint8"===e||"bool"===e||"uint4"===e||"int4"===e,Ue=e=>"float32"===e||"float16"===e||"int32"===e||"int64"===e||"uint32"===e||"uint64"===e||"int8"===e||"uint8"===e||"bool"===e||"uint4"===e||"int4"===e,rr=e=>{switch(e){case"none":return 0;case"cpu":return 1;case"cpu-pinned":return 2;case"texture":return 3;case"gpu-buffer":return 4;case"ml-tensor":return 5;default:throw new Error(`unsupported data location: ${e}`)}};})),et=T((()=>{be(),ce=async e=>{if("string"==typeof e){{let t=await fetch(e);if(!t.ok)throw new Error(`failed to load external data file: ${e}`);let r=t.headers.get("Content-Length"),n=r?parseInt(r,10):0;if(n<1073741824)return new Uint8Array(await t.arrayBuffer());{if(!t.body)throw new Error(`failed to load external data file: ${e}, no response body.`);let r,o=t.body.getReader();try{r=new ArrayBuffer(n);}catch(e){if(!(e instanceof RangeError))throw e;{let e=Math.ceil(n/65536);r=new WebAssembly.Memory({initial:e,maximum:e}).buffer;}}let a=0;for(;;){let{done:e,value:t}=await o.read();if(e)break;let n=t.byteLength;new Uint8Array(r,a,n).set(t),a+=n;}return new Uint8Array(r,0,n)}}}return e instanceof Blob?new Uint8Array(await e.arrayBuffer()):e instanceof Uint8Array?e:new Uint8Array(e)};})),Je=T((()=>{Xt(),Kt(),Qe(),J(),Be(),et(),Rr=(e,t)=>{0!==x()._OrtInit(e,t)&&S("Can't initialize onnxruntime.");},Te=async e=>{Rr(e.wasm.numThreads,tr(e.logLevel));},Se=async(e,t)=>{},re=new Map,Fr=e=>{let t=x(),r=t.stackSave();try{let r=t.PTR_SIZE,n=t.stackAlloc(2*r);0!==t._OrtGetInputOutputCount(e,n,n+r)&&S("Can't get session input/output count.");let o=4===r?"i32":"i64";return [Number(t.getValue(n,o)),Number(t.getValue(n+r,o))]}finally{t.stackRestore(r);}},ue=e=>{let t=x(),r=t._malloc(e.byteLength);if(0===r)throw new Error(`Can't create a session. failed to allocate a buffer of size ${e.byteLength}.`);return t.HEAPU8.set(e,r),[r,e.byteLength]},Ae=async(e,t)=>{let r,n,o=x();Array.isArray(e)?[r,n]=e:e.buffer===o.HEAPU8.buffer?[r,n]=[e.byteOffset,e.byteLength]:[r,n]=ue(e);let a=0,i=0,s=[],l=[],u=[];try{if([i,s]=Zt(t),t?.externalData&&o.mountExternalData){let e=[];for(let r of t.externalData){let t="string"==typeof r?r:r.path;e.push(ce("string"==typeof r?r:r.data).then((e=>{o.mountExternalData(t,e);})));}await Promise.all(e);}for(let e of t?.executionProviders??[])if("webnn"===("string"==typeof e?e:e.name)){if(o.shouldTransferToMLTensor=!1,"string"!=typeof e){let t=e,r=t?.context,n=t?.gpuDevice,a=t?.deviceType,i=t?.powerPreference;o.currentContext=r||(n?await o.jsepCreateMLContext(n):await o.jsepCreateMLContext({deviceType:a,powerPreference:i}));}else o.currentContext=await o.jsepCreateMLContext();break}a=await o._OrtCreateSession(r,n,i),0===a&&S("Can't create a session."),o.jsepOnCreateSession?.(),o.currentContext&&(o.jsepRegisterMLContext(a,o.currentContext),o.currentContext=void 0,o.shouldTransferToMLTensor=!0);let[e,f]=Fr(a),d=!!t?.enableGraphCapture,p=[],c=[];for(let t=0;t<e;t++){let e=o._OrtGetInputName(a,t);0===e&&S("Can't get an input name."),l.push(e),p.push(o.UTF8ToString(e));}for(let e=0;e<f;e++){let t=o._OrtGetOutputName(a,e);0===t&&S("Can't get an output name."),u.push(t);let r=o.UTF8ToString(t);c.push(r);}return re.set(a,[a,l,u,null,d,!1]),[a,p,c]}catch(e){throw l.forEach((e=>o._OrtFree(e))),u.forEach((e=>o._OrtFree(e))),0!==a&&0!==o._OrtReleaseSession(a)&&S("Can't release session."),e}finally{o._free(r),0!==i&&0!==o._OrtReleaseSessionOptions(i)&&S("Can't release session options."),s.forEach((e=>o._free(e))),o.unmountExternalData?.();}},Oe=e=>{let t=x(),r=re.get(e);if(!r)throw new Error(`cannot release session. invalid session id: ${e}`);let[n,o,a,i,s]=r;i&&(s&&0!==t._OrtClearBoundOutputs(i.handle)&&S("Can't clear bound outputs."),0!==t._OrtReleaseBinding(i.handle)&&S("Can't release IO binding.")),t.jsepOnReleaseSession?.(e),o.forEach((e=>t._OrtFree(e))),a.forEach((e=>t._OrtFree(e))),0!==t._OrtReleaseSession(n)&&S("Can't release session."),re.delete(e);},nr=async(e,t,r,n,o,a=!1)=>{if(!e)return void t.push(0);let i,s,l=x(),u=l.PTR_SIZE,f=e[0],d=e[1],p=e[3],c=p;if("string"===f&&("gpu-buffer"===p||"ml-tensor"===p))throw new Error("String tensor is not supported on GPU.");if(a&&"gpu-buffer"!==p)throw new Error(`External buffer must be provided for input/output index ${o} when enableGraphCapture is true.`);if("gpu-buffer"===p){let t=e[2].gpuBuffer;s=te(ee(f),d);let r=l.jsepRegisterBuffer;if(!r)throw new Error('Tensor location "gpu-buffer" is not supported without using WebGPU.');i=r(n,o,t,s);}else if("ml-tensor"===p){let t=e[2].mlTensor;s=te(ee(f),d);let r=l.jsepRegisterMLTensor;if(!r)throw new Error('Tensor location "ml-tensor" is not supported without using WebNN.');i=r(n,t,ee(f),d);}else {let t=e[2];if(Array.isArray(t)){s=u*t.length,i=l._malloc(s),r.push(i);for(let e=0;e<t.length;e++){if("string"!=typeof t[e])throw new TypeError(`tensor data at index ${e} is not a string`);l.setValue(i+e*u,L(t[e],r),"*");}}else {let e=l.jsepIsGraphInput;if("string"!==f&&e){let a=l._OrtGetInputName(n,o);if(e(n,l.UTF8ToString(a))){let e=ee(f);s=te(e,d),c="ml-tensor";let r=l.jsepCreateTemporaryTensor,o=l.jsepUploadTensor;if(!r||!o)throw new Error('Tensor location "ml-tensor" is not supported without using WebNN.');let a=await r(n,e,d);o(a,new Uint8Array(t.buffer,t.byteOffset,t.byteLength)),i=a;}else s=t.byteLength,i=l._malloc(s),r.push(i),l.HEAPU8.set(new Uint8Array(t.buffer,t.byteOffset,s),i);}else s=t.byteLength,i=l._malloc(s),r.push(i),l.HEAPU8.set(new Uint8Array(t.buffer,t.byteOffset,s),i);}}let h=l.stackSave(),w=l.stackAlloc(4*d.length);try{d.forEach(((e,t)=>l.setValue(w+t*u,e,4===u?"i32":"i64")));let e=l._OrtCreateTensor(ee(f),i,s,w,d.length,rr(c));0===e&&S(`Can't create tensor for input/output. session=${n}, index=${o}.`),t.push(e);}finally{l.stackRestore(h);}},xe=async(e,t,r,n,o,a)=>{let i=x(),s=i.PTR_SIZE,l=re.get(e);if(!l)throw new Error(`cannot run inference. invalid session id: ${e}`);let u=l[0],f=l[1],d=l[2],p=l[3],c=l[4],h=(l[5],t.length),w=n.length,y=0,m=[],g=[],b=[],v=[],E=i.stackSave(),T=i.stackAlloc(h*s),A=i.stackAlloc(h*s),L=i.stackAlloc(w*s),C=i.stackAlloc(w*s);try{[y,m]=Jt(a);for(let n=0;n<h;n++)await nr(r[n],g,v,e,t[n],c);for(let t=0;t<w;t++)await nr(o[t],b,v,e,h+n[t],c);for(let e=0;e<h;e++)i.setValue(T+e*s,g[e],"*"),i.setValue(A+e*s,f[t[e]],"*");for(let e=0;e<w;e++)i.setValue(L+e*s,b[e],"*"),i.setValue(C+e*s,d[n[e]],"*");let l;i.jsepOnRunStart?.(u),l=await i._OrtRun(u,A,T,h,C,w,L,y),0!==l&&S("failed to call OrtRun().");let E=[];for(let t=0;t<w;t++){let r=Number(i.getValue(L+t*s,"*"));if(r===b[t]){E.push(o[t]);continue}let a,l=i.stackSave(),f=i.stackAlloc(4*s),d=!1,c=0;try{0!==i._OrtGetTensorData(r,f,f+s,f+2*s,f+3*s)&&S(`Can't access output tensor data on index ${t}.`);let o=4===s?"i32":"i64",l=Number(i.getValue(f,o));c=i.getValue(f+s,"*");let u=i.getValue(f+2*s,"*"),h=Number(i.getValue(f+3*s,o)),w=[];for(let e=0;e<h;e++)w.push(Number(i.getValue(u+e*s,o)));0!==i._OrtFree(u)&&S("Can't free memory for tensor dims.");let y=w.reduce(((e,t)=>e*t),1);a=Qt(l);let m=p?.outputPreferredLocations[n[t]];if("string"===a){if("gpu-buffer"===m||"ml-tensor"===m)throw new Error("String tensor is not supported on GPU.");let e=[];for(let t=0;t<y;t++){let r=i.getValue(c+t*s,"*"),n=i.getValue(c+(t+1)*s,"*"),o=t===y-1?void 0:n-r;e.push(i.UTF8ToString(r,o));}E.push([a,w,e,"cpu"]);}else if("gpu-buffer"===m&&y>0){let e=i.jsepGetBuffer;if(!e)throw new Error('preferredLocation "gpu-buffer" is not supported without using WebGPU.');let t=e(c),n=te(l,y);if(void 0===n||!Ce(a))throw new Error(`Unsupported data type: ${a}`);d=!0,E.push([a,w,{gpuBuffer:t,download:i.jsepCreateDownloader(t,n,a),dispose:()=>{0!==i._OrtReleaseTensor(r)&&S("Can't release tensor.");}},"gpu-buffer"]);}else if("ml-tensor"===m&&y>0){let t=i.jsepEnsureTensor;if(!t)throw new Error('preferredLocation "ml-tensor" is not supported without using WebNN.');if(void 0===te(l,y)||!Ue(a))throw new Error(`Unsupported data type: ${a}`);let n=await t(e,c,l,w,!1);d=!0,E.push([a,w,{mlTensor:n,download:i.jsepCreateMLTensorDownloader(c,a),dispose:()=>{i.jsepReleaseTensorId(c),i._OrtReleaseTensor(r);}},"ml-tensor"]);}else {let e=new(er(a))(y);new Uint8Array(e.buffer,e.byteOffset,e.byteLength).set(i.HEAPU8.subarray(c,c+e.byteLength)),E.push([a,w,e,"cpu"]);}}finally{i.stackRestore(l),"string"===a&&c&&i._free(c),d||i._OrtReleaseTensor(r),i.jsepOnRunEnd?.(u);}}return p&&!c&&(0!==i._OrtClearBoundOutputs(p.handle)&&S("Can't clear bound outputs."),re.set(e,[u,f,d,p,c,!1])),E}finally{i.stackRestore(E),g.forEach((e=>i._OrtReleaseTensor(e))),b.forEach((e=>i._OrtReleaseTensor(e))),v.forEach((e=>i._free(e))),0!==y&&i._OrtReleaseRunOptions(y),m.forEach((e=>i._free(e)));}},Le=e=>{let t=x(),r=re.get(e);if(!r)throw new Error("invalid session id");let n=r[0],o=t._OrtEndProfiling(n);0===o&&S("Can't get an profile file name."),t._OrtFree(o);},Ie=e=>{let t=[];for(let r of e){let e=r[2];!Array.isArray(e)&&"buffer"in e&&t.push(e.buffer);}return t};})),nt=T((()=>{q(),Je(),J(),ge(),Z=()=>!!A.wasm.proxy&&typeof document<"u",le=!1,Me=!1,De=!1,rt=new Map,ne=(e,t)=>{let r=rt.get(e);r?r.push(t):rt.set(e,[t]);},oe=()=>{if(le||!Me||De||!D)throw new Error("worker not ready")},Nr=e=>{switch(e.data.type){case"init-wasm":le=!1,e.data.err?(De=!0,tt[1](e.data.err)):(Me=!0,tt[0]()),_e&&(URL.revokeObjectURL(_e),_e=void 0);break;case"init-ep":case"copy-from":case"create":case"release":case"run":case"end-profiling":{let t=rt.get(e.data.type);e.data.err?t.shift()[1](e.data.err):t.shift()[0](e.data.out);break}}},or=async()=>{if(!Me){if(le)throw new Error("multiple calls to 'initWasm()' detected.");if(De)throw new Error("previous call to 'initWasm()' failed.");if(le=!0,Z())return new Promise(((e,t)=>{D?.terminate(),Vt().then((([r,n])=>{try{(D=n).onerror=e=>t(e),D.onmessage=Nr,tt=[e,t];let o={type:"init-wasm",in:A};if(!o.in.wasm.wasmPaths&&r){let e=Pe();e&&(o.in.wasm.wasmPaths=e);}D.postMessage(o),_e=r;}catch(e){t(e);}}),t);}));try{await Ee(A.wasm),await Te(A),Me=!0;}catch(e){throw De=!0,e}finally{le=!1;}}},sr=async e=>{if(Z())return oe(),new Promise(((t,r)=>{ne("init-ep",[t,r]);let n={type:"init-ep",in:{epName:e,env:A}};D.postMessage(n);}));await Se(A,e);},ir=async e=>Z()?(oe(),new Promise(((t,r)=>{ne("copy-from",[t,r]);let n={type:"copy-from",in:{buffer:e}};D.postMessage(n,[e.buffer]);}))):ue(e),ar=async(e,t)=>{if(Z()){if(t?.preferredOutputLocation)throw new Error('session option "preferredOutputLocation" is not supported for proxy.');return oe(),new Promise(((r,n)=>{ne("create",[r,n]);let o={type:"create",in:{model:e,options:{...t}}},a=[];e instanceof Uint8Array&&a.push(e.buffer),D.postMessage(o,a);}))}return Ae(e,t)},ur=async e=>{if(Z())return oe(),new Promise(((t,r)=>{ne("release",[t,r]);let n={type:"release",in:e};D.postMessage(n);}));Oe(e);},fr=async(e,t,r,n,o,a)=>{if(Z()){if(r.some((e=>"cpu"!==e[3])))throw new Error("input tensor on GPU is not supported for proxy.");if(o.some((e=>e)))throw new Error("pre-allocated output tensor is not supported for proxy.");return oe(),new Promise(((o,i)=>{ne("run",[o,i]);let s=r,l={type:"run",in:{sessionId:e,inputIndices:t,inputs:s,outputIndices:n,options:a}};D.postMessage(l,Ie(s));}))}return xe(e,t,r,n,o,a)},cr=async e=>{if(Z())return oe(),new Promise(((t,r)=>{ne("end-profiling",[t,r]);let n={type:"end-profiling",in:e};D.postMessage(n);}));Le(e);};})),dr=T((()=>{q(),nt(),Qe(),be(),et(),lr=(e,t)=>{switch(e.location){case"cpu":return [e.type,e.dims,e.data,"cpu"];case"gpu-buffer":return [e.type,e.dims,{gpuBuffer:e.gpuBuffer},"gpu-buffer"];case"ml-tensor":return [e.type,e.dims,{mlTensor:e.mlTensor},"ml-tensor"];default:throw new Error(`invalid data location: ${e.location} for ${t()}`)}},Wr=e=>{switch(e[3]){case"cpu":return new R(e[0],e[2],e[1]);case"gpu-buffer":{let t=e[0];if(!Ce(t))throw new Error(`not supported data type: ${t} for deserializing GPU tensor`);let{gpuBuffer:r,download:n,dispose:o}=e[2];return R.fromGpuBuffer(r,{dataType:t,dims:e[1],download:n,dispose:o})}case"ml-tensor":{let t=e[0];if(!Ue(t))throw new Error(`not supported data type: ${t} for deserializing MLTensor tensor`);let{mlTensor:r,download:n,dispose:o}=e[2];return R.fromMLTensor(r,{dataType:t,dims:e[1],download:n,dispose:o})}default:throw new Error(`invalid data location: ${e[3]}`)}},Re=class{async fetchModelAndCopyToWasmMemory(e){return ir(await ce(e))}async loadModel(e,t){let r;V(),r="string"==typeof e?await this.fetchModelAndCopyToWasmMemory(e):e,[this.sessionId,this.inputNames,this.outputNames]=await ar(r,t),Y();}async dispose(){return ur(this.sessionId)}async run(e,t,r){V();let n=[],o=[];Object.entries(e).forEach((e=>{let t=e[0],r=e[1],a=this.inputNames.indexOf(t);if(-1===a)throw new Error(`invalid input '${t}'`);n.push(r),o.push(a);}));let a=[],i=[];Object.entries(t).forEach((e=>{let t=e[0],r=e[1],n=this.outputNames.indexOf(t);if(-1===n)throw new Error(`invalid output '${t}'`);a.push(r),i.push(n);}));let s=n.map(((e,t)=>lr(e,(()=>`input "${this.inputNames[o[t]]}"`)))),l=a.map(((e,t)=>e?lr(e,(()=>`output "${this.outputNames[i[t]]}"`)):null)),u=await fr(this.sessionId,o,s,i,l,r),f={};for(let e=0;e<u.length;e++)f[this.outputNames[i[e]]]=a[e]??Wr(u[e]);return Y(),f}startProfiling(){}endProfiling(){cr(this.sessionId);}};})),mr={};Ge(mr,{OnnxruntimeWebAssemblyBackend:()=>Fe,initializeFlags:()=>pr,wasmBackend:()=>$r});var pr,Fe,$r,hr=T((()=>{q(),nt(),dr(),pr=()=>{if(("number"!=typeof A.wasm.initTimeout||A.wasm.initTimeout<0)&&(A.wasm.initTimeout=0),!1===A.wasm.simd&&console.warn('Deprecated property "env.wasm.simd" is set to false. non-SIMD build is no longer provided, and this setting will be ignored.'),"boolean"!=typeof A.wasm.proxy&&(A.wasm.proxy=!1),"boolean"!=typeof A.wasm.trace&&(A.wasm.trace=!1),"number"!=typeof A.wasm.numThreads||!Number.isInteger(A.wasm.numThreads)||A.wasm.numThreads<=0)if(typeof self<"u"&&!self.crossOriginIsolated)A.wasm.numThreads=1;else {let e=typeof navigator>"u"?$e("node:os").cpus().length:navigator.hardwareConcurrency;A.wasm.numThreads=Math.min(4,Math.ceil((e||1)/2));}},$r=new(Fe=class{async init(e){pr(),await or(),await sr(e);}async createInferenceSessionHandler(e,t){let r=new Re;return await r.loadModel(e,t),Promise.resolve(r)}});}));q(),q(),q();var Ft="1.21.0";{let e=(hr(),at(mr)).wasmBackend;ie("cpu",e,10),ie("wasm",e,10);}Object.defineProperty(A.versions,"web",{value:Ft,enumerable:!0});

class WorkerNative{constructor(){this.ready=!1;this.indexedDBManager=new IndexedDBManager("onirix-sdk","files"),this.indexedDBManager.getFileFromIndexedDB("SDK_1.10.0").then((async t=>{let e=URL.createObjectURL(new Blob([t],{type:"text/javascript"}));const{default:a}=await import(/* webpackIgnore: true, webpackMode: "lazy" */e),i=await a();this.nativeSDK=i,this.coarseFrame=this.nativeSDK._malloc(3686400),this.extractionFrame=this.nativeSDK._malloc(3686400),this.bufferLength=0,this.frameLayoutStruct=this.nativeSDK._malloc(28),A.wasm.numThreads=1;const s=await this.indexedDBManager.getFileFromIndexedDB("ort.wasm"),r=URL.createObjectURL(new Blob([s],{type:"application/wasm"}));A.wasm.wasmPaths={wasm:r,mjs:"https://cdn.onirix.com/onirix-engine-sdk/ort_v1.21.0_min/ort-wasm-simd.mjs"};let n=await this.indexedDBManager.getFromCacheOrFetch("coarseloc.ort","https://cdn.onirix.com/onirix-engine-sdk/coarseloc.ort");const o=await Or.create(n,{executionProviders:["wasm"]});let h=await this.indexedDBManager.getFromCacheOrFetch("sparse_extract.ort","https://cdn.onirix.com/onirix-engine-sdk/sparse_extract.ort");const c=await Or.create(h,{executionProviders:["wasm"]});this.session=o,this.sessionExtraction=c,await this.session.run({input:new R(new Float32Array(Array(921600).fill(0)),[1,3,640,480])}),this.ready=!0,postMessage("ready");}));}start(){addEventListener("message",(async t=>{if(!this.ready)return void postMessage(!1);this.ready=!1;const e=t.data,a=e.width*e.height*4;0!=this.bufferLength&&this.bufferLength==a||(0!=this.bufferLength&&this.nativeSDK._free(this.buffer),this.bufferLength=a,this.buffer=this.nativeSDK._malloc(this.bufferLength)),this.nativeSDK.HEAPU8.set(e.data,this.buffer),this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+0]=e.width,this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+1]=e.height,this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+2]=4*e.width,this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+3]=!1,this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+4]=e.colorSpace,this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+5]=e.rotate,this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+6]=e.flip;let i=this.nativeSDK._OX_Extract(this.buffer,this.coarseFrame,this.extractionFrame,this.frameLayoutStruct,e.dtype),s=[];if(e.onlyCoarse||2!=e.dtype)s=new Float32Array(this.readExtractionData(this.nativeSDK.HEAPF32,i/4));else {let t=[];for(let e=0;e<921600;e++)t.push(this.nativeSDK.HEAPF32[this.extractionFrame/4+e]);let{keypoints:e,descriptors:a}=await this.sessionExtraction.run({image:new R(new Float32Array(t),[1,3,480,640])}),i=[e.dims[0],...e.data,...a.data];s=new Float32Array(i);}let r=[];for(let t=0;t<921600;t++)r.push(this.nativeSDK.HEAPF32[this.coarseFrame/4+t]);let n=await this.session.run({input:new R(new Float32Array(r),[1,3,640,480])});postMessage({extraction:s,descriptor:n.output.data,onlyCoarse:e.onlyCoarse}),this.ready=!0;}));}readExtractionData(t,e){let a=e,i=[],s=t[a];i.push(s),a++;for(let e=0;e<s;e++)i.push(t[a]),i.push(t[a+1]),a+=2;for(let e=0;e<128*s;e++)i.push(t[a]),a++;return i}}const worker=new WorkerNative;worker.start();
"),b=new Blob([d],{type:"application/javascript"});this.workers[Z]=new Worker(/* webpackIgnore: true, webpackMode: "lazy" */URL.createObjectURL(b),{type:"module"}),this.callbacks[Z]=l,this.workers[Z].addEventListener("message",(l=>{this.callbacks[Z](l.data);}));}}createMatchingWorker(Z,l){if(!this.workerExists(Z)){let d=atob("class IndexedDBManager{constructor(e,r){this.dbName=e,this.storeName=r;}async getFromCacheOrFetch(e,r){let t=null;try{t=await this.getFileFromIndexedDB(e);}catch(e){console.log("An error occurred while trying to get element from indexedDB.");}return t||(t=await this.fetchAndCacheFile(r,e)),new Uint8Array(t)}async getFileFromIndexedDB(e){return new Promise(((r,t)=>{const o=indexedDB.open(this.dbName);o.onerror=()=>t(o.error),o.onsuccess=()=>{const s=o.result.transaction(this.storeName,"readonly").objectStore(this.storeName).get(e);s.onsuccess=()=>r(s.result),s.onerror=()=>t(s.error);},o.onupgradeneeded=e=>{e.target.result.createObjectStore(this.storeName);};}))}async saveFileToIndexedDB(e,r){return new Promise(((t,o)=>{const s=indexedDB.open(this.dbName);s.onerror=()=>o(s.error),s.onupgradeneeded=e=>{e.target.result.createObjectStore(this.storeName);},s.onsuccess=()=>{try{const n=s.result.transaction(this.storeName,"readwrite"),a=n.objectStore(this.storeName).put(r,e);a.onsuccess=()=>t(a.result),a.onerror=()=>o(a.error);}catch(e){o(e);}};}))}async fetchAndCacheFile(e,r){const t=await fetch(e),o=await t.arrayBuffer();return await this.saveFileToIndexedDB(r,o),o}}

var he,j,ie,Ar,ut,ct,dt,_,A,mt,ht,He,yt,bt,gt,Et,Tt,H,ae,At,Ot,Lt,It,v,R,vt,Bt,V,Y,ye,Or,We=Object.defineProperty,gr=Object.getOwnPropertyDescriptor,Er=Object.getOwnPropertyNames,Tr=Object.prototype.hasOwnProperty,$e=(e=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(e,{get:(e,t)=>(typeof require<"u"?require:e)[t]}):e)((function(e){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+e+'" is not supported')})),T=(e,t)=>()=>(e&&(t=e(e=0)),t),Ge=(e,t)=>{for(var r in t)We(e,r,{get:t[r],enumerable:!0});},Sr=(e,t,r,n)=>{if(t&&"object"==typeof t||"function"==typeof t)for(let o of Er(t))!Tr.call(e,o)&&o!==r&&We(e,o,{get:()=>t[o],enumerable:!(n=gr(t,o))||n.enumerable});return e},at=e=>Sr(We({},"__esModule",{value:!0}),e),ze=T((()=>{he=new Map,j=[],ie=(e,t,r)=>{if(!t||"function"!=typeof t.init||"function"!=typeof t.createInferenceSessionHandler)throw new TypeError("not a valid backend");{let n=he.get(e);if(void 0===n)he.set(e,{backend:t,priority:r});else {if(n.priority>r)return;if(n.priority===r&&n.backend!==t)throw new Error(`cannot register backend "${e}" using priority ${r}`)}if(r>=0){let t=j.indexOf(e);-1!==t&&j.splice(t,1);for(let t=0;t<j.length;t++)if(he.get(j[t]).priority<=r)return void j.splice(t,0,e);j.push(e);}}},Ar=async e=>{let t=he.get(e);if(!t)return "backend not found.";if(t.initialized)return t.backend;if(t.aborted)return t.error;{let r=!!t.initPromise;try{return r||(t.initPromise=t.backend.init(e)),await t.initPromise,t.initialized=!0,t.backend}catch(e){return r||(t.error=`${e}`,t.aborted=!0),t.error}finally{delete t.initPromise;}}},ut=async e=>{let t,r=e.executionProviders||[],n=r.map((e=>"string"==typeof e?e:e.name)),o=0===n.length?j:n,a=[],i=new Set;for(let e of o){let r=await Ar(e);"string"==typeof r?a.push({name:e,err:r}):(t||(t=r),t===r&&i.add(e));}if(!t)throw new Error(`no available backend found. ERR: ${a.map((e=>`[${e.name}] ${e.err}`)).join(", ")}`);for(let{name:e,err:t}of a)n.includes(e)&&console.warn(`removing requested execution provider "${e}" from session options because it is not available: ${t}`);let s=r.filter((e=>i.has("string"==typeof e?e:e.name)));return [t,new Proxy(e,{get:(e,t)=>"executionProviders"===t?s:Reflect.get(e,t)})]};})),ft=T((()=>{ze();})),lt=T((()=>{ct="1.21.0";})),je=T((()=>{lt(),dt="warning",_={wasm:{},webgl:{},webgpu:{},versions:{common:ct},set logLevel(e){if(void 0!==e){if("string"!=typeof e||-1===["verbose","info","warning","error","fatal"].indexOf(e))throw new Error(`Unsupported logging level: ${e}`);dt=e;}},get logLevel(){return dt}},Object.defineProperty(_,"logLevel",{enumerable:!0});})),pt=T((()=>{je(),A=_;})),wt=T((()=>{mt=(e,t)=>{let r=typeof document<"u"?document.createElement("canvas"):new OffscreenCanvas(1,1);r.width=e.dims[3],r.height=e.dims[2];let n=r.getContext("2d");if(null!=n){let o,a;void 0!==t?.tensorLayout&&"NHWC"===t.tensorLayout?(o=e.dims[2],a=e.dims[3]):(o=e.dims[3],a=e.dims[2]);let i,s,l=void 0!==t?.format?t.format:"RGB",u=t?.norm;void 0===u||void 0===u.mean?i=[255,255,255,255]:"number"==typeof u.mean?i=[u.mean,u.mean,u.mean,u.mean]:(i=[u.mean[0],u.mean[1],u.mean[2],0],void 0!==u.mean[3]&&(i[3]=u.mean[3])),void 0===u||void 0===u.bias?s=[0,0,0,0]:"number"==typeof u.bias?s=[u.bias,u.bias,u.bias,u.bias]:(s=[u.bias[0],u.bias[1],u.bias[2],0],void 0!==u.bias[3]&&(s[3]=u.bias[3]));let f=a*o,d=0,p=f,c=2*f,h=-1;"RGBA"===l?(d=0,p=f,c=2*f,h=3*f):"RGB"===l?(d=0,p=f,c=2*f):"RBG"===l&&(d=0,c=f,p=2*f);for(let t=0;t<a;t++)for(let r=0;r<o;r++){let o=(e.data[d++]-s[0])*i[0],a=(e.data[p++]-s[1])*i[1],l=(e.data[c++]-s[2])*i[2],u=-1===h?255:(e.data[h++]-s[3])*i[3];n.fillStyle="rgba("+o+","+a+","+l+","+u+")",n.fillRect(r,t,1,1);}if("toDataURL"in r)return r.toDataURL();throw new Error("toDataURL is not supported")}throw new Error("Can not access image data")},ht=(e,t)=>{let r,n=typeof document<"u"?document.createElement("canvas").getContext("2d"):new OffscreenCanvas(1,1).getContext("2d");if(null==n)throw new Error("Can not access image data");{let o,a,i;void 0!==t?.tensorLayout&&"NHWC"===t.tensorLayout?(o=e.dims[2],a=e.dims[1],i=e.dims[3]):(o=e.dims[3],a=e.dims[2],i=e.dims[1]);let s,l,u=void 0!==t&&void 0!==t.format?t.format:"RGB",f=t?.norm;void 0===f||void 0===f.mean?s=[255,255,255,255]:"number"==typeof f.mean?s=[f.mean,f.mean,f.mean,f.mean]:(s=[f.mean[0],f.mean[1],f.mean[2],255],void 0!==f.mean[3]&&(s[3]=f.mean[3])),void 0===f||void 0===f.bias?l=[0,0,0,0]:"number"==typeof f.bias?l=[f.bias,f.bias,f.bias,f.bias]:(l=[f.bias[0],f.bias[1],f.bias[2],0],void 0!==f.bias[3]&&(l[3]=f.bias[3]));let d=a*o;if(void 0!==t&&(void 0!==t.format&&4===i&&"RGBA"!==t.format||3===i&&"RGB"!==t.format&&"BGR"!==t.format))throw new Error("Tensor format doesn't match input tensor dims");let p=4,c=0,h=1,w=2,y=3,m=0,g=d,b=2*d,v=-1;"RGBA"===u?(m=0,g=d,b=2*d,v=3*d):"RGB"===u?(m=0,g=d,b=2*d):"RBG"===u&&(m=0,b=d,g=2*d),r=n.createImageData(o,a);for(let t=0;t<a*o;c+=p,h+=p,w+=p,y+=p,t++)r.data[c]=(e.data[m++]-l[0])*s[0],r.data[h]=(e.data[g++]-l[1])*s[1],r.data[w]=(e.data[b++]-l[2])*s[2],r.data[y]=-1===v?255:(e.data[v++]-l[3])*s[3];}return r};})),St=T((()=>{we(),He=(e,t)=>{if(void 0===e)throw new Error("Image buffer must be defined");if(void 0===t.height||void 0===t.width)throw new Error("Image height and width must be defined");if("NHWC"===t.tensorLayout)throw new Error("NHWC Tensor layout is not supported yet");let r,n,{height:o,width:a}=t,i=t.norm??{mean:255,bias:0};r="number"==typeof i.mean?[i.mean,i.mean,i.mean,i.mean]:[i.mean[0],i.mean[1],i.mean[2],i.mean[3]??255],n="number"==typeof i.bias?[i.bias,i.bias,i.bias,i.bias]:[i.bias[0],i.bias[1],i.bias[2],i.bias[3]??0];let s=void 0!==t.format?t.format:"RGBA",l=void 0!==t.tensorFormat&&void 0!==t.tensorFormat?t.tensorFormat:"RGB",u=o*a,f="RGBA"===l?new Float32Array(4*u):new Float32Array(3*u),d=4,p=0,c=1,h=2,w=3,y=0,m=u,g=2*u,b=-1;"RGB"===s&&(d=3,p=0,c=1,h=2,w=-1),"RGBA"===l?b=3*u:"RBG"===l?(y=0,g=u,m=2*u):"BGR"===l&&(g=0,m=u,y=2*u);for(let t=0;t<u;t++,p+=d,h+=d,c+=d,w+=d)f[y++]=(e[p]+n[0])/r[0],f[m++]=(e[c]+n[1])/r[1],f[g++]=(e[h]+n[2])/r[2],-1!==b&&-1!==w&&(f[b++]=(e[w]+n[3])/r[3]);return new v("float32",f,"RGBA"===l?[1,4,o,a]:[1,3,o,a])},yt=async(e,t)=>{let r,n=typeof HTMLImageElement<"u"&&e instanceof HTMLImageElement,o=typeof ImageData<"u"&&e instanceof ImageData,a=typeof ImageBitmap<"u"&&e instanceof ImageBitmap,i="string"==typeof e,s=t??{},l=()=>{if(typeof document<"u")return document.createElement("canvas");if(typeof OffscreenCanvas<"u")return new OffscreenCanvas(1,1);throw new Error("Canvas is not supported")},u=e=>typeof HTMLCanvasElement<"u"&&e instanceof HTMLCanvasElement||e instanceof OffscreenCanvas?e.getContext("2d"):null;if(n){let n=l();n.width=e.width,n.height=e.height;let o=u(n);if(null==o)throw new Error("Can not access image data");{let n=e.height,a=e.width;if(void 0!==t&&void 0!==t.resizedHeight&&void 0!==t.resizedWidth&&(n=t.resizedHeight,a=t.resizedWidth),void 0!==t){if(s=t,void 0!==t.tensorFormat)throw new Error("Image input config format must be RGBA for HTMLImageElement");s.tensorFormat="RGBA",s.height=n,s.width=a;}else s.tensorFormat="RGBA",s.height=n,s.width=a;o.drawImage(e,0,0),r=o.getImageData(0,0,a,n).data;}}else {if(!o){if(a){if(void 0===t)throw new Error("Please provide image config with format for Imagebitmap");let n=l();n.width=e.width,n.height=e.height;let o=u(n);if(null!=o){let t=e.height,n=e.width;return o.drawImage(e,0,0,n,t),r=o.getImageData(0,0,n,t).data,s.height=t,s.width=n,He(r,s)}throw new Error("Can not access image data")}if(i)return new Promise(((t,r)=>{let n=l(),o=u(n);if(!e||!o)return r();let a=new Image;a.crossOrigin="Anonymous",a.src=e,a.onload=()=>{n.width=a.width,n.height=a.height,o.drawImage(a,0,0,n.width,n.height);let e=o.getImageData(0,0,n.width,n.height);s.height=n.height,s.width=n.width,t(He(e.data,s));};}));throw new Error("Input data provided is not supported - aborted tensor creation")}{let n,o;if(void 0!==t&&void 0!==t.resizedWidth&&void 0!==t.resizedHeight?(n=t.resizedHeight,o=t.resizedWidth):(n=e.height,o=e.width),void 0!==t&&(s=t),s.format="RGBA",s.height=n,s.width=o,void 0!==t){let t=l();t.width=o,t.height=n;let a=u(t);if(null==a)throw new Error("Can not access image data");a.putImageData(e,0,0),r=a.getImageData(0,0,o,n).data;}else r=e.data;}}if(void 0!==r)return He(r,s);throw new Error("Input data provided is not supported - aborted tensor creation")},bt=(e,t)=>{let{width:r,height:n,download:o,dispose:a}=t;return new v({location:"texture",type:"float32",texture:e,dims:[1,n,r,4],download:o,dispose:a})},gt=(e,t)=>{let{dataType:r,dims:n,download:o,dispose:a}=t;return new v({location:"gpu-buffer",type:r??"float32",gpuBuffer:e,dims:n,download:o,dispose:a})},Et=(e,t)=>{let{dataType:r,dims:n,download:o,dispose:a}=t;return new v({location:"ml-tensor",type:r??"float32",mlTensor:e,dims:n,download:o,dispose:a})},Tt=(e,t,r)=>new v({location:"cpu-pinned",type:e,data:t,dims:r??[t.length]});})),xt=T((()=>{H=new Map([["float32",Float32Array],["uint8",Uint8Array],["int8",Int8Array],["uint16",Uint16Array],["int16",Int16Array],["int32",Int32Array],["bool",Uint8Array],["float64",Float64Array],["uint32",Uint32Array],["int4",Uint8Array],["uint4",Uint8Array]]),ae=new Map([[Float32Array,"float32"],[Uint8Array,"uint8"],[Int8Array,"int8"],[Uint16Array,"uint16"],[Int16Array,"int16"],[Int32Array,"int32"],[Float64Array,"float64"],[Uint32Array,"uint32"]]),At=!1,Ot=()=>{if(!At){At=!0;let e=typeof BigInt64Array<"u"&&BigInt64Array.from,t=typeof BigUint64Array<"u"&&BigUint64Array.from,r=globalThis.Float16Array,n=typeof r<"u"&&r.from;e&&(H.set("int64",BigInt64Array),ae.set(BigInt64Array,"int64")),t&&(H.set("uint64",BigUint64Array),ae.set(BigUint64Array,"uint64")),n?(H.set("float16",r),ae.set(r,"float16")):H.set("float16",Uint16Array);}};})),Pt=T((()=>{we(),Lt=e=>{let t=1;for(let r=0;r<e.length;r++){let n=e[r];if("number"!=typeof n||!Number.isSafeInteger(n))throw new TypeError(`dims[${r}] must be an integer, got: ${n}`);if(n<0)throw new RangeError(`dims[${r}] must be a non-negative integer, got: ${n}`);t*=n;}return t},It=(e,t)=>{switch(e.location){case"cpu":return new v(e.type,e.data,t);case"cpu-pinned":return new v({location:"cpu-pinned",data:e.data,type:e.type,dims:t});case"texture":return new v({location:"texture",texture:e.texture,type:e.type,dims:t});case"gpu-buffer":return new v({location:"gpu-buffer",gpuBuffer:e.gpuBuffer,type:e.type,dims:t});case"ml-tensor":return new v({location:"ml-tensor",mlTensor:e.mlTensor,type:e.type,dims:t});default:throw new Error(`tensorReshape: tensor location ${e.location} is not supported`)}};})),we=T((()=>{wt(),St(),xt(),Pt(),v=class{constructor(e,t,r){let n,o;if(Ot(),"object"==typeof e&&"location"in e)switch(this.dataLocation=e.location,n=e.type,o=e.dims,e.location){case"cpu-pinned":{let t=H.get(n);if(!t)throw new TypeError(`unsupported type "${n}" to create tensor from pinned buffer`);if(!(e.data instanceof t))throw new TypeError(`buffer should be of type ${t.name}`);this.cpuData=e.data;break}case"texture":if("float32"!==n)throw new TypeError(`unsupported type "${n}" to create tensor from texture`);this.gpuTextureData=e.texture,this.downloader=e.download,this.disposer=e.dispose;break;case"gpu-buffer":if("float32"!==n&&"float16"!==n&&"int32"!==n&&"int64"!==n&&"uint32"!==n&&"uint8"!==n&&"bool"!==n&&"uint4"!==n&&"int4"!==n)throw new TypeError(`unsupported type "${n}" to create tensor from gpu buffer`);this.gpuBufferData=e.gpuBuffer,this.downloader=e.download,this.disposer=e.dispose;break;case"ml-tensor":if("float32"!==n&&"float16"!==n&&"int32"!==n&&"int64"!==n&&"uint32"!==n&&"uint64"!==n&&"int8"!==n&&"uint8"!==n&&"bool"!==n&&"uint4"!==n&&"int4"!==n)throw new TypeError(`unsupported type "${n}" to create tensor from MLTensor`);this.mlTensorData=e.mlTensor,this.downloader=e.download,this.disposer=e.dispose;break;default:throw new Error(`Tensor constructor: unsupported location '${this.dataLocation}'`)}else {let a,i;if("string"==typeof e)if(n=e,i=r,"string"===e){if(!Array.isArray(t))throw new TypeError("A string tensor's data must be a string array.");a=t;}else {let r=H.get(e);if(void 0===r)throw new TypeError(`Unsupported tensor type: ${e}.`);if(Array.isArray(t)){if("float16"===e&&r===Uint16Array||"uint4"===e||"int4"===e)throw new TypeError(`Creating a ${e} tensor from number array is not supported. Please use ${r.name} as data.`);a="uint64"===e||"int64"===e?r.from(t,BigInt):r.from(t);}else if(t instanceof r)a=t;else if(t instanceof Uint8ClampedArray){if("uint8"!==e)throw new TypeError("A Uint8ClampedArray tensor's data must be type of uint8");a=Uint8Array.from(t);}else {if(!("float16"===e&&t instanceof Uint16Array&&r!==Uint16Array))throw new TypeError(`A ${n} tensor's data must be type of ${r}`);a=new globalThis.Float16Array(t.buffer,t.byteOffset,t.length);}}else if(i=t,Array.isArray(e)){if(0===e.length)throw new TypeError("Tensor type cannot be inferred from an empty array.");let t=typeof e[0];if("string"===t)n="string",a=e;else {if("boolean"!==t)throw new TypeError(`Invalid element type of data array: ${t}.`);n="bool",a=Uint8Array.from(e);}}else if(e instanceof Uint8ClampedArray)n="uint8",a=Uint8Array.from(e);else {let t=ae.get(e.constructor);if(void 0===t)throw new TypeError(`Unsupported type for tensor data: ${e.constructor}.`);n=t,a=e;}if(void 0===i)i=[a.length];else if(!Array.isArray(i))throw new TypeError("A tensor's dims must be a number array");o=i,this.cpuData=a,this.dataLocation="cpu";}let a=Lt(o);if(this.cpuData&&a!==this.cpuData.length&&("uint4"!==n&&"int4"!==n||Math.ceil(a/2)!==this.cpuData.length))throw new Error(`Tensor's size(${a}) does not match data length(${this.cpuData.length}).`);this.type=n,this.dims=o,this.size=a;}static async fromImage(e,t){return yt(e,t)}static fromTexture(e,t){return bt(e,t)}static fromGpuBuffer(e,t){return gt(e,t)}static fromMLTensor(e,t){return Et(e,t)}static fromPinnedBuffer(e,t,r){return Tt(e,t,r)}toDataURL(e){return mt(this,e)}toImageData(e){return ht(this,e)}get data(){if(this.ensureValid(),!this.cpuData)throw new Error("The data is not on CPU. Use `getData()` to download GPU data to CPU, or use `texture` or `gpuBuffer` property to access the GPU data directly.");return this.cpuData}get location(){return this.dataLocation}get texture(){if(this.ensureValid(),!this.gpuTextureData)throw new Error("The data is not stored as a WebGL texture.");return this.gpuTextureData}get gpuBuffer(){if(this.ensureValid(),!this.gpuBufferData)throw new Error("The data is not stored as a WebGPU buffer.");return this.gpuBufferData}get mlTensor(){if(this.ensureValid(),!this.mlTensorData)throw new Error("The data is not stored as a WebNN MLTensor.");return this.mlTensorData}async getData(e){switch(this.ensureValid(),this.dataLocation){case"cpu":case"cpu-pinned":return this.data;case"texture":case"gpu-buffer":case"ml-tensor":if(!this.downloader)throw new Error("The current tensor is not created with a specified data downloader.");if(this.isDownloading)throw new Error("The current tensor is being downloaded.");try{this.isDownloading=!0;let t=await this.downloader();return this.downloader=void 0,this.dataLocation="cpu",this.cpuData=t,e&&this.disposer&&(this.disposer(),this.disposer=void 0),t}finally{this.isDownloading=!1;}default:throw new Error(`cannot get data from location: ${this.dataLocation}`)}}dispose(){if(this.isDownloading)throw new Error("The current tensor is being downloaded.");this.disposer&&(this.disposer(),this.disposer=void 0),this.cpuData=void 0,this.gpuTextureData=void 0,this.gpuBufferData=void 0,this.mlTensorData=void 0,this.downloader=void 0,this.isDownloading=void 0,this.dataLocation="none";}ensureValid(){if("none"===this.dataLocation)throw new Error("The tensor is disposed.")}reshape(e){if(this.ensureValid(),this.downloader||this.disposer)throw new Error("Cannot reshape a tensor that owns GPU resource.");return It(this,e)}};})),Ve=T((()=>{we(),R=v;})),Ye=T((()=>{je(),vt=(e,t)=>{(typeof _.trace>"u"?!_.wasm.trace:!_.trace)||console.timeStamp(`${e}::ORT::${t}`);},Bt=(e,t)=>{let r=(new Error).stack?.split(/\r\n|\r|\n/g)||[],n=!1;for(let o=0;o<r.length;o++){if(n&&!r[o].includes("TRACE_FUNC")){let n=`FUNC_${e}::${r[o].trim().split(" ")[1]}`;return t&&(n+=`::${t}`),void vt("CPU",n)}r[o].includes("TRACE_FUNC")&&(n=!0);}},V=e=>{(typeof _.trace>"u"?!_.wasm.trace:!_.trace)||Bt("BEGIN",e);},Y=e=>{(typeof _.trace>"u"?!_.wasm.trace:!_.trace)||Bt("END",e);};})),Ct=T((()=>{ze(),Ve(),Ye(),ye=class e{constructor(e){this.handler=e;}async run(e,t,r){V();let n={},o={};if("object"!=typeof e||null===e||e instanceof R||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("object"==typeof t){if(null===t)throw new TypeError("Unexpected argument[1]: cannot be null.");if(t instanceof R)throw new TypeError("'fetches' cannot be a Tensor");if(Array.isArray(t)){if(0===t.length)throw new TypeError("'fetches' cannot be an empty array.");a=!1;for(let e of t){if("string"!=typeof e)throw new TypeError("'fetches' must be a string array or an object.");if(-1===this.outputNames.indexOf(e))throw new RangeError(`'fetches' contains invalid output name: ${e}.`);n[e]=null;}if("object"==typeof r&&null!==r)o=r;else if(typeof r<"u")throw new TypeError("'options' must be an object.")}else {let e=!1,i=Object.getOwnPropertyNames(t);for(let r of this.outputNames)if(-1!==i.indexOf(r)){let o=t[r];(null===o||o instanceof R)&&(e=!0,a=!1,n[r]=o);}if(e){if("object"==typeof r&&null!==r)o=r;else if(typeof r<"u")throw new TypeError("'options' must be an object.")}else o=t;}}else if(typeof t<"u")throw new TypeError("Unexpected argument[1]: must be 'fetches' or 'options'.");for(let t of this.inputNames)if(typeof e[t]>"u")throw new Error(`input '${t}' is missing in 'feeds'.`);if(a)for(let e of this.outputNames)n[e]=null;let i=await this.handler.run(e,n,o),s={};for(let e in i)if(Object.hasOwnProperty.call(i,e)){let t=i[e];s[e]=t instanceof R?t:new R(t.type,t.data,t.dims);}return Y(),s}async release(){return this.handler.dispose()}static async create(t,r,n,o){V();let a,i={};if("string"==typeof t){if(a=t,"object"==typeof r&&null!==r)i=r;else if(typeof r<"u")throw new TypeError("'options' must be an object.")}else if(t instanceof Uint8Array){if(a=t,"object"==typeof r&&null!==r)i=r;else if(typeof r<"u")throw new TypeError("'options' must be an object.")}else {if(!(t instanceof ArrayBuffer||typeof SharedArrayBuffer<"u"&&t instanceof SharedArrayBuffer))throw new TypeError("Unexpected argument[0]: must be 'path' or 'buffer'.");{let e=t,s=0,l=t.byteLength;if("object"==typeof r&&null!==r)i=r;else if("number"==typeof r){if(s=r,!Number.isSafeInteger(s))throw new RangeError("'byteOffset' must be an integer.");if(s<0||s>=e.byteLength)throw new RangeError(`'byteOffset' is out of range [0, ${e.byteLength}).`);if(l=t.byteLength-s,"number"==typeof n){if(l=n,!Number.isSafeInteger(l))throw new RangeError("'byteLength' must be an integer.");if(l<=0||s+l>e.byteLength)throw new RangeError(`'byteLength' is out of range (0, ${e.byteLength-s}].`);if("object"==typeof o&&null!==o)i=o;else if(typeof o<"u")throw new TypeError("'options' must be an object.")}else if(typeof n<"u")throw new TypeError("'byteLength' must be a number.")}else if(typeof r<"u")throw new TypeError("'options' must be an object.");a=new Uint8Array(e,s,l);}}let[s,l]=await ut(i),u=await s.createInferenceSessionHandler(a,l);return Y(),new e(u)}startProfiling(){this.handler.startProfiling();}endProfiling(){this.handler.endProfiling();}get inputNames(){return this.handler.inputNames}get outputNames(){return this.handler.outputNames}};})),Ut=T((()=>{Ct(),Or=ye;})),_t=T((()=>{})),Mt=T((()=>{})),Dt=T((()=>{})),Rt=T((()=>{})),qe={};Ge(qe,{InferenceSession:()=>Or,TRACE:()=>vt,TRACE_FUNC_BEGIN:()=>V,TRACE_FUNC_END:()=>Y,Tensor:()=>R,env:()=>A,registerBackend:()=>ie});var q=T((()=>{ft(),pt(),Ut(),Ve(),_t(),Mt(),Ye(),Dt(),Rt();})),be=T((()=>{})),Wt={};Ge(Wt,{default:()=>xr});var kt,Nt,xr,jt,M,Pe,Xe,Ir,Pr,Ht,vr,Gt,Vt,zt,Yt,Ze,Ke,ve,qt,Br,Cr,Ee,x,L,fe,S,Jt,Ur,_r,Mr,Dr,Zt,ee,Qt,te,er,tr,Ce,Ue,rr,ce,Rr,Te,Se,re,Fr,ue,Ae,Oe,nr,xe,Le,Ie,Z,D,le,Me,De,_e,tt,rt,ne,oe,Nr,or,sr,ir,ar,ur,fr,cr,lr,Wr,Re,$t=T((()=>{Je(),J(),ge(),kt="ort-wasm-proxy-worker",(Nt=globalThis.self?.name===kt)&&(self.onmessage=e=>{let{type:t,in:r}=e.data;try{switch(t){case"init-wasm":Ee(r.wasm).then((()=>{Te(r).then((()=>{postMessage({type:t});}),(e=>{postMessage({type:t,err:e});}));}),(e=>{postMessage({type:t,err:e});}));break;case"init-ep":{let{epName:e,env:n}=r;Se(n,e).then((()=>{postMessage({type:t});}),(e=>{postMessage({type:t,err:e});}));break}case"copy-from":{let{buffer:e}=r,n=ue(e);postMessage({type:t,out:n});break}case"create":{let{model:e,options:n}=r;Ae(e,n).then((e=>{postMessage({type:t,out:e});}),(e=>{postMessage({type:t,err:e});}));break}case"release":Oe(r),postMessage({type:t});break;case"run":{let{sessionId:e,inputIndices:n,inputs:o,outputIndices:a,options:i}=r;xe(e,n,o,a,new Array(a.length).fill(null),i).then((e=>{e.some((e=>"cpu"!==e[3]))?postMessage({type:t,err:"Proxy does not support non-cpu tensor location."}):postMessage({type:t,out:e},Ie([...o,...e]));}),(e=>{postMessage({type:t,err:e});}));break}case"end-profiling":Le(r),postMessage({type:t});}}catch(e){postMessage({type:t,err:e});}}),xr=Nt?null:e=>new Worker(e??M,{type:"module",name:kt});})),ge=T((()=>{be(),jt=typeof location>"u"?void 0:location.origin,M=(()=>import.meta.url?.startsWith("file:")?new URL(new URL("ort.wasm.bundle.min.mjs",import.meta.url).href,jt).href:import.meta.url)(),Pe=()=>{if(M&&!M.startsWith("blob:"))return M.substring(0,M.lastIndexOf("/")+1)},Xe=(e,t)=>{try{let r=t??M;return (r?new URL(e,r):new URL(e)).origin===jt}catch{return !1}},Ir=(e,t)=>{let r=t??M;try{return (r?new URL(e,r):new URL(e)).href}catch{return}},Pr=(e,t)=>`${t??"./"}${e}`,Ht=async e=>{let t=await(await fetch(e,{credentials:"same-origin"})).blob();return URL.createObjectURL(t)},vr=async e=>(await import(e)).default,Gt=($t(),at(Wt)).default,Vt=async()=>{if(!M)throw new Error("Failed to load proxy worker: cannot determine the script source URL.");if(Xe(M))return [void 0,Gt()];let e=await Ht(M);return [e,Gt(e)]},zt=void 0,Yt=async(e,t,r)=>{if(!e&&!t&&zt&&M&&Xe(M))return [void 0,zt];{let n="ort-wasm-simd-threaded.mjs",o=e??Ir(n,t),a=r&&o&&!Xe(o,t),i=a?await Ht(o):o??Pr(n,t);return [a?i:void 0,await vr(i)]}};})),J=T((()=>{ge(),Ke=!1,ve=!1,qt=!1,Br=()=>{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}},Cr=()=>{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}},Ee=async e=>{if(Ke)return Promise.resolve();if(ve)throw new Error("multiple calls to 'initializeWebAssembly()' detected.");if(qt)throw new Error("previous call to 'initializeWebAssembly()' failed.");ve=!0;let t=e.initTimeout,r=e.numThreads;if(!Cr())throw new Error("WebAssembly SIMD is not supported in the current environment.");let n=Br();r>1&&!n&&(typeof self<"u"&&!self.crossOriginIsolated&&console.warn("env.wasm.numThreads is set to "+r+", but this will not work unless you enable crossOriginIsolated mode. See https://web.dev/cross-origin-isolation-guide/ for more info."),console.warn("WebAssembly multi-threading is not supported in the current environment. Falling back to single-threading."),e.numThreads=r=1);let o=e.wasmPaths,a="string"==typeof o?o:void 0,i=o?.mjs,s=i?.href??i,l=o?.wasm,u=l?.href??l,f=e.wasmBinary,[d,p]=await Yt(s,a,r>1),c=!1,h=[];if(t>0&&h.push(new Promise((e=>{setTimeout((()=>{c=!0,e();}),t);}))),h.push(new Promise(((e,t)=>{let n={numThreads:r};if(f)n.wasmBinary=f;else if(u||a)n.locateFile=e=>u??a+e;else if(s&&0!==s.indexOf("blob:"))n.locateFile=e=>new URL(e,s).href;else if(d){let e=Pe();e&&(n.locateFile=t=>e+t);}p(n).then((t=>{ve=!1,Ke=!0,Ze=t,e(),d&&URL.revokeObjectURL(d);}),(e=>{ve=!1,qt=!0,t(e);}));}))),await Promise.race(h),c)throw new Error(`WebAssembly backend initializing failed due to timeout: ${t}ms`)},x=()=>{if(Ke&&Ze)return Ze;throw new Error("WebAssembly is not initialized yet.")};})),Be=T((()=>{J(),L=(e,t)=>{let r=x(),n=r.lengthBytesUTF8(e)+1,o=r._malloc(n);return r.stringToUTF8(e,o,n),t.push(o),o},fe=(e,t,r,n)=>{if("object"==typeof e&&null!==e){if(r.has(e))throw new Error("Circular reference in options");r.add(e);}Object.entries(e).forEach((([e,o])=>{let a=t?t+e:e;if("object"==typeof o)fe(o,a+".",r,n);else if("string"==typeof o||"number"==typeof o)n(a,o.toString());else {if("boolean"!=typeof o)throw new Error("Can't handle extra config type: "+typeof o);n(a,o?"1":"0");}}));},S=e=>{let t=x(),r=t.stackSave();try{let r=t.PTR_SIZE,n=t.stackAlloc(2*r);t._OrtGetLastError(n,n+r);let o=Number(t.getValue(n,4===r?"i32":"i64")),a=t.getValue(n+r,"*"),i=a?t.UTF8ToString(a):"";throw new Error(`${e} ERROR_CODE: ${o}, ERROR_MESSAGE: ${i}`)}finally{t.stackRestore(r);}};})),Xt=T((()=>{J(),Be(),Jt=e=>{let t=x(),r=0,n=[],o=e||{};try{if(void 0===e?.logSeverityLevel)o.logSeverityLevel=2;else if("number"!=typeof e.logSeverityLevel||!Number.isInteger(e.logSeverityLevel)||e.logSeverityLevel<0||e.logSeverityLevel>4)throw new Error(`log serverity level is not valid: ${e.logSeverityLevel}`);if(void 0===e?.logVerbosityLevel)o.logVerbosityLevel=0;else if("number"!=typeof e.logVerbosityLevel||!Number.isInteger(e.logVerbosityLevel))throw new Error(`log verbosity level is not valid: ${e.logVerbosityLevel}`);void 0===e?.terminate&&(o.terminate=!1);let a=0;return void 0!==e?.tag&&(a=L(e.tag,n)),r=t._OrtCreateRunOptions(o.logSeverityLevel,o.logVerbosityLevel,!!o.terminate,a),0===r&&S("Can't create run options."),void 0!==e?.extra&&fe(e.extra,"",new WeakSet,((e,o)=>{let a=L(e,n),i=L(o,n);0!==t._OrtAddRunConfigEntry(r,a,i)&&S(`Can't set a run config entry: ${e} - ${o}.`);})),[r,n]}catch(e){throw 0!==r&&t._OrtReleaseRunOptions(r),n.forEach((e=>t._free(e))),e}};})),Kt=T((()=>{J(),Be(),Ur=e=>{switch(e){case"disabled":return 0;case"basic":return 1;case"extended":return 2;case"all":return 99;default:throw new Error(`unsupported graph optimization level: ${e}`)}},_r=e=>{switch(e){case"sequential":return 0;case"parallel":return 1;default:throw new Error(`unsupported execution mode: ${e}`)}},Mr=e=>{e.extra||(e.extra={}),e.extra.session||(e.extra.session={});let t=e.extra.session;t.use_ort_model_bytes_directly||(t.use_ort_model_bytes_directly="1"),e.executionProviders&&e.executionProviders.some((e=>"webgpu"===("string"==typeof e?e:e.name)))&&(e.enableMemPattern=!1);},Dr=(e,t,r)=>{for(let n of t){let t="string"==typeof n?n:n.name;switch(t){case"webnn":if(t="WEBNN","string"!=typeof n){let t=n?.deviceType;if(t){let n=L("deviceType",r),o=L(t,r);0!==x()._OrtAddSessionConfigEntry(e,n,o)&&S(`Can't set a session config entry: 'deviceType' - ${t}.`);}}break;case"webgpu":if(t="JS","string"!=typeof n){let t=n;if(t?.preferredLayout){if("NCHW"!==t.preferredLayout&&"NHWC"!==t.preferredLayout)throw new Error(`preferredLayout must be either 'NCHW' or 'NHWC': ${t.preferredLayout}`);let n=L("preferredLayout",r),o=L(t.preferredLayout,r);0!==x()._OrtAddSessionConfigEntry(e,n,o)&&S(`Can't set a session config entry: 'preferredLayout' - ${t.preferredLayout}.`);}}break;case"wasm":case"cpu":continue;default:throw new Error(`not supported execution provider: ${t}`)}let o=L(t,r);0!==x()._OrtAppendExecutionProvider(e,o)&&S(`Can't append execution provider: ${t}.`);}},Zt=e=>{let t=x(),r=0,n=[],o=e||{};Mr(o);try{let e=Ur(o.graphOptimizationLevel??"all"),a=_r(o.executionMode??"sequential"),i="string"==typeof o.logId?L(o.logId,n):0,s=o.logSeverityLevel??2;if(!Number.isInteger(s)||s<0||s>4)throw new Error(`log serverity level is not valid: ${s}`);let l=o.logVerbosityLevel??0;if(!Number.isInteger(l)||l<0||l>4)throw new Error(`log verbosity level is not valid: ${l}`);let u="string"==typeof o.optimizedModelFilePath?L(o.optimizedModelFilePath,n):0;if(r=t._OrtCreateSessionOptions(e,!!o.enableCpuMemArena,!!o.enableMemPattern,a,!!o.enableProfiling,0,i,s,l,u),0===r&&S("Can't create session options."),o.executionProviders&&Dr(r,o.executionProviders,n),void 0!==o.enableGraphCapture){if("boolean"!=typeof o.enableGraphCapture)throw new Error(`enableGraphCapture must be a boolean value: ${o.enableGraphCapture}`);let e=L("enableGraphCapture",n),a=L(o.enableGraphCapture.toString(),n);0!==t._OrtAddSessionConfigEntry(r,e,a)&&S(`Can't set a session config entry: 'enableGraphCapture' - ${o.enableGraphCapture}.`);}if(o.freeDimensionOverrides)for(let[e,a]of Object.entries(o.freeDimensionOverrides)){if("string"!=typeof e)throw new Error(`free dimension override name must be a string: ${e}`);if("number"!=typeof a||!Number.isInteger(a)||a<0)throw new Error(`free dimension override value must be a non-negative integer: ${a}`);let o=L(e,n);0!==t._OrtAddFreeDimensionOverride(r,o,a)&&S(`Can't set a free dimension override: ${e} - ${a}.`);}return void 0!==o.extra&&fe(o.extra,"",new WeakSet,((e,o)=>{let a=L(e,n),i=L(o,n);0!==t._OrtAddSessionConfigEntry(r,a,i)&&S(`Can't set a session config entry: ${e} - ${o}.`);})),[r,n]}catch(e){throw 0!==r&&0!==t._OrtReleaseSessionOptions(r)&&S("Can't release session options."),n.forEach((e=>t._free(e))),e}};})),Qe=T((()=>{ee=e=>{switch(e){case"int8":return 3;case"uint8":return 2;case"bool":return 9;case"int16":return 5;case"uint16":return 4;case"int32":return 6;case"uint32":return 12;case"float16":return 10;case"float32":return 1;case"float64":return 11;case"string":return 8;case"int64":return 7;case"uint64":return 13;case"int4":return 22;case"uint4":return 21;default:throw new Error(`unsupported data type: ${e}`)}},Qt=e=>{switch(e){case 3:return "int8";case 2:return "uint8";case 9:return "bool";case 5:return "int16";case 4:return "uint16";case 6:return "int32";case 12:return "uint32";case 10:return "float16";case 1:return "float32";case 11:return "float64";case 8:return "string";case 7:return "int64";case 13:return "uint64";case 22:return "int4";case 21:return "uint4";default:throw new Error(`unsupported data type: ${e}`)}},te=(e,t)=>{let r=[-1,4,1,1,2,2,4,8,-1,1,2,8,4,8,-1,-1,-1,-1,-1,-1,-1,.5,.5][e],n="number"==typeof t?t:t.reduce(((e,t)=>e*t),1);return r>0?Math.ceil(n*r):void 0},er=e=>{switch(e){case"float16":return typeof Float16Array<"u"&&Float16Array.from?Float16Array:Uint16Array;case"float32":return Float32Array;case"uint8":case"bool":return Uint8Array;case"int8":return Int8Array;case"uint16":return Uint16Array;case"int16":return Int16Array;case"int32":return Int32Array;case"float64":return Float64Array;case"uint32":return Uint32Array;case"int64":return BigInt64Array;case"uint64":return BigUint64Array;default:throw new Error(`unsupported type: ${e}`)}},tr=e=>{switch(e){case"verbose":return 0;case"info":return 1;case"warning":return 2;case"error":return 3;case"fatal":return 4;default:throw new Error(`unsupported logging level: ${e}`)}},Ce=e=>"float32"===e||"float16"===e||"int32"===e||"int64"===e||"uint32"===e||"uint8"===e||"bool"===e||"uint4"===e||"int4"===e,Ue=e=>"float32"===e||"float16"===e||"int32"===e||"int64"===e||"uint32"===e||"uint64"===e||"int8"===e||"uint8"===e||"bool"===e||"uint4"===e||"int4"===e,rr=e=>{switch(e){case"none":return 0;case"cpu":return 1;case"cpu-pinned":return 2;case"texture":return 3;case"gpu-buffer":return 4;case"ml-tensor":return 5;default:throw new Error(`unsupported data location: ${e}`)}};})),et=T((()=>{be(),ce=async e=>{if("string"==typeof e){{let t=await fetch(e);if(!t.ok)throw new Error(`failed to load external data file: ${e}`);let r=t.headers.get("Content-Length"),n=r?parseInt(r,10):0;if(n<1073741824)return new Uint8Array(await t.arrayBuffer());{if(!t.body)throw new Error(`failed to load external data file: ${e}, no response body.`);let r,o=t.body.getReader();try{r=new ArrayBuffer(n);}catch(e){if(!(e instanceof RangeError))throw e;{let e=Math.ceil(n/65536);r=new WebAssembly.Memory({initial:e,maximum:e}).buffer;}}let a=0;for(;;){let{done:e,value:t}=await o.read();if(e)break;let n=t.byteLength;new Uint8Array(r,a,n).set(t),a+=n;}return new Uint8Array(r,0,n)}}}return e instanceof Blob?new Uint8Array(await e.arrayBuffer()):e instanceof Uint8Array?e:new Uint8Array(e)};})),Je=T((()=>{Xt(),Kt(),Qe(),J(),Be(),et(),Rr=(e,t)=>{0!==x()._OrtInit(e,t)&&S("Can't initialize onnxruntime.");},Te=async e=>{Rr(e.wasm.numThreads,tr(e.logLevel));},Se=async(e,t)=>{},re=new Map,Fr=e=>{let t=x(),r=t.stackSave();try{let r=t.PTR_SIZE,n=t.stackAlloc(2*r);0!==t._OrtGetInputOutputCount(e,n,n+r)&&S("Can't get session input/output count.");let o=4===r?"i32":"i64";return [Number(t.getValue(n,o)),Number(t.getValue(n+r,o))]}finally{t.stackRestore(r);}},ue=e=>{let t=x(),r=t._malloc(e.byteLength);if(0===r)throw new Error(`Can't create a session. failed to allocate a buffer of size ${e.byteLength}.`);return t.HEAPU8.set(e,r),[r,e.byteLength]},Ae=async(e,t)=>{let r,n,o=x();Array.isArray(e)?[r,n]=e:e.buffer===o.HEAPU8.buffer?[r,n]=[e.byteOffset,e.byteLength]:[r,n]=ue(e);let a=0,i=0,s=[],l=[],u=[];try{if([i,s]=Zt(t),t?.externalData&&o.mountExternalData){let e=[];for(let r of t.externalData){let t="string"==typeof r?r:r.path;e.push(ce("string"==typeof r?r:r.data).then((e=>{o.mountExternalData(t,e);})));}await Promise.all(e);}for(let e of t?.executionProviders??[])if("webnn"===("string"==typeof e?e:e.name)){if(o.shouldTransferToMLTensor=!1,"string"!=typeof e){let t=e,r=t?.context,n=t?.gpuDevice,a=t?.deviceType,i=t?.powerPreference;o.currentContext=r||(n?await o.jsepCreateMLContext(n):await o.jsepCreateMLContext({deviceType:a,powerPreference:i}));}else o.currentContext=await o.jsepCreateMLContext();break}a=await o._OrtCreateSession(r,n,i),0===a&&S("Can't create a session."),o.jsepOnCreateSession?.(),o.currentContext&&(o.jsepRegisterMLContext(a,o.currentContext),o.currentContext=void 0,o.shouldTransferToMLTensor=!0);let[e,f]=Fr(a),d=!!t?.enableGraphCapture,p=[],c=[];for(let t=0;t<e;t++){let e=o._OrtGetInputName(a,t);0===e&&S("Can't get an input name."),l.push(e),p.push(o.UTF8ToString(e));}for(let e=0;e<f;e++){let t=o._OrtGetOutputName(a,e);0===t&&S("Can't get an output name."),u.push(t);let r=o.UTF8ToString(t);c.push(r);}return re.set(a,[a,l,u,null,d,!1]),[a,p,c]}catch(e){throw l.forEach((e=>o._OrtFree(e))),u.forEach((e=>o._OrtFree(e))),0!==a&&0!==o._OrtReleaseSession(a)&&S("Can't release session."),e}finally{o._free(r),0!==i&&0!==o._OrtReleaseSessionOptions(i)&&S("Can't release session options."),s.forEach((e=>o._free(e))),o.unmountExternalData?.();}},Oe=e=>{let t=x(),r=re.get(e);if(!r)throw new Error(`cannot release session. invalid session id: ${e}`);let[n,o,a,i,s]=r;i&&(s&&0!==t._OrtClearBoundOutputs(i.handle)&&S("Can't clear bound outputs."),0!==t._OrtReleaseBinding(i.handle)&&S("Can't release IO binding.")),t.jsepOnReleaseSession?.(e),o.forEach((e=>t._OrtFree(e))),a.forEach((e=>t._OrtFree(e))),0!==t._OrtReleaseSession(n)&&S("Can't release session."),re.delete(e);},nr=async(e,t,r,n,o,a=!1)=>{if(!e)return void t.push(0);let i,s,l=x(),u=l.PTR_SIZE,f=e[0],d=e[1],p=e[3],c=p;if("string"===f&&("gpu-buffer"===p||"ml-tensor"===p))throw new Error("String tensor is not supported on GPU.");if(a&&"gpu-buffer"!==p)throw new Error(`External buffer must be provided for input/output index ${o} when enableGraphCapture is true.`);if("gpu-buffer"===p){let t=e[2].gpuBuffer;s=te(ee(f),d);let r=l.jsepRegisterBuffer;if(!r)throw new Error('Tensor location "gpu-buffer" is not supported without using WebGPU.');i=r(n,o,t,s);}else if("ml-tensor"===p){let t=e[2].mlTensor;s=te(ee(f),d);let r=l.jsepRegisterMLTensor;if(!r)throw new Error('Tensor location "ml-tensor" is not supported without using WebNN.');i=r(n,t,ee(f),d);}else {let t=e[2];if(Array.isArray(t)){s=u*t.length,i=l._malloc(s),r.push(i);for(let e=0;e<t.length;e++){if("string"!=typeof t[e])throw new TypeError(`tensor data at index ${e} is not a string`);l.setValue(i+e*u,L(t[e],r),"*");}}else {let e=l.jsepIsGraphInput;if("string"!==f&&e){let a=l._OrtGetInputName(n,o);if(e(n,l.UTF8ToString(a))){let e=ee(f);s=te(e,d),c="ml-tensor";let r=l.jsepCreateTemporaryTensor,o=l.jsepUploadTensor;if(!r||!o)throw new Error('Tensor location "ml-tensor" is not supported without using WebNN.');let a=await r(n,e,d);o(a,new Uint8Array(t.buffer,t.byteOffset,t.byteLength)),i=a;}else s=t.byteLength,i=l._malloc(s),r.push(i),l.HEAPU8.set(new Uint8Array(t.buffer,t.byteOffset,s),i);}else s=t.byteLength,i=l._malloc(s),r.push(i),l.HEAPU8.set(new Uint8Array(t.buffer,t.byteOffset,s),i);}}let h=l.stackSave(),w=l.stackAlloc(4*d.length);try{d.forEach(((e,t)=>l.setValue(w+t*u,e,4===u?"i32":"i64")));let e=l._OrtCreateTensor(ee(f),i,s,w,d.length,rr(c));0===e&&S(`Can't create tensor for input/output. session=${n}, index=${o}.`),t.push(e);}finally{l.stackRestore(h);}},xe=async(e,t,r,n,o,a)=>{let i=x(),s=i.PTR_SIZE,l=re.get(e);if(!l)throw new Error(`cannot run inference. invalid session id: ${e}`);let u=l[0],f=l[1],d=l[2],p=l[3],c=l[4],h=(l[5],t.length),w=n.length,y=0,m=[],g=[],b=[],v=[],E=i.stackSave(),T=i.stackAlloc(h*s),A=i.stackAlloc(h*s),L=i.stackAlloc(w*s),C=i.stackAlloc(w*s);try{[y,m]=Jt(a);for(let n=0;n<h;n++)await nr(r[n],g,v,e,t[n],c);for(let t=0;t<w;t++)await nr(o[t],b,v,e,h+n[t],c);for(let e=0;e<h;e++)i.setValue(T+e*s,g[e],"*"),i.setValue(A+e*s,f[t[e]],"*");for(let e=0;e<w;e++)i.setValue(L+e*s,b[e],"*"),i.setValue(C+e*s,d[n[e]],"*");let l;i.jsepOnRunStart?.(u),l=await i._OrtRun(u,A,T,h,C,w,L,y),0!==l&&S("failed to call OrtRun().");let E=[];for(let t=0;t<w;t++){let r=Number(i.getValue(L+t*s,"*"));if(r===b[t]){E.push(o[t]);continue}let a,l=i.stackSave(),f=i.stackAlloc(4*s),d=!1,c=0;try{0!==i._OrtGetTensorData(r,f,f+s,f+2*s,f+3*s)&&S(`Can't access output tensor data on index ${t}.`);let o=4===s?"i32":"i64",l=Number(i.getValue(f,o));c=i.getValue(f+s,"*");let u=i.getValue(f+2*s,"*"),h=Number(i.getValue(f+3*s,o)),w=[];for(let e=0;e<h;e++)w.push(Number(i.getValue(u+e*s,o)));0!==i._OrtFree(u)&&S("Can't free memory for tensor dims.");let y=w.reduce(((e,t)=>e*t),1);a=Qt(l);let m=p?.outputPreferredLocations[n[t]];if("string"===a){if("gpu-buffer"===m||"ml-tensor"===m)throw new Error("String tensor is not supported on GPU.");let e=[];for(let t=0;t<y;t++){let r=i.getValue(c+t*s,"*"),n=i.getValue(c+(t+1)*s,"*"),o=t===y-1?void 0:n-r;e.push(i.UTF8ToString(r,o));}E.push([a,w,e,"cpu"]);}else if("gpu-buffer"===m&&y>0){let e=i.jsepGetBuffer;if(!e)throw new Error('preferredLocation "gpu-buffer" is not supported without using WebGPU.');let t=e(c),n=te(l,y);if(void 0===n||!Ce(a))throw new Error(`Unsupported data type: ${a}`);d=!0,E.push([a,w,{gpuBuffer:t,download:i.jsepCreateDownloader(t,n,a),dispose:()=>{0!==i._OrtReleaseTensor(r)&&S("Can't release tensor.");}},"gpu-buffer"]);}else if("ml-tensor"===m&&y>0){let t=i.jsepEnsureTensor;if(!t)throw new Error('preferredLocation "ml-tensor" is not supported without using WebNN.');if(void 0===te(l,y)||!Ue(a))throw new Error(`Unsupported data type: ${a}`);let n=await t(e,c,l,w,!1);d=!0,E.push([a,w,{mlTensor:n,download:i.jsepCreateMLTensorDownloader(c,a),dispose:()=>{i.jsepReleaseTensorId(c),i._OrtReleaseTensor(r);}},"ml-tensor"]);}else {let e=new(er(a))(y);new Uint8Array(e.buffer,e.byteOffset,e.byteLength).set(i.HEAPU8.subarray(c,c+e.byteLength)),E.push([a,w,e,"cpu"]);}}finally{i.stackRestore(l),"string"===a&&c&&i._free(c),d||i._OrtReleaseTensor(r),i.jsepOnRunEnd?.(u);}}return p&&!c&&(0!==i._OrtClearBoundOutputs(p.handle)&&S("Can't clear bound outputs."),re.set(e,[u,f,d,p,c,!1])),E}finally{i.stackRestore(E),g.forEach((e=>i._OrtReleaseTensor(e))),b.forEach((e=>i._OrtReleaseTensor(e))),v.forEach((e=>i._free(e))),0!==y&&i._OrtReleaseRunOptions(y),m.forEach((e=>i._free(e)));}},Le=e=>{let t=x(),r=re.get(e);if(!r)throw new Error("invalid session id");let n=r[0],o=t._OrtEndProfiling(n);0===o&&S("Can't get an profile file name."),t._OrtFree(o);},Ie=e=>{let t=[];for(let r of e){let e=r[2];!Array.isArray(e)&&"buffer"in e&&t.push(e.buffer);}return t};})),nt=T((()=>{q(),Je(),J(),ge(),Z=()=>!!A.wasm.proxy&&typeof document<"u",le=!1,Me=!1,De=!1,rt=new Map,ne=(e,t)=>{let r=rt.get(e);r?r.push(t):rt.set(e,[t]);},oe=()=>{if(le||!Me||De||!D)throw new Error("worker not ready")},Nr=e=>{switch(e.data.type){case"init-wasm":le=!1,e.data.err?(De=!0,tt[1](e.data.err)):(Me=!0,tt[0]()),_e&&(URL.revokeObjectURL(_e),_e=void 0);break;case"init-ep":case"copy-from":case"create":case"release":case"run":case"end-profiling":{let t=rt.get(e.data.type);e.data.err?t.shift()[1](e.data.err):t.shift()[0](e.data.out);break}}},or=async()=>{if(!Me){if(le)throw new Error("multiple calls to 'initWasm()' detected.");if(De)throw new Error("previous call to 'initWasm()' failed.");if(le=!0,Z())return new Promise(((e,t)=>{D?.terminate(),Vt().then((([r,n])=>{try{(D=n).onerror=e=>t(e),D.onmessage=Nr,tt=[e,t];let o={type:"init-wasm",in:A};if(!o.in.wasm.wasmPaths&&r){let e=Pe();e&&(o.in.wasm.wasmPaths=e);}D.postMessage(o),_e=r;}catch(e){t(e);}}),t);}));try{await Ee(A.wasm),await Te(A),Me=!0;}catch(e){throw De=!0,e}finally{le=!1;}}},sr=async e=>{if(Z())return oe(),new Promise(((t,r)=>{ne("init-ep",[t,r]);let n={type:"init-ep",in:{epName:e,env:A}};D.postMessage(n);}));await Se(A,e);},ir=async e=>Z()?(oe(),new Promise(((t,r)=>{ne("copy-from",[t,r]);let n={type:"copy-from",in:{buffer:e}};D.postMessage(n,[e.buffer]);}))):ue(e),ar=async(e,t)=>{if(Z()){if(t?.preferredOutputLocation)throw new Error('session option "preferredOutputLocation" is not supported for proxy.');return oe(),new Promise(((r,n)=>{ne("create",[r,n]);let o={type:"create",in:{model:e,options:{...t}}},a=[];e instanceof Uint8Array&&a.push(e.buffer),D.postMessage(o,a);}))}return Ae(e,t)},ur=async e=>{if(Z())return oe(),new Promise(((t,r)=>{ne("release",[t,r]);let n={type:"release",in:e};D.postMessage(n);}));Oe(e);},fr=async(e,t,r,n,o,a)=>{if(Z()){if(r.some((e=>"cpu"!==e[3])))throw new Error("input tensor on GPU is not supported for proxy.");if(o.some((e=>e)))throw new Error("pre-allocated output tensor is not supported for proxy.");return oe(),new Promise(((o,i)=>{ne("run",[o,i]);let s=r,l={type:"run",in:{sessionId:e,inputIndices:t,inputs:s,outputIndices:n,options:a}};D.postMessage(l,Ie(s));}))}return xe(e,t,r,n,o,a)},cr=async e=>{if(Z())return oe(),new Promise(((t,r)=>{ne("end-profiling",[t,r]);let n={type:"end-profiling",in:e};D.postMessage(n);}));Le(e);};})),dr=T((()=>{q(),nt(),Qe(),be(),et(),lr=(e,t)=>{switch(e.location){case"cpu":return [e.type,e.dims,e.data,"cpu"];case"gpu-buffer":return [e.type,e.dims,{gpuBuffer:e.gpuBuffer},"gpu-buffer"];case"ml-tensor":return [e.type,e.dims,{mlTensor:e.mlTensor},"ml-tensor"];default:throw new Error(`invalid data location: ${e.location} for ${t()}`)}},Wr=e=>{switch(e[3]){case"cpu":return new R(e[0],e[2],e[1]);case"gpu-buffer":{let t=e[0];if(!Ce(t))throw new Error(`not supported data type: ${t} for deserializing GPU tensor`);let{gpuBuffer:r,download:n,dispose:o}=e[2];return R.fromGpuBuffer(r,{dataType:t,dims:e[1],download:n,dispose:o})}case"ml-tensor":{let t=e[0];if(!Ue(t))throw new Error(`not supported data type: ${t} for deserializing MLTensor tensor`);let{mlTensor:r,download:n,dispose:o}=e[2];return R.fromMLTensor(r,{dataType:t,dims:e[1],download:n,dispose:o})}default:throw new Error(`invalid data location: ${e[3]}`)}},Re=class{async fetchModelAndCopyToWasmMemory(e){return ir(await ce(e))}async loadModel(e,t){let r;V(),r="string"==typeof e?await this.fetchModelAndCopyToWasmMemory(e):e,[this.sessionId,this.inputNames,this.outputNames]=await ar(r,t),Y();}async dispose(){return ur(this.sessionId)}async run(e,t,r){V();let n=[],o=[];Object.entries(e).forEach((e=>{let t=e[0],r=e[1],a=this.inputNames.indexOf(t);if(-1===a)throw new Error(`invalid input '${t}'`);n.push(r),o.push(a);}));let a=[],i=[];Object.entries(t).forEach((e=>{let t=e[0],r=e[1],n=this.outputNames.indexOf(t);if(-1===n)throw new Error(`invalid output '${t}'`);a.push(r),i.push(n);}));let s=n.map(((e,t)=>lr(e,(()=>`input "${this.inputNames[o[t]]}"`)))),l=a.map(((e,t)=>e?lr(e,(()=>`output "${this.outputNames[i[t]]}"`)):null)),u=await fr(this.sessionId,o,s,i,l,r),f={};for(let e=0;e<u.length;e++)f[this.outputNames[i[e]]]=a[e]??Wr(u[e]);return Y(),f}startProfiling(){}endProfiling(){cr(this.sessionId);}};})),mr={};Ge(mr,{OnnxruntimeWebAssemblyBackend:()=>Fe,initializeFlags:()=>pr,wasmBackend:()=>$r});var pr,Fe,$r,hr=T((()=>{q(),nt(),dr(),pr=()=>{if(("number"!=typeof A.wasm.initTimeout||A.wasm.initTimeout<0)&&(A.wasm.initTimeout=0),!1===A.wasm.simd&&console.warn('Deprecated property "env.wasm.simd" is set to false. non-SIMD build is no longer provided, and this setting will be ignored.'),"boolean"!=typeof A.wasm.proxy&&(A.wasm.proxy=!1),"boolean"!=typeof A.wasm.trace&&(A.wasm.trace=!1),"number"!=typeof A.wasm.numThreads||!Number.isInteger(A.wasm.numThreads)||A.wasm.numThreads<=0)if(typeof self<"u"&&!self.crossOriginIsolated)A.wasm.numThreads=1;else {let e=typeof navigator>"u"?$e("node:os").cpus().length:navigator.hardwareConcurrency;A.wasm.numThreads=Math.min(4,Math.ceil((e||1)/2));}},$r=new(Fe=class{async init(e){pr(),await or(),await sr(e);}async createInferenceSessionHandler(e,t){let r=new Re;return await r.loadModel(e,t),Promise.resolve(r)}});}));q(),q(),q();var Ft="1.21.0";{let e=(hr(),at(mr)).wasmBackend;ie("cpu",e,10),ie("wasm",e,10);}Object.defineProperty(A.versions,"web",{value:Ft,enumerable:!0});

class WorkerNative{constructor(){this.ready=!1;this.indexedDBManager=new IndexedDBManager("onirix-sdk","files"),this.indexedDBManager.getFileFromIndexedDB("SDK_1.10.0").then((async e=>{let t=URL.createObjectURL(new Blob([e],{type:"text/javascript"}));const{default:a}=await import(/* webpackIgnore: true, webpackMode: "lazy" */t),s=await a();this.nativeSDK=s,this.spatialBufferSize=this.nativeSDK._OX_GetBufferSize(),this.fromBuffer=this.nativeSDK._malloc(4*this.spatialBufferSize),this.toBuffer=this.nativeSDK._malloc(4*this.spatialBufferSize),A.wasm.numThreads=1;const r=await this.indexedDBManager.getFileFromIndexedDB("ort.wasm"),i=URL.createObjectURL(new Blob([r],{type:"application/wasm"}));A.wasm.wasmPaths={wasm:i,mjs:"https://cdn.onirix.com/onirix-engine-sdk/ort_v1.21.0_min/ort-wasm-simd.mjs"};let n=await this.indexedDBManager.getFromCacheOrFetch("sparse_matching.ort","https://cdn.onirix.com/onirix-engine-sdk/sparse_matching.ort");const o=await Or.create(n,{executionProviders:["wasm"]});this.sessionMatching=o,await this.sessionMatching.run({feats0:new R(new Float32Array(Array(64e3).fill(0)),[1e3,64]),feats1:new R(new Float32Array(Array(64e3).fill(0)),[1e3,64])}),this.ready=!0,postMessage("ready");}));}start(){addEventListener("message",(async e=>{if(!this.ready)return;const t=e.data,a=t.from,s=t.to;let r;if(2==t.dtype){let e=this.readDescriptors(a),t=this.readDescriptors(s),i=await this.sessionMatching.run({feats0:e,feats1:t}),{idx0:n,idx1:o}=i,h=[n.dims[0]];for(let e=0;e<n.dims[0];e++)h.push(Number(n.data[e])),h.push(Number(o.data[e]));r=new Float32Array(h);}else {this.nativeSDK.HEAPF32.set(a,this.fromBuffer/4),this.nativeSDK.HEAPF32.set(s,this.toBuffer/4);let e=this.nativeSDK._OX_Match(this.fromBuffer,this.toBuffer,t.dtype);r=new Float32Array(this.readMatchingData(this.nativeSDK.HEAPF32,e/4));}postMessage(r);}));}readDescriptors(e){let t=e[0],a=1+2*t;return new R(new Float32Array(e.slice(a,a+64*t)),[t,64])}readMatchingData(e,t){let a=t,s=[],r=e[a];s.push(r),a++;for(let t=0;t<r;t++)s.push(e[a]),s.push(e[a+1]),a+=2;return s}}const worker=new WorkerNative;worker.start();
"),b=new Blob([d],{type:"application/javascript"});this.workers[Z]=new Worker(/* webpackIgnore: true, webpackMode: "lazy" */URL.createObjectURL(b),{type:"module"}),this.callbacks[Z]=l,this.workers[Z].addEventListener("message",(l=>{this.callbacks[Z](l.data);}));}}replaceCallback(Z,l){this.workerExists(Z)&&(this.callbacks[Z]=l);}sendDataToWorker(Z,l){this.workers[Z].postMessage(l);}async createWorkers(){return await this.indexedDBManager.getFromCacheOrFetch("ort.wasm","https://cdn.onirix.com/onirix-engine-sdk/ort_v1.21.0_min/ort-wasm-simd.wasm"),Promise.all([new Promise(((Z,l)=>{this.createExtractionWorker("extraction",(l=>{"ready"===l&&Z();}));})),new Promise(((Z,l)=>{this.createMatchingWorker("matching",(l=>{"ready"===l&&Z();}));}))])}}
|
51
|
+
class WorkerExtractionData{constructor(Z,l,d,b,c,m,G=5,X=!1){this.data=Z,this.width=l,this.height=d,this.rotate=b,this.flip=c,this.colorSpace=G,this.onlyCoarse=X,this.dtype=m;}}class WorkerMatchingData{constructor(Z,l,d,b){this.idx=Z,this.from=l,this.to=d,this.dtype=b;}}class WorkerManager{constructor(){this.workers={},this.callbacks={};this.indexedDBManager=new IndexedDBManager("onirix-sdk","files");}workerExists(Z){return void 0!==this.workers[Z]&&void 0!==this.callbacks[Z]}createExtractionWorker(Z,l){if(!this.workerExists(Z)){let d=atob("class IndexedDBManager{constructor(e,r){this.dbName=e,this.storeName=r;}async getFromCacheOrFetch(e,r){let t=null;try{t=await this.getFileFromIndexedDB(e);}catch(e){console.log("An error occurred while trying to get element from indexedDB.");}return t||(t=await this.fetchAndCacheFile(r,e)),new Uint8Array(t)}async getFileFromIndexedDB(e){return new Promise(((r,t)=>{const o=indexedDB.open(this.dbName);o.onerror=()=>t(o.error),o.onsuccess=()=>{const s=o.result.transaction(this.storeName,"readonly").objectStore(this.storeName).get(e);s.onsuccess=()=>r(s.result),s.onerror=()=>t(s.error);},o.onupgradeneeded=e=>{e.target.result.createObjectStore(this.storeName);};}))}async saveFileToIndexedDB(e,r){return new Promise(((t,o)=>{const s=indexedDB.open(this.dbName);s.onerror=()=>o(s.error),s.onupgradeneeded=e=>{e.target.result.createObjectStore(this.storeName);},s.onsuccess=()=>{try{const n=s.result.transaction(this.storeName,"readwrite"),a=n.objectStore(this.storeName).put(r,e);a.onsuccess=()=>t(a.result),a.onerror=()=>o(a.error);}catch(e){o(e);}};}))}async fetchAndCacheFile(e,r){const t=await fetch(e),o=await t.arrayBuffer();return await this.saveFileToIndexedDB(r,o),o}}

var he,j,ie,Ar,ut,ct,dt,_,A,mt,ht,He,yt,bt,gt,Et,Tt,H,ae,At,Ot,Lt,It,v,R,vt,Bt,V,Y,ye,Or,We=Object.defineProperty,gr=Object.getOwnPropertyDescriptor,Er=Object.getOwnPropertyNames,Tr=Object.prototype.hasOwnProperty,$e=(e=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(e,{get:(e,t)=>(typeof require<"u"?require:e)[t]}):e)((function(e){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+e+'" is not supported')})),T=(e,t)=>()=>(e&&(t=e(e=0)),t),Ge=(e,t)=>{for(var r in t)We(e,r,{get:t[r],enumerable:!0});},Sr=(e,t,r,n)=>{if(t&&"object"==typeof t||"function"==typeof t)for(let o of Er(t))!Tr.call(e,o)&&o!==r&&We(e,o,{get:()=>t[o],enumerable:!(n=gr(t,o))||n.enumerable});return e},at=e=>Sr(We({},"__esModule",{value:!0}),e),ze=T((()=>{he=new Map,j=[],ie=(e,t,r)=>{if(!t||"function"!=typeof t.init||"function"!=typeof t.createInferenceSessionHandler)throw new TypeError("not a valid backend");{let n=he.get(e);if(void 0===n)he.set(e,{backend:t,priority:r});else {if(n.priority>r)return;if(n.priority===r&&n.backend!==t)throw new Error(`cannot register backend "${e}" using priority ${r}`)}if(r>=0){let t=j.indexOf(e);-1!==t&&j.splice(t,1);for(let t=0;t<j.length;t++)if(he.get(j[t]).priority<=r)return void j.splice(t,0,e);j.push(e);}}},Ar=async e=>{let t=he.get(e);if(!t)return "backend not found.";if(t.initialized)return t.backend;if(t.aborted)return t.error;{let r=!!t.initPromise;try{return r||(t.initPromise=t.backend.init(e)),await t.initPromise,t.initialized=!0,t.backend}catch(e){return r||(t.error=`${e}`,t.aborted=!0),t.error}finally{delete t.initPromise;}}},ut=async e=>{let t,r=e.executionProviders||[],n=r.map((e=>"string"==typeof e?e:e.name)),o=0===n.length?j:n,a=[],i=new Set;for(let e of o){let r=await Ar(e);"string"==typeof r?a.push({name:e,err:r}):(t||(t=r),t===r&&i.add(e));}if(!t)throw new Error(`no available backend found. ERR: ${a.map((e=>`[${e.name}] ${e.err}`)).join(", ")}`);for(let{name:e,err:t}of a)n.includes(e)&&console.warn(`removing requested execution provider "${e}" from session options because it is not available: ${t}`);let s=r.filter((e=>i.has("string"==typeof e?e:e.name)));return [t,new Proxy(e,{get:(e,t)=>"executionProviders"===t?s:Reflect.get(e,t)})]};})),ft=T((()=>{ze();})),lt=T((()=>{ct="1.21.0";})),je=T((()=>{lt(),dt="warning",_={wasm:{},webgl:{},webgpu:{},versions:{common:ct},set logLevel(e){if(void 0!==e){if("string"!=typeof e||-1===["verbose","info","warning","error","fatal"].indexOf(e))throw new Error(`Unsupported logging level: ${e}`);dt=e;}},get logLevel(){return dt}},Object.defineProperty(_,"logLevel",{enumerable:!0});})),pt=T((()=>{je(),A=_;})),wt=T((()=>{mt=(e,t)=>{let r=typeof document<"u"?document.createElement("canvas"):new OffscreenCanvas(1,1);r.width=e.dims[3],r.height=e.dims[2];let n=r.getContext("2d");if(null!=n){let o,a;void 0!==t?.tensorLayout&&"NHWC"===t.tensorLayout?(o=e.dims[2],a=e.dims[3]):(o=e.dims[3],a=e.dims[2]);let i,s,l=void 0!==t?.format?t.format:"RGB",u=t?.norm;void 0===u||void 0===u.mean?i=[255,255,255,255]:"number"==typeof u.mean?i=[u.mean,u.mean,u.mean,u.mean]:(i=[u.mean[0],u.mean[1],u.mean[2],0],void 0!==u.mean[3]&&(i[3]=u.mean[3])),void 0===u||void 0===u.bias?s=[0,0,0,0]:"number"==typeof u.bias?s=[u.bias,u.bias,u.bias,u.bias]:(s=[u.bias[0],u.bias[1],u.bias[2],0],void 0!==u.bias[3]&&(s[3]=u.bias[3]));let f=a*o,d=0,p=f,c=2*f,h=-1;"RGBA"===l?(d=0,p=f,c=2*f,h=3*f):"RGB"===l?(d=0,p=f,c=2*f):"RBG"===l&&(d=0,c=f,p=2*f);for(let t=0;t<a;t++)for(let r=0;r<o;r++){let o=(e.data[d++]-s[0])*i[0],a=(e.data[p++]-s[1])*i[1],l=(e.data[c++]-s[2])*i[2],u=-1===h?255:(e.data[h++]-s[3])*i[3];n.fillStyle="rgba("+o+","+a+","+l+","+u+")",n.fillRect(r,t,1,1);}if("toDataURL"in r)return r.toDataURL();throw new Error("toDataURL is not supported")}throw new Error("Can not access image data")},ht=(e,t)=>{let r,n=typeof document<"u"?document.createElement("canvas").getContext("2d"):new OffscreenCanvas(1,1).getContext("2d");if(null==n)throw new Error("Can not access image data");{let o,a,i;void 0!==t?.tensorLayout&&"NHWC"===t.tensorLayout?(o=e.dims[2],a=e.dims[1],i=e.dims[3]):(o=e.dims[3],a=e.dims[2],i=e.dims[1]);let s,l,u=void 0!==t&&void 0!==t.format?t.format:"RGB",f=t?.norm;void 0===f||void 0===f.mean?s=[255,255,255,255]:"number"==typeof f.mean?s=[f.mean,f.mean,f.mean,f.mean]:(s=[f.mean[0],f.mean[1],f.mean[2],255],void 0!==f.mean[3]&&(s[3]=f.mean[3])),void 0===f||void 0===f.bias?l=[0,0,0,0]:"number"==typeof f.bias?l=[f.bias,f.bias,f.bias,f.bias]:(l=[f.bias[0],f.bias[1],f.bias[2],0],void 0!==f.bias[3]&&(l[3]=f.bias[3]));let d=a*o;if(void 0!==t&&(void 0!==t.format&&4===i&&"RGBA"!==t.format||3===i&&"RGB"!==t.format&&"BGR"!==t.format))throw new Error("Tensor format doesn't match input tensor dims");let p=4,c=0,h=1,w=2,y=3,m=0,g=d,b=2*d,v=-1;"RGBA"===u?(m=0,g=d,b=2*d,v=3*d):"RGB"===u?(m=0,g=d,b=2*d):"RBG"===u&&(m=0,b=d,g=2*d),r=n.createImageData(o,a);for(let t=0;t<a*o;c+=p,h+=p,w+=p,y+=p,t++)r.data[c]=(e.data[m++]-l[0])*s[0],r.data[h]=(e.data[g++]-l[1])*s[1],r.data[w]=(e.data[b++]-l[2])*s[2],r.data[y]=-1===v?255:(e.data[v++]-l[3])*s[3];}return r};})),St=T((()=>{we(),He=(e,t)=>{if(void 0===e)throw new Error("Image buffer must be defined");if(void 0===t.height||void 0===t.width)throw new Error("Image height and width must be defined");if("NHWC"===t.tensorLayout)throw new Error("NHWC Tensor layout is not supported yet");let r,n,{height:o,width:a}=t,i=t.norm??{mean:255,bias:0};r="number"==typeof i.mean?[i.mean,i.mean,i.mean,i.mean]:[i.mean[0],i.mean[1],i.mean[2],i.mean[3]??255],n="number"==typeof i.bias?[i.bias,i.bias,i.bias,i.bias]:[i.bias[0],i.bias[1],i.bias[2],i.bias[3]??0];let s=void 0!==t.format?t.format:"RGBA",l=void 0!==t.tensorFormat&&void 0!==t.tensorFormat?t.tensorFormat:"RGB",u=o*a,f="RGBA"===l?new Float32Array(4*u):new Float32Array(3*u),d=4,p=0,c=1,h=2,w=3,y=0,m=u,g=2*u,b=-1;"RGB"===s&&(d=3,p=0,c=1,h=2,w=-1),"RGBA"===l?b=3*u:"RBG"===l?(y=0,g=u,m=2*u):"BGR"===l&&(g=0,m=u,y=2*u);for(let t=0;t<u;t++,p+=d,h+=d,c+=d,w+=d)f[y++]=(e[p]+n[0])/r[0],f[m++]=(e[c]+n[1])/r[1],f[g++]=(e[h]+n[2])/r[2],-1!==b&&-1!==w&&(f[b++]=(e[w]+n[3])/r[3]);return new v("float32",f,"RGBA"===l?[1,4,o,a]:[1,3,o,a])},yt=async(e,t)=>{let r,n=typeof HTMLImageElement<"u"&&e instanceof HTMLImageElement,o=typeof ImageData<"u"&&e instanceof ImageData,a=typeof ImageBitmap<"u"&&e instanceof ImageBitmap,i="string"==typeof e,s=t??{},l=()=>{if(typeof document<"u")return document.createElement("canvas");if(typeof OffscreenCanvas<"u")return new OffscreenCanvas(1,1);throw new Error("Canvas is not supported")},u=e=>typeof HTMLCanvasElement<"u"&&e instanceof HTMLCanvasElement||e instanceof OffscreenCanvas?e.getContext("2d"):null;if(n){let n=l();n.width=e.width,n.height=e.height;let o=u(n);if(null==o)throw new Error("Can not access image data");{let n=e.height,a=e.width;if(void 0!==t&&void 0!==t.resizedHeight&&void 0!==t.resizedWidth&&(n=t.resizedHeight,a=t.resizedWidth),void 0!==t){if(s=t,void 0!==t.tensorFormat)throw new Error("Image input config format must be RGBA for HTMLImageElement");s.tensorFormat="RGBA",s.height=n,s.width=a;}else s.tensorFormat="RGBA",s.height=n,s.width=a;o.drawImage(e,0,0),r=o.getImageData(0,0,a,n).data;}}else {if(!o){if(a){if(void 0===t)throw new Error("Please provide image config with format for Imagebitmap");let n=l();n.width=e.width,n.height=e.height;let o=u(n);if(null!=o){let t=e.height,n=e.width;return o.drawImage(e,0,0,n,t),r=o.getImageData(0,0,n,t).data,s.height=t,s.width=n,He(r,s)}throw new Error("Can not access image data")}if(i)return new Promise(((t,r)=>{let n=l(),o=u(n);if(!e||!o)return r();let a=new Image;a.crossOrigin="Anonymous",a.src=e,a.onload=()=>{n.width=a.width,n.height=a.height,o.drawImage(a,0,0,n.width,n.height);let e=o.getImageData(0,0,n.width,n.height);s.height=n.height,s.width=n.width,t(He(e.data,s));};}));throw new Error("Input data provided is not supported - aborted tensor creation")}{let n,o;if(void 0!==t&&void 0!==t.resizedWidth&&void 0!==t.resizedHeight?(n=t.resizedHeight,o=t.resizedWidth):(n=e.height,o=e.width),void 0!==t&&(s=t),s.format="RGBA",s.height=n,s.width=o,void 0!==t){let t=l();t.width=o,t.height=n;let a=u(t);if(null==a)throw new Error("Can not access image data");a.putImageData(e,0,0),r=a.getImageData(0,0,o,n).data;}else r=e.data;}}if(void 0!==r)return He(r,s);throw new Error("Input data provided is not supported - aborted tensor creation")},bt=(e,t)=>{let{width:r,height:n,download:o,dispose:a}=t;return new v({location:"texture",type:"float32",texture:e,dims:[1,n,r,4],download:o,dispose:a})},gt=(e,t)=>{let{dataType:r,dims:n,download:o,dispose:a}=t;return new v({location:"gpu-buffer",type:r??"float32",gpuBuffer:e,dims:n,download:o,dispose:a})},Et=(e,t)=>{let{dataType:r,dims:n,download:o,dispose:a}=t;return new v({location:"ml-tensor",type:r??"float32",mlTensor:e,dims:n,download:o,dispose:a})},Tt=(e,t,r)=>new v({location:"cpu-pinned",type:e,data:t,dims:r??[t.length]});})),xt=T((()=>{H=new Map([["float32",Float32Array],["uint8",Uint8Array],["int8",Int8Array],["uint16",Uint16Array],["int16",Int16Array],["int32",Int32Array],["bool",Uint8Array],["float64",Float64Array],["uint32",Uint32Array],["int4",Uint8Array],["uint4",Uint8Array]]),ae=new Map([[Float32Array,"float32"],[Uint8Array,"uint8"],[Int8Array,"int8"],[Uint16Array,"uint16"],[Int16Array,"int16"],[Int32Array,"int32"],[Float64Array,"float64"],[Uint32Array,"uint32"]]),At=!1,Ot=()=>{if(!At){At=!0;let e=typeof BigInt64Array<"u"&&BigInt64Array.from,t=typeof BigUint64Array<"u"&&BigUint64Array.from,r=globalThis.Float16Array,n=typeof r<"u"&&r.from;e&&(H.set("int64",BigInt64Array),ae.set(BigInt64Array,"int64")),t&&(H.set("uint64",BigUint64Array),ae.set(BigUint64Array,"uint64")),n?(H.set("float16",r),ae.set(r,"float16")):H.set("float16",Uint16Array);}};})),Pt=T((()=>{we(),Lt=e=>{let t=1;for(let r=0;r<e.length;r++){let n=e[r];if("number"!=typeof n||!Number.isSafeInteger(n))throw new TypeError(`dims[${r}] must be an integer, got: ${n}`);if(n<0)throw new RangeError(`dims[${r}] must be a non-negative integer, got: ${n}`);t*=n;}return t},It=(e,t)=>{switch(e.location){case"cpu":return new v(e.type,e.data,t);case"cpu-pinned":return new v({location:"cpu-pinned",data:e.data,type:e.type,dims:t});case"texture":return new v({location:"texture",texture:e.texture,type:e.type,dims:t});case"gpu-buffer":return new v({location:"gpu-buffer",gpuBuffer:e.gpuBuffer,type:e.type,dims:t});case"ml-tensor":return new v({location:"ml-tensor",mlTensor:e.mlTensor,type:e.type,dims:t});default:throw new Error(`tensorReshape: tensor location ${e.location} is not supported`)}};})),we=T((()=>{wt(),St(),xt(),Pt(),v=class{constructor(e,t,r){let n,o;if(Ot(),"object"==typeof e&&"location"in e)switch(this.dataLocation=e.location,n=e.type,o=e.dims,e.location){case"cpu-pinned":{let t=H.get(n);if(!t)throw new TypeError(`unsupported type "${n}" to create tensor from pinned buffer`);if(!(e.data instanceof t))throw new TypeError(`buffer should be of type ${t.name}`);this.cpuData=e.data;break}case"texture":if("float32"!==n)throw new TypeError(`unsupported type "${n}" to create tensor from texture`);this.gpuTextureData=e.texture,this.downloader=e.download,this.disposer=e.dispose;break;case"gpu-buffer":if("float32"!==n&&"float16"!==n&&"int32"!==n&&"int64"!==n&&"uint32"!==n&&"uint8"!==n&&"bool"!==n&&"uint4"!==n&&"int4"!==n)throw new TypeError(`unsupported type "${n}" to create tensor from gpu buffer`);this.gpuBufferData=e.gpuBuffer,this.downloader=e.download,this.disposer=e.dispose;break;case"ml-tensor":if("float32"!==n&&"float16"!==n&&"int32"!==n&&"int64"!==n&&"uint32"!==n&&"uint64"!==n&&"int8"!==n&&"uint8"!==n&&"bool"!==n&&"uint4"!==n&&"int4"!==n)throw new TypeError(`unsupported type "${n}" to create tensor from MLTensor`);this.mlTensorData=e.mlTensor,this.downloader=e.download,this.disposer=e.dispose;break;default:throw new Error(`Tensor constructor: unsupported location '${this.dataLocation}'`)}else {let a,i;if("string"==typeof e)if(n=e,i=r,"string"===e){if(!Array.isArray(t))throw new TypeError("A string tensor's data must be a string array.");a=t;}else {let r=H.get(e);if(void 0===r)throw new TypeError(`Unsupported tensor type: ${e}.`);if(Array.isArray(t)){if("float16"===e&&r===Uint16Array||"uint4"===e||"int4"===e)throw new TypeError(`Creating a ${e} tensor from number array is not supported. Please use ${r.name} as data.`);a="uint64"===e||"int64"===e?r.from(t,BigInt):r.from(t);}else if(t instanceof r)a=t;else if(t instanceof Uint8ClampedArray){if("uint8"!==e)throw new TypeError("A Uint8ClampedArray tensor's data must be type of uint8");a=Uint8Array.from(t);}else {if(!("float16"===e&&t instanceof Uint16Array&&r!==Uint16Array))throw new TypeError(`A ${n} tensor's data must be type of ${r}`);a=new globalThis.Float16Array(t.buffer,t.byteOffset,t.length);}}else if(i=t,Array.isArray(e)){if(0===e.length)throw new TypeError("Tensor type cannot be inferred from an empty array.");let t=typeof e[0];if("string"===t)n="string",a=e;else {if("boolean"!==t)throw new TypeError(`Invalid element type of data array: ${t}.`);n="bool",a=Uint8Array.from(e);}}else if(e instanceof Uint8ClampedArray)n="uint8",a=Uint8Array.from(e);else {let t=ae.get(e.constructor);if(void 0===t)throw new TypeError(`Unsupported type for tensor data: ${e.constructor}.`);n=t,a=e;}if(void 0===i)i=[a.length];else if(!Array.isArray(i))throw new TypeError("A tensor's dims must be a number array");o=i,this.cpuData=a,this.dataLocation="cpu";}let a=Lt(o);if(this.cpuData&&a!==this.cpuData.length&&("uint4"!==n&&"int4"!==n||Math.ceil(a/2)!==this.cpuData.length))throw new Error(`Tensor's size(${a}) does not match data length(${this.cpuData.length}).`);this.type=n,this.dims=o,this.size=a;}static async fromImage(e,t){return yt(e,t)}static fromTexture(e,t){return bt(e,t)}static fromGpuBuffer(e,t){return gt(e,t)}static fromMLTensor(e,t){return Et(e,t)}static fromPinnedBuffer(e,t,r){return Tt(e,t,r)}toDataURL(e){return mt(this,e)}toImageData(e){return ht(this,e)}get data(){if(this.ensureValid(),!this.cpuData)throw new Error("The data is not on CPU. Use `getData()` to download GPU data to CPU, or use `texture` or `gpuBuffer` property to access the GPU data directly.");return this.cpuData}get location(){return this.dataLocation}get texture(){if(this.ensureValid(),!this.gpuTextureData)throw new Error("The data is not stored as a WebGL texture.");return this.gpuTextureData}get gpuBuffer(){if(this.ensureValid(),!this.gpuBufferData)throw new Error("The data is not stored as a WebGPU buffer.");return this.gpuBufferData}get mlTensor(){if(this.ensureValid(),!this.mlTensorData)throw new Error("The data is not stored as a WebNN MLTensor.");return this.mlTensorData}async getData(e){switch(this.ensureValid(),this.dataLocation){case"cpu":case"cpu-pinned":return this.data;case"texture":case"gpu-buffer":case"ml-tensor":if(!this.downloader)throw new Error("The current tensor is not created with a specified data downloader.");if(this.isDownloading)throw new Error("The current tensor is being downloaded.");try{this.isDownloading=!0;let t=await this.downloader();return this.downloader=void 0,this.dataLocation="cpu",this.cpuData=t,e&&this.disposer&&(this.disposer(),this.disposer=void 0),t}finally{this.isDownloading=!1;}default:throw new Error(`cannot get data from location: ${this.dataLocation}`)}}dispose(){if(this.isDownloading)throw new Error("The current tensor is being downloaded.");this.disposer&&(this.disposer(),this.disposer=void 0),this.cpuData=void 0,this.gpuTextureData=void 0,this.gpuBufferData=void 0,this.mlTensorData=void 0,this.downloader=void 0,this.isDownloading=void 0,this.dataLocation="none";}ensureValid(){if("none"===this.dataLocation)throw new Error("The tensor is disposed.")}reshape(e){if(this.ensureValid(),this.downloader||this.disposer)throw new Error("Cannot reshape a tensor that owns GPU resource.");return It(this,e)}};})),Ve=T((()=>{we(),R=v;})),Ye=T((()=>{je(),vt=(e,t)=>{(typeof _.trace>"u"?!_.wasm.trace:!_.trace)||console.timeStamp(`${e}::ORT::${t}`);},Bt=(e,t)=>{let r=(new Error).stack?.split(/\r\n|\r|\n/g)||[],n=!1;for(let o=0;o<r.length;o++){if(n&&!r[o].includes("TRACE_FUNC")){let n=`FUNC_${e}::${r[o].trim().split(" ")[1]}`;return t&&(n+=`::${t}`),void vt("CPU",n)}r[o].includes("TRACE_FUNC")&&(n=!0);}},V=e=>{(typeof _.trace>"u"?!_.wasm.trace:!_.trace)||Bt("BEGIN",e);},Y=e=>{(typeof _.trace>"u"?!_.wasm.trace:!_.trace)||Bt("END",e);};})),Ct=T((()=>{ze(),Ve(),Ye(),ye=class e{constructor(e){this.handler=e;}async run(e,t,r){V();let n={},o={};if("object"!=typeof e||null===e||e instanceof R||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("object"==typeof t){if(null===t)throw new TypeError("Unexpected argument[1]: cannot be null.");if(t instanceof R)throw new TypeError("'fetches' cannot be a Tensor");if(Array.isArray(t)){if(0===t.length)throw new TypeError("'fetches' cannot be an empty array.");a=!1;for(let e of t){if("string"!=typeof e)throw new TypeError("'fetches' must be a string array or an object.");if(-1===this.outputNames.indexOf(e))throw new RangeError(`'fetches' contains invalid output name: ${e}.`);n[e]=null;}if("object"==typeof r&&null!==r)o=r;else if(typeof r<"u")throw new TypeError("'options' must be an object.")}else {let e=!1,i=Object.getOwnPropertyNames(t);for(let r of this.outputNames)if(-1!==i.indexOf(r)){let o=t[r];(null===o||o instanceof R)&&(e=!0,a=!1,n[r]=o);}if(e){if("object"==typeof r&&null!==r)o=r;else if(typeof r<"u")throw new TypeError("'options' must be an object.")}else o=t;}}else if(typeof t<"u")throw new TypeError("Unexpected argument[1]: must be 'fetches' or 'options'.");for(let t of this.inputNames)if(typeof e[t]>"u")throw new Error(`input '${t}' is missing in 'feeds'.`);if(a)for(let e of this.outputNames)n[e]=null;let i=await this.handler.run(e,n,o),s={};for(let e in i)if(Object.hasOwnProperty.call(i,e)){let t=i[e];s[e]=t instanceof R?t:new R(t.type,t.data,t.dims);}return Y(),s}async release(){return this.handler.dispose()}static async create(t,r,n,o){V();let a,i={};if("string"==typeof t){if(a=t,"object"==typeof r&&null!==r)i=r;else if(typeof r<"u")throw new TypeError("'options' must be an object.")}else if(t instanceof Uint8Array){if(a=t,"object"==typeof r&&null!==r)i=r;else if(typeof r<"u")throw new TypeError("'options' must be an object.")}else {if(!(t instanceof ArrayBuffer||typeof SharedArrayBuffer<"u"&&t instanceof SharedArrayBuffer))throw new TypeError("Unexpected argument[0]: must be 'path' or 'buffer'.");{let e=t,s=0,l=t.byteLength;if("object"==typeof r&&null!==r)i=r;else if("number"==typeof r){if(s=r,!Number.isSafeInteger(s))throw new RangeError("'byteOffset' must be an integer.");if(s<0||s>=e.byteLength)throw new RangeError(`'byteOffset' is out of range [0, ${e.byteLength}).`);if(l=t.byteLength-s,"number"==typeof n){if(l=n,!Number.isSafeInteger(l))throw new RangeError("'byteLength' must be an integer.");if(l<=0||s+l>e.byteLength)throw new RangeError(`'byteLength' is out of range (0, ${e.byteLength-s}].`);if("object"==typeof o&&null!==o)i=o;else if(typeof o<"u")throw new TypeError("'options' must be an object.")}else if(typeof n<"u")throw new TypeError("'byteLength' must be a number.")}else if(typeof r<"u")throw new TypeError("'options' must be an object.");a=new Uint8Array(e,s,l);}}let[s,l]=await ut(i),u=await s.createInferenceSessionHandler(a,l);return Y(),new e(u)}startProfiling(){this.handler.startProfiling();}endProfiling(){this.handler.endProfiling();}get inputNames(){return this.handler.inputNames}get outputNames(){return this.handler.outputNames}};})),Ut=T((()=>{Ct(),Or=ye;})),_t=T((()=>{})),Mt=T((()=>{})),Dt=T((()=>{})),Rt=T((()=>{})),qe={};Ge(qe,{InferenceSession:()=>Or,TRACE:()=>vt,TRACE_FUNC_BEGIN:()=>V,TRACE_FUNC_END:()=>Y,Tensor:()=>R,env:()=>A,registerBackend:()=>ie});var q=T((()=>{ft(),pt(),Ut(),Ve(),_t(),Mt(),Ye(),Dt(),Rt();})),be=T((()=>{})),Wt={};Ge(Wt,{default:()=>xr});var kt,Nt,xr,jt,M,Pe,Xe,Ir,Pr,Ht,vr,Gt,Vt,zt,Yt,Ze,Ke,ve,qt,Br,Cr,Ee,x,L,fe,S,Jt,Ur,_r,Mr,Dr,Zt,ee,Qt,te,er,tr,Ce,Ue,rr,ce,Rr,Te,Se,re,Fr,ue,Ae,Oe,nr,xe,Le,Ie,Z,D,le,Me,De,_e,tt,rt,ne,oe,Nr,or,sr,ir,ar,ur,fr,cr,lr,Wr,Re,$t=T((()=>{Je(),J(),ge(),kt="ort-wasm-proxy-worker",(Nt=globalThis.self?.name===kt)&&(self.onmessage=e=>{let{type:t,in:r}=e.data;try{switch(t){case"init-wasm":Ee(r.wasm).then((()=>{Te(r).then((()=>{postMessage({type:t});}),(e=>{postMessage({type:t,err:e});}));}),(e=>{postMessage({type:t,err:e});}));break;case"init-ep":{let{epName:e,env:n}=r;Se(n,e).then((()=>{postMessage({type:t});}),(e=>{postMessage({type:t,err:e});}));break}case"copy-from":{let{buffer:e}=r,n=ue(e);postMessage({type:t,out:n});break}case"create":{let{model:e,options:n}=r;Ae(e,n).then((e=>{postMessage({type:t,out:e});}),(e=>{postMessage({type:t,err:e});}));break}case"release":Oe(r),postMessage({type:t});break;case"run":{let{sessionId:e,inputIndices:n,inputs:o,outputIndices:a,options:i}=r;xe(e,n,o,a,new Array(a.length).fill(null),i).then((e=>{e.some((e=>"cpu"!==e[3]))?postMessage({type:t,err:"Proxy does not support non-cpu tensor location."}):postMessage({type:t,out:e},Ie([...o,...e]));}),(e=>{postMessage({type:t,err:e});}));break}case"end-profiling":Le(r),postMessage({type:t});}}catch(e){postMessage({type:t,err:e});}}),xr=Nt?null:e=>new Worker(e??M,{type:"module",name:kt});})),ge=T((()=>{be(),jt=typeof location>"u"?void 0:location.origin,M=(()=>import.meta.url?.startsWith("file:")?new URL(new URL("ort.wasm.bundle.min.mjs",import.meta.url).href,jt).href:import.meta.url)(),Pe=()=>{if(M&&!M.startsWith("blob:"))return M.substring(0,M.lastIndexOf("/")+1)},Xe=(e,t)=>{try{let r=t??M;return (r?new URL(e,r):new URL(e)).origin===jt}catch{return !1}},Ir=(e,t)=>{let r=t??M;try{return (r?new URL(e,r):new URL(e)).href}catch{return}},Pr=(e,t)=>`${t??"./"}${e}`,Ht=async e=>{let t=await(await fetch(e,{credentials:"same-origin"})).blob();return URL.createObjectURL(t)},vr=async e=>(await import(e)).default,Gt=($t(),at(Wt)).default,Vt=async()=>{if(!M)throw new Error("Failed to load proxy worker: cannot determine the script source URL.");if(Xe(M))return [void 0,Gt()];let e=await Ht(M);return [e,Gt(e)]},zt=void 0,Yt=async(e,t,r)=>{if(!e&&!t&&zt&&M&&Xe(M))return [void 0,zt];{let n="ort-wasm-simd-threaded.mjs",o=e??Ir(n,t),a=r&&o&&!Xe(o,t),i=a?await Ht(o):o??Pr(n,t);return [a?i:void 0,await vr(i)]}};})),J=T((()=>{ge(),Ke=!1,ve=!1,qt=!1,Br=()=>{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}},Cr=()=>{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}},Ee=async e=>{if(Ke)return Promise.resolve();if(ve)throw new Error("multiple calls to 'initializeWebAssembly()' detected.");if(qt)throw new Error("previous call to 'initializeWebAssembly()' failed.");ve=!0;let t=e.initTimeout,r=e.numThreads;if(!Cr())throw new Error("WebAssembly SIMD is not supported in the current environment.");let n=Br();r>1&&!n&&(typeof self<"u"&&!self.crossOriginIsolated&&console.warn("env.wasm.numThreads is set to "+r+", but this will not work unless you enable crossOriginIsolated mode. See https://web.dev/cross-origin-isolation-guide/ for more info."),console.warn("WebAssembly multi-threading is not supported in the current environment. Falling back to single-threading."),e.numThreads=r=1);let o=e.wasmPaths,a="string"==typeof o?o:void 0,i=o?.mjs,s=i?.href??i,l=o?.wasm,u=l?.href??l,f=e.wasmBinary,[d,p]=await Yt(s,a,r>1),c=!1,h=[];if(t>0&&h.push(new Promise((e=>{setTimeout((()=>{c=!0,e();}),t);}))),h.push(new Promise(((e,t)=>{let n={numThreads:r};if(f)n.wasmBinary=f;else if(u||a)n.locateFile=e=>u??a+e;else if(s&&0!==s.indexOf("blob:"))n.locateFile=e=>new URL(e,s).href;else if(d){let e=Pe();e&&(n.locateFile=t=>e+t);}p(n).then((t=>{ve=!1,Ke=!0,Ze=t,e(),d&&URL.revokeObjectURL(d);}),(e=>{ve=!1,qt=!0,t(e);}));}))),await Promise.race(h),c)throw new Error(`WebAssembly backend initializing failed due to timeout: ${t}ms`)},x=()=>{if(Ke&&Ze)return Ze;throw new Error("WebAssembly is not initialized yet.")};})),Be=T((()=>{J(),L=(e,t)=>{let r=x(),n=r.lengthBytesUTF8(e)+1,o=r._malloc(n);return r.stringToUTF8(e,o,n),t.push(o),o},fe=(e,t,r,n)=>{if("object"==typeof e&&null!==e){if(r.has(e))throw new Error("Circular reference in options");r.add(e);}Object.entries(e).forEach((([e,o])=>{let a=t?t+e:e;if("object"==typeof o)fe(o,a+".",r,n);else if("string"==typeof o||"number"==typeof o)n(a,o.toString());else {if("boolean"!=typeof o)throw new Error("Can't handle extra config type: "+typeof o);n(a,o?"1":"0");}}));},S=e=>{let t=x(),r=t.stackSave();try{let r=t.PTR_SIZE,n=t.stackAlloc(2*r);t._OrtGetLastError(n,n+r);let o=Number(t.getValue(n,4===r?"i32":"i64")),a=t.getValue(n+r,"*"),i=a?t.UTF8ToString(a):"";throw new Error(`${e} ERROR_CODE: ${o}, ERROR_MESSAGE: ${i}`)}finally{t.stackRestore(r);}};})),Xt=T((()=>{J(),Be(),Jt=e=>{let t=x(),r=0,n=[],o=e||{};try{if(void 0===e?.logSeverityLevel)o.logSeverityLevel=2;else if("number"!=typeof e.logSeverityLevel||!Number.isInteger(e.logSeverityLevel)||e.logSeverityLevel<0||e.logSeverityLevel>4)throw new Error(`log serverity level is not valid: ${e.logSeverityLevel}`);if(void 0===e?.logVerbosityLevel)o.logVerbosityLevel=0;else if("number"!=typeof e.logVerbosityLevel||!Number.isInteger(e.logVerbosityLevel))throw new Error(`log verbosity level is not valid: ${e.logVerbosityLevel}`);void 0===e?.terminate&&(o.terminate=!1);let a=0;return void 0!==e?.tag&&(a=L(e.tag,n)),r=t._OrtCreateRunOptions(o.logSeverityLevel,o.logVerbosityLevel,!!o.terminate,a),0===r&&S("Can't create run options."),void 0!==e?.extra&&fe(e.extra,"",new WeakSet,((e,o)=>{let a=L(e,n),i=L(o,n);0!==t._OrtAddRunConfigEntry(r,a,i)&&S(`Can't set a run config entry: ${e} - ${o}.`);})),[r,n]}catch(e){throw 0!==r&&t._OrtReleaseRunOptions(r),n.forEach((e=>t._free(e))),e}};})),Kt=T((()=>{J(),Be(),Ur=e=>{switch(e){case"disabled":return 0;case"basic":return 1;case"extended":return 2;case"all":return 99;default:throw new Error(`unsupported graph optimization level: ${e}`)}},_r=e=>{switch(e){case"sequential":return 0;case"parallel":return 1;default:throw new Error(`unsupported execution mode: ${e}`)}},Mr=e=>{e.extra||(e.extra={}),e.extra.session||(e.extra.session={});let t=e.extra.session;t.use_ort_model_bytes_directly||(t.use_ort_model_bytes_directly="1"),e.executionProviders&&e.executionProviders.some((e=>"webgpu"===("string"==typeof e?e:e.name)))&&(e.enableMemPattern=!1);},Dr=(e,t,r)=>{for(let n of t){let t="string"==typeof n?n:n.name;switch(t){case"webnn":if(t="WEBNN","string"!=typeof n){let t=n?.deviceType;if(t){let n=L("deviceType",r),o=L(t,r);0!==x()._OrtAddSessionConfigEntry(e,n,o)&&S(`Can't set a session config entry: 'deviceType' - ${t}.`);}}break;case"webgpu":if(t="JS","string"!=typeof n){let t=n;if(t?.preferredLayout){if("NCHW"!==t.preferredLayout&&"NHWC"!==t.preferredLayout)throw new Error(`preferredLayout must be either 'NCHW' or 'NHWC': ${t.preferredLayout}`);let n=L("preferredLayout",r),o=L(t.preferredLayout,r);0!==x()._OrtAddSessionConfigEntry(e,n,o)&&S(`Can't set a session config entry: 'preferredLayout' - ${t.preferredLayout}.`);}}break;case"wasm":case"cpu":continue;default:throw new Error(`not supported execution provider: ${t}`)}let o=L(t,r);0!==x()._OrtAppendExecutionProvider(e,o)&&S(`Can't append execution provider: ${t}.`);}},Zt=e=>{let t=x(),r=0,n=[],o=e||{};Mr(o);try{let e=Ur(o.graphOptimizationLevel??"all"),a=_r(o.executionMode??"sequential"),i="string"==typeof o.logId?L(o.logId,n):0,s=o.logSeverityLevel??2;if(!Number.isInteger(s)||s<0||s>4)throw new Error(`log serverity level is not valid: ${s}`);let l=o.logVerbosityLevel??0;if(!Number.isInteger(l)||l<0||l>4)throw new Error(`log verbosity level is not valid: ${l}`);let u="string"==typeof o.optimizedModelFilePath?L(o.optimizedModelFilePath,n):0;if(r=t._OrtCreateSessionOptions(e,!!o.enableCpuMemArena,!!o.enableMemPattern,a,!!o.enableProfiling,0,i,s,l,u),0===r&&S("Can't create session options."),o.executionProviders&&Dr(r,o.executionProviders,n),void 0!==o.enableGraphCapture){if("boolean"!=typeof o.enableGraphCapture)throw new Error(`enableGraphCapture must be a boolean value: ${o.enableGraphCapture}`);let e=L("enableGraphCapture",n),a=L(o.enableGraphCapture.toString(),n);0!==t._OrtAddSessionConfigEntry(r,e,a)&&S(`Can't set a session config entry: 'enableGraphCapture' - ${o.enableGraphCapture}.`);}if(o.freeDimensionOverrides)for(let[e,a]of Object.entries(o.freeDimensionOverrides)){if("string"!=typeof e)throw new Error(`free dimension override name must be a string: ${e}`);if("number"!=typeof a||!Number.isInteger(a)||a<0)throw new Error(`free dimension override value must be a non-negative integer: ${a}`);let o=L(e,n);0!==t._OrtAddFreeDimensionOverride(r,o,a)&&S(`Can't set a free dimension override: ${e} - ${a}.`);}return void 0!==o.extra&&fe(o.extra,"",new WeakSet,((e,o)=>{let a=L(e,n),i=L(o,n);0!==t._OrtAddSessionConfigEntry(r,a,i)&&S(`Can't set a session config entry: ${e} - ${o}.`);})),[r,n]}catch(e){throw 0!==r&&0!==t._OrtReleaseSessionOptions(r)&&S("Can't release session options."),n.forEach((e=>t._free(e))),e}};})),Qe=T((()=>{ee=e=>{switch(e){case"int8":return 3;case"uint8":return 2;case"bool":return 9;case"int16":return 5;case"uint16":return 4;case"int32":return 6;case"uint32":return 12;case"float16":return 10;case"float32":return 1;case"float64":return 11;case"string":return 8;case"int64":return 7;case"uint64":return 13;case"int4":return 22;case"uint4":return 21;default:throw new Error(`unsupported data type: ${e}`)}},Qt=e=>{switch(e){case 3:return "int8";case 2:return "uint8";case 9:return "bool";case 5:return "int16";case 4:return "uint16";case 6:return "int32";case 12:return "uint32";case 10:return "float16";case 1:return "float32";case 11:return "float64";case 8:return "string";case 7:return "int64";case 13:return "uint64";case 22:return "int4";case 21:return "uint4";default:throw new Error(`unsupported data type: ${e}`)}},te=(e,t)=>{let r=[-1,4,1,1,2,2,4,8,-1,1,2,8,4,8,-1,-1,-1,-1,-1,-1,-1,.5,.5][e],n="number"==typeof t?t:t.reduce(((e,t)=>e*t),1);return r>0?Math.ceil(n*r):void 0},er=e=>{switch(e){case"float16":return typeof Float16Array<"u"&&Float16Array.from?Float16Array:Uint16Array;case"float32":return Float32Array;case"uint8":case"bool":return Uint8Array;case"int8":return Int8Array;case"uint16":return Uint16Array;case"int16":return Int16Array;case"int32":return Int32Array;case"float64":return Float64Array;case"uint32":return Uint32Array;case"int64":return BigInt64Array;case"uint64":return BigUint64Array;default:throw new Error(`unsupported type: ${e}`)}},tr=e=>{switch(e){case"verbose":return 0;case"info":return 1;case"warning":return 2;case"error":return 3;case"fatal":return 4;default:throw new Error(`unsupported logging level: ${e}`)}},Ce=e=>"float32"===e||"float16"===e||"int32"===e||"int64"===e||"uint32"===e||"uint8"===e||"bool"===e||"uint4"===e||"int4"===e,Ue=e=>"float32"===e||"float16"===e||"int32"===e||"int64"===e||"uint32"===e||"uint64"===e||"int8"===e||"uint8"===e||"bool"===e||"uint4"===e||"int4"===e,rr=e=>{switch(e){case"none":return 0;case"cpu":return 1;case"cpu-pinned":return 2;case"texture":return 3;case"gpu-buffer":return 4;case"ml-tensor":return 5;default:throw new Error(`unsupported data location: ${e}`)}};})),et=T((()=>{be(),ce=async e=>{if("string"==typeof e){{let t=await fetch(e);if(!t.ok)throw new Error(`failed to load external data file: ${e}`);let r=t.headers.get("Content-Length"),n=r?parseInt(r,10):0;if(n<1073741824)return new Uint8Array(await t.arrayBuffer());{if(!t.body)throw new Error(`failed to load external data file: ${e}, no response body.`);let r,o=t.body.getReader();try{r=new ArrayBuffer(n);}catch(e){if(!(e instanceof RangeError))throw e;{let e=Math.ceil(n/65536);r=new WebAssembly.Memory({initial:e,maximum:e}).buffer;}}let a=0;for(;;){let{done:e,value:t}=await o.read();if(e)break;let n=t.byteLength;new Uint8Array(r,a,n).set(t),a+=n;}return new Uint8Array(r,0,n)}}}return e instanceof Blob?new Uint8Array(await e.arrayBuffer()):e instanceof Uint8Array?e:new Uint8Array(e)};})),Je=T((()=>{Xt(),Kt(),Qe(),J(),Be(),et(),Rr=(e,t)=>{0!==x()._OrtInit(e,t)&&S("Can't initialize onnxruntime.");},Te=async e=>{Rr(e.wasm.numThreads,tr(e.logLevel));},Se=async(e,t)=>{},re=new Map,Fr=e=>{let t=x(),r=t.stackSave();try{let r=t.PTR_SIZE,n=t.stackAlloc(2*r);0!==t._OrtGetInputOutputCount(e,n,n+r)&&S("Can't get session input/output count.");let o=4===r?"i32":"i64";return [Number(t.getValue(n,o)),Number(t.getValue(n+r,o))]}finally{t.stackRestore(r);}},ue=e=>{let t=x(),r=t._malloc(e.byteLength);if(0===r)throw new Error(`Can't create a session. failed to allocate a buffer of size ${e.byteLength}.`);return t.HEAPU8.set(e,r),[r,e.byteLength]},Ae=async(e,t)=>{let r,n,o=x();Array.isArray(e)?[r,n]=e:e.buffer===o.HEAPU8.buffer?[r,n]=[e.byteOffset,e.byteLength]:[r,n]=ue(e);let a=0,i=0,s=[],l=[],u=[];try{if([i,s]=Zt(t),t?.externalData&&o.mountExternalData){let e=[];for(let r of t.externalData){let t="string"==typeof r?r:r.path;e.push(ce("string"==typeof r?r:r.data).then((e=>{o.mountExternalData(t,e);})));}await Promise.all(e);}for(let e of t?.executionProviders??[])if("webnn"===("string"==typeof e?e:e.name)){if(o.shouldTransferToMLTensor=!1,"string"!=typeof e){let t=e,r=t?.context,n=t?.gpuDevice,a=t?.deviceType,i=t?.powerPreference;o.currentContext=r||(n?await o.jsepCreateMLContext(n):await o.jsepCreateMLContext({deviceType:a,powerPreference:i}));}else o.currentContext=await o.jsepCreateMLContext();break}a=await o._OrtCreateSession(r,n,i),0===a&&S("Can't create a session."),o.jsepOnCreateSession?.(),o.currentContext&&(o.jsepRegisterMLContext(a,o.currentContext),o.currentContext=void 0,o.shouldTransferToMLTensor=!0);let[e,f]=Fr(a),d=!!t?.enableGraphCapture,p=[],c=[];for(let t=0;t<e;t++){let e=o._OrtGetInputName(a,t);0===e&&S("Can't get an input name."),l.push(e),p.push(o.UTF8ToString(e));}for(let e=0;e<f;e++){let t=o._OrtGetOutputName(a,e);0===t&&S("Can't get an output name."),u.push(t);let r=o.UTF8ToString(t);c.push(r);}return re.set(a,[a,l,u,null,d,!1]),[a,p,c]}catch(e){throw l.forEach((e=>o._OrtFree(e))),u.forEach((e=>o._OrtFree(e))),0!==a&&0!==o._OrtReleaseSession(a)&&S("Can't release session."),e}finally{o._free(r),0!==i&&0!==o._OrtReleaseSessionOptions(i)&&S("Can't release session options."),s.forEach((e=>o._free(e))),o.unmountExternalData?.();}},Oe=e=>{let t=x(),r=re.get(e);if(!r)throw new Error(`cannot release session. invalid session id: ${e}`);let[n,o,a,i,s]=r;i&&(s&&0!==t._OrtClearBoundOutputs(i.handle)&&S("Can't clear bound outputs."),0!==t._OrtReleaseBinding(i.handle)&&S("Can't release IO binding.")),t.jsepOnReleaseSession?.(e),o.forEach((e=>t._OrtFree(e))),a.forEach((e=>t._OrtFree(e))),0!==t._OrtReleaseSession(n)&&S("Can't release session."),re.delete(e);},nr=async(e,t,r,n,o,a=!1)=>{if(!e)return void t.push(0);let i,s,l=x(),u=l.PTR_SIZE,f=e[0],d=e[1],p=e[3],c=p;if("string"===f&&("gpu-buffer"===p||"ml-tensor"===p))throw new Error("String tensor is not supported on GPU.");if(a&&"gpu-buffer"!==p)throw new Error(`External buffer must be provided for input/output index ${o} when enableGraphCapture is true.`);if("gpu-buffer"===p){let t=e[2].gpuBuffer;s=te(ee(f),d);let r=l.jsepRegisterBuffer;if(!r)throw new Error('Tensor location "gpu-buffer" is not supported without using WebGPU.');i=r(n,o,t,s);}else if("ml-tensor"===p){let t=e[2].mlTensor;s=te(ee(f),d);let r=l.jsepRegisterMLTensor;if(!r)throw new Error('Tensor location "ml-tensor" is not supported without using WebNN.');i=r(n,t,ee(f),d);}else {let t=e[2];if(Array.isArray(t)){s=u*t.length,i=l._malloc(s),r.push(i);for(let e=0;e<t.length;e++){if("string"!=typeof t[e])throw new TypeError(`tensor data at index ${e} is not a string`);l.setValue(i+e*u,L(t[e],r),"*");}}else {let e=l.jsepIsGraphInput;if("string"!==f&&e){let a=l._OrtGetInputName(n,o);if(e(n,l.UTF8ToString(a))){let e=ee(f);s=te(e,d),c="ml-tensor";let r=l.jsepCreateTemporaryTensor,o=l.jsepUploadTensor;if(!r||!o)throw new Error('Tensor location "ml-tensor" is not supported without using WebNN.');let a=await r(n,e,d);o(a,new Uint8Array(t.buffer,t.byteOffset,t.byteLength)),i=a;}else s=t.byteLength,i=l._malloc(s),r.push(i),l.HEAPU8.set(new Uint8Array(t.buffer,t.byteOffset,s),i);}else s=t.byteLength,i=l._malloc(s),r.push(i),l.HEAPU8.set(new Uint8Array(t.buffer,t.byteOffset,s),i);}}let h=l.stackSave(),w=l.stackAlloc(4*d.length);try{d.forEach(((e,t)=>l.setValue(w+t*u,e,4===u?"i32":"i64")));let e=l._OrtCreateTensor(ee(f),i,s,w,d.length,rr(c));0===e&&S(`Can't create tensor for input/output. session=${n}, index=${o}.`),t.push(e);}finally{l.stackRestore(h);}},xe=async(e,t,r,n,o,a)=>{let i=x(),s=i.PTR_SIZE,l=re.get(e);if(!l)throw new Error(`cannot run inference. invalid session id: ${e}`);let u=l[0],f=l[1],d=l[2],p=l[3],c=l[4],h=(l[5],t.length),w=n.length,y=0,m=[],g=[],b=[],v=[],E=i.stackSave(),T=i.stackAlloc(h*s),A=i.stackAlloc(h*s),L=i.stackAlloc(w*s),C=i.stackAlloc(w*s);try{[y,m]=Jt(a);for(let n=0;n<h;n++)await nr(r[n],g,v,e,t[n],c);for(let t=0;t<w;t++)await nr(o[t],b,v,e,h+n[t],c);for(let e=0;e<h;e++)i.setValue(T+e*s,g[e],"*"),i.setValue(A+e*s,f[t[e]],"*");for(let e=0;e<w;e++)i.setValue(L+e*s,b[e],"*"),i.setValue(C+e*s,d[n[e]],"*");let l;i.jsepOnRunStart?.(u),l=await i._OrtRun(u,A,T,h,C,w,L,y),0!==l&&S("failed to call OrtRun().");let E=[];for(let t=0;t<w;t++){let r=Number(i.getValue(L+t*s,"*"));if(r===b[t]){E.push(o[t]);continue}let a,l=i.stackSave(),f=i.stackAlloc(4*s),d=!1,c=0;try{0!==i._OrtGetTensorData(r,f,f+s,f+2*s,f+3*s)&&S(`Can't access output tensor data on index ${t}.`);let o=4===s?"i32":"i64",l=Number(i.getValue(f,o));c=i.getValue(f+s,"*");let u=i.getValue(f+2*s,"*"),h=Number(i.getValue(f+3*s,o)),w=[];for(let e=0;e<h;e++)w.push(Number(i.getValue(u+e*s,o)));0!==i._OrtFree(u)&&S("Can't free memory for tensor dims.");let y=w.reduce(((e,t)=>e*t),1);a=Qt(l);let m=p?.outputPreferredLocations[n[t]];if("string"===a){if("gpu-buffer"===m||"ml-tensor"===m)throw new Error("String tensor is not supported on GPU.");let e=[];for(let t=0;t<y;t++){let r=i.getValue(c+t*s,"*"),n=i.getValue(c+(t+1)*s,"*"),o=t===y-1?void 0:n-r;e.push(i.UTF8ToString(r,o));}E.push([a,w,e,"cpu"]);}else if("gpu-buffer"===m&&y>0){let e=i.jsepGetBuffer;if(!e)throw new Error('preferredLocation "gpu-buffer" is not supported without using WebGPU.');let t=e(c),n=te(l,y);if(void 0===n||!Ce(a))throw new Error(`Unsupported data type: ${a}`);d=!0,E.push([a,w,{gpuBuffer:t,download:i.jsepCreateDownloader(t,n,a),dispose:()=>{0!==i._OrtReleaseTensor(r)&&S("Can't release tensor.");}},"gpu-buffer"]);}else if("ml-tensor"===m&&y>0){let t=i.jsepEnsureTensor;if(!t)throw new Error('preferredLocation "ml-tensor" is not supported without using WebNN.');if(void 0===te(l,y)||!Ue(a))throw new Error(`Unsupported data type: ${a}`);let n=await t(e,c,l,w,!1);d=!0,E.push([a,w,{mlTensor:n,download:i.jsepCreateMLTensorDownloader(c,a),dispose:()=>{i.jsepReleaseTensorId(c),i._OrtReleaseTensor(r);}},"ml-tensor"]);}else {let e=new(er(a))(y);new Uint8Array(e.buffer,e.byteOffset,e.byteLength).set(i.HEAPU8.subarray(c,c+e.byteLength)),E.push([a,w,e,"cpu"]);}}finally{i.stackRestore(l),"string"===a&&c&&i._free(c),d||i._OrtReleaseTensor(r),i.jsepOnRunEnd?.(u);}}return p&&!c&&(0!==i._OrtClearBoundOutputs(p.handle)&&S("Can't clear bound outputs."),re.set(e,[u,f,d,p,c,!1])),E}finally{i.stackRestore(E),g.forEach((e=>i._OrtReleaseTensor(e))),b.forEach((e=>i._OrtReleaseTensor(e))),v.forEach((e=>i._free(e))),0!==y&&i._OrtReleaseRunOptions(y),m.forEach((e=>i._free(e)));}},Le=e=>{let t=x(),r=re.get(e);if(!r)throw new Error("invalid session id");let n=r[0],o=t._OrtEndProfiling(n);0===o&&S("Can't get an profile file name."),t._OrtFree(o);},Ie=e=>{let t=[];for(let r of e){let e=r[2];!Array.isArray(e)&&"buffer"in e&&t.push(e.buffer);}return t};})),nt=T((()=>{q(),Je(),J(),ge(),Z=()=>!!A.wasm.proxy&&typeof document<"u",le=!1,Me=!1,De=!1,rt=new Map,ne=(e,t)=>{let r=rt.get(e);r?r.push(t):rt.set(e,[t]);},oe=()=>{if(le||!Me||De||!D)throw new Error("worker not ready")},Nr=e=>{switch(e.data.type){case"init-wasm":le=!1,e.data.err?(De=!0,tt[1](e.data.err)):(Me=!0,tt[0]()),_e&&(URL.revokeObjectURL(_e),_e=void 0);break;case"init-ep":case"copy-from":case"create":case"release":case"run":case"end-profiling":{let t=rt.get(e.data.type);e.data.err?t.shift()[1](e.data.err):t.shift()[0](e.data.out);break}}},or=async()=>{if(!Me){if(le)throw new Error("multiple calls to 'initWasm()' detected.");if(De)throw new Error("previous call to 'initWasm()' failed.");if(le=!0,Z())return new Promise(((e,t)=>{D?.terminate(),Vt().then((([r,n])=>{try{(D=n).onerror=e=>t(e),D.onmessage=Nr,tt=[e,t];let o={type:"init-wasm",in:A};if(!o.in.wasm.wasmPaths&&r){let e=Pe();e&&(o.in.wasm.wasmPaths=e);}D.postMessage(o),_e=r;}catch(e){t(e);}}),t);}));try{await Ee(A.wasm),await Te(A),Me=!0;}catch(e){throw De=!0,e}finally{le=!1;}}},sr=async e=>{if(Z())return oe(),new Promise(((t,r)=>{ne("init-ep",[t,r]);let n={type:"init-ep",in:{epName:e,env:A}};D.postMessage(n);}));await Se(A,e);},ir=async e=>Z()?(oe(),new Promise(((t,r)=>{ne("copy-from",[t,r]);let n={type:"copy-from",in:{buffer:e}};D.postMessage(n,[e.buffer]);}))):ue(e),ar=async(e,t)=>{if(Z()){if(t?.preferredOutputLocation)throw new Error('session option "preferredOutputLocation" is not supported for proxy.');return oe(),new Promise(((r,n)=>{ne("create",[r,n]);let o={type:"create",in:{model:e,options:{...t}}},a=[];e instanceof Uint8Array&&a.push(e.buffer),D.postMessage(o,a);}))}return Ae(e,t)},ur=async e=>{if(Z())return oe(),new Promise(((t,r)=>{ne("release",[t,r]);let n={type:"release",in:e};D.postMessage(n);}));Oe(e);},fr=async(e,t,r,n,o,a)=>{if(Z()){if(r.some((e=>"cpu"!==e[3])))throw new Error("input tensor on GPU is not supported for proxy.");if(o.some((e=>e)))throw new Error("pre-allocated output tensor is not supported for proxy.");return oe(),new Promise(((o,i)=>{ne("run",[o,i]);let s=r,l={type:"run",in:{sessionId:e,inputIndices:t,inputs:s,outputIndices:n,options:a}};D.postMessage(l,Ie(s));}))}return xe(e,t,r,n,o,a)},cr=async e=>{if(Z())return oe(),new Promise(((t,r)=>{ne("end-profiling",[t,r]);let n={type:"end-profiling",in:e};D.postMessage(n);}));Le(e);};})),dr=T((()=>{q(),nt(),Qe(),be(),et(),lr=(e,t)=>{switch(e.location){case"cpu":return [e.type,e.dims,e.data,"cpu"];case"gpu-buffer":return [e.type,e.dims,{gpuBuffer:e.gpuBuffer},"gpu-buffer"];case"ml-tensor":return [e.type,e.dims,{mlTensor:e.mlTensor},"ml-tensor"];default:throw new Error(`invalid data location: ${e.location} for ${t()}`)}},Wr=e=>{switch(e[3]){case"cpu":return new R(e[0],e[2],e[1]);case"gpu-buffer":{let t=e[0];if(!Ce(t))throw new Error(`not supported data type: ${t} for deserializing GPU tensor`);let{gpuBuffer:r,download:n,dispose:o}=e[2];return R.fromGpuBuffer(r,{dataType:t,dims:e[1],download:n,dispose:o})}case"ml-tensor":{let t=e[0];if(!Ue(t))throw new Error(`not supported data type: ${t} for deserializing MLTensor tensor`);let{mlTensor:r,download:n,dispose:o}=e[2];return R.fromMLTensor(r,{dataType:t,dims:e[1],download:n,dispose:o})}default:throw new Error(`invalid data location: ${e[3]}`)}},Re=class{async fetchModelAndCopyToWasmMemory(e){return ir(await ce(e))}async loadModel(e,t){let r;V(),r="string"==typeof e?await this.fetchModelAndCopyToWasmMemory(e):e,[this.sessionId,this.inputNames,this.outputNames]=await ar(r,t),Y();}async dispose(){return ur(this.sessionId)}async run(e,t,r){V();let n=[],o=[];Object.entries(e).forEach((e=>{let t=e[0],r=e[1],a=this.inputNames.indexOf(t);if(-1===a)throw new Error(`invalid input '${t}'`);n.push(r),o.push(a);}));let a=[],i=[];Object.entries(t).forEach((e=>{let t=e[0],r=e[1],n=this.outputNames.indexOf(t);if(-1===n)throw new Error(`invalid output '${t}'`);a.push(r),i.push(n);}));let s=n.map(((e,t)=>lr(e,(()=>`input "${this.inputNames[o[t]]}"`)))),l=a.map(((e,t)=>e?lr(e,(()=>`output "${this.outputNames[i[t]]}"`)):null)),u=await fr(this.sessionId,o,s,i,l,r),f={};for(let e=0;e<u.length;e++)f[this.outputNames[i[e]]]=a[e]??Wr(u[e]);return Y(),f}startProfiling(){}endProfiling(){cr(this.sessionId);}};})),mr={};Ge(mr,{OnnxruntimeWebAssemblyBackend:()=>Fe,initializeFlags:()=>pr,wasmBackend:()=>$r});var pr,Fe,$r,hr=T((()=>{q(),nt(),dr(),pr=()=>{if(("number"!=typeof A.wasm.initTimeout||A.wasm.initTimeout<0)&&(A.wasm.initTimeout=0),!1===A.wasm.simd&&console.warn('Deprecated property "env.wasm.simd" is set to false. non-SIMD build is no longer provided, and this setting will be ignored.'),"boolean"!=typeof A.wasm.proxy&&(A.wasm.proxy=!1),"boolean"!=typeof A.wasm.trace&&(A.wasm.trace=!1),"number"!=typeof A.wasm.numThreads||!Number.isInteger(A.wasm.numThreads)||A.wasm.numThreads<=0)if(typeof self<"u"&&!self.crossOriginIsolated)A.wasm.numThreads=1;else {let e=typeof navigator>"u"?$e("node:os").cpus().length:navigator.hardwareConcurrency;A.wasm.numThreads=Math.min(4,Math.ceil((e||1)/2));}},$r=new(Fe=class{async init(e){pr(),await or(),await sr(e);}async createInferenceSessionHandler(e,t){let r=new Re;return await r.loadModel(e,t),Promise.resolve(r)}});}));q(),q(),q();var Ft="1.21.0";{let e=(hr(),at(mr)).wasmBackend;ie("cpu",e,10),ie("wasm",e,10);}Object.defineProperty(A.versions,"web",{value:Ft,enumerable:!0});

class WorkerNative{constructor(){this.ready=!1;this.indexedDBManager=new IndexedDBManager("onirix-sdk","files"),this.indexedDBManager.getFileFromIndexedDB("SDK_1.11.0").then((async t=>{let e=URL.createObjectURL(new Blob([t],{type:"text/javascript"}));const{default:a}=await import(/* webpackIgnore: true, webpackMode: "lazy" */e),i=await a();this.nativeSDK=i,this.coarseFrame=this.nativeSDK._malloc(3686400),this.extractionFrame=this.nativeSDK._malloc(3686400),this.bufferLength=0,this.frameLayoutStruct=this.nativeSDK._malloc(28),A.wasm.numThreads=1;const s=await this.indexedDBManager.getFileFromIndexedDB("ort.wasm"),r=URL.createObjectURL(new Blob([s],{type:"application/wasm"}));A.wasm.wasmPaths={wasm:r,mjs:"https://cdn.onirix.com/onirix-engine-sdk/ort_v1.21.0_min/ort-wasm-simd.mjs"};let n=await this.indexedDBManager.getFromCacheOrFetch("coarseloc.ort","https://cdn.onirix.com/onirix-engine-sdk/coarseloc.ort");const o=await Or.create(n,{executionProviders:["wasm"]});let h=await this.indexedDBManager.getFromCacheOrFetch("sparse_extract.ort","https://cdn.onirix.com/onirix-engine-sdk/sparse_extract.ort");const c=await Or.create(h,{executionProviders:["wasm"]});this.session=o,this.sessionExtraction=c,await this.session.run({input:new R(new Float32Array(Array(921600).fill(0)),[1,3,640,480])}),this.ready=!0,postMessage("ready");}));}start(){addEventListener("message",(async t=>{if(!this.ready)return void postMessage(!1);this.ready=!1;const e=t.data,a=e.width*e.height*4;0!=this.bufferLength&&this.bufferLength==a||(0!=this.bufferLength&&this.nativeSDK._free(this.buffer),this.bufferLength=a,this.buffer=this.nativeSDK._malloc(this.bufferLength)),this.nativeSDK.HEAPU8.set(e.data,this.buffer),this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+0]=e.width,this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+1]=e.height,this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+2]=4*e.width,this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+3]=!1,this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+4]=e.colorSpace,this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+5]=e.rotate,this.nativeSDK.HEAPU32[this.frameLayoutStruct/4+6]=e.flip;let i=this.nativeSDK._OX_Extract(this.buffer,this.coarseFrame,this.extractionFrame,this.frameLayoutStruct,e.dtype),s=[];if(e.onlyCoarse||2!=e.dtype)s=new Float32Array(this.readExtractionData(this.nativeSDK.HEAPF32,i/4));else {let t=[];for(let e=0;e<921600;e++)t.push(this.nativeSDK.HEAPF32[this.extractionFrame/4+e]);let{keypoints:e,descriptors:a}=await this.sessionExtraction.run({image:new R(new Float32Array(t),[1,3,480,640])}),i=[e.dims[0],...e.data,...a.data];s=new Float32Array(i);}let r=[];for(let t=0;t<921600;t++)r.push(this.nativeSDK.HEAPF32[this.coarseFrame/4+t]);let n=await this.session.run({input:new R(new Float32Array(r),[1,3,640,480])});postMessage({extraction:s,descriptor:n.output.data,onlyCoarse:e.onlyCoarse}),this.ready=!0;}));}readExtractionData(t,e){let a=e,i=[],s=t[a];i.push(s),a++;for(let e=0;e<s;e++)i.push(t[a]),i.push(t[a+1]),a+=2;for(let e=0;e<128*s;e++)i.push(t[a]),a++;return i}}const worker=new WorkerNative;worker.start();
"),b=new Blob([d],{type:"application/javascript"});this.workers[Z]=new Worker(/* webpackIgnore: true, webpackMode: "lazy" */URL.createObjectURL(b),{type:"module"}),this.callbacks[Z]=l,this.workers[Z].addEventListener("message",(l=>{this.callbacks[Z](l.data);}));}}createMatchingWorker(Z,l){if(!this.workerExists(Z)){let d=atob("class IndexedDBManager{constructor(e,r){this.dbName=e,this.storeName=r;}async getFromCacheOrFetch(e,r){let t=null;try{t=await this.getFileFromIndexedDB(e);}catch(e){console.log("An error occurred while trying to get element from indexedDB.");}return t||(t=await this.fetchAndCacheFile(r,e)),new Uint8Array(t)}async getFileFromIndexedDB(e){return new Promise(((r,t)=>{const o=indexedDB.open(this.dbName);o.onerror=()=>t(o.error),o.onsuccess=()=>{const s=o.result.transaction(this.storeName,"readonly").objectStore(this.storeName).get(e);s.onsuccess=()=>r(s.result),s.onerror=()=>t(s.error);},o.onupgradeneeded=e=>{e.target.result.createObjectStore(this.storeName);};}))}async saveFileToIndexedDB(e,r){return new Promise(((t,o)=>{const s=indexedDB.open(this.dbName);s.onerror=()=>o(s.error),s.onupgradeneeded=e=>{e.target.result.createObjectStore(this.storeName);},s.onsuccess=()=>{try{const n=s.result.transaction(this.storeName,"readwrite"),a=n.objectStore(this.storeName).put(r,e);a.onsuccess=()=>t(a.result),a.onerror=()=>o(a.error);}catch(e){o(e);}};}))}async fetchAndCacheFile(e,r){const t=await fetch(e),o=await t.arrayBuffer();return await this.saveFileToIndexedDB(r,o),o}}

var he,j,ie,Ar,ut,ct,dt,_,A,mt,ht,He,yt,bt,gt,Et,Tt,H,ae,At,Ot,Lt,It,v,R,vt,Bt,V,Y,ye,Or,We=Object.defineProperty,gr=Object.getOwnPropertyDescriptor,Er=Object.getOwnPropertyNames,Tr=Object.prototype.hasOwnProperty,$e=(e=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(e,{get:(e,t)=>(typeof require<"u"?require:e)[t]}):e)((function(e){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+e+'" is not supported')})),T=(e,t)=>()=>(e&&(t=e(e=0)),t),Ge=(e,t)=>{for(var r in t)We(e,r,{get:t[r],enumerable:!0});},Sr=(e,t,r,n)=>{if(t&&"object"==typeof t||"function"==typeof t)for(let o of Er(t))!Tr.call(e,o)&&o!==r&&We(e,o,{get:()=>t[o],enumerable:!(n=gr(t,o))||n.enumerable});return e},at=e=>Sr(We({},"__esModule",{value:!0}),e),ze=T((()=>{he=new Map,j=[],ie=(e,t,r)=>{if(!t||"function"!=typeof t.init||"function"!=typeof t.createInferenceSessionHandler)throw new TypeError("not a valid backend");{let n=he.get(e);if(void 0===n)he.set(e,{backend:t,priority:r});else {if(n.priority>r)return;if(n.priority===r&&n.backend!==t)throw new Error(`cannot register backend "${e}" using priority ${r}`)}if(r>=0){let t=j.indexOf(e);-1!==t&&j.splice(t,1);for(let t=0;t<j.length;t++)if(he.get(j[t]).priority<=r)return void j.splice(t,0,e);j.push(e);}}},Ar=async e=>{let t=he.get(e);if(!t)return "backend not found.";if(t.initialized)return t.backend;if(t.aborted)return t.error;{let r=!!t.initPromise;try{return r||(t.initPromise=t.backend.init(e)),await t.initPromise,t.initialized=!0,t.backend}catch(e){return r||(t.error=`${e}`,t.aborted=!0),t.error}finally{delete t.initPromise;}}},ut=async e=>{let t,r=e.executionProviders||[],n=r.map((e=>"string"==typeof e?e:e.name)),o=0===n.length?j:n,a=[],i=new Set;for(let e of o){let r=await Ar(e);"string"==typeof r?a.push({name:e,err:r}):(t||(t=r),t===r&&i.add(e));}if(!t)throw new Error(`no available backend found. ERR: ${a.map((e=>`[${e.name}] ${e.err}`)).join(", ")}`);for(let{name:e,err:t}of a)n.includes(e)&&console.warn(`removing requested execution provider "${e}" from session options because it is not available: ${t}`);let s=r.filter((e=>i.has("string"==typeof e?e:e.name)));return [t,new Proxy(e,{get:(e,t)=>"executionProviders"===t?s:Reflect.get(e,t)})]};})),ft=T((()=>{ze();})),lt=T((()=>{ct="1.21.0";})),je=T((()=>{lt(),dt="warning",_={wasm:{},webgl:{},webgpu:{},versions:{common:ct},set logLevel(e){if(void 0!==e){if("string"!=typeof e||-1===["verbose","info","warning","error","fatal"].indexOf(e))throw new Error(`Unsupported logging level: ${e}`);dt=e;}},get logLevel(){return dt}},Object.defineProperty(_,"logLevel",{enumerable:!0});})),pt=T((()=>{je(),A=_;})),wt=T((()=>{mt=(e,t)=>{let r=typeof document<"u"?document.createElement("canvas"):new OffscreenCanvas(1,1);r.width=e.dims[3],r.height=e.dims[2];let n=r.getContext("2d");if(null!=n){let o,a;void 0!==t?.tensorLayout&&"NHWC"===t.tensorLayout?(o=e.dims[2],a=e.dims[3]):(o=e.dims[3],a=e.dims[2]);let i,s,l=void 0!==t?.format?t.format:"RGB",u=t?.norm;void 0===u||void 0===u.mean?i=[255,255,255,255]:"number"==typeof u.mean?i=[u.mean,u.mean,u.mean,u.mean]:(i=[u.mean[0],u.mean[1],u.mean[2],0],void 0!==u.mean[3]&&(i[3]=u.mean[3])),void 0===u||void 0===u.bias?s=[0,0,0,0]:"number"==typeof u.bias?s=[u.bias,u.bias,u.bias,u.bias]:(s=[u.bias[0],u.bias[1],u.bias[2],0],void 0!==u.bias[3]&&(s[3]=u.bias[3]));let f=a*o,d=0,p=f,c=2*f,h=-1;"RGBA"===l?(d=0,p=f,c=2*f,h=3*f):"RGB"===l?(d=0,p=f,c=2*f):"RBG"===l&&(d=0,c=f,p=2*f);for(let t=0;t<a;t++)for(let r=0;r<o;r++){let o=(e.data[d++]-s[0])*i[0],a=(e.data[p++]-s[1])*i[1],l=(e.data[c++]-s[2])*i[2],u=-1===h?255:(e.data[h++]-s[3])*i[3];n.fillStyle="rgba("+o+","+a+","+l+","+u+")",n.fillRect(r,t,1,1);}if("toDataURL"in r)return r.toDataURL();throw new Error("toDataURL is not supported")}throw new Error("Can not access image data")},ht=(e,t)=>{let r,n=typeof document<"u"?document.createElement("canvas").getContext("2d"):new OffscreenCanvas(1,1).getContext("2d");if(null==n)throw new Error("Can not access image data");{let o,a,i;void 0!==t?.tensorLayout&&"NHWC"===t.tensorLayout?(o=e.dims[2],a=e.dims[1],i=e.dims[3]):(o=e.dims[3],a=e.dims[2],i=e.dims[1]);let s,l,u=void 0!==t&&void 0!==t.format?t.format:"RGB",f=t?.norm;void 0===f||void 0===f.mean?s=[255,255,255,255]:"number"==typeof f.mean?s=[f.mean,f.mean,f.mean,f.mean]:(s=[f.mean[0],f.mean[1],f.mean[2],255],void 0!==f.mean[3]&&(s[3]=f.mean[3])),void 0===f||void 0===f.bias?l=[0,0,0,0]:"number"==typeof f.bias?l=[f.bias,f.bias,f.bias,f.bias]:(l=[f.bias[0],f.bias[1],f.bias[2],0],void 0!==f.bias[3]&&(l[3]=f.bias[3]));let d=a*o;if(void 0!==t&&(void 0!==t.format&&4===i&&"RGBA"!==t.format||3===i&&"RGB"!==t.format&&"BGR"!==t.format))throw new Error("Tensor format doesn't match input tensor dims");let p=4,c=0,h=1,w=2,y=3,m=0,g=d,b=2*d,v=-1;"RGBA"===u?(m=0,g=d,b=2*d,v=3*d):"RGB"===u?(m=0,g=d,b=2*d):"RBG"===u&&(m=0,b=d,g=2*d),r=n.createImageData(o,a);for(let t=0;t<a*o;c+=p,h+=p,w+=p,y+=p,t++)r.data[c]=(e.data[m++]-l[0])*s[0],r.data[h]=(e.data[g++]-l[1])*s[1],r.data[w]=(e.data[b++]-l[2])*s[2],r.data[y]=-1===v?255:(e.data[v++]-l[3])*s[3];}return r};})),St=T((()=>{we(),He=(e,t)=>{if(void 0===e)throw new Error("Image buffer must be defined");if(void 0===t.height||void 0===t.width)throw new Error("Image height and width must be defined");if("NHWC"===t.tensorLayout)throw new Error("NHWC Tensor layout is not supported yet");let r,n,{height:o,width:a}=t,i=t.norm??{mean:255,bias:0};r="number"==typeof i.mean?[i.mean,i.mean,i.mean,i.mean]:[i.mean[0],i.mean[1],i.mean[2],i.mean[3]??255],n="number"==typeof i.bias?[i.bias,i.bias,i.bias,i.bias]:[i.bias[0],i.bias[1],i.bias[2],i.bias[3]??0];let s=void 0!==t.format?t.format:"RGBA",l=void 0!==t.tensorFormat&&void 0!==t.tensorFormat?t.tensorFormat:"RGB",u=o*a,f="RGBA"===l?new Float32Array(4*u):new Float32Array(3*u),d=4,p=0,c=1,h=2,w=3,y=0,m=u,g=2*u,b=-1;"RGB"===s&&(d=3,p=0,c=1,h=2,w=-1),"RGBA"===l?b=3*u:"RBG"===l?(y=0,g=u,m=2*u):"BGR"===l&&(g=0,m=u,y=2*u);for(let t=0;t<u;t++,p+=d,h+=d,c+=d,w+=d)f[y++]=(e[p]+n[0])/r[0],f[m++]=(e[c]+n[1])/r[1],f[g++]=(e[h]+n[2])/r[2],-1!==b&&-1!==w&&(f[b++]=(e[w]+n[3])/r[3]);return new v("float32",f,"RGBA"===l?[1,4,o,a]:[1,3,o,a])},yt=async(e,t)=>{let r,n=typeof HTMLImageElement<"u"&&e instanceof HTMLImageElement,o=typeof ImageData<"u"&&e instanceof ImageData,a=typeof ImageBitmap<"u"&&e instanceof ImageBitmap,i="string"==typeof e,s=t??{},l=()=>{if(typeof document<"u")return document.createElement("canvas");if(typeof OffscreenCanvas<"u")return new OffscreenCanvas(1,1);throw new Error("Canvas is not supported")},u=e=>typeof HTMLCanvasElement<"u"&&e instanceof HTMLCanvasElement||e instanceof OffscreenCanvas?e.getContext("2d"):null;if(n){let n=l();n.width=e.width,n.height=e.height;let o=u(n);if(null==o)throw new Error("Can not access image data");{let n=e.height,a=e.width;if(void 0!==t&&void 0!==t.resizedHeight&&void 0!==t.resizedWidth&&(n=t.resizedHeight,a=t.resizedWidth),void 0!==t){if(s=t,void 0!==t.tensorFormat)throw new Error("Image input config format must be RGBA for HTMLImageElement");s.tensorFormat="RGBA",s.height=n,s.width=a;}else s.tensorFormat="RGBA",s.height=n,s.width=a;o.drawImage(e,0,0),r=o.getImageData(0,0,a,n).data;}}else {if(!o){if(a){if(void 0===t)throw new Error("Please provide image config with format for Imagebitmap");let n=l();n.width=e.width,n.height=e.height;let o=u(n);if(null!=o){let t=e.height,n=e.width;return o.drawImage(e,0,0,n,t),r=o.getImageData(0,0,n,t).data,s.height=t,s.width=n,He(r,s)}throw new Error("Can not access image data")}if(i)return new Promise(((t,r)=>{let n=l(),o=u(n);if(!e||!o)return r();let a=new Image;a.crossOrigin="Anonymous",a.src=e,a.onload=()=>{n.width=a.width,n.height=a.height,o.drawImage(a,0,0,n.width,n.height);let e=o.getImageData(0,0,n.width,n.height);s.height=n.height,s.width=n.width,t(He(e.data,s));};}));throw new Error("Input data provided is not supported - aborted tensor creation")}{let n,o;if(void 0!==t&&void 0!==t.resizedWidth&&void 0!==t.resizedHeight?(n=t.resizedHeight,o=t.resizedWidth):(n=e.height,o=e.width),void 0!==t&&(s=t),s.format="RGBA",s.height=n,s.width=o,void 0!==t){let t=l();t.width=o,t.height=n;let a=u(t);if(null==a)throw new Error("Can not access image data");a.putImageData(e,0,0),r=a.getImageData(0,0,o,n).data;}else r=e.data;}}if(void 0!==r)return He(r,s);throw new Error("Input data provided is not supported - aborted tensor creation")},bt=(e,t)=>{let{width:r,height:n,download:o,dispose:a}=t;return new v({location:"texture",type:"float32",texture:e,dims:[1,n,r,4],download:o,dispose:a})},gt=(e,t)=>{let{dataType:r,dims:n,download:o,dispose:a}=t;return new v({location:"gpu-buffer",type:r??"float32",gpuBuffer:e,dims:n,download:o,dispose:a})},Et=(e,t)=>{let{dataType:r,dims:n,download:o,dispose:a}=t;return new v({location:"ml-tensor",type:r??"float32",mlTensor:e,dims:n,download:o,dispose:a})},Tt=(e,t,r)=>new v({location:"cpu-pinned",type:e,data:t,dims:r??[t.length]});})),xt=T((()=>{H=new Map([["float32",Float32Array],["uint8",Uint8Array],["int8",Int8Array],["uint16",Uint16Array],["int16",Int16Array],["int32",Int32Array],["bool",Uint8Array],["float64",Float64Array],["uint32",Uint32Array],["int4",Uint8Array],["uint4",Uint8Array]]),ae=new Map([[Float32Array,"float32"],[Uint8Array,"uint8"],[Int8Array,"int8"],[Uint16Array,"uint16"],[Int16Array,"int16"],[Int32Array,"int32"],[Float64Array,"float64"],[Uint32Array,"uint32"]]),At=!1,Ot=()=>{if(!At){At=!0;let e=typeof BigInt64Array<"u"&&BigInt64Array.from,t=typeof BigUint64Array<"u"&&BigUint64Array.from,r=globalThis.Float16Array,n=typeof r<"u"&&r.from;e&&(H.set("int64",BigInt64Array),ae.set(BigInt64Array,"int64")),t&&(H.set("uint64",BigUint64Array),ae.set(BigUint64Array,"uint64")),n?(H.set("float16",r),ae.set(r,"float16")):H.set("float16",Uint16Array);}};})),Pt=T((()=>{we(),Lt=e=>{let t=1;for(let r=0;r<e.length;r++){let n=e[r];if("number"!=typeof n||!Number.isSafeInteger(n))throw new TypeError(`dims[${r}] must be an integer, got: ${n}`);if(n<0)throw new RangeError(`dims[${r}] must be a non-negative integer, got: ${n}`);t*=n;}return t},It=(e,t)=>{switch(e.location){case"cpu":return new v(e.type,e.data,t);case"cpu-pinned":return new v({location:"cpu-pinned",data:e.data,type:e.type,dims:t});case"texture":return new v({location:"texture",texture:e.texture,type:e.type,dims:t});case"gpu-buffer":return new v({location:"gpu-buffer",gpuBuffer:e.gpuBuffer,type:e.type,dims:t});case"ml-tensor":return new v({location:"ml-tensor",mlTensor:e.mlTensor,type:e.type,dims:t});default:throw new Error(`tensorReshape: tensor location ${e.location} is not supported`)}};})),we=T((()=>{wt(),St(),xt(),Pt(),v=class{constructor(e,t,r){let n,o;if(Ot(),"object"==typeof e&&"location"in e)switch(this.dataLocation=e.location,n=e.type,o=e.dims,e.location){case"cpu-pinned":{let t=H.get(n);if(!t)throw new TypeError(`unsupported type "${n}" to create tensor from pinned buffer`);if(!(e.data instanceof t))throw new TypeError(`buffer should be of type ${t.name}`);this.cpuData=e.data;break}case"texture":if("float32"!==n)throw new TypeError(`unsupported type "${n}" to create tensor from texture`);this.gpuTextureData=e.texture,this.downloader=e.download,this.disposer=e.dispose;break;case"gpu-buffer":if("float32"!==n&&"float16"!==n&&"int32"!==n&&"int64"!==n&&"uint32"!==n&&"uint8"!==n&&"bool"!==n&&"uint4"!==n&&"int4"!==n)throw new TypeError(`unsupported type "${n}" to create tensor from gpu buffer`);this.gpuBufferData=e.gpuBuffer,this.downloader=e.download,this.disposer=e.dispose;break;case"ml-tensor":if("float32"!==n&&"float16"!==n&&"int32"!==n&&"int64"!==n&&"uint32"!==n&&"uint64"!==n&&"int8"!==n&&"uint8"!==n&&"bool"!==n&&"uint4"!==n&&"int4"!==n)throw new TypeError(`unsupported type "${n}" to create tensor from MLTensor`);this.mlTensorData=e.mlTensor,this.downloader=e.download,this.disposer=e.dispose;break;default:throw new Error(`Tensor constructor: unsupported location '${this.dataLocation}'`)}else {let a,i;if("string"==typeof e)if(n=e,i=r,"string"===e){if(!Array.isArray(t))throw new TypeError("A string tensor's data must be a string array.");a=t;}else {let r=H.get(e);if(void 0===r)throw new TypeError(`Unsupported tensor type: ${e}.`);if(Array.isArray(t)){if("float16"===e&&r===Uint16Array||"uint4"===e||"int4"===e)throw new TypeError(`Creating a ${e} tensor from number array is not supported. Please use ${r.name} as data.`);a="uint64"===e||"int64"===e?r.from(t,BigInt):r.from(t);}else if(t instanceof r)a=t;else if(t instanceof Uint8ClampedArray){if("uint8"!==e)throw new TypeError("A Uint8ClampedArray tensor's data must be type of uint8");a=Uint8Array.from(t);}else {if(!("float16"===e&&t instanceof Uint16Array&&r!==Uint16Array))throw new TypeError(`A ${n} tensor's data must be type of ${r}`);a=new globalThis.Float16Array(t.buffer,t.byteOffset,t.length);}}else if(i=t,Array.isArray(e)){if(0===e.length)throw new TypeError("Tensor type cannot be inferred from an empty array.");let t=typeof e[0];if("string"===t)n="string",a=e;else {if("boolean"!==t)throw new TypeError(`Invalid element type of data array: ${t}.`);n="bool",a=Uint8Array.from(e);}}else if(e instanceof Uint8ClampedArray)n="uint8",a=Uint8Array.from(e);else {let t=ae.get(e.constructor);if(void 0===t)throw new TypeError(`Unsupported type for tensor data: ${e.constructor}.`);n=t,a=e;}if(void 0===i)i=[a.length];else if(!Array.isArray(i))throw new TypeError("A tensor's dims must be a number array");o=i,this.cpuData=a,this.dataLocation="cpu";}let a=Lt(o);if(this.cpuData&&a!==this.cpuData.length&&("uint4"!==n&&"int4"!==n||Math.ceil(a/2)!==this.cpuData.length))throw new Error(`Tensor's size(${a}) does not match data length(${this.cpuData.length}).`);this.type=n,this.dims=o,this.size=a;}static async fromImage(e,t){return yt(e,t)}static fromTexture(e,t){return bt(e,t)}static fromGpuBuffer(e,t){return gt(e,t)}static fromMLTensor(e,t){return Et(e,t)}static fromPinnedBuffer(e,t,r){return Tt(e,t,r)}toDataURL(e){return mt(this,e)}toImageData(e){return ht(this,e)}get data(){if(this.ensureValid(),!this.cpuData)throw new Error("The data is not on CPU. Use `getData()` to download GPU data to CPU, or use `texture` or `gpuBuffer` property to access the GPU data directly.");return this.cpuData}get location(){return this.dataLocation}get texture(){if(this.ensureValid(),!this.gpuTextureData)throw new Error("The data is not stored as a WebGL texture.");return this.gpuTextureData}get gpuBuffer(){if(this.ensureValid(),!this.gpuBufferData)throw new Error("The data is not stored as a WebGPU buffer.");return this.gpuBufferData}get mlTensor(){if(this.ensureValid(),!this.mlTensorData)throw new Error("The data is not stored as a WebNN MLTensor.");return this.mlTensorData}async getData(e){switch(this.ensureValid(),this.dataLocation){case"cpu":case"cpu-pinned":return this.data;case"texture":case"gpu-buffer":case"ml-tensor":if(!this.downloader)throw new Error("The current tensor is not created with a specified data downloader.");if(this.isDownloading)throw new Error("The current tensor is being downloaded.");try{this.isDownloading=!0;let t=await this.downloader();return this.downloader=void 0,this.dataLocation="cpu",this.cpuData=t,e&&this.disposer&&(this.disposer(),this.disposer=void 0),t}finally{this.isDownloading=!1;}default:throw new Error(`cannot get data from location: ${this.dataLocation}`)}}dispose(){if(this.isDownloading)throw new Error("The current tensor is being downloaded.");this.disposer&&(this.disposer(),this.disposer=void 0),this.cpuData=void 0,this.gpuTextureData=void 0,this.gpuBufferData=void 0,this.mlTensorData=void 0,this.downloader=void 0,this.isDownloading=void 0,this.dataLocation="none";}ensureValid(){if("none"===this.dataLocation)throw new Error("The tensor is disposed.")}reshape(e){if(this.ensureValid(),this.downloader||this.disposer)throw new Error("Cannot reshape a tensor that owns GPU resource.");return It(this,e)}};})),Ve=T((()=>{we(),R=v;})),Ye=T((()=>{je(),vt=(e,t)=>{(typeof _.trace>"u"?!_.wasm.trace:!_.trace)||console.timeStamp(`${e}::ORT::${t}`);},Bt=(e,t)=>{let r=(new Error).stack?.split(/\r\n|\r|\n/g)||[],n=!1;for(let o=0;o<r.length;o++){if(n&&!r[o].includes("TRACE_FUNC")){let n=`FUNC_${e}::${r[o].trim().split(" ")[1]}`;return t&&(n+=`::${t}`),void vt("CPU",n)}r[o].includes("TRACE_FUNC")&&(n=!0);}},V=e=>{(typeof _.trace>"u"?!_.wasm.trace:!_.trace)||Bt("BEGIN",e);},Y=e=>{(typeof _.trace>"u"?!_.wasm.trace:!_.trace)||Bt("END",e);};})),Ct=T((()=>{ze(),Ve(),Ye(),ye=class e{constructor(e){this.handler=e;}async run(e,t,r){V();let n={},o={};if("object"!=typeof e||null===e||e instanceof R||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("object"==typeof t){if(null===t)throw new TypeError("Unexpected argument[1]: cannot be null.");if(t instanceof R)throw new TypeError("'fetches' cannot be a Tensor");if(Array.isArray(t)){if(0===t.length)throw new TypeError("'fetches' cannot be an empty array.");a=!1;for(let e of t){if("string"!=typeof e)throw new TypeError("'fetches' must be a string array or an object.");if(-1===this.outputNames.indexOf(e))throw new RangeError(`'fetches' contains invalid output name: ${e}.`);n[e]=null;}if("object"==typeof r&&null!==r)o=r;else if(typeof r<"u")throw new TypeError("'options' must be an object.")}else {let e=!1,i=Object.getOwnPropertyNames(t);for(let r of this.outputNames)if(-1!==i.indexOf(r)){let o=t[r];(null===o||o instanceof R)&&(e=!0,a=!1,n[r]=o);}if(e){if("object"==typeof r&&null!==r)o=r;else if(typeof r<"u")throw new TypeError("'options' must be an object.")}else o=t;}}else if(typeof t<"u")throw new TypeError("Unexpected argument[1]: must be 'fetches' or 'options'.");for(let t of this.inputNames)if(typeof e[t]>"u")throw new Error(`input '${t}' is missing in 'feeds'.`);if(a)for(let e of this.outputNames)n[e]=null;let i=await this.handler.run(e,n,o),s={};for(let e in i)if(Object.hasOwnProperty.call(i,e)){let t=i[e];s[e]=t instanceof R?t:new R(t.type,t.data,t.dims);}return Y(),s}async release(){return this.handler.dispose()}static async create(t,r,n,o){V();let a,i={};if("string"==typeof t){if(a=t,"object"==typeof r&&null!==r)i=r;else if(typeof r<"u")throw new TypeError("'options' must be an object.")}else if(t instanceof Uint8Array){if(a=t,"object"==typeof r&&null!==r)i=r;else if(typeof r<"u")throw new TypeError("'options' must be an object.")}else {if(!(t instanceof ArrayBuffer||typeof SharedArrayBuffer<"u"&&t instanceof SharedArrayBuffer))throw new TypeError("Unexpected argument[0]: must be 'path' or 'buffer'.");{let e=t,s=0,l=t.byteLength;if("object"==typeof r&&null!==r)i=r;else if("number"==typeof r){if(s=r,!Number.isSafeInteger(s))throw new RangeError("'byteOffset' must be an integer.");if(s<0||s>=e.byteLength)throw new RangeError(`'byteOffset' is out of range [0, ${e.byteLength}).`);if(l=t.byteLength-s,"number"==typeof n){if(l=n,!Number.isSafeInteger(l))throw new RangeError("'byteLength' must be an integer.");if(l<=0||s+l>e.byteLength)throw new RangeError(`'byteLength' is out of range (0, ${e.byteLength-s}].`);if("object"==typeof o&&null!==o)i=o;else if(typeof o<"u")throw new TypeError("'options' must be an object.")}else if(typeof n<"u")throw new TypeError("'byteLength' must be a number.")}else if(typeof r<"u")throw new TypeError("'options' must be an object.");a=new Uint8Array(e,s,l);}}let[s,l]=await ut(i),u=await s.createInferenceSessionHandler(a,l);return Y(),new e(u)}startProfiling(){this.handler.startProfiling();}endProfiling(){this.handler.endProfiling();}get inputNames(){return this.handler.inputNames}get outputNames(){return this.handler.outputNames}};})),Ut=T((()=>{Ct(),Or=ye;})),_t=T((()=>{})),Mt=T((()=>{})),Dt=T((()=>{})),Rt=T((()=>{})),qe={};Ge(qe,{InferenceSession:()=>Or,TRACE:()=>vt,TRACE_FUNC_BEGIN:()=>V,TRACE_FUNC_END:()=>Y,Tensor:()=>R,env:()=>A,registerBackend:()=>ie});var q=T((()=>{ft(),pt(),Ut(),Ve(),_t(),Mt(),Ye(),Dt(),Rt();})),be=T((()=>{})),Wt={};Ge(Wt,{default:()=>xr});var kt,Nt,xr,jt,M,Pe,Xe,Ir,Pr,Ht,vr,Gt,Vt,zt,Yt,Ze,Ke,ve,qt,Br,Cr,Ee,x,L,fe,S,Jt,Ur,_r,Mr,Dr,Zt,ee,Qt,te,er,tr,Ce,Ue,rr,ce,Rr,Te,Se,re,Fr,ue,Ae,Oe,nr,xe,Le,Ie,Z,D,le,Me,De,_e,tt,rt,ne,oe,Nr,or,sr,ir,ar,ur,fr,cr,lr,Wr,Re,$t=T((()=>{Je(),J(),ge(),kt="ort-wasm-proxy-worker",(Nt=globalThis.self?.name===kt)&&(self.onmessage=e=>{let{type:t,in:r}=e.data;try{switch(t){case"init-wasm":Ee(r.wasm).then((()=>{Te(r).then((()=>{postMessage({type:t});}),(e=>{postMessage({type:t,err:e});}));}),(e=>{postMessage({type:t,err:e});}));break;case"init-ep":{let{epName:e,env:n}=r;Se(n,e).then((()=>{postMessage({type:t});}),(e=>{postMessage({type:t,err:e});}));break}case"copy-from":{let{buffer:e}=r,n=ue(e);postMessage({type:t,out:n});break}case"create":{let{model:e,options:n}=r;Ae(e,n).then((e=>{postMessage({type:t,out:e});}),(e=>{postMessage({type:t,err:e});}));break}case"release":Oe(r),postMessage({type:t});break;case"run":{let{sessionId:e,inputIndices:n,inputs:o,outputIndices:a,options:i}=r;xe(e,n,o,a,new Array(a.length).fill(null),i).then((e=>{e.some((e=>"cpu"!==e[3]))?postMessage({type:t,err:"Proxy does not support non-cpu tensor location."}):postMessage({type:t,out:e},Ie([...o,...e]));}),(e=>{postMessage({type:t,err:e});}));break}case"end-profiling":Le(r),postMessage({type:t});}}catch(e){postMessage({type:t,err:e});}}),xr=Nt?null:e=>new Worker(e??M,{type:"module",name:kt});})),ge=T((()=>{be(),jt=typeof location>"u"?void 0:location.origin,M=(()=>import.meta.url?.startsWith("file:")?new URL(new URL("ort.wasm.bundle.min.mjs",import.meta.url).href,jt).href:import.meta.url)(),Pe=()=>{if(M&&!M.startsWith("blob:"))return M.substring(0,M.lastIndexOf("/")+1)},Xe=(e,t)=>{try{let r=t??M;return (r?new URL(e,r):new URL(e)).origin===jt}catch{return !1}},Ir=(e,t)=>{let r=t??M;try{return (r?new URL(e,r):new URL(e)).href}catch{return}},Pr=(e,t)=>`${t??"./"}${e}`,Ht=async e=>{let t=await(await fetch(e,{credentials:"same-origin"})).blob();return URL.createObjectURL(t)},vr=async e=>(await import(e)).default,Gt=($t(),at(Wt)).default,Vt=async()=>{if(!M)throw new Error("Failed to load proxy worker: cannot determine the script source URL.");if(Xe(M))return [void 0,Gt()];let e=await Ht(M);return [e,Gt(e)]},zt=void 0,Yt=async(e,t,r)=>{if(!e&&!t&&zt&&M&&Xe(M))return [void 0,zt];{let n="ort-wasm-simd-threaded.mjs",o=e??Ir(n,t),a=r&&o&&!Xe(o,t),i=a?await Ht(o):o??Pr(n,t);return [a?i:void 0,await vr(i)]}};})),J=T((()=>{ge(),Ke=!1,ve=!1,qt=!1,Br=()=>{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}},Cr=()=>{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}},Ee=async e=>{if(Ke)return Promise.resolve();if(ve)throw new Error("multiple calls to 'initializeWebAssembly()' detected.");if(qt)throw new Error("previous call to 'initializeWebAssembly()' failed.");ve=!0;let t=e.initTimeout,r=e.numThreads;if(!Cr())throw new Error("WebAssembly SIMD is not supported in the current environment.");let n=Br();r>1&&!n&&(typeof self<"u"&&!self.crossOriginIsolated&&console.warn("env.wasm.numThreads is set to "+r+", but this will not work unless you enable crossOriginIsolated mode. See https://web.dev/cross-origin-isolation-guide/ for more info."),console.warn("WebAssembly multi-threading is not supported in the current environment. Falling back to single-threading."),e.numThreads=r=1);let o=e.wasmPaths,a="string"==typeof o?o:void 0,i=o?.mjs,s=i?.href??i,l=o?.wasm,u=l?.href??l,f=e.wasmBinary,[d,p]=await Yt(s,a,r>1),c=!1,h=[];if(t>0&&h.push(new Promise((e=>{setTimeout((()=>{c=!0,e();}),t);}))),h.push(new Promise(((e,t)=>{let n={numThreads:r};if(f)n.wasmBinary=f;else if(u||a)n.locateFile=e=>u??a+e;else if(s&&0!==s.indexOf("blob:"))n.locateFile=e=>new URL(e,s).href;else if(d){let e=Pe();e&&(n.locateFile=t=>e+t);}p(n).then((t=>{ve=!1,Ke=!0,Ze=t,e(),d&&URL.revokeObjectURL(d);}),(e=>{ve=!1,qt=!0,t(e);}));}))),await Promise.race(h),c)throw new Error(`WebAssembly backend initializing failed due to timeout: ${t}ms`)},x=()=>{if(Ke&&Ze)return Ze;throw new Error("WebAssembly is not initialized yet.")};})),Be=T((()=>{J(),L=(e,t)=>{let r=x(),n=r.lengthBytesUTF8(e)+1,o=r._malloc(n);return r.stringToUTF8(e,o,n),t.push(o),o},fe=(e,t,r,n)=>{if("object"==typeof e&&null!==e){if(r.has(e))throw new Error("Circular reference in options");r.add(e);}Object.entries(e).forEach((([e,o])=>{let a=t?t+e:e;if("object"==typeof o)fe(o,a+".",r,n);else if("string"==typeof o||"number"==typeof o)n(a,o.toString());else {if("boolean"!=typeof o)throw new Error("Can't handle extra config type: "+typeof o);n(a,o?"1":"0");}}));},S=e=>{let t=x(),r=t.stackSave();try{let r=t.PTR_SIZE,n=t.stackAlloc(2*r);t._OrtGetLastError(n,n+r);let o=Number(t.getValue(n,4===r?"i32":"i64")),a=t.getValue(n+r,"*"),i=a?t.UTF8ToString(a):"";throw new Error(`${e} ERROR_CODE: ${o}, ERROR_MESSAGE: ${i}`)}finally{t.stackRestore(r);}};})),Xt=T((()=>{J(),Be(),Jt=e=>{let t=x(),r=0,n=[],o=e||{};try{if(void 0===e?.logSeverityLevel)o.logSeverityLevel=2;else if("number"!=typeof e.logSeverityLevel||!Number.isInteger(e.logSeverityLevel)||e.logSeverityLevel<0||e.logSeverityLevel>4)throw new Error(`log serverity level is not valid: ${e.logSeverityLevel}`);if(void 0===e?.logVerbosityLevel)o.logVerbosityLevel=0;else if("number"!=typeof e.logVerbosityLevel||!Number.isInteger(e.logVerbosityLevel))throw new Error(`log verbosity level is not valid: ${e.logVerbosityLevel}`);void 0===e?.terminate&&(o.terminate=!1);let a=0;return void 0!==e?.tag&&(a=L(e.tag,n)),r=t._OrtCreateRunOptions(o.logSeverityLevel,o.logVerbosityLevel,!!o.terminate,a),0===r&&S("Can't create run options."),void 0!==e?.extra&&fe(e.extra,"",new WeakSet,((e,o)=>{let a=L(e,n),i=L(o,n);0!==t._OrtAddRunConfigEntry(r,a,i)&&S(`Can't set a run config entry: ${e} - ${o}.`);})),[r,n]}catch(e){throw 0!==r&&t._OrtReleaseRunOptions(r),n.forEach((e=>t._free(e))),e}};})),Kt=T((()=>{J(),Be(),Ur=e=>{switch(e){case"disabled":return 0;case"basic":return 1;case"extended":return 2;case"all":return 99;default:throw new Error(`unsupported graph optimization level: ${e}`)}},_r=e=>{switch(e){case"sequential":return 0;case"parallel":return 1;default:throw new Error(`unsupported execution mode: ${e}`)}},Mr=e=>{e.extra||(e.extra={}),e.extra.session||(e.extra.session={});let t=e.extra.session;t.use_ort_model_bytes_directly||(t.use_ort_model_bytes_directly="1"),e.executionProviders&&e.executionProviders.some((e=>"webgpu"===("string"==typeof e?e:e.name)))&&(e.enableMemPattern=!1);},Dr=(e,t,r)=>{for(let n of t){let t="string"==typeof n?n:n.name;switch(t){case"webnn":if(t="WEBNN","string"!=typeof n){let t=n?.deviceType;if(t){let n=L("deviceType",r),o=L(t,r);0!==x()._OrtAddSessionConfigEntry(e,n,o)&&S(`Can't set a session config entry: 'deviceType' - ${t}.`);}}break;case"webgpu":if(t="JS","string"!=typeof n){let t=n;if(t?.preferredLayout){if("NCHW"!==t.preferredLayout&&"NHWC"!==t.preferredLayout)throw new Error(`preferredLayout must be either 'NCHW' or 'NHWC': ${t.preferredLayout}`);let n=L("preferredLayout",r),o=L(t.preferredLayout,r);0!==x()._OrtAddSessionConfigEntry(e,n,o)&&S(`Can't set a session config entry: 'preferredLayout' - ${t.preferredLayout}.`);}}break;case"wasm":case"cpu":continue;default:throw new Error(`not supported execution provider: ${t}`)}let o=L(t,r);0!==x()._OrtAppendExecutionProvider(e,o)&&S(`Can't append execution provider: ${t}.`);}},Zt=e=>{let t=x(),r=0,n=[],o=e||{};Mr(o);try{let e=Ur(o.graphOptimizationLevel??"all"),a=_r(o.executionMode??"sequential"),i="string"==typeof o.logId?L(o.logId,n):0,s=o.logSeverityLevel??2;if(!Number.isInteger(s)||s<0||s>4)throw new Error(`log serverity level is not valid: ${s}`);let l=o.logVerbosityLevel??0;if(!Number.isInteger(l)||l<0||l>4)throw new Error(`log verbosity level is not valid: ${l}`);let u="string"==typeof o.optimizedModelFilePath?L(o.optimizedModelFilePath,n):0;if(r=t._OrtCreateSessionOptions(e,!!o.enableCpuMemArena,!!o.enableMemPattern,a,!!o.enableProfiling,0,i,s,l,u),0===r&&S("Can't create session options."),o.executionProviders&&Dr(r,o.executionProviders,n),void 0!==o.enableGraphCapture){if("boolean"!=typeof o.enableGraphCapture)throw new Error(`enableGraphCapture must be a boolean value: ${o.enableGraphCapture}`);let e=L("enableGraphCapture",n),a=L(o.enableGraphCapture.toString(),n);0!==t._OrtAddSessionConfigEntry(r,e,a)&&S(`Can't set a session config entry: 'enableGraphCapture' - ${o.enableGraphCapture}.`);}if(o.freeDimensionOverrides)for(let[e,a]of Object.entries(o.freeDimensionOverrides)){if("string"!=typeof e)throw new Error(`free dimension override name must be a string: ${e}`);if("number"!=typeof a||!Number.isInteger(a)||a<0)throw new Error(`free dimension override value must be a non-negative integer: ${a}`);let o=L(e,n);0!==t._OrtAddFreeDimensionOverride(r,o,a)&&S(`Can't set a free dimension override: ${e} - ${a}.`);}return void 0!==o.extra&&fe(o.extra,"",new WeakSet,((e,o)=>{let a=L(e,n),i=L(o,n);0!==t._OrtAddSessionConfigEntry(r,a,i)&&S(`Can't set a session config entry: ${e} - ${o}.`);})),[r,n]}catch(e){throw 0!==r&&0!==t._OrtReleaseSessionOptions(r)&&S("Can't release session options."),n.forEach((e=>t._free(e))),e}};})),Qe=T((()=>{ee=e=>{switch(e){case"int8":return 3;case"uint8":return 2;case"bool":return 9;case"int16":return 5;case"uint16":return 4;case"int32":return 6;case"uint32":return 12;case"float16":return 10;case"float32":return 1;case"float64":return 11;case"string":return 8;case"int64":return 7;case"uint64":return 13;case"int4":return 22;case"uint4":return 21;default:throw new Error(`unsupported data type: ${e}`)}},Qt=e=>{switch(e){case 3:return "int8";case 2:return "uint8";case 9:return "bool";case 5:return "int16";case 4:return "uint16";case 6:return "int32";case 12:return "uint32";case 10:return "float16";case 1:return "float32";case 11:return "float64";case 8:return "string";case 7:return "int64";case 13:return "uint64";case 22:return "int4";case 21:return "uint4";default:throw new Error(`unsupported data type: ${e}`)}},te=(e,t)=>{let r=[-1,4,1,1,2,2,4,8,-1,1,2,8,4,8,-1,-1,-1,-1,-1,-1,-1,.5,.5][e],n="number"==typeof t?t:t.reduce(((e,t)=>e*t),1);return r>0?Math.ceil(n*r):void 0},er=e=>{switch(e){case"float16":return typeof Float16Array<"u"&&Float16Array.from?Float16Array:Uint16Array;case"float32":return Float32Array;case"uint8":case"bool":return Uint8Array;case"int8":return Int8Array;case"uint16":return Uint16Array;case"int16":return Int16Array;case"int32":return Int32Array;case"float64":return Float64Array;case"uint32":return Uint32Array;case"int64":return BigInt64Array;case"uint64":return BigUint64Array;default:throw new Error(`unsupported type: ${e}`)}},tr=e=>{switch(e){case"verbose":return 0;case"info":return 1;case"warning":return 2;case"error":return 3;case"fatal":return 4;default:throw new Error(`unsupported logging level: ${e}`)}},Ce=e=>"float32"===e||"float16"===e||"int32"===e||"int64"===e||"uint32"===e||"uint8"===e||"bool"===e||"uint4"===e||"int4"===e,Ue=e=>"float32"===e||"float16"===e||"int32"===e||"int64"===e||"uint32"===e||"uint64"===e||"int8"===e||"uint8"===e||"bool"===e||"uint4"===e||"int4"===e,rr=e=>{switch(e){case"none":return 0;case"cpu":return 1;case"cpu-pinned":return 2;case"texture":return 3;case"gpu-buffer":return 4;case"ml-tensor":return 5;default:throw new Error(`unsupported data location: ${e}`)}};})),et=T((()=>{be(),ce=async e=>{if("string"==typeof e){{let t=await fetch(e);if(!t.ok)throw new Error(`failed to load external data file: ${e}`);let r=t.headers.get("Content-Length"),n=r?parseInt(r,10):0;if(n<1073741824)return new Uint8Array(await t.arrayBuffer());{if(!t.body)throw new Error(`failed to load external data file: ${e}, no response body.`);let r,o=t.body.getReader();try{r=new ArrayBuffer(n);}catch(e){if(!(e instanceof RangeError))throw e;{let e=Math.ceil(n/65536);r=new WebAssembly.Memory({initial:e,maximum:e}).buffer;}}let a=0;for(;;){let{done:e,value:t}=await o.read();if(e)break;let n=t.byteLength;new Uint8Array(r,a,n).set(t),a+=n;}return new Uint8Array(r,0,n)}}}return e instanceof Blob?new Uint8Array(await e.arrayBuffer()):e instanceof Uint8Array?e:new Uint8Array(e)};})),Je=T((()=>{Xt(),Kt(),Qe(),J(),Be(),et(),Rr=(e,t)=>{0!==x()._OrtInit(e,t)&&S("Can't initialize onnxruntime.");},Te=async e=>{Rr(e.wasm.numThreads,tr(e.logLevel));},Se=async(e,t)=>{},re=new Map,Fr=e=>{let t=x(),r=t.stackSave();try{let r=t.PTR_SIZE,n=t.stackAlloc(2*r);0!==t._OrtGetInputOutputCount(e,n,n+r)&&S("Can't get session input/output count.");let o=4===r?"i32":"i64";return [Number(t.getValue(n,o)),Number(t.getValue(n+r,o))]}finally{t.stackRestore(r);}},ue=e=>{let t=x(),r=t._malloc(e.byteLength);if(0===r)throw new Error(`Can't create a session. failed to allocate a buffer of size ${e.byteLength}.`);return t.HEAPU8.set(e,r),[r,e.byteLength]},Ae=async(e,t)=>{let r,n,o=x();Array.isArray(e)?[r,n]=e:e.buffer===o.HEAPU8.buffer?[r,n]=[e.byteOffset,e.byteLength]:[r,n]=ue(e);let a=0,i=0,s=[],l=[],u=[];try{if([i,s]=Zt(t),t?.externalData&&o.mountExternalData){let e=[];for(let r of t.externalData){let t="string"==typeof r?r:r.path;e.push(ce("string"==typeof r?r:r.data).then((e=>{o.mountExternalData(t,e);})));}await Promise.all(e);}for(let e of t?.executionProviders??[])if("webnn"===("string"==typeof e?e:e.name)){if(o.shouldTransferToMLTensor=!1,"string"!=typeof e){let t=e,r=t?.context,n=t?.gpuDevice,a=t?.deviceType,i=t?.powerPreference;o.currentContext=r||(n?await o.jsepCreateMLContext(n):await o.jsepCreateMLContext({deviceType:a,powerPreference:i}));}else o.currentContext=await o.jsepCreateMLContext();break}a=await o._OrtCreateSession(r,n,i),0===a&&S("Can't create a session."),o.jsepOnCreateSession?.(),o.currentContext&&(o.jsepRegisterMLContext(a,o.currentContext),o.currentContext=void 0,o.shouldTransferToMLTensor=!0);let[e,f]=Fr(a),d=!!t?.enableGraphCapture,p=[],c=[];for(let t=0;t<e;t++){let e=o._OrtGetInputName(a,t);0===e&&S("Can't get an input name."),l.push(e),p.push(o.UTF8ToString(e));}for(let e=0;e<f;e++){let t=o._OrtGetOutputName(a,e);0===t&&S("Can't get an output name."),u.push(t);let r=o.UTF8ToString(t);c.push(r);}return re.set(a,[a,l,u,null,d,!1]),[a,p,c]}catch(e){throw l.forEach((e=>o._OrtFree(e))),u.forEach((e=>o._OrtFree(e))),0!==a&&0!==o._OrtReleaseSession(a)&&S("Can't release session."),e}finally{o._free(r),0!==i&&0!==o._OrtReleaseSessionOptions(i)&&S("Can't release session options."),s.forEach((e=>o._free(e))),o.unmountExternalData?.();}},Oe=e=>{let t=x(),r=re.get(e);if(!r)throw new Error(`cannot release session. invalid session id: ${e}`);let[n,o,a,i,s]=r;i&&(s&&0!==t._OrtClearBoundOutputs(i.handle)&&S("Can't clear bound outputs."),0!==t._OrtReleaseBinding(i.handle)&&S("Can't release IO binding.")),t.jsepOnReleaseSession?.(e),o.forEach((e=>t._OrtFree(e))),a.forEach((e=>t._OrtFree(e))),0!==t._OrtReleaseSession(n)&&S("Can't release session."),re.delete(e);},nr=async(e,t,r,n,o,a=!1)=>{if(!e)return void t.push(0);let i,s,l=x(),u=l.PTR_SIZE,f=e[0],d=e[1],p=e[3],c=p;if("string"===f&&("gpu-buffer"===p||"ml-tensor"===p))throw new Error("String tensor is not supported on GPU.");if(a&&"gpu-buffer"!==p)throw new Error(`External buffer must be provided for input/output index ${o} when enableGraphCapture is true.`);if("gpu-buffer"===p){let t=e[2].gpuBuffer;s=te(ee(f),d);let r=l.jsepRegisterBuffer;if(!r)throw new Error('Tensor location "gpu-buffer" is not supported without using WebGPU.');i=r(n,o,t,s);}else if("ml-tensor"===p){let t=e[2].mlTensor;s=te(ee(f),d);let r=l.jsepRegisterMLTensor;if(!r)throw new Error('Tensor location "ml-tensor" is not supported without using WebNN.');i=r(n,t,ee(f),d);}else {let t=e[2];if(Array.isArray(t)){s=u*t.length,i=l._malloc(s),r.push(i);for(let e=0;e<t.length;e++){if("string"!=typeof t[e])throw new TypeError(`tensor data at index ${e} is not a string`);l.setValue(i+e*u,L(t[e],r),"*");}}else {let e=l.jsepIsGraphInput;if("string"!==f&&e){let a=l._OrtGetInputName(n,o);if(e(n,l.UTF8ToString(a))){let e=ee(f);s=te(e,d),c="ml-tensor";let r=l.jsepCreateTemporaryTensor,o=l.jsepUploadTensor;if(!r||!o)throw new Error('Tensor location "ml-tensor" is not supported without using WebNN.');let a=await r(n,e,d);o(a,new Uint8Array(t.buffer,t.byteOffset,t.byteLength)),i=a;}else s=t.byteLength,i=l._malloc(s),r.push(i),l.HEAPU8.set(new Uint8Array(t.buffer,t.byteOffset,s),i);}else s=t.byteLength,i=l._malloc(s),r.push(i),l.HEAPU8.set(new Uint8Array(t.buffer,t.byteOffset,s),i);}}let h=l.stackSave(),w=l.stackAlloc(4*d.length);try{d.forEach(((e,t)=>l.setValue(w+t*u,e,4===u?"i32":"i64")));let e=l._OrtCreateTensor(ee(f),i,s,w,d.length,rr(c));0===e&&S(`Can't create tensor for input/output. session=${n}, index=${o}.`),t.push(e);}finally{l.stackRestore(h);}},xe=async(e,t,r,n,o,a)=>{let i=x(),s=i.PTR_SIZE,l=re.get(e);if(!l)throw new Error(`cannot run inference. invalid session id: ${e}`);let u=l[0],f=l[1],d=l[2],p=l[3],c=l[4],h=(l[5],t.length),w=n.length,y=0,m=[],g=[],b=[],v=[],E=i.stackSave(),T=i.stackAlloc(h*s),A=i.stackAlloc(h*s),L=i.stackAlloc(w*s),C=i.stackAlloc(w*s);try{[y,m]=Jt(a);for(let n=0;n<h;n++)await nr(r[n],g,v,e,t[n],c);for(let t=0;t<w;t++)await nr(o[t],b,v,e,h+n[t],c);for(let e=0;e<h;e++)i.setValue(T+e*s,g[e],"*"),i.setValue(A+e*s,f[t[e]],"*");for(let e=0;e<w;e++)i.setValue(L+e*s,b[e],"*"),i.setValue(C+e*s,d[n[e]],"*");let l;i.jsepOnRunStart?.(u),l=await i._OrtRun(u,A,T,h,C,w,L,y),0!==l&&S("failed to call OrtRun().");let E=[];for(let t=0;t<w;t++){let r=Number(i.getValue(L+t*s,"*"));if(r===b[t]){E.push(o[t]);continue}let a,l=i.stackSave(),f=i.stackAlloc(4*s),d=!1,c=0;try{0!==i._OrtGetTensorData(r,f,f+s,f+2*s,f+3*s)&&S(`Can't access output tensor data on index ${t}.`);let o=4===s?"i32":"i64",l=Number(i.getValue(f,o));c=i.getValue(f+s,"*");let u=i.getValue(f+2*s,"*"),h=Number(i.getValue(f+3*s,o)),w=[];for(let e=0;e<h;e++)w.push(Number(i.getValue(u+e*s,o)));0!==i._OrtFree(u)&&S("Can't free memory for tensor dims.");let y=w.reduce(((e,t)=>e*t),1);a=Qt(l);let m=p?.outputPreferredLocations[n[t]];if("string"===a){if("gpu-buffer"===m||"ml-tensor"===m)throw new Error("String tensor is not supported on GPU.");let e=[];for(let t=0;t<y;t++){let r=i.getValue(c+t*s,"*"),n=i.getValue(c+(t+1)*s,"*"),o=t===y-1?void 0:n-r;e.push(i.UTF8ToString(r,o));}E.push([a,w,e,"cpu"]);}else if("gpu-buffer"===m&&y>0){let e=i.jsepGetBuffer;if(!e)throw new Error('preferredLocation "gpu-buffer" is not supported without using WebGPU.');let t=e(c),n=te(l,y);if(void 0===n||!Ce(a))throw new Error(`Unsupported data type: ${a}`);d=!0,E.push([a,w,{gpuBuffer:t,download:i.jsepCreateDownloader(t,n,a),dispose:()=>{0!==i._OrtReleaseTensor(r)&&S("Can't release tensor.");}},"gpu-buffer"]);}else if("ml-tensor"===m&&y>0){let t=i.jsepEnsureTensor;if(!t)throw new Error('preferredLocation "ml-tensor" is not supported without using WebNN.');if(void 0===te(l,y)||!Ue(a))throw new Error(`Unsupported data type: ${a}`);let n=await t(e,c,l,w,!1);d=!0,E.push([a,w,{mlTensor:n,download:i.jsepCreateMLTensorDownloader(c,a),dispose:()=>{i.jsepReleaseTensorId(c),i._OrtReleaseTensor(r);}},"ml-tensor"]);}else {let e=new(er(a))(y);new Uint8Array(e.buffer,e.byteOffset,e.byteLength).set(i.HEAPU8.subarray(c,c+e.byteLength)),E.push([a,w,e,"cpu"]);}}finally{i.stackRestore(l),"string"===a&&c&&i._free(c),d||i._OrtReleaseTensor(r),i.jsepOnRunEnd?.(u);}}return p&&!c&&(0!==i._OrtClearBoundOutputs(p.handle)&&S("Can't clear bound outputs."),re.set(e,[u,f,d,p,c,!1])),E}finally{i.stackRestore(E),g.forEach((e=>i._OrtReleaseTensor(e))),b.forEach((e=>i._OrtReleaseTensor(e))),v.forEach((e=>i._free(e))),0!==y&&i._OrtReleaseRunOptions(y),m.forEach((e=>i._free(e)));}},Le=e=>{let t=x(),r=re.get(e);if(!r)throw new Error("invalid session id");let n=r[0],o=t._OrtEndProfiling(n);0===o&&S("Can't get an profile file name."),t._OrtFree(o);},Ie=e=>{let t=[];for(let r of e){let e=r[2];!Array.isArray(e)&&"buffer"in e&&t.push(e.buffer);}return t};})),nt=T((()=>{q(),Je(),J(),ge(),Z=()=>!!A.wasm.proxy&&typeof document<"u",le=!1,Me=!1,De=!1,rt=new Map,ne=(e,t)=>{let r=rt.get(e);r?r.push(t):rt.set(e,[t]);},oe=()=>{if(le||!Me||De||!D)throw new Error("worker not ready")},Nr=e=>{switch(e.data.type){case"init-wasm":le=!1,e.data.err?(De=!0,tt[1](e.data.err)):(Me=!0,tt[0]()),_e&&(URL.revokeObjectURL(_e),_e=void 0);break;case"init-ep":case"copy-from":case"create":case"release":case"run":case"end-profiling":{let t=rt.get(e.data.type);e.data.err?t.shift()[1](e.data.err):t.shift()[0](e.data.out);break}}},or=async()=>{if(!Me){if(le)throw new Error("multiple calls to 'initWasm()' detected.");if(De)throw new Error("previous call to 'initWasm()' failed.");if(le=!0,Z())return new Promise(((e,t)=>{D?.terminate(),Vt().then((([r,n])=>{try{(D=n).onerror=e=>t(e),D.onmessage=Nr,tt=[e,t];let o={type:"init-wasm",in:A};if(!o.in.wasm.wasmPaths&&r){let e=Pe();e&&(o.in.wasm.wasmPaths=e);}D.postMessage(o),_e=r;}catch(e){t(e);}}),t);}));try{await Ee(A.wasm),await Te(A),Me=!0;}catch(e){throw De=!0,e}finally{le=!1;}}},sr=async e=>{if(Z())return oe(),new Promise(((t,r)=>{ne("init-ep",[t,r]);let n={type:"init-ep",in:{epName:e,env:A}};D.postMessage(n);}));await Se(A,e);},ir=async e=>Z()?(oe(),new Promise(((t,r)=>{ne("copy-from",[t,r]);let n={type:"copy-from",in:{buffer:e}};D.postMessage(n,[e.buffer]);}))):ue(e),ar=async(e,t)=>{if(Z()){if(t?.preferredOutputLocation)throw new Error('session option "preferredOutputLocation" is not supported for proxy.');return oe(),new Promise(((r,n)=>{ne("create",[r,n]);let o={type:"create",in:{model:e,options:{...t}}},a=[];e instanceof Uint8Array&&a.push(e.buffer),D.postMessage(o,a);}))}return Ae(e,t)},ur=async e=>{if(Z())return oe(),new Promise(((t,r)=>{ne("release",[t,r]);let n={type:"release",in:e};D.postMessage(n);}));Oe(e);},fr=async(e,t,r,n,o,a)=>{if(Z()){if(r.some((e=>"cpu"!==e[3])))throw new Error("input tensor on GPU is not supported for proxy.");if(o.some((e=>e)))throw new Error("pre-allocated output tensor is not supported for proxy.");return oe(),new Promise(((o,i)=>{ne("run",[o,i]);let s=r,l={type:"run",in:{sessionId:e,inputIndices:t,inputs:s,outputIndices:n,options:a}};D.postMessage(l,Ie(s));}))}return xe(e,t,r,n,o,a)},cr=async e=>{if(Z())return oe(),new Promise(((t,r)=>{ne("end-profiling",[t,r]);let n={type:"end-profiling",in:e};D.postMessage(n);}));Le(e);};})),dr=T((()=>{q(),nt(),Qe(),be(),et(),lr=(e,t)=>{switch(e.location){case"cpu":return [e.type,e.dims,e.data,"cpu"];case"gpu-buffer":return [e.type,e.dims,{gpuBuffer:e.gpuBuffer},"gpu-buffer"];case"ml-tensor":return [e.type,e.dims,{mlTensor:e.mlTensor},"ml-tensor"];default:throw new Error(`invalid data location: ${e.location} for ${t()}`)}},Wr=e=>{switch(e[3]){case"cpu":return new R(e[0],e[2],e[1]);case"gpu-buffer":{let t=e[0];if(!Ce(t))throw new Error(`not supported data type: ${t} for deserializing GPU tensor`);let{gpuBuffer:r,download:n,dispose:o}=e[2];return R.fromGpuBuffer(r,{dataType:t,dims:e[1],download:n,dispose:o})}case"ml-tensor":{let t=e[0];if(!Ue(t))throw new Error(`not supported data type: ${t} for deserializing MLTensor tensor`);let{mlTensor:r,download:n,dispose:o}=e[2];return R.fromMLTensor(r,{dataType:t,dims:e[1],download:n,dispose:o})}default:throw new Error(`invalid data location: ${e[3]}`)}},Re=class{async fetchModelAndCopyToWasmMemory(e){return ir(await ce(e))}async loadModel(e,t){let r;V(),r="string"==typeof e?await this.fetchModelAndCopyToWasmMemory(e):e,[this.sessionId,this.inputNames,this.outputNames]=await ar(r,t),Y();}async dispose(){return ur(this.sessionId)}async run(e,t,r){V();let n=[],o=[];Object.entries(e).forEach((e=>{let t=e[0],r=e[1],a=this.inputNames.indexOf(t);if(-1===a)throw new Error(`invalid input '${t}'`);n.push(r),o.push(a);}));let a=[],i=[];Object.entries(t).forEach((e=>{let t=e[0],r=e[1],n=this.outputNames.indexOf(t);if(-1===n)throw new Error(`invalid output '${t}'`);a.push(r),i.push(n);}));let s=n.map(((e,t)=>lr(e,(()=>`input "${this.inputNames[o[t]]}"`)))),l=a.map(((e,t)=>e?lr(e,(()=>`output "${this.outputNames[i[t]]}"`)):null)),u=await fr(this.sessionId,o,s,i,l,r),f={};for(let e=0;e<u.length;e++)f[this.outputNames[i[e]]]=a[e]??Wr(u[e]);return Y(),f}startProfiling(){}endProfiling(){cr(this.sessionId);}};})),mr={};Ge(mr,{OnnxruntimeWebAssemblyBackend:()=>Fe,initializeFlags:()=>pr,wasmBackend:()=>$r});var pr,Fe,$r,hr=T((()=>{q(),nt(),dr(),pr=()=>{if(("number"!=typeof A.wasm.initTimeout||A.wasm.initTimeout<0)&&(A.wasm.initTimeout=0),!1===A.wasm.simd&&console.warn('Deprecated property "env.wasm.simd" is set to false. non-SIMD build is no longer provided, and this setting will be ignored.'),"boolean"!=typeof A.wasm.proxy&&(A.wasm.proxy=!1),"boolean"!=typeof A.wasm.trace&&(A.wasm.trace=!1),"number"!=typeof A.wasm.numThreads||!Number.isInteger(A.wasm.numThreads)||A.wasm.numThreads<=0)if(typeof self<"u"&&!self.crossOriginIsolated)A.wasm.numThreads=1;else {let e=typeof navigator>"u"?$e("node:os").cpus().length:navigator.hardwareConcurrency;A.wasm.numThreads=Math.min(4,Math.ceil((e||1)/2));}},$r=new(Fe=class{async init(e){pr(),await or(),await sr(e);}async createInferenceSessionHandler(e,t){let r=new Re;return await r.loadModel(e,t),Promise.resolve(r)}});}));q(),q(),q();var Ft="1.21.0";{let e=(hr(),at(mr)).wasmBackend;ie("cpu",e,10),ie("wasm",e,10);}Object.defineProperty(A.versions,"web",{value:Ft,enumerable:!0});

class WorkerNative{constructor(){this.ready=!1;this.indexedDBManager=new IndexedDBManager("onirix-sdk","files"),this.indexedDBManager.getFileFromIndexedDB("SDK_1.11.0").then((async e=>{let t=URL.createObjectURL(new Blob([e],{type:"text/javascript"}));const{default:a}=await import(/* webpackIgnore: true, webpackMode: "lazy" */t),s=await a();this.nativeSDK=s,this.spatialBufferSize=this.nativeSDK._OX_GetBufferSize(),this.fromBuffer=this.nativeSDK._malloc(4*this.spatialBufferSize),this.toBuffer=this.nativeSDK._malloc(4*this.spatialBufferSize),A.wasm.numThreads=1;const r=await this.indexedDBManager.getFileFromIndexedDB("ort.wasm"),i=URL.createObjectURL(new Blob([r],{type:"application/wasm"}));A.wasm.wasmPaths={wasm:i,mjs:"https://cdn.onirix.com/onirix-engine-sdk/ort_v1.21.0_min/ort-wasm-simd.mjs"};let n=await this.indexedDBManager.getFromCacheOrFetch("sparse_matching.ort","https://cdn.onirix.com/onirix-engine-sdk/sparse_matching.ort");const o=await Or.create(n,{executionProviders:["wasm"]});this.sessionMatching=o,await this.sessionMatching.run({feats0:new R(new Float32Array(Array(64e3).fill(0)),[1e3,64]),feats1:new R(new Float32Array(Array(64e3).fill(0)),[1e3,64])}),this.ready=!0,postMessage("ready");}));}start(){addEventListener("message",(async e=>{if(!this.ready)return;const t=e.data,a=t.from,s=t.to;let r;if(2==t.dtype){let e=this.readDescriptors(a),t=this.readDescriptors(s),i=await this.sessionMatching.run({feats0:e,feats1:t}),{idx0:n,idx1:o}=i,h=[n.dims[0]];for(let e=0;e<n.dims[0];e++)h.push(Number(n.data[e])),h.push(Number(o.data[e]));r=new Float32Array(h);}else {this.nativeSDK.HEAPF32.set(a,this.fromBuffer/4),this.nativeSDK.HEAPF32.set(s,this.toBuffer/4);let e=this.nativeSDK._OX_Match(this.fromBuffer,this.toBuffer,t.dtype);r=new Float32Array(this.readMatchingData(this.nativeSDK.HEAPF32,e/4));}postMessage(r);}));}readDescriptors(e){let t=e[0],a=1+2*t;return new R(new Float32Array(e.slice(a,a+64*t)),[t,64])}readMatchingData(e,t){let a=t,s=[],r=e[a];s.push(r),a++;for(let t=0;t<r;t++)s.push(e[a]),s.push(e[a+1]),a+=2;return s}}const worker=new WorkerNative;worker.start();
"),b=new Blob([d],{type:"application/javascript"});this.workers[Z]=new Worker(/* webpackIgnore: true, webpackMode: "lazy" */URL.createObjectURL(b),{type:"module"}),this.callbacks[Z]=l,this.workers[Z].addEventListener("message",(l=>{this.callbacks[Z](l.data);}));}}replaceCallback(Z,l){this.workerExists(Z)&&(this.callbacks[Z]=l);}sendDataToWorker(Z,l){this.workers[Z].postMessage(l);}async createWorkers(){return await this.indexedDBManager.getFromCacheOrFetch("ort.wasm","https://cdn.onirix.com/onirix-engine-sdk/ort_v1.21.0_min/ort-wasm-simd.wasm"),Promise.all([new Promise(((Z,l)=>{this.createExtractionWorker("extraction",(l=>{"ready"===l&&Z();}));})),new Promise(((Z,l)=>{this.createMatchingWorker("matching",(l=>{"ready"===l&&Z();}));}))])}}
|
52
52
|
|
53
|
-
class WebXRManager{constructor(t,e,i,a){this.uiManager=t,this.nativeManager=e,this.deviceManager=i,this.workerManager=a,this.hitTestTimeout=void 0,this.hotSwap=!1,this.continuousLocalizationEnabled=!1,this.initialCalibrationPose=null,this.isCalibrated=!0,this.startedOnce=!1;}async isWebXRSupported(){let t=!1;return navigator.xr&&(t=await navigator.xr.isSessionSupported("immersive-ar")),t}async init(t,e,i,a){this.onPose=e,this.onSessionEnd=i,this.isCalibrated=!a;const r=async()=>{const e=["hit-test"],i=["dom-overlay"];t&&i.push("camera-access");try{const t=await new Promise((async(t,a)=>{let r,s=!1;this.requestStallTime&&this.requestStallTime>0&&(r=window.setTimeout((()=>{s=!0,a(new TimeoutError);}),this.requestStallTime));try{const a=await navigator.xr.requestSession("immersive-ar",{requiredFeatures:e,optionalFeatures:i,domOverlay:{root:document.body}});s?await a.end():(window.clearTimeout(r),t(a));}catch(t){window.clearTimeout(r),a(t);}}));await this.onXRSessionStarted(t),this.hitTestStallTime&&this.hitTestStallTime>0&&(this.hitTestTimeout=window.setTimeout((async()=>{this.onHitTestStall&&this.onHitTestStall();}),this.hitTestStallTime));}catch(t){throw console.log(t),new SensorsError(`error while initializing webXR API: ${t}`)}};window.navigator.userAgent.includes("OnirixPlayer")?await r():await this.uiManager.displayPermissionsDialog(r);}startImageDetection(){this.usingImageDetection=!0,this.detectingImage=!0;}stopImageDetection(){this.detectingImage=!1;}start(){this.started=!0,this.usingSpatial&&(this.relocating=!1,this.nativeManager.setWebXRRelocationListener(this.onXRRelocation.bind(this)),this.workerManager.replaceCallback("extraction",(t=>{if(!1!==t)if(this.nativeManager.coarseLocationCheck(t)){let e=this.nativeManager.loadExtractionData(t);this.candidates=Array.from(Array(e).keys()).reverse(),this.extractionData=t.extraction,this.matchKeyframes();}else this.relocating=!1;else this.relocating=!1;})),this.workerManager.replaceCallback("matching",(t=>{this.nativeManager.loadMatch(t),this.matchKeyframes();})));}stop(){this.started=!1,this.xrTransform=null,this.lastRelocationTry=null;}setStartedFlag(){this.startedOnce=!0;}hasStartedOnce(){return this.startedOnce}matchKeyframes(){if(this.candidates.length>0)if(this.nativeManager.spatialLocalize())this.relocating=!1;else {let t=this.candidates.pop();this.workerManager.sendDataToWorker("matching",new WorkerMatchingData(t,this.extractionData,this.nativeManager.getCandidateData(t),this.nativeManager.extractionType()));}else this.nativeManager.spatialLocalize(),this.relocating=!1;}async destroy(){this.xrSession&&(await this.xrSession.end(),this.xrSession=null,this.xrLastPose=null);}async onXRSessionStarted(t){let e=this.uiManager.renderCanvas.getContext("webgl2");e||(e=this.uiManager.renderCanvas.getContext("webgl")),e.getContextAttributes().xrCompatible||await e.makeXRCompatible(),this.xrContext=e,this.framebuffer=this.xrContext.createFramebuffer(),this.xrLayer=new XRWebGLLayer(t,this.xrContext),this.usingSpatial?(navigator.userAgent.includes("OnirixPlayer")||(this.glBinding=new XRWebGLBinding(t,this.xrContext)),this.nativeManager.initExtractionBuffers()):this.detectingImage&&(navigator.userAgent.includes("OnirixPlayer")||(this.glBinding=new XRWebGLBinding(t,this.xrContext))),t.updateRenderState({baseLayer:this.xrLayer}),this.xrLocalRefSpace=await t.requestReferenceSpace("local"),this.xrViewerRefSpace=await t.requestReferenceSpace("viewer"),this.xrHitTestSource=await t.requestHitTestSource({space:this.xrViewerRefSpace}),t.requestAnimationFrame(this.onXRFrame.bind(this)),window.navigator.userAgent.includes("WebXRViewer")?(this.uiManager.renderCanvas.addEventListener("click",(t=>{this.onTouch&&this.onTouch(this.getNormalizedTouchCoords(t));})),this.uiManager.renderCanvas.addEventListener("touchstart",(t=>{this.onTouchStart&&this.onTouchStart(this.getNormalizedTouchCoords(t));})),this.uiManager.renderCanvas.addEventListener("touchend",(t=>{this.onTouchEnd&&this.onTouchEnd(this.getNormalizedTouchCoords(t));}))):(t.addEventListener("select",(t=>{this.onTouch&&this.onTouch(this.getXRInputCoords(t));})),t.addEventListener("selectstart",(t=>{this.onTouchStart&&this.onTouchStart(this.getXRInputCoords(t));})),t.addEventListener("selectend",(t=>{this.onTouchEnd&&this.onTouchEnd(this.getXRInputCoords(t));}))),this.uiManager.renderCanvas.addEventListener("touchmove",(t=>{this.onTouchMove&&this.onTouchMove(this.getNormalizedTouchCoords(t));})),t.addEventListener("end",(()=>{this.hotSwap||this.onSessionEnd&&this.onSessionEnd();})),this.xrSession=t;}enableHotSwap(){this.hotSwap=!0;}disableHotSwap(){this.hotSwap=!1;}hasRelocatedOrDetected(){return (this.usingSpatial||this.usingImageDetection)&&null!=this.xrTransform}needsSmoothing(){return null!=this.xrTransform&&null!=this.prevXrTransform}needsSpatialRelocation(){return this.usingSpatial&&(null==this.lastRelocationTry||this.msSinceRelocation()>2e3)&&(!this.hasRelocatedOrDetected()||this.continuousLocalizationEnabled)}needsImageDetection(){return this.detectingImage&&(null==this.lastRelocationTry||this.msSinceRelocation()>200)}startRelocationTimer(){this.lastRelocationTry=new Date;}msSinceRelocation(){let t=new Date;return this.lastRelocationTry?t-this.lastRelocationTry:0}msSinceOkRelocation(){let t=new Date;return this.lastRelocationTry?t-this.xrTransitionTimer:0}resizeTexture(t,e,i,a,r,s){const n=t.createFramebuffer();t.bindFramebuffer(t.FRAMEBUFFER,n),t.framebufferTexture2D(t.FRAMEBUFFER,t.COLOR_ATTACHMENT0,t.TEXTURE_2D,e,0);const o=t.createTexture();t.bindTexture(t.TEXTURE_2D,o),t.texImage2D(t.TEXTURE_2D,0,t.RGBA,r,s,0,t.RGBA,t.UNSIGNED_BYTE,null),t.texParameteri(t.TEXTURE_2D,t.TEXTURE_WRAP_S,t.CLAMP_TO_EDGE),t.texParameteri(t.TEXTURE_2D,t.TEXTURE_WRAP_T,t.CLAMP_TO_EDGE),t.texParameteri(t.TEXTURE_2D,t.TEXTURE_MIN_FILTER,t.LINEAR),t.texParameteri(t.TEXTURE_2D,t.TEXTURE_MAG_FILTER,t.LINEAR);const h=t.createFramebuffer();return t.bindFramebuffer(t.FRAMEBUFFER,h),t.framebufferTexture2D(t.FRAMEBUFFER,t.COLOR_ATTACHMENT0,t.TEXTURE_2D,o,0),t.bindFramebuffer(t.READ_FRAMEBUFFER,n),t.bindFramebuffer(t.DRAW_FRAMEBUFFER,h),t.blitFramebuffer(0,0,i,a,0,0,r,s,t.COLOR_BUFFER_BIT,t.LINEAR),o}getCameraIntrinsics(t,e){const i=t,a=e.width,r=e.height;if(this.uiManager.isPortrait()){return [r/2*i[5]*Math.min(480/r,640/a),320,240]}return [r/2*i[5]*Math.min(640/r,480/a),320,240]}offsetByXRTransform(t,e){return e?(new Matrix4).fromArray(e.elements).multiply(t):(new Matrix4).fromArray(this.xrTransform.elements).multiply(t)}onXRRelocation(t){if(this.lastCameraImagePose){let e=(new Matrix4).fromArray(this.lastCameraImagePose),i=(new Matrix4).fromArray(t.elements);this.xrTransitionTimer=new Date,null!=this.xrTransform&&(this.prevXrTransform=this.xrTransform.clone()),this.xrTransform=i.multiply(e.invert());}}onXRFrame(t,e){const i=e.session;if(i.requestAnimationFrame(this.onXRFrame.bind(this)),!this.started)return;const a=e.getViewerPose(this.xrLocalRefSpace);if(!a)return;const r=this.xrContext;this.isCalibrated&&(this.needsSpatialRelocation()&&!this.relocating||this.needsImageDetection())&&(this.relocating=!0,(async()=>{const t=this.getGLState(r),{cameraWidth:i,cameraHeight:s,cameraTexture:n,cameraPose:o}=await this.fetchCameraImage(e,a,r);if(!n)return;this.lastCameraImagePose=o;const{scaledWidth:h,scaledHeight:c}=this.calculateScale(i,s),l=this.resizeTexture(r,n,i,s,h,c);this.cameraData||(this.cameraData=new Uint8ClampedArray(h*c*4)),r.bindTexture(r.TEXTURE_2D,l),r.bindFramebuffer(r.FRAMEBUFFER,this.framebuffer),r.framebufferTexture2D(r.FRAMEBUFFER,r.COLOR_ATTACHMENT0,r.TEXTURE_2D,l,0),r.readPixels(0,0,h,c,r.RGBA,r.UNSIGNED_BYTE,this.cameraData),this.restoreGLState(r,t);const{flip:d,rotate:u}=this.getOrientationFlags();if(this.usingSpatial&&this.workerManager.sendDataToWorker("extraction",new WorkerExtractionData(this.cameraData,h,c,u,d,this.nativeManager.extractionType())),this.detectingImage){let t=this.nativeManager.getXRFrameBuffer(h,c);this.nativeManager.processFrame(this.cameraData,t,c,h,d,u);}this.startRelocationTimer();})()),r.bindFramebuffer(r.FRAMEBUFFER,i.renderState.baseLayer.framebuffer);const s=a.views[0];let n=(new Matrix4).fromArray(s.transform.matrix);if(this.shouldCorrectJump(n)?(n=this.correctJump(n),this.isCalibrated||this.resetCalibration()):this.lastPose=n,this.checkTrackingCalibration(n),this.hasRelocatedOrDetected())if(this.needsSmoothing()){let t=this.lastInterpolatedTransform??this.prevXrTransform,e=this.xrTransform;this.lastInterpolatedTransform=t.interpolatePose(e,.1),n=this.offsetByXRTransform(n,this.lastInterpolatedTransform);}else n=this.offsetByXRTransform(n);if((!this.usingSpatial&&!this.usingImageDetection||this.hasRelocatedOrDetected())&&this.onPose(n.toArray()),this.handleViewportResize(a),this.onHitTestResult){const t=e.getHitTestResults(this.xrHitTestSource);if(t.length>0){this.hitTestTimeout&&(window.clearInterval(this.hitTestTimeout),this.hitTestTimeout=void 0);const e=t[0].getPose(this.xrLocalRefSpace),i=(new Matrix4).fromArray(e.transform.matrix),a=i.extractPosition(),r=((new Quaternion).setFromRotationMatrix(i),n.extractPosition()),s=Math.atan2(r.x-a.x,r.z-a.z),o={position:a,rotation:(new Quaternion).setFromEuler(new Euler(0,s,0))};this.onHitTestResult(o);}}this.onFrame&&this.onFrame(e);}async fetchCameraImage(t,e,i){let a,r,s,n;if(navigator.userAgent.includes("OnirixPlayer")){const o=await t.getCameraImage();a=o.width,r=o.height,n=o.pose??e.views[0].transform.matrix,s=await this.createTextureFromImage(i,o),await this.updateIntrinsicsIfNeeded(o);}else for(const t of e.views)t.camera&&(a=t.camera.width,r=t.camera.height,s=this.glBinding.getCameraImage(t.camera),n=e.views[0].transform.matrix);return {cameraWidth:a,cameraHeight:r,cameraTexture:s,cameraPose:n}}async updateIntrinsicsIfNeeded(t){const[e,i,a]=this.nativeManager.getIntrinsics();Math.abs(e-t.focalLength)>1&&this.nativeManager.setIntrinsics(t.focalLength,320,240);}handleViewportResize(t){const e=this.xrLayer.getViewport(t.views[0]),i=e.width,a=e.height,r=null==this.xrLastPose||this.lastViewportWidth!=i||this.lastViewportHeight!=a;this.xrLastPose=t,this.lastViewportWidth=i,this.lastViewportHeight=a,r&&this.onResize&&this.onResize();}calculateScale(t,e){let i,a;this.uiManager.isPortrait()?(i=640/e,a=480/t):(i=480/e,a=640/t);const r=Math.max(i,a);return {scaledWidth:t*r,scaledHeight:e*r}}async createTextureFromImage(t,e){const i=new Image;await new Promise((t=>{i.src=`data:image/jpeg;base64,${e.data}`,i.onload=t;}));const a=t.createTexture();return t.bindTexture(t.TEXTURE_2D,a),t.texImage2D(t.TEXTURE_2D,0,t.RGBA,t.RGBA,t.UNSIGNED_BYTE,i),a}getOrientationFlags(){return this.uiManager.isPortrait()?{flip:1,rotate:3}:{flip:2,rotate:0}}shouldCorrectJump(t){return this.deviceManager.os===DeviceManager.OS.Android&&this.started&&this.lastPose&&!this.jumpPose&&this.hasLargeRotationChange(t)}hasLargeRotationChange(t){return 2*Math.acos(Math.abs((new Quaternion).setFromRotationMatrix(t).dot((new Quaternion).setFromRotationMatrix(this.lastPose))))>1}correctJump(t){this.jumpPose||(this.jumpPose=t.clone());const e=this.jumpPose.clone().invert().multiply(t);return this.lastPose.clone().multiply(e)}getGLState(t){return {readFramebuffer:t.getParameter(t.READ_FRAMEBUFFER_BINDING),drawFramebuffer:t.getParameter(t.DRAW_FRAMEBUFFER_BINDING),texture:t.getParameter(t.TEXTURE_BINDING_2D)}}restoreGLState(t,e){t.bindFramebuffer(t.READ_FRAMEBUFFER,e.readFramebuffer),t.bindFramebuffer(t.DRAW_FRAMEBUFFER,e.drawFramebuffer),t.bindTexture(t.TEXTURE_2D,e.texture);}checkTrackingCalibration(t){if(this.isCalibrated)return;if(!this.initialCalibrationPose)return void(this.initialCalibrationPose=t.clone());const e=t.extractPosition(),i=this.initialCalibrationPose.extractPosition();e.distanceTo(i)>TrackingCalibrationTranslationThreshold&&(this.isCalibrated=!0,this.onTrackingCalibrated&&this.onTrackingCalibrated());}fitCanvasToXRViewport(){if(this.xrLastPose){const t=this.xrLastPose.views[0],e=this.xrLayer.getViewport(t);if((e.width>e.height&&window.innerWidth>window.innerHeight||e.width<=e.height&&window.innerWidth<=window.innerHeight)&&e.width*e.height>window.innerWidth*window.innerHeight)this.uiManager.renderCanvas.width=e.width,this.uiManager.renderCanvas.height=e.height;else {this.uiManager.renderCanvas.width=window.innerWidth;const t=parseInt(getComputedStyle(document.documentElement).getPropertyValue("--sat"),10)||0,e=parseInt(getComputedStyle(document.documentElement).getPropertyValue("--sab"),10)||0,i=window.innerHeight+t+e;this.uiManager.renderCanvas.height=i;}}}getCameraParameters(){let t=60,e=9/16;if(this.xrSession&&this.xrLastPose){const i=this.xrLastPose.views[0].projectionMatrix;e=this.uiManager.renderCanvas.width/this.uiManager.renderCanvas.height,t=radToDeg(2*Math.atan(1/i[5]));}return {fov:t,aspect:e}}getXRLayer(){return this.xrLayer}getXRInputCoords(t){const e=t.inputSource.gamepad.axes;return new Vector2(e[0],-e[1])}getNormalizedTouchCoords(t){const e=new Vector2,i=this.uiManager.renderCanvas.getBoundingClientRect();return null!=t.clientX?(e.x=(t.clientX-i.left)/i.width*2-1,e.y=-(t.clientY-i.top)/i.height*2+1):t.touches[0]?(e.x=t.touches[0].clientX/window.innerWidth*2-1,e.y=-t.touches[0].clientY/window.innerHeight*2+1):(e.x=t.changedTouches[0].clientX/window.innerWidth*2-1,e.y=-t.changedTouches[0].clientY/window.innerHeight*2+1),e}setResizeListener(t){this.onResize=t;}setTouchListener(t){this.onTouch=t;}setTouchStartListener(t){this.onTouchStart=t;}setTouchMoveListener(t){this.onTouchMove=t;}setTouchEndListener(t){this.onTouchEnd=t;}setSessionEndListener(t){this.onSessionEnd=t;}setHitTestListener(t){this.onHitTestResult=t;}setFrameListener(t){this.onFrame=t;}setHitTestStallListener(t){this.onHitTestStall=t;}setRequestStallTimeout(t){this.requestStallTime=t;}setHitTestStallTimeout(t){this.hitTestStallTime=t;}setTrackingCalibratedListener(t){this.onTrackingCalibrated=t;}resetCalibration(){this.initialCalibrationPose=null,this.isCalibrated=!1;}}
|
53
|
+
class WebXRManager{constructor(t,e,i,a){this.uiManager=t,this.nativeManager=e,this.deviceManager=i,this.workerManager=a,this.hitTestTimeout=void 0,this.hotSwap=!1,this.continuousLocalizationEnabled=!1,this.initialCalibrationPose=null,this.isCalibrated=!0,this.startedOnce=!1,this.cameraTexture=null;}async isWebXRSupported(){let t=!1;return navigator.xr&&(t=await navigator.xr.isSessionSupported("immersive-ar")),t}async init(t,e,i,a){this.onPose=e,this.onSessionEnd=i,this.isCalibrated=!a;const r=async()=>{const e=["hit-test"],i=["dom-overlay"];t&&i.push("camera-access");try{const t=await new Promise((async(t,a)=>{let r,s=!1;this.requestStallTime&&this.requestStallTime>0&&(r=window.setTimeout((()=>{s=!0,a(new TimeoutError);}),this.requestStallTime));try{const a=await navigator.xr.requestSession("immersive-ar",{requiredFeatures:e,optionalFeatures:i,domOverlay:{root:document.body}});s?await a.end():(window.clearTimeout(r),t(a));}catch(t){window.clearTimeout(r),a(t);}}));await this.onXRSessionStarted(t),this.hitTestStallTime&&this.hitTestStallTime>0&&(this.hitTestTimeout=window.setTimeout((async()=>{this.onHitTestStall&&this.onHitTestStall();}),this.hitTestStallTime));}catch(t){throw console.log(t),new SensorsError(`error while initializing webXR API: ${t}`)}};window.navigator.userAgent.includes("OnirixPlayer")?await r():await this.uiManager.displayPermissionsDialog(r);}startImageDetection(){this.usingImageDetection=!0,this.detectingImage=!0;}stopImageDetection(){this.detectingImage=!1;}start(){this.started=!0,this.usingSpatial&&(this.relocating=!1,this.nativeManager.setWebXRRelocationListener(this.onXRRelocation.bind(this)),this.workerManager.replaceCallback("extraction",(t=>{if(!1!==t)if(this.nativeManager.coarseLocationCheck(t)){let e=this.nativeManager.loadExtractionData(t);this.candidates=Array.from(Array(e).keys()).reverse(),this.extractionData=t.extraction,this.matchKeyframes();}else this.relocating=!1;else this.relocating=!1;})),this.workerManager.replaceCallback("matching",(t=>{this.nativeManager.loadMatch(t),this.matchKeyframes();})));}stop(){this.started=!1,this.xrTransform=null,this.lastRelocationTry=null;}setStartedFlag(){this.startedOnce=!0;}hasStartedOnce(){return this.startedOnce}matchKeyframes(){if(this.candidates.length>0)if(this.nativeManager.spatialLocalize(this.lastXrPose))this.relocating=!1;else {let t=this.candidates.pop();this.workerManager.sendDataToWorker("matching",new WorkerMatchingData(t,this.extractionData,this.nativeManager.getCandidateData(t),this.nativeManager.extractionType()));}else this.nativeManager.spatialLocalize(this.lastXrPose),this.relocating=!1;}async destroy(){this.xrSession&&(await this.xrSession.end(),this.xrSession=null,this.xrLastPose=null);}async onXRSessionStarted(t){let e=this.uiManager.renderCanvas.getContext("webgl2");e||(e=this.uiManager.renderCanvas.getContext("webgl")),e.getContextAttributes().xrCompatible||await e.makeXRCompatible(),this.xrContext=e,this.framebuffer=this.xrContext.createFramebuffer(),this.xrLayer=new XRWebGLLayer(t,this.xrContext),this.usingSpatial?(navigator.userAgent.includes("OnirixPlayer")||(this.glBinding=new XRWebGLBinding(t,this.xrContext)),this.nativeManager.initExtractionBuffers()):this.detectingImage&&(navigator.userAgent.includes("OnirixPlayer")||(this.glBinding=new XRWebGLBinding(t,this.xrContext))),t.updateRenderState({baseLayer:this.xrLayer}),this.xrLocalRefSpace=await t.requestReferenceSpace("local"),this.xrViewerRefSpace=await t.requestReferenceSpace("viewer"),this.xrHitTestSource=await t.requestHitTestSource({space:this.xrViewerRefSpace}),t.requestAnimationFrame(this.onXRFrame.bind(this)),window.navigator.userAgent.includes("WebXRViewer")?(this.uiManager.renderCanvas.addEventListener("click",(t=>{this.onTouch&&this.onTouch(this.getNormalizedTouchCoords(t));})),this.uiManager.renderCanvas.addEventListener("touchstart",(t=>{this.onTouchStart&&this.onTouchStart(this.getNormalizedTouchCoords(t));})),this.uiManager.renderCanvas.addEventListener("touchend",(t=>{this.onTouchEnd&&this.onTouchEnd(this.getNormalizedTouchCoords(t));}))):(t.addEventListener("select",(t=>{this.onTouch&&this.onTouch(this.getXRInputCoords(t));})),t.addEventListener("selectstart",(t=>{this.onTouchStart&&this.onTouchStart(this.getXRInputCoords(t));})),t.addEventListener("selectend",(t=>{this.onTouchEnd&&this.onTouchEnd(this.getXRInputCoords(t));}))),this.uiManager.renderCanvas.addEventListener("touchmove",(t=>{this.onTouchMove&&this.onTouchMove(this.getNormalizedTouchCoords(t));})),t.addEventListener("end",(()=>{this.hotSwap||this.onSessionEnd&&this.onSessionEnd();})),this.xrSession=t;}enableHotSwap(){this.hotSwap=!0;}disableHotSwap(){this.hotSwap=!1;}hasRelocatedOrDetected(){return (this.usingSpatial||this.usingImageDetection)&&null!=this.xrTransform}needsSmoothing(){return null!=this.xrTransform&&null!=this.prevXrTransform}needsSpatialRelocation(){return this.usingSpatial&&(null==this.lastRelocationTry||this.msSinceRelocation()>2e3)&&(!this.hasRelocatedOrDetected()||this.continuousLocalizationEnabled)}needsImageDetection(){return this.detectingImage&&(null==this.lastRelocationTry||this.msSinceRelocation()>200)}startRelocationTimer(){this.lastRelocationTry=new Date;}msSinceRelocation(){let t=new Date;return this.lastRelocationTry?t-this.lastRelocationTry:0}msSinceOkRelocation(){let t=new Date;return this.lastRelocationTry?t-this.xrTransitionTimer:0}resizeTexture(t,e,i,a,r,s){const n=t.createFramebuffer();t.bindFramebuffer(t.FRAMEBUFFER,n),t.framebufferTexture2D(t.FRAMEBUFFER,t.COLOR_ATTACHMENT0,t.TEXTURE_2D,e,0);const o=t.createTexture();t.bindTexture(t.TEXTURE_2D,o),t.texImage2D(t.TEXTURE_2D,0,t.RGBA,r,s,0,t.RGBA,t.UNSIGNED_BYTE,null),t.texParameteri(t.TEXTURE_2D,t.TEXTURE_WRAP_S,t.CLAMP_TO_EDGE),t.texParameteri(t.TEXTURE_2D,t.TEXTURE_WRAP_T,t.CLAMP_TO_EDGE),t.texParameteri(t.TEXTURE_2D,t.TEXTURE_MIN_FILTER,t.LINEAR),t.texParameteri(t.TEXTURE_2D,t.TEXTURE_MAG_FILTER,t.LINEAR);const h=t.createFramebuffer();return t.bindFramebuffer(t.FRAMEBUFFER,h),t.framebufferTexture2D(t.FRAMEBUFFER,t.COLOR_ATTACHMENT0,t.TEXTURE_2D,o,0),t.bindFramebuffer(t.READ_FRAMEBUFFER,n),t.bindFramebuffer(t.DRAW_FRAMEBUFFER,h),t.blitFramebuffer(0,0,i,a,0,0,r,s,t.COLOR_BUFFER_BIT,t.LINEAR),o}getCameraIntrinsics(t,e){const i=t,a=e.width,r=e.height;if(this.uiManager.isPortrait()){return [r/2*i[5]*Math.min(480/r,640/a),320,240]}return [r/2*i[5]*Math.min(640/r,480/a),320,240]}offsetByXRTransform(t,e){return e?(new Matrix4).fromArray(e.elements).multiply(t):(new Matrix4).fromArray(this.xrTransform.elements).multiply(t)}onXRRelocation(t){if(this.lastCameraImagePose){let e=(new Matrix4).fromArray(this.lastCameraImagePose),i=(new Matrix4).fromArray(t.elements);this.xrTransitionTimer=new Date,null!=this.xrTransform&&(this.prevXrTransform=this.xrTransform.clone()),this.xrTransform=i.multiply(e.invert());}}onXRFrame(t,e){const i=e.session;if(i.requestAnimationFrame(this.onXRFrame.bind(this)),!this.started)return;const a=e.getViewerPose(this.xrLocalRefSpace);if(!a)return;const r=this.xrContext;this.isCalibrated&&(this.needsSpatialRelocation()&&!this.relocating||this.needsImageDetection())&&(this.relocating=!0,(async()=>{const t=this.getGLState(r),{cameraWidth:i,cameraHeight:s,cameraPose:n}=await this.fetchCameraImage(e,a,r);if(!this.cameraTexture)return;this.lastCameraImagePose=n;const{scaledWidth:o,scaledHeight:h}=this.calculateScale(i,s),c=this.resizeTexture(r,this.cameraTexture,i,s,o,h);this.cameraData||(this.cameraData=new Uint8ClampedArray(o*h*4)),r.bindTexture(r.TEXTURE_2D,c),r.bindFramebuffer(r.FRAMEBUFFER,this.framebuffer),r.framebufferTexture2D(r.FRAMEBUFFER,r.COLOR_ATTACHMENT0,r.TEXTURE_2D,c,0),r.readPixels(0,0,o,h,r.RGBA,r.UNSIGNED_BYTE,this.cameraData),r.deleteTexture(c),this.restoreGLState(r,t);const{flip:l,rotate:u}=this.getOrientationFlags();if(this.usingSpatial&&this.workerManager.sendDataToWorker("extraction",new WorkerExtractionData(this.cameraData,o,h,u,l,this.nativeManager.extractionType())),this.detectingImage){let t=this.nativeManager.getXRFrameBuffer(o,h);this.nativeManager.processFrame(this.cameraData,t,h,o,l,u);}this.startRelocationTimer();})()),r.bindFramebuffer(r.FRAMEBUFFER,i.renderState.baseLayer.framebuffer);const s=a.views[0];let n=(new Matrix4).fromArray(s.transform.matrix);if(this.shouldCorrectJump(n)?(n=this.correctJump(n),this.isCalibrated||this.resetCalibration()):this.lastPose=n,this.lastXrPose=n,this.checkTrackingCalibration(n),this.hasRelocatedOrDetected())if(this.needsSmoothing()){let t=this.lastInterpolatedTransform??this.prevXrTransform,e=this.xrTransform;this.lastInterpolatedTransform=t.interpolatePose(e,.1),n=this.offsetByXRTransform(n,this.lastInterpolatedTransform);}else n=this.offsetByXRTransform(n);if((!this.usingSpatial&&!this.usingImageDetection||this.hasRelocatedOrDetected())&&this.onPose(n.toArray()),this.handleViewportResize(a),this.onHitTestResult){const t=e.getHitTestResults(this.xrHitTestSource);if(t.length>0){this.hitTestTimeout&&(window.clearInterval(this.hitTestTimeout),this.hitTestTimeout=void 0);const e=t[0].getPose(this.xrLocalRefSpace),i=(new Matrix4).fromArray(e.transform.matrix),a=i.extractPosition(),r=((new Quaternion).setFromRotationMatrix(i),n.extractPosition()),s=Math.atan2(r.x-a.x,r.z-a.z),o={position:a,rotation:(new Quaternion).setFromEuler(new Euler(0,s,0))};this.onHitTestResult(o);}}this.onFrame&&this.onFrame(e);}async fetchCameraImage(t,e,i){let a,r,s;if(navigator.userAgent.includes("OnirixPlayer")){const n=await t.getCameraImage();a=n.width,r=n.height,s=n.pose??e.views[0].transform.matrix,await this.setCameraTextureFromImage(i,n),await this.updateIntrinsicsIfNeeded(n);}else for(const t of e.views)t.camera&&(a=t.camera.width,r=t.camera.height,this.cameraTexture=this.glBinding.getCameraImage(t.camera),s=e.views[0].transform.matrix);return {cameraWidth:a,cameraHeight:r,cameraPose:s}}async updateIntrinsicsIfNeeded(t){const[e,i,a]=this.nativeManager.getIntrinsics();Math.abs(e-t.focalLength)>1&&this.nativeManager.setIntrinsics(t.focalLength,320,240);}handleViewportResize(t){const e=this.xrLayer.getViewport(t.views[0]),i=e.width,a=e.height,r=null==this.xrLastPose||this.lastViewportWidth!=i||this.lastViewportHeight!=a;this.xrLastPose=t,this.lastViewportWidth=i,this.lastViewportHeight=a,r&&this.onResize&&this.onResize();}calculateScale(t,e){let i,a;this.uiManager.isPortrait()?(i=640/e,a=480/t):(i=480/e,a=640/t);const r=Math.max(i,a);return {scaledWidth:t*r,scaledHeight:e*r}}async setCameraTextureFromImage(t,e){const i=new Image;await new Promise((t=>{i.src=`data:image/jpeg;base64,${e.data}`,i.onload=t;})),this.cameraTexture||(this.cameraTexture=t.createTexture()),t.bindTexture(t.TEXTURE_2D,this.cameraTexture),t.texImage2D(t.TEXTURE_2D,0,t.RGBA,t.RGBA,t.UNSIGNED_BYTE,i);}getOrientationFlags(){return this.uiManager.isPortrait()?{flip:1,rotate:3}:{flip:2,rotate:0}}shouldCorrectJump(t){return this.deviceManager.os===DeviceManager.OS.Android&&this.started&&this.lastPose&&!this.jumpPose&&this.hasLargeRotationChange(t)}hasLargeRotationChange(t){return 2*Math.acos(Math.abs((new Quaternion).setFromRotationMatrix(t).dot((new Quaternion).setFromRotationMatrix(this.lastPose))))>1}correctJump(t){this.jumpPose||(this.jumpPose=t.clone());const e=this.jumpPose.clone().invert().multiply(t);return this.lastPose.clone().multiply(e)}getGLState(t){return {readFramebuffer:t.getParameter(t.READ_FRAMEBUFFER_BINDING),drawFramebuffer:t.getParameter(t.DRAW_FRAMEBUFFER_BINDING),texture:t.getParameter(t.TEXTURE_BINDING_2D)}}restoreGLState(t,e){t.bindFramebuffer(t.READ_FRAMEBUFFER,e.readFramebuffer),t.bindFramebuffer(t.DRAW_FRAMEBUFFER,e.drawFramebuffer),t.bindTexture(t.TEXTURE_2D,e.texture);}checkTrackingCalibration(t){if(this.isCalibrated)return;if(!this.initialCalibrationPose)return void(this.initialCalibrationPose=t.clone());const e=t.extractPosition(),i=this.initialCalibrationPose.extractPosition();e.distanceTo(i)>TrackingCalibrationTranslationThreshold&&(this.isCalibrated=!0,this.onTrackingCalibrated&&this.onTrackingCalibrated());}fitCanvasToXRViewport(){if(this.xrLastPose){const t=this.xrLastPose.views[0],e=this.xrLayer.getViewport(t);if((e.width>e.height&&window.innerWidth>window.innerHeight||e.width<=e.height&&window.innerWidth<=window.innerHeight)&&e.width*e.height>window.innerWidth*window.innerHeight)this.uiManager.renderCanvas.width=e.width,this.uiManager.renderCanvas.height=e.height;else {this.uiManager.renderCanvas.width=window.innerWidth;const t=parseInt(getComputedStyle(document.documentElement).getPropertyValue("--sat"),10)||0,e=parseInt(getComputedStyle(document.documentElement).getPropertyValue("--sab"),10)||0,i=window.innerHeight+t+e;this.uiManager.renderCanvas.height=i;}}}getCameraParameters(){let t=60,e=9/16;if(this.xrSession&&this.xrLastPose){const i=this.xrLastPose.views[0].projectionMatrix;e=this.uiManager.renderCanvas.width/this.uiManager.renderCanvas.height,t=radToDeg(2*Math.atan(1/i[5]));}return {fov:t,aspect:e}}getXRLayer(){return this.xrLayer}getXRInputCoords(t){const e=t.inputSource.gamepad.axes;return new Vector2(e[0],-e[1])}getNormalizedTouchCoords(t){const e=new Vector2,i=this.uiManager.renderCanvas.getBoundingClientRect();return null!=t.clientX?(e.x=(t.clientX-i.left)/i.width*2-1,e.y=-(t.clientY-i.top)/i.height*2+1):t.touches[0]?(e.x=t.touches[0].clientX/window.innerWidth*2-1,e.y=-t.touches[0].clientY/window.innerHeight*2+1):(e.x=t.changedTouches[0].clientX/window.innerWidth*2-1,e.y=-t.changedTouches[0].clientY/window.innerHeight*2+1),e}setResizeListener(t){this.onResize=t;}setTouchListener(t){this.onTouch=t;}setTouchStartListener(t){this.onTouchStart=t;}setTouchMoveListener(t){this.onTouchMove=t;}setTouchEndListener(t){this.onTouchEnd=t;}setSessionEndListener(t){this.onSessionEnd=t;}setHitTestListener(t){this.onHitTestResult=t;}setFrameListener(t){this.onFrame=t;}setHitTestStallListener(t){this.onHitTestStall=t;}setRequestStallTimeout(t){this.requestStallTime=t;}setHitTestStallTimeout(t){this.hitTestStallTime=t;}setTrackingCalibratedListener(t){this.onTrackingCalibrated=t;}resetCalibration(){this.initialCalibrationPose=null,this.isCalibrated=!1;}}
|
54
54
|
|
55
55
|
class EventManager{constructor(){this.eventListeners={},this.eventListenerCount=0;}stop(){this.eventListeners={},this.eventListenerCount=0;}addEventListener(e,t){this.eventListeners[e]||(this.eventListeners[e]=[]);const n=this.eventListenerCount++;return this.eventListeners[e].push({id:n,func:t}),n}triggerEvent(e,t){this.eventListeners[e]&&this.eventListeners[e].map((e=>e.func(t)));}removeEventListener(e){for(let t of Object.keys(this.eventListeners))for(let n=0;n<t.length;n++)if(t[n].id===e){t.splice(n,1);break}}}
|
56
56
|
|